From a286861b9b9f8073766243e8bac718f8e54949e6 Mon Sep 17 00:00:00 2001 From: Scott Beddall <45376673+scbedd@users.noreply.github.com> Date: Tue, 23 Feb 2021 13:44:18 -0800 Subject: [PATCH 01/30] Update apiview artifact search to account for the new artifact taxonomy (#16887) * update apiview artifact search to account for the new artifact taxonomy --- .../templates/stages/archetype-python-release.yml | 4 ++-- eng/scripts/Language-Settings.ps1 | 11 ++++++----- 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/eng/pipelines/templates/stages/archetype-python-release.yml b/eng/pipelines/templates/stages/archetype-python-release.yml index 7540e4bba413..ba80cecf9a23 100644 --- a/eng/pipelines/templates/stages/archetype-python-release.yml +++ b/eng/pipelines/templates/stages/archetype-python-release.yml @@ -292,8 +292,8 @@ stages: exit 0 } - twine upload --repository $(DevFeedName) --config-file $(PYPIRC_PATH) $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$(Package.Name)/*a*.whl + twine upload --repository $(DevFeedName) --config-file $(PYPIRC_PATH) $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$(Package.Name)/*-*a*.whl echo "Uploaded whl to devops feed $(DevFeedName)" - twine upload --repository $(DevFeedName) --config-file $(PYPIRC_PATH) $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$(Package.Name)/*a*.zip + twine upload --repository $(DevFeedName) --config-file $(PYPIRC_PATH) $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$(Package.Name)/*-*a*.zip echo "Uploaded sdist to devops feed $(DevFeedName)" displayName: 'Publish ${{artifact.name}} alpha package' diff --git a/eng/scripts/Language-Settings.ps1 b/eng/scripts/Language-Settings.ps1 index 755894e0b8e6..5b7044afee3e 100644 --- a/eng/scripts/Language-Settings.ps1 +++ b/eng/scripts/Language-Settings.ps1 @@ -225,17 +225,18 @@ function Find-python-Artifacts-For-Apireview($artifactDir, $artifactName) return $null } - $packageName = $artifactName + "-" - Write-Host "Searching for $($packageName) wheel in artifact path $($artifactDir)" - $files = Get-ChildItem "${artifactDir}" | Where-Object -FilterScript {$_.Name.StartsWith($packageName) -and $_.Name.EndsWith(".whl")} + $whlDirectory = (Join-Path -Path $artifactDir -ChildPath $artifactName.Replace("_","-")) + + Write-Host "Searching for $($artifactName) wheel in artifact path $($whlDirectory)" + $files = Get-ChildItem $whlDirectory | ? {$_.Name.EndsWith(".whl")} if (!$files) { - Write-Host "$($artifactDir) does not have wheel package for $($packageName)" + Write-Host "$whlDirectory does not have wheel package for $($artifactName)" return $null } elseif($files.Count -ne 1) { - Write-Host "$($artifactDir) should contain only one published wheel package for $($packageName)" + Write-Host "$whlDirectory should contain only one published wheel package for $($artifactName)" Write-Host "No of Packages $($files.Count)" return $null } From 1a60ae0275808108ef655ff01b5ed265fe0ccd0d Mon Sep 17 00:00:00 2001 From: Craig Treasure Date: Tue, 23 Feb 2021 13:53:09 -0800 Subject: [PATCH 02/30] Added the Azure.MixedReality.Authentication library (#16714) This change adds an authentication library for Mixed Reality services, which all currently utilize a custom STS for authentication. Upcoming Mixed Reality client libraries will depend on this library to perform authentication using identities from Azure.Identity. See the added README.md for more information about the library. [ApiView link](https://apiview.dev/Assemblies/Review/986545855b9c499faeff72b25115ab96) --- eng/.docsettings.yml | 1 + .../CHANGELOG.md | 5 + .../LICENSE.txt | 21 ++ .../MANIFEST.in | 6 + .../README.md | 199 ++++++++++++++++++ .../azure/__init__.py | 7 + .../azure/mixedreality/__init__.py | 7 + .../mixedreality/authentication/__init__.py | 11 + .../mixedreality/authentication/_client.py | 113 ++++++++++ .../authentication/_generated/__init__.py | 16 ++ .../_generated/_configuration.py | 51 +++++ .../_mixed_reality_sts_rest_client.py | 57 +++++ .../authentication/_generated/aio/__init__.py | 10 + .../_generated/aio/_configuration.py | 45 ++++ .../aio/_mixed_reality_sts_rest_client.py | 49 +++++ .../_generated/aio/operations/__init__.py | 13 ++ ...ixed_reality_sts_rest_client_operations.py | 89 ++++++++ .../_generated/models/__init__.py | 19 ++ .../_generated/models/_models.py | 54 +++++ .../_generated/models/_models_py3.py | 60 ++++++ .../_generated/operations/__init__.py | 13 ++ ...ixed_reality_sts_rest_client_operations.py | 94 +++++++++ .../authentication/_generated/py.typed | 1 + .../authentication/_shared/__init__.py | 5 + .../authentication/_shared/aio/__init__.py | 5 + .../aio/mixed_reality_token_credential.py | 67 ++++++ .../mixedreality_account_key_credential.py | 54 +++++ .../aio/static_access_token_credential.py | 38 ++++ .../_shared/authentication_endpoint.py | 9 + .../_shared/mixed_reality_token_credential.py | 50 +++++ .../mixedreality_account_key_credential.py | 46 ++++ .../_shared/static_access_token_credential.py | 27 +++ .../mixedreality/authentication/_utils.py | 73 +++++++ .../mixedreality/authentication/_version.py | 10 + .../authentication/aio/__init__.py | 11 + .../authentication/aio/_client_async.py | 112 ++++++++++ .../dev_requirements.txt | 4 + .../samples/client_sample async.py | 70 ++++++ .../samples/client_sample.py | 63 ++++++ .../sdk_packaging.toml | 7 + .../setup.cfg | 2 + .../setup.py | 80 +++++++ .../swagger/SWAGGER.md | 30 +++ .../swagger/update.ps1 | 6 + .../tests/_constants.py | 10 + .../tests/conftest.py | 11 + .../test_client.test_get_token.yaml | 38 ++++ .../test_client_async.test_get_token.yaml | 28 +++ .../tests/test_client.py | 106 ++++++++++ .../tests/test_client_async.py | 108 ++++++++++ .../test_mixed_reality_token_credential.py | 37 ++++ ...st_mixed_reality_token_credential_async.py | 37 ++++ .../test_static_access_token_credential.py | 21 ++ ...st_static_access_token_credential_async.py | 23 ++ .../tests/test_utils.py | 60 ++++++ .../azure-mixedreality-nspkg/CHANGELOG.md | 5 + .../azure-mixedreality-nspkg/MANIFEST.in | 3 + .../azure-mixedreality-nspkg/README.md | 11 + .../azure/__init__.py | 1 + .../azure/mixedreality/__init__.py | 0 .../azure-mixedreality-nspkg/setup.cfg | 2 + .../azure-mixedreality-nspkg/setup.py | 41 ++++ sdk/mixedreality/ci.yml | 4 + sdk/mixedreality/test-resources.json | 141 +++++++++++++ sdk/mixedreality/tests.yml | 13 ++ shared_requirements.txt | 1 + 66 files changed, 2411 insertions(+) create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/CHANGELOG.md create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/LICENSE.txt create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/MANIFEST.in create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/README.md create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_client.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_configuration.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_mixed_reality_sts_rest_client.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_configuration.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_mixed_reality_sts_rest_client.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/_mixed_reality_sts_rest_client_operations.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models_py3.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/_mixed_reality_sts_rest_client_operations.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/py.typed create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixed_reality_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixedreality_account_key_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/static_access_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/authentication_endpoint.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixed_reality_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixedreality_account_key_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/static_access_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_utils.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_version.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/_client_async.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample async.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/sdk_packaging.toml create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/setup.cfg create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/setup.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/swagger/SWAGGER.md create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/swagger/update.ps1 create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/_constants.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/conftest.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client.test_get_token.yaml create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client_async.test_get_token.yaml create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_client.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_client_async.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential_async.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential_async.py create mode 100644 sdk/mixedreality/azure-mixedreality-authentication/tests/test_utils.py create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/CHANGELOG.md create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/MANIFEST.in create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/README.md create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/azure/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/azure/mixedreality/__init__.py create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/setup.cfg create mode 100644 sdk/mixedreality/azure-mixedreality-nspkg/setup.py create mode 100644 sdk/mixedreality/test-resources.json create mode 100644 sdk/mixedreality/tests.yml diff --git a/eng/.docsettings.yml b/eng/.docsettings.yml index a732c246e727..d0dba16dd0bb 100644 --- a/eng/.docsettings.yml +++ b/eng/.docsettings.yml @@ -124,6 +124,7 @@ known_content_issues: - ['sdk/core/azure-mgmt-nspkg/README.rst', 'nspkg and common'] - ['sdk/core/azure-nspkg/README.rst', 'nspkg and common'] - ['sdk/keyvault/azure-keyvault-nspkg/README.md', 'nspkg and common'] + - ['sdk/mixedreality/azure-mixedreality-nspkg/README.md', 'nspkg and common'] - ['sdk/search/azure-search-nspkg/README.md', 'nspkg and common'] - ['sdk/storage/azure-storage-blob/samples/README.md', 'nspkg and common'] - ['sdk/storage/azure-storage-file-datalake/samples/README.md', 'nspkg and common'] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/CHANGELOG.md b/sdk/mixedreality/azure-mixedreality-authentication/CHANGELOG.md new file mode 100644 index 000000000000..11533387e830 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/CHANGELOG.md @@ -0,0 +1,5 @@ +# Release History + +## 1.0.0b1 (Unreleased) + +- Initial release. diff --git a/sdk/mixedreality/azure-mixedreality-authentication/LICENSE.txt b/sdk/mixedreality/azure-mixedreality-authentication/LICENSE.txt new file mode 100644 index 000000000000..0313a903d76c --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/LICENSE.txt @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2017 Microsoft + +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. \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-authentication/MANIFEST.in b/sdk/mixedreality/azure-mixedreality-authentication/MANIFEST.in new file mode 100644 index 000000000000..b69eaab9edd0 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/MANIFEST.in @@ -0,0 +1,6 @@ +include *.md +include azure/__init__.py +include azure/mixedreality/__init__.py +include LICENSE.txt +recursive-include tests *.py +recursive-include samples *.py *.md \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-authentication/README.md b/sdk/mixedreality/azure-mixedreality-authentication/README.md new file mode 100644 index 000000000000..ca0845d344a6 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/README.md @@ -0,0 +1,199 @@ +[![Build Status](https://dev.azure.com/azure-sdk/public/_apis/build/status/azure-sdk-for-python.client?branchName=master)](https://dev.azure.com/azure-sdk/public/_build/latest?definitionId=46?branchName=master) + +# Azure Mixed Reality Authentication Package client library for Python + +Mixed Reality services, like Azure Spatial Anchors, Azure Remote Rendering, and others, use the Mixed Reality security +token service (STS) for authentication. This package supports exchanging Mixed Reality account credentials for an access +token from the STS that can be used to access Mixed Reality services. + +![Mixed Reality service authentication diagram](https://docs.microsoft.com/azure/spatial-anchors/concepts/media/spatial-anchors-authentication-overview.png) + +# Getting started + +## Currently supported environments + +This package has been tested with Python 2.7, 3.5, 3.6, 3.7, 3.8, and 3.9. + +## Prerequisites + +- An [Azure subscription][azure_sub]. +- You must have an account with an [Azure Mixed Reality service](https://azure.microsoft.com/topic/mixed-reality/): + - [Azure Remote Rendering](https://docs.microsoft.com/azure/remote-rendering/) + - [Azure Spatial Anchors](https://docs.microsoft.com/azure/spatial-anchors/) +- Familiarity with the authentication and credential concepts from the [Azure Identity library][azure_identity]. +- Python 2.7, or 3.5 or later is required to use this package. + +## Install the package + +Install the Azure Mixed Reality Authentication SDK. + +```bash +pip install --pre azure-mixedreality-authentication +``` + +## Create and authenticate a `MixedRealityStsClient` + +To create a client object to request an access token for a Mixed Reality service, you will need the `account identifier` +and `account domain` of your Mixed Reality service resource and a `credential`. + +Mixed Reality services support a few different forms of authentication: + +- Account Key authentication + - Account keys enable you to get started quickly with using Mixed Reality services. But before you deploy your application + to production, we recommend that you update your app to use Azure AD authentication. +- Azure Active Directory (AD) token authentication + - If you're building an enterprise application and your company is using Azure AD as its identity system, you can use + user-based Azure AD authentication in your app. You then grant access to your Mixed Reality accounts by using your + existing Azure AD security groups. You can also grant access directly to users in your organization. + - Otherwise, we recommend that you obtain Azure AD tokens from a web service that supports your app. We recommend this + method for production applications because it allows you to avoid embedding the credentials for access to a Mixed + Reality service in your client application. + +See [here][register_aad_app] for detailed instructions and information. + +### Using account key authentication + +Use the [Azure Portal][azure_portal] to browse to your Mixed Reality service resource and retrieve an `account key`. + +Once you have an account key, you can use the `AzureKeyCredential` class to authenticate the client as follows: + +```python +from azure.core.credentials import AzureKeyCredential +from azure.mixedreality.authentication import MixedRealityStsClient + +account_id = "" +account_domain = "" +account_key = "" +key_credential = AzureKeyCredential(account_key) + +client = MixedRealityStsClient(account_id, account_domain, key_credential) +``` + +> Note: Account key authentication is **not recommended** for production applications. + +### Using an Azure Active Directory Credential + +Account key authentication is used in most of the examples, but you can also authenticate with Azure Active Directory +using the [Azure Identity library][azure_identity]. This is the recommended method for production applications. To use +the [DefaultAzureCredential][defaultazurecredential] provider shown below, or other credential providers provided with +the Azure SDK, please install the `@azure/identity` package: + +You will also need to [register a new AAD application][register_aad_app] and grant access to your Mixed Reality resource +by assigning the appropriate role for your Mixed Reality service to your service principal. + +```python +from azure.identity import DefaultAzureCredential +from azure.mixedreality.authentication import MixedRealityStsClient + +account_id = "" +account_domain = "" +default_credential = DefaultAzureCredential() + +client = MixedRealityStsClient(account_id, account_domain, default_credential) +``` + +# Key concepts + +## MixedRealityStsClient + +The `MixedRealityStsClient` is the client library used to access the Mixed Reality STS to get an access token. An access +token can be retrieved by calling `get_token()` on an `MixedRealityStsClient` instance. + +Tokens obtained from the Mixed Reality STS have a lifetime of **24 hours**. + +### Token result value + +The return value for a successful call to `get_token` is an `azure.core.credentials.AccessToken`. + +See the authentication examples [above](#authenticate-the-client) or [Azure Identity][azure_identity] for more complex +authentication scenarios. + +## Retrieve an access token synchronously + +```python +from azure.core.credentials import AzureKeyCredential +from azure.mixedreality.authentication import MixedRealityStsClient + +account_id = "" +account_domain = "" +account_key = "" +key_credential = AzureKeyCredential(account_key) + +client = MixedRealityStsClient(account_id, account_domain, key_credential) + +token = client.get_token() +``` + +## Retrieve an access token asynchronously + +```python +from azure.core.credentials import AzureKeyCredential +from azure.mixedreality.authentication.aio import MixedRealityStsClient + +account_id = "" +account_domain = "" +account_key = "" +key_credential = AzureKeyCredential(account_key) + +client = MixedRealityStsClient(account_id, account_domain, key_credential) + +token = await client.get_token() +``` + +# Examples + +These are code samples that show common scenario operations with the Azure Mixed Reality Authentication client library. +The async versions of the samples (the python sample files appended with `_async`) show asynchronous operations, +and require Python 3.5 or later. +Before running the sample code, refer to Prerequisites + +to create a resource, then set some Environment Variables + +```bash +set MIXEDREALITY_ACCOUNT_DOMAIN="" +set MIXEDREALITY_ACCOUNT_ID="" +set MIXEDREALITY_ACCOUNT_KEY="" + +pip install azure-mixedreality-authentication + +python samples\client_sample.py +python samples\client_sample_async.py +``` + +# Troubleshooting + +The [troubleshooting](https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/identity/azure-identity#troubleshooting) +section for Azure Identity can be helpful when troubleshooting authentication issues. + +# Next steps + +## Mixed Reality client libraries + +- Coming soon + +## Contributing + +This project welcomes contributions and suggestions. Most contributions require you to agree to a +Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us +the rights to use your contribution. For details, visit https://cla.microsoft.com. + +When you submit a pull request, a CLA-bot will automatically determine whether you need to provide +a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions +provided by the bot. You will only need to do this once across all repos using our CLA. + +This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/). +For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or +contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments. + +If you'd like to contribute to this library, please read the +[contributing guide](https://github.com/Azure/azure-sdk-for-python/blob/master/CONTRIBUTING.md) to learn more about how to +build and test the code. + +![Impressions](https://azure-sdk-impressions.azurewebsites.net/api/impressions/azure-sdk-for-python%2Fsdk%2Ftemplate%2Fazure-template%2FREADME.png) + +[azure_cli]: https://docs.microsoft.com/cli/azure +[azure_sub]: https://azure.microsoft.com/free/ +[azure_portal]: https://portal.azure.com +[azure_identity]: https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/identity/azure-identity +[register_aad_app]: https://docs.microsoft.com/azure/spatial-anchors/concepts/authentication +[defaultazurecredential]: https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/identity/azure-identity#defaultazurecredential diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/__init__.py new file mode 100644 index 000000000000..431ed648086a --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/__init__.py @@ -0,0 +1,7 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +__path__ = __import__('pkgutil').extend_path(__path__, __name__) # type: ignore diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/__init__.py new file mode 100644 index 000000000000..431ed648086a --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/__init__.py @@ -0,0 +1,7 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +__path__ = __import__('pkgutil').extend_path(__path__, __name__) # type: ignore diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/__init__.py new file mode 100644 index 000000000000..2996cdaaeb4c --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/__init__.py @@ -0,0 +1,11 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from ._version import VERSION +from ._client import MixedRealityStsClient + +__version__ = VERSION +__all__ = ['MixedRealityStsClient'] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_client.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_client.py new file mode 100644 index 000000000000..919a99cb55a1 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_client.py @@ -0,0 +1,113 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +try: + from urllib.parse import urlparse +except ImportError: + from urlparse import urlparse # type: ignore + +from azure.core.credentials import AzureKeyCredential +from azure.core.tracing.decorator import distributed_trace +from azure.core.pipeline.policies import BearerTokenCredentialPolicy + +from ._generated import MixedRealityStsRestClient +from ._generated.models import TokenRequestOptions +from ._version import SDK_MONIKER +from ._shared.authentication_endpoint import construct_endpoint_url +from ._shared.mixedreality_account_key_credential import MixedRealityAccountKeyCredential +from ._utils import convert_to_access_token, generate_cv_base + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Union + from azure.core.credentials import TokenCredential + from azure.core.credentials import AccessToken + + +class MixedRealityStsClient(object): + """ A client to interact with the Mixed Reality STS service. + + :param str account_id: + The Mixed Reality service account identifier. + :param str account_domain: + The Mixed Reality service account domain. + :param Union[TokenCredential, AzureKeyCredential] credential: + The credential used to access the Mixed Reality service. + :keyword str custom_endpoint_url: + Override the Mixed Reality STS service endpoint. + """ + + def __init__(self, account_id, account_domain, credential, **kwargs): + # type: (str, str, Union[TokenCredential, AzureKeyCredential], Any) -> None + if not account_id: + raise ValueError("account_id must be a non-empty string.") + + if not account_domain: + raise ValueError("account_domain must be a non-empty string.") + + if not credential: + raise ValueError("credential can not be None.") + + self._account_id = account_id + self._account_domain = account_domain + + if isinstance(credential, AzureKeyCredential): + credential = MixedRealityAccountKeyCredential(account_id, credential) + + self._credential = credential + + endpoint_url = kwargs.pop('custom_endpoint_url', construct_endpoint_url(account_domain)) + + try: + if not endpoint_url.lower().startswith('http'): + endpoint_url = "https://" + endpoint_url + except AttributeError: + raise ValueError("Host URL must be a string.") + + parsed_url = urlparse(endpoint_url.rstrip('/')) + if not parsed_url.netloc: + raise ValueError("Invalid URL: {}".format(endpoint_url)) + + self._endpoint_url = endpoint_url + + authentication_policy = BearerTokenCredentialPolicy(credential, endpoint_url + '/.default') + + self._client = MixedRealityStsRestClient( + base_url=endpoint_url, + authentication_policy=authentication_policy, + sdk_moniker=SDK_MONIKER, + **kwargs) + + @distributed_trace + def get_token(self, **kwargs): + # type: (Any) -> AccessToken + """ + Retrieve a token from the STS service for the specified account identifier asynchronously. + :return: Instance of azure.core.credentials.AccessToken - token and expiry date of it + :rtype: ~azure.core.credentials.AccessToken + """ + token_request_options = TokenRequestOptions() + token_request_options.client_request_id = generate_cv_base() + + response = self._client.get_token( + self._account_id, + token_request_options=token_request_options, + **kwargs) + return convert_to_access_token(response) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> MixedRealityStsClient + self._client.__enter__() # pylint:disable=no-member + return self + + def __exit__(self, *args): + # type: (*Any) -> None + self._client.__exit__(*args) # pylint:disable=no-member diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/__init__.py new file mode 100644 index 000000000000..86838c6b621e --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/__init__.py @@ -0,0 +1,16 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._mixed_reality_sts_rest_client import MixedRealityStsRestClient +__all__ = ['MixedRealityStsRestClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_configuration.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_configuration.py new file mode 100644 index 000000000000..9a762cc1fa5c --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_configuration.py @@ -0,0 +1,51 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + +VERSION = "unknown" + +class MixedRealityStsRestClientConfiguration(Configuration): + """Configuration for MixedRealityStsRestClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + """ + + def __init__( + self, + **kwargs # type: Any + ): + # type: (...) -> None + super(MixedRealityStsRestClientConfiguration, self).__init__(**kwargs) + + kwargs.setdefault('sdk_moniker', 'mixedrealitystsrestclient/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or policies.HttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_mixed_reality_sts_rest_client.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_mixed_reality_sts_rest_client.py new file mode 100644 index 000000000000..53973ea0933f --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/_mixed_reality_sts_rest_client.py @@ -0,0 +1,57 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core import PipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + +from ._configuration import MixedRealityStsRestClientConfiguration +from .operations import MixedRealityStsRestClientOperationsMixin +from . import models + + +class MixedRealityStsRestClient(MixedRealityStsRestClientOperationsMixin): + """Definition for the Mixed Reality Cloud STS service APIs. + + :param str base_url: Service URL + """ + + def __init__( + self, + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://sts.mixedreality.azure.com' + self._config = MixedRealityStsRestClientConfiguration(**kwargs) + self._client = PipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> MixedRealityStsRestClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/__init__.py new file mode 100644 index 000000000000..17251fcb2dbf --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/__init__.py @@ -0,0 +1,10 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._mixed_reality_sts_rest_client import MixedRealityStsRestClient +__all__ = ['MixedRealityStsRestClient'] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_configuration.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_configuration.py new file mode 100644 index 000000000000..6045303ca6c1 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_configuration.py @@ -0,0 +1,45 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies + +VERSION = "unknown" + +class MixedRealityStsRestClientConfiguration(Configuration): + """Configuration for MixedRealityStsRestClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + """ + + def __init__( + self, + **kwargs: Any + ) -> None: + super(MixedRealityStsRestClientConfiguration, self).__init__(**kwargs) + + kwargs.setdefault('sdk_moniker', 'mixedrealitystsrestclient/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or policies.HttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_mixed_reality_sts_rest_client.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_mixed_reality_sts_rest_client.py new file mode 100644 index 000000000000..593e47542967 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/_mixed_reality_sts_rest_client.py @@ -0,0 +1,49 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional + +from azure.core import AsyncPipelineClient +from msrest import Deserializer, Serializer + +from ._configuration import MixedRealityStsRestClientConfiguration +from .operations import MixedRealityStsRestClientOperationsMixin +from .. import models + + +class MixedRealityStsRestClient(MixedRealityStsRestClientOperationsMixin): + """Definition for the Mixed Reality Cloud STS service APIs. + + :param str base_url: Service URL + """ + + def __init__( + self, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://sts.mixedreality.azure.com' + self._config = MixedRealityStsRestClientConfiguration(**kwargs) + self._client = AsyncPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "MixedRealityStsRestClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/__init__.py new file mode 100644 index 000000000000..56b55f918c06 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/__init__.py @@ -0,0 +1,13 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._mixed_reality_sts_rest_client_operations import MixedRealityStsRestClientOperationsMixin + +__all__ = [ + 'MixedRealityStsRestClientOperationsMixin', +] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/_mixed_reality_sts_rest_client_operations.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/_mixed_reality_sts_rest_client_operations.py new file mode 100644 index 000000000000..90031d443396 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/aio/operations/_mixed_reality_sts_rest_client_operations.py @@ -0,0 +1,89 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class MixedRealityStsRestClientOperationsMixin: + + async def get_token( + self, + account_id: str, + api_version: Optional[str] = "2019-02-28-preview", + token_request_options: Optional["_models.TokenRequestOptions"] = None, + **kwargs + ) -> "_models.StsTokenResponseMessage": + """Gets an access token to be used with Mixed Reality services. + + Gets an access token to be used with Mixed Reality services. + + :param account_id: The Mixed Reality account identifier. + :type account_id: str + :param api_version: Api Version. + :type api_version: str + :param token_request_options: Parameter group. + :type token_request_options: ~azure.mixedreality.authentication._generated.models.TokenRequestOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StsTokenResponseMessage, or the result of cls(response) + :rtype: ~azure.mixedreality.authentication._generated.models.StsTokenResponseMessage + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StsTokenResponseMessage"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _client_request_id = None + if token_request_options is not None: + _client_request_id = token_request_options.client_request_id + accept = "application/json" + + # Construct URL + url = self.get_token.metadata['url'] # type: ignore + path_format_arguments = { + 'accountId': self._serialize.url("account_id", account_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if api_version is not None: + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + if _client_request_id is not None: + header_parameters['X-MRC-CV'] = self._serialize.header("client_request_id", _client_request_id, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response) + + response_headers = {} + response_headers['MS-CV']=self._deserialize('str', response.headers.get('MS-CV')) + deserialized = self._deserialize('StsTokenResponseMessage', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + get_token.metadata = {'url': '/Accounts/{accountId}/token'} # type: ignore diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/__init__.py new file mode 100644 index 000000000000..6e706bc24cdc --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/__init__.py @@ -0,0 +1,19 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import StsTokenResponseMessage + from ._models_py3 import TokenRequestOptions +except (SyntaxError, ImportError): + from ._models import StsTokenResponseMessage # type: ignore + from ._models import TokenRequestOptions # type: ignore + +__all__ = [ + 'StsTokenResponseMessage', + 'TokenRequestOptions', +] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models.py new file mode 100644 index 000000000000..2b8d812be323 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models.py @@ -0,0 +1,54 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import msrest.serialization + + +class StsTokenResponseMessage(msrest.serialization.Model): + """Represents a token response message from the STS service. + + All required parameters must be populated in order to send to Azure. + + :param access_token: Required. An access token for the account. + :type access_token: str + """ + + _validation = { + 'access_token': {'required': True}, + } + + _attribute_map = { + 'access_token': {'key': 'AccessToken', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StsTokenResponseMessage, self).__init__(**kwargs) + self.access_token = kwargs['access_token'] + + +class TokenRequestOptions(msrest.serialization.Model): + """Parameter group. + + :param client_request_id: The client request correlation vector, which should be set to a new + value for each request. Useful when debugging with Microsoft. + :type client_request_id: str + """ + + _attribute_map = { + 'client_request_id': {'key': 'clientRequestId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TokenRequestOptions, self).__init__(**kwargs) + self.client_request_id = kwargs.get('client_request_id', None) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models_py3.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models_py3.py new file mode 100644 index 000000000000..5ecff28c8992 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/models/_models_py3.py @@ -0,0 +1,60 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Optional + +import msrest.serialization + + +class StsTokenResponseMessage(msrest.serialization.Model): + """Represents a token response message from the STS service. + + All required parameters must be populated in order to send to Azure. + + :param access_token: Required. An access token for the account. + :type access_token: str + """ + + _validation = { + 'access_token': {'required': True}, + } + + _attribute_map = { + 'access_token': {'key': 'AccessToken', 'type': 'str'}, + } + + def __init__( + self, + *, + access_token: str, + **kwargs + ): + super(StsTokenResponseMessage, self).__init__(**kwargs) + self.access_token = access_token + + +class TokenRequestOptions(msrest.serialization.Model): + """Parameter group. + + :param client_request_id: The client request correlation vector, which should be set to a new + value for each request. Useful when debugging with Microsoft. + :type client_request_id: str + """ + + _attribute_map = { + 'client_request_id': {'key': 'clientRequestId', 'type': 'str'}, + } + + def __init__( + self, + *, + client_request_id: Optional[str] = None, + **kwargs + ): + super(TokenRequestOptions, self).__init__(**kwargs) + self.client_request_id = client_request_id diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/__init__.py new file mode 100644 index 000000000000..56b55f918c06 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/__init__.py @@ -0,0 +1,13 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._mixed_reality_sts_rest_client_operations import MixedRealityStsRestClientOperationsMixin + +__all__ = [ + 'MixedRealityStsRestClientOperationsMixin', +] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/_mixed_reality_sts_rest_client_operations.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/_mixed_reality_sts_rest_client_operations.py new file mode 100644 index 000000000000..8b8628e0c285 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/operations/_mixed_reality_sts_rest_client_operations.py @@ -0,0 +1,94 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class MixedRealityStsRestClientOperationsMixin(object): + + def get_token( + self, + account_id, # type: str + api_version="2019-02-28-preview", # type: Optional[str] + token_request_options=None, # type: Optional["_models.TokenRequestOptions"] + **kwargs # type: Any + ): + # type: (...) -> "_models.StsTokenResponseMessage" + """Gets an access token to be used with Mixed Reality services. + + Gets an access token to be used with Mixed Reality services. + + :param account_id: The Mixed Reality account identifier. + :type account_id: str + :param api_version: Api Version. + :type api_version: str + :param token_request_options: Parameter group. + :type token_request_options: ~azure.mixedreality.authentication._generated.models.TokenRequestOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StsTokenResponseMessage, or the result of cls(response) + :rtype: ~azure.mixedreality.authentication._generated.models.StsTokenResponseMessage + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StsTokenResponseMessage"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _client_request_id = None + if token_request_options is not None: + _client_request_id = token_request_options.client_request_id + accept = "application/json" + + # Construct URL + url = self.get_token.metadata['url'] # type: ignore + path_format_arguments = { + 'accountId': self._serialize.url("account_id", account_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if api_version is not None: + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + if _client_request_id is not None: + header_parameters['X-MRC-CV'] = self._serialize.header("client_request_id", _client_request_id, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response) + + response_headers = {} + response_headers['MS-CV']=self._deserialize('str', response.headers.get('MS-CV')) + deserialized = self._deserialize('StsTokenResponseMessage', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + get_token.metadata = {'url': '/Accounts/{accountId}/token'} # type: ignore diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/py.typed b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_generated/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/__init__.py new file mode 100644 index 000000000000..5b396cd202e8 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/__init__.py @@ -0,0 +1,5 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/__init__.py new file mode 100644 index 000000000000..5b396cd202e8 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/__init__.py @@ -0,0 +1,5 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixed_reality_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixed_reality_token_credential.py new file mode 100644 index 000000000000..7cc4e98d8bc6 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixed_reality_token_credential.py @@ -0,0 +1,67 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +from azure.mixedreality.authentication.aio import MixedRealityStsClient +from .static_access_token_credential import StaticAccessTokenCredential + +if TYPE_CHECKING: + from typing import Any + from azure.core.credentials import AccessToken + from azure.core.credentials_async import AsyncTokenCredential + +def get_mixedreality_credential( + account_id: str, + account_domain: str, + endpoint_url: str, + credential: "AsyncTokenCredential", + **kwargs): + if isinstance(credential, StaticAccessTokenCredential): + return credential + + return MixedRealityTokenCredential( + account_id=account_id, + account_domain=account_domain, + endpoint_url=endpoint_url, + credential=credential, + **kwargs) + + +class MixedRealityTokenCredential(object): + """ Represents a token credential that can be used to access a Mixed Reality service. + This implements the TokenCredential protocol. + + :param str account_id: The Mixed Reality service account identifier. + :param str endpoint_url: The Mixed Reality STS service endpoint. + :param TokenCredential credential: The credential used to access the Mixed Reality service. + """ + + def __init__( + self, + account_id: str, + account_domain: str, + endpoint_url: str, + credential: "AsyncTokenCredential", + **kwargs): + self.stsClient = MixedRealityStsClient( + account_id=account_id, + account_domain=account_domain, + endpoint_url=endpoint_url, + credential=credential, + **kwargs) + + async def get_token(self, *scopes: str, **kwargs: "Any") -> "AccessToken": #pylint: disable=unused-argument + return await self.stsClient.get_token(**kwargs) + + async def close(self) -> None: + self.stsClient.close() + + async def __aenter__(self): + await self.stsClient.__aenter__() + return self + + async def __aexit__(self, exc_type, exc_value, traceback) -> None: + await self.stsClient.__aexit__() diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixedreality_account_key_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixedreality_account_key_credential.py new file mode 100644 index 000000000000..2f9efb559a53 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/mixedreality_account_key_credential.py @@ -0,0 +1,54 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +from datetime import date, datetime + +from azure.core.credentials import AccessToken + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + from azure.core.credentials import AzureKeyCredential + +ACCOUNT_KEY_VALID_YEARS = 10 + +class MixedRealityAccountKeyCredential(object): + """ Represents an object used for Mixed Reality account key authentication. + + :param str account_id: The Mixed Reality service account identifier. + :param AzureKeyCredential account_key: The Mixed Reality service account primary or secondary key credential. + """ + + def __init__(self, account_id, account_key): + # type: (str, AzureKeyCredential) -> None + self.account_id = account_id + self.account_key = account_key + + async def get_token(self, *scopes: str, **kwargs: "Any") -> "AccessToken": #pylint: disable=unused-argument + token = self.account_id + ":" + self.account_key.key + + # No way to know when an account key might expire, so we'll set the + # access token wrapping it to expire 10 years in the future. + expiration_date = _add_years(datetime.now(), ACCOUNT_KEY_VALID_YEARS) + expiration_timestamp = int(expiration_date.timestamp()) + + return AccessToken(token, expiration_timestamp) + + async def close(self) -> None: + pass + + async def __aenter__(self): + pass + + async def __aexit__(self, exc_type, exc_value, traceback) -> None: + pass + +def _add_years(date_to_update, years): + try: + return date_to_update.replace(year=date_to_update.year + years) + except ValueError: + return date_to_update + (date(date_to_update.year + years, 1, 1) - date(date_to_update.year, 1, 1)) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/static_access_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/static_access_token_credential.py new file mode 100644 index 000000000000..fccbd6f1a2b0 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/aio/static_access_token_credential.py @@ -0,0 +1,38 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + from azure.core.credentials_async import AsyncTokenCredential + from azure.core.credentials import AccessToken + +class StaticAccessTokenCredential(object): + """ Represents a static access token credential. + This implements the AsyncTokenCredential protocol. + + :param AccessToken access_token: An access token. + """ + + def __init__(self, access_token: "AccessToken"): + self._access_token = access_token + + async def get_token( + self, + #pylint: disable=unused-argument + *scopes: str, + **kwargs: "Any") -> "AccessToken": + return self._access_token + + async def close(self) -> None: + pass + + async def __aenter__(self): + pass + + async def __aexit__(self, exc_type, exc_value, traceback) -> None: + pass diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/authentication_endpoint.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/authentication_endpoint.py new file mode 100644 index 000000000000..72bdcc70fd96 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/authentication_endpoint.py @@ -0,0 +1,9 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +def construct_endpoint_url(account_domain): + # type: (str) -> str + return 'https://sts.' + account_domain diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixed_reality_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixed_reality_token_credential.py new file mode 100644 index 000000000000..e0bb1dda3627 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixed_reality_token_credential.py @@ -0,0 +1,50 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +from azure.mixedreality.authentication import MixedRealityStsClient +from .static_access_token_credential import StaticAccessTokenCredential + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Union + from azure.core.credentials import AccessToken, TokenCredential + + +def get_mixedreality_credential(account_id, account_domain, endpoint_url, credential, **kwargs): + # type: (str, str, str, TokenCredential, Any) -> TokenCredential + if isinstance(credential, StaticAccessTokenCredential): + return credential + + return MixedRealityTokenCredential( + account_id=account_id, + account_domain=account_domain, + endpoint_url=endpoint_url, + credential=credential, + **kwargs) + + +class MixedRealityTokenCredential(object): + """ Represents a token credential that can be used to access a Mixed Reality service. + This implements the TokenCredential protocol. + + :param str account_id: The Mixed Reality service account identifier. + :param str endpoint_url: The Mixed Reality STS service endpoint. + :param TokenCredential credential: The credential used to access the Mixed Reality service. + """ + + def __init__(self, account_id, account_domain, endpoint_url, credential, **kwargs): + # type: (str, str, str, TokenCredential, Any) -> None + self.stsClient = MixedRealityStsClient( + account_id=account_id, + account_domain=account_domain, + endpoint_url=endpoint_url, + credential=credential, + **kwargs) + + def get_token(self, *scopes, **kwargs): #pylint: disable=unused-argument + # type: (*str, **Any) -> AccessToken + return self.stsClient.get_token(**kwargs) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixedreality_account_key_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixedreality_account_key_credential.py new file mode 100644 index 000000000000..a7ec1ca5db63 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/mixedreality_account_key_credential.py @@ -0,0 +1,46 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +from datetime import date, datetime +import time + +from azure.core.credentials import AzureKeyCredential, AccessToken + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + +ACCOUNT_KEY_VALID_YEARS = 10 + +class MixedRealityAccountKeyCredential(object): + """ Represents an object used for Mixed Reality account key authentication. + + :param str account_id: The Mixed Reality service account identifier. + :param AzureKeyCredential account_key: The Mixed Reality service account primary or secondary key credential. + """ + + def __init__(self, account_id, account_key): + # type: (str, AzureKeyCredential) -> None + self.account_id = account_id + self.account_key = account_key + + def get_token(self, *scopes, **kwargs): #pylint: disable=unused-argument + # type: (*str, **Any) -> AccessToken + + token = self.account_id + ":" + self.account_key.key + + # No way to know when an account key might expire, so we'll set the + # access token wrapping it to expire 10 years in the future. + expiration_date = _add_years(datetime.now(), ACCOUNT_KEY_VALID_YEARS) + expiration_timestamp = int(time.mktime(expiration_date.timetuple())) + + return AccessToken(token, expiration_timestamp) + +def _add_years(date_to_update, years): + try: + return date_to_update.replace(year=date_to_update.year + years) + except ValueError: + return date_to_update + (date(date_to_update.year + years, 1, 1) - date(date_to_update.year, 1, 1)) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/static_access_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/static_access_token_credential.py new file mode 100644 index 000000000000..712f4e20738f --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_shared/static_access_token_credential.py @@ -0,0 +1,27 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + from azure.core.credentials import TokenCredential + from azure.core.credentials import AccessToken + +class StaticAccessTokenCredential(object): + """ Represents a static access token credential. + This implements the TokenCredential protocol. + + :param AccessToken access_token: An access token. + """ + + def __init__(self, access_token): + # type: (AccessToken) -> None + self._access_token = access_token + + def get_token(self, *scopes, **kwargs): #pylint: disable=unused-argument + # type: (*str, **Any) -> AccessToken + return self._access_token diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_utils.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_utils.py new file mode 100644 index 000000000000..9a016a0692a7 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_utils.py @@ -0,0 +1,73 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +import base64 +import json +import random + +from azure.core.credentials import AccessToken + +from ._generated.models import StsTokenResponseMessage + + +def convert_to_access_token(token_response_message): + # type: (StsTokenResponseMessage) -> AccessToken + """ + Converts the specified token response message to an AccessToken. + """ + if not token_response_message: + raise ValueError("token_response_message must be a non-empty string.") + + expiration_timestamp = retrieve_jwt_expiration_timestamp(token_response_message.access_token) + + return AccessToken(token_response_message.access_token, expiration_timestamp) + +def retrieve_jwt_expiration_timestamp(jwt_value): + # type: (str) -> int + """ + Retrieves the expiration value from the JWT. + + :param str jwt_value: The JWT value. + :returns: int + """ + if not jwt_value: + raise ValueError("jwt_value must be a non-empty string.") + + parts = jwt_value.split(".") + + if len(parts) < 3: + raise ValueError("Invalid JWT structure. Expected a JWS Compact Serialization formatted value.") + + try: + padded_base64_payload = base64.b64decode(parts[1]).decode('utf-8') + payload = json.loads(padded_base64_payload) + except ValueError: + raise ValueError("Unable to decode the JWT.") + + try: + exp = payload['exp'] + except KeyError: + raise ValueError("Invalid JWT payload structure. No expiration.") + + return int(exp) + +BASE_64_CHAR_SET = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" +CV_BASE_LENGTH = 22 + +def generate_cv_base(): + # type: () -> str + """ + Seed function to randomly generate a 16 character base64 encoded string for + the Correlation Vector's base value. + """ + result = '' + + #pylint: disable=unused-variable + for i in range(CV_BASE_LENGTH): + random_index = random.randint(0, len(BASE_64_CHAR_SET) - 1) + result += BASE_64_CHAR_SET[random_index] + + return result diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_version.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_version.py new file mode 100644 index 000000000000..14cf0981d001 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/_version.py @@ -0,0 +1,10 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +# matches SEMVER +VERSION = "1.0.0b1" + +SDK_MONIKER = "mixedreality-authentication/{}".format(VERSION) # type: str diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/__init__.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/__init__.py new file mode 100644 index 000000000000..736dc1c08fe4 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/__init__.py @@ -0,0 +1,11 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from ._client_async import MixedRealityStsClient + +__all__ = [ + 'MixedRealityStsClient' +] diff --git a/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/_client_async.py b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/_client_async.py new file mode 100644 index 000000000000..fedbacccf397 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/azure/mixedreality/authentication/aio/_client_async.py @@ -0,0 +1,112 @@ +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +# pylint: disable=unused-import,ungrouped-imports +from typing import Any, TYPE_CHECKING, Union + +try: + from urllib.parse import urlparse +except ImportError: + from urlparse import urlparse # type: ignore + +from azure.core.credentials import AzureKeyCredential +from azure.core.tracing.decorator_async import distributed_trace_async +from azure.core.pipeline.policies import AsyncBearerTokenCredentialPolicy + +from .._generated.aio import MixedRealityStsRestClient +from .._generated.models import TokenRequestOptions +from .._version import SDK_MONIKER +from .._shared.authentication_endpoint import construct_endpoint_url +from .._shared.aio.mixedreality_account_key_credential import MixedRealityAccountKeyCredential +from .._utils import convert_to_access_token, generate_cv_base + +if TYPE_CHECKING: + from azure.core.credentials import AccessToken + from azure.core.credentials_async import AsyncTokenCredential + + +class MixedRealityStsClient(object): + """ A client to interact with the Mixed Reality STS service. + + :param str account_id: + The Mixed Reality service account identifier. + :param str account_domain: + The Mixed Reality service account domain. + :param Union[TokenCredential, AzureKeyCredential] credential: + The credential used to access the Mixed Reality service. + :keyword str custom_endpoint_url: + Override the Mixed Reality STS service endpoint. + """ + + def __init__(self, + account_id: str, + account_domain: str, + credential: Union[AzureKeyCredential, "AsyncTokenCredential"], #pylint: disable=unsubscriptable-object + **kwargs) -> None: + if not account_id: + raise ValueError("account_id must be a non-empty string.") + + if not account_domain: + raise ValueError("account_domain must be a non-empty string.") + + if not credential: + raise ValueError("credential can not be None.") + + self._account_id = account_id + self._account_domain = account_domain + + if isinstance(credential, AzureKeyCredential): + credential = MixedRealityAccountKeyCredential(account_id, credential) + + self._credential = credential + + endpoint_url = kwargs.pop('custom_endpoint_url', construct_endpoint_url(account_domain)) + + try: + if not endpoint_url.lower().startswith('http'): + endpoint_url = "https://" + endpoint_url + except AttributeError as ex: + raise ValueError("Host URL must be a string.") from ex + + parsed_url = urlparse(endpoint_url.rstrip('/')) + if not parsed_url.netloc: + raise ValueError("Invalid URL: {}".format(endpoint_url)) + + self._endpoint_url = endpoint_url + + authentication_policy = AsyncBearerTokenCredentialPolicy(credential, [endpoint_url + '/.default']) + + self._client = MixedRealityStsRestClient( + base_url=endpoint_url, + authentication_policy=authentication_policy, + sdk_moniker=SDK_MONIKER, + **kwargs) + + @distributed_trace_async + async def get_token(self, **kwargs) -> "AccessToken": + """ + Retrieve a token from the STS service for the specified account identifier asynchronously. + :return: Instance of azure.core.credentials.AccessToken - token and expiry date of it + :rtype: :class:`azure.core.credentials.AccessToken` + """ + token_request_options = TokenRequestOptions() + token_request_options.client_request_id = generate_cv_base() + + response = await self._client.get_token( + self._account_id, + token_request_options=token_request_options, + **kwargs) + return convert_to_access_token(response) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "MixedRealityStsClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *args) -> None: + await self._client.__aexit__(*args) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt b/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt new file mode 100644 index 000000000000..d9b5454b3434 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt @@ -0,0 +1,4 @@ +-e ../../../tools/azure-sdk-tools +../azure-mixedreality-nspkg +../../core/azure-core +aiohttp>=3.0; python_version >= '3.5' diff --git a/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample async.py b/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample async.py new file mode 100644 index 000000000000..5dc595bc2f3e --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample async.py @@ -0,0 +1,70 @@ + +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +""" +FILE: client_sample_async.py +DESCRIPTION: + These samples demonstrate creating a client and requesting a token. + +USAGE: + python client_sample_async.py + Set the environment variables with your own values before running the sample: + 1) MIXEDREALITY_ACCOUNT_DOMAIN - the Mixed Reality account domain. + 2) MIXEDREALITY_ACCOUNT_ID - the Mixed Reality account identifier. + 3) MIXEDREALITY_ACCOUNT_KEY - the Mixed Reality account primary or secondary key. +""" + + +import os +import asyncio + + +class ClientSamplesAsync(object): + from azure.core.credentials import AzureKeyCredential + + account_domain = os.environ.get("MIXEDREALITY_ACCOUNT_DOMAIN", None) + if not account_domain: + raise ValueError("Set MIXEDREALITY_ACCOUNT_DOMAIN env before run this sample.") + + account_id = os.environ.get("MIXEDREALITY_ACCOUNT_ID", None) + if not account_id: + raise ValueError("Set MIXEDREALITY_ACCOUNT_ID env before run this sample.") + + account_key = os.environ.get("MIXEDREALITY_ACCOUNT_KEY", None) + if not account_key: + raise ValueError("Set MIXEDREALITY_ACCOUNT_KEY env before run this sample.") + + key_credential = AzureKeyCredential(account_key) + + def create_client(self): + # [START create_client] + from azure.mixedreality.authentication.aio import MixedRealityStsClient + client = MixedRealityStsClient(self.account_id, self.account_domain, self.key_credential) + # [END create_client] + + print("client created") + + async def get_token(self): + from azure.mixedreality.authentication.aio import MixedRealityStsClient + client = MixedRealityStsClient(self.account_id, self.account_domain, self.key_credential) + + async with client: + # [START get_token] + access_token = await client.get_token() + # [END get_token] + + print("token retrieved: " + access_token.token) + + +async def main(): + sample = ClientSamplesAsync() + sample.create_client() + await sample.get_token() + +if __name__ == '__main__': + loop = asyncio.get_event_loop() + loop.run_until_complete(main()) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample.py b/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample.py new file mode 100644 index 000000000000..0de0e21a39de --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/samples/client_sample.py @@ -0,0 +1,63 @@ + +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +""" +FILE: client_sample.py +DESCRIPTION: + These samples demonstrate creating a client and requesting a token. + +USAGE: + python client_sample.py + Set the environment variables with your own values before running the sample: + 1) MIXEDREALITY_ACCOUNT_DOMAIN - the Mixed Reality account domain. + 2) MIXEDREALITY_ACCOUNT_ID - the Mixed Reality account identifier. + 3) MIXEDREALITY_ACCOUNT_KEY - the Mixed Reality account primary or secondary key. +""" + + +import os + + +class ClientSamples(object): + from azure.core.credentials import AzureKeyCredential + + account_domain = os.environ.get("MIXEDREALITY_ACCOUNT_DOMAIN", None) + if not account_domain: + raise ValueError("Set MIXEDREALITY_ACCOUNT_DOMAIN env before run this sample.") + + account_id = os.environ.get("MIXEDREALITY_ACCOUNT_ID", None) + if not account_id: + raise ValueError("Set MIXEDREALITY_ACCOUNT_ID env before run this sample.") + + account_key = os.environ.get("MIXEDREALITY_ACCOUNT_KEY", None) + if not account_key: + raise ValueError("Set MIXEDREALITY_ACCOUNT_KEY env before run this sample.") + + key_credential = AzureKeyCredential(account_key) + + def create_client(self): + # [START create_client] + from azure.mixedreality.authentication import MixedRealityStsClient + client = MixedRealityStsClient(self.account_id, self.account_domain, self.key_credential) + # [END create_client] + + print("client created") + + def get_token(self): + # [START get_token] + from azure.mixedreality.authentication import MixedRealityStsClient + client = MixedRealityStsClient(self.account_id, self.account_domain, self.key_credential) + access_token = client.get_token() + # [END get_token] + + print("token retrieved: " + access_token.token) + + +if __name__ == '__main__': + sample = ClientSamples() + sample.create_client() + sample.get_token() diff --git a/sdk/mixedreality/azure-mixedreality-authentication/sdk_packaging.toml b/sdk/mixedreality/azure-mixedreality-authentication/sdk_packaging.toml new file mode 100644 index 000000000000..2684d587e162 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/sdk_packaging.toml @@ -0,0 +1,7 @@ +[packaging] +auto_update = false +package_name = "azure-mixedreality-authentication" +package_pprint_name = "Mixed Reality Authentication" +package_doc_id = "" +is_stable = false +is_arm = false diff --git a/sdk/mixedreality/azure-mixedreality-authentication/setup.cfg b/sdk/mixedreality/azure-mixedreality-authentication/setup.cfg new file mode 100644 index 000000000000..3c6e79cf31da --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/setup.cfg @@ -0,0 +1,2 @@ +[bdist_wheel] +universal=1 diff --git a/sdk/mixedreality/azure-mixedreality-authentication/setup.py b/sdk/mixedreality/azure-mixedreality-authentication/setup.py new file mode 100644 index 000000000000..0384e23bf7c8 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/setup.py @@ -0,0 +1,80 @@ +from setuptools import setup, find_packages +import os +from io import open +import re + +# example setup.py Feel free to copy the entire "azure-template" folder into a package folder named +# with "azure-". Ensure that the below arguments to setup() are updated to reflect +# your package. + +# this setup.py is set up in a specific way to keep the azure* and azure-mgmt-* namespaces WORKING all the way +# up from python 2.7. Reference here: https://github.com/Azure/azure-sdk-for-python/wiki/Azure-packaging + +PACKAGE_NAME = "azure-mixedreality-authentication" +PACKAGE_PPRINT_NAME = "Mixed Reality Authentication" + +# a-b-c => a/b/c +package_folder_path = PACKAGE_NAME.replace('-', '/') +# a-b-c => a.b.c +namespace_name = PACKAGE_NAME.replace('-', '.') + +# Version extraction inspired from 'requests' +with open(os.path.join(package_folder_path, '_version.py'), 'r') as fd: + version = re.search(r'^VERSION\s*=\s*[\'"]([^\'"]*)[\'"]', + fd.read(), re.MULTILINE).group(1) +if not version: + raise RuntimeError('Cannot find version information') + +with open('README.md', encoding='utf-8') as f: + readme = f.read() + +with open('CHANGELOG.md', encoding='utf-8') as f: + changelog = f.read() + +setup( + name=PACKAGE_NAME, + version=version, + description='Microsoft Azure {} Client Library for Python'.format(PACKAGE_PPRINT_NAME), + + # ensure that these are updated to reflect the package owners' information + long_description=readme + "\n\n" + changelog, + long_description_content_type='text/markdown', + url='https://github.com/Azure/azure-sdk-for-python', + author='Microsoft Corporation', + author_email='azuresdkengsysadmins@microsoft.com', + + license='MIT License', + # ensure that the development status reflects the status of your package + classifiers=[ + "Development Status :: 4 - Beta", + + 'Programming Language :: Python', + 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3', + 'Programming Language :: Python :: 3.5', + 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: 3.9', + 'License :: OSI Approved :: MIT License', + ], + packages=find_packages(exclude=[ + 'tests', + # Exclude packages that will be covered by PEP420 or nspkg + 'azure', + 'azure.mixedreality' + ]), + install_requires=[ + 'azure-core<2.0.0,>=1.2.2', + 'msrest>=0.5.0' + ], + extras_require={ + ":python_version<'3.0'": ['azure-mixedreality-nspkg'], + ":python_version<'3.5'": ["typing"] + }, + project_urls={ + 'Bug Reports': 'https://github.com/Azure/azure-sdk-for-python/issues', + 'Source': 'https://github.com/Azure/azure-sdk-python', + } +) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/swagger/SWAGGER.md b/sdk/mixedreality/azure-mixedreality-authentication/swagger/SWAGGER.md new file mode 100644 index 000000000000..40af809e4840 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/swagger/SWAGGER.md @@ -0,0 +1,30 @@ +# Azure Mixed Reality Authentication Service client library for Python + +## Setup + +```ps +npm install -g autorest +``` + +## Generation + +```ps +cd +autorest SWAGGER.md +``` + +### Code generation settings + +```yaml +title: MixedRealityStsRestClient +input-file: https://raw.githubusercontent.com/Azure/azure-rest-api-specs/aa19725fe79aea2a9dc580f3c66f77f89cc34563/specification/mixedreality/data-plane/Microsoft.MixedReality/preview/2019-02-28-preview/mr-sts.json +output-folder: ../azure/mixedreality/authentication/_generated +namespace: azure.mixedreality.authentication._generated +no-namespace-folders: true +license-header: MICROSOFT_MIT_NO_VERSION +enable-xml: false +clear-output-folder: true +python: true +v3: true +add-credentials: false +``` diff --git a/sdk/mixedreality/azure-mixedreality-authentication/swagger/update.ps1 b/sdk/mixedreality/azure-mixedreality-authentication/swagger/update.ps1 new file mode 100644 index 000000000000..a7490a9848d1 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/swagger/update.ps1 @@ -0,0 +1,6 @@ +Push-Location $PSScriptRoot +try { + & autorest SWAGGER.md +} finally { + Pop-Location +} diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/_constants.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/_constants.py new file mode 100644 index 000000000000..9de02c451788 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/_constants.py @@ -0,0 +1,10 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +# Fake account details matching recordings. +MIXEDREALITY_ACCOUNT_DOMAIN="mixedreality.azure.com" +MIXEDREALITY_ACCOUNT_ID="68321d5a-7978-4ceb-b880-0f49751daae9" +MIXEDREALITY_ACCOUNT_KEY="NjgzMjFkNWEtNzk3OC00Y2ViLWI4ODAtMGY0OTc1MWRhYWU5" \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/conftest.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/conftest.py new file mode 100644 index 000000000000..9f69fcac8bdc --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/conftest.py @@ -0,0 +1,11 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +import sys + +# Ignore collection of async tests for Python 2 +collect_ignore_glob = [] +if sys.version_info < (3, 5): + collect_ignore_glob.append("*_async.py") diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client.test_get_token.yaml b/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client.test_get_token.yaml new file mode 100644 index 000000000000..6be3baa36955 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client.test_get_token.yaml @@ -0,0 +1,38 @@ +interactions: +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-mixedreality-authentication/1.0.0b1 Python/3.9.1 (Windows-10-10.0.19041-SP0) + X-MRC-CV: + - z2TH5gImRhQCZc4ubhqtRV + method: GET + uri: https://sts.mixedreality.azure.com/Accounts/68321d5a-7978-4ceb-b880-0f49751daae9/token?api-version=2019-02-28-preview + response: + body: + string: '{"AccessToken":"eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTYwNzk3ODY4MyIsIm5iZiI6IjE2MDc5Nzg2ODMiLCJleHAiOiIxNjA3OTc4OTgzIn0=."}' + headers: + cache-control: + - no-store,no-cache + content-length: + - '1264' + content-type: + - application/json; charset=utf-8 + date: + - Thu, 28 Jan 2021 01:56:10 GMT + ms-cv: + - gKXl1CkeG0mRb6HEtMUmHQ.0 + pragma: + - no-cache + x-content-type-options: + - nosniff + status: + code: 200 + message: OK +version: 1 diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client_async.test_get_token.yaml b/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client_async.test_get_token.yaml new file mode 100644 index 000000000000..32b3c3b0e66c --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/recordings/test_client_async.test_get_token.yaml @@ -0,0 +1,28 @@ +interactions: +- request: + body: null + headers: + Accept: + - application/json + User-Agent: + - azsdk-python-mixedreality-authentication/1.0.0b1 Python/3.9.1 (Windows-10-10.0.19041-SP0) + X-MRC-CV: + - DOGUG9rex0lylvLZmhuJgR + method: GET + uri: https://sts.mixedreality.azure.com/Accounts/68321d5a-7978-4ceb-b880-0f49751daae9/token?api-version=2019-02-28-preview + response: + body: + string: '{"AccessToken":"eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTYwNzk3ODY4MyIsIm5iZiI6IjE2MDc5Nzg2ODMiLCJleHAiOiIxNjA3OTc4OTgzIn0=."}' + headers: + cache-control: no-store,no-cache + content-length: '1264' + content-type: application/json; charset=utf-8 + date: Thu, 28 Jan 2021 18:31:51 GMT + ms-cv: K89E7J8QQ0qfkjIiukWztw.0 + pragma: no-cache + x-content-type-options: nosniff + status: + code: 200 + message: OK + url: https://sts.mixedreality.azure.com/Accounts/68321d5a-7978-4ceb-b880-0f49751daae9/token?api-version=2019-02-28-preview +version: 1 diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client.py new file mode 100644 index 000000000000..33e4fee685df --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client.py @@ -0,0 +1,106 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +import os +import pytest + +from devtools_testutils import AzureTestCase + +from azure.core.credentials import AzureKeyCredential +from azure.mixedreality.authentication import MixedRealityStsClient +from azure.mixedreality.authentication._shared.mixedreality_account_key_credential import MixedRealityAccountKeyCredential + +# Import fake account details matching recordings. +from _constants import ( + MIXEDREALITY_ACCOUNT_DOMAIN, + MIXEDREALITY_ACCOUNT_ID, + MIXEDREALITY_ACCOUNT_KEY +) + + +class ClientTests(AzureTestCase): + def __init__(self, *args, **kwargs): + super(ClientTests, self).__init__(*args, **kwargs) + self.account_domain = self.get_var('MIXEDREALITY_ACCOUNT_DOMAIN', MIXEDREALITY_ACCOUNT_DOMAIN) + self.account_id = self.get_var('MIXEDREALITY_ACCOUNT_ID', MIXEDREALITY_ACCOUNT_ID) + self.account_key = self.get_var('MIXEDREALITY_ACCOUNT_KEY', MIXEDREALITY_ACCOUNT_KEY) + self.key_credential = AzureKeyCredential(self.account_key) + + def setUp(self): + super(ClientTests, self).setUp() + + def tearDown(self): + super(ClientTests, self).tearDown() + + def get_var(self, variable_name, default_or_playback_value): + if self.is_live: + return os.environ.get(variable_name, default_or_playback_value) + + return default_or_playback_value + + def test_create_client(self): + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential) + + assert client is not None + + def test_create_client_custom_with_endpoint(self): + custom_endpoint_url = "https://my.custom.endpoint" + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential, + custom_endpoint_url=custom_endpoint_url) + + assert client._endpoint_url == custom_endpoint_url + + def test_create_client_with_credential(self): + token_credential = MixedRealityAccountKeyCredential(self.account_id, self.key_credential) + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=token_credential) + + assert client._credential == token_credential + + def test_create_client_with_invalid_arguments(self): + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=None, + account_domain=self.account_domain, + credential=self.key_credential) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=None, + credential=self.key_credential) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=None) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential, + custom_endpoint_url="#") + + def test_get_token(self): + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential) + + token = client.get_token() + + assert token is not None + assert token.token is not None + assert token.expires_on is not None diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client_async.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client_async.py new file mode 100644 index 000000000000..aeead54991fc --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_client_async.py @@ -0,0 +1,108 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- +import os +import pytest + +from devtools_testutils import AzureTestCase + +from azure.core.credentials import AzureKeyCredential +from azure.mixedreality.authentication.aio import MixedRealityStsClient +from azure.mixedreality.authentication._shared.aio.mixedreality_account_key_credential import MixedRealityAccountKeyCredential + +# Import fake account details matching recordings. +from _constants import ( + MIXEDREALITY_ACCOUNT_DOMAIN, + MIXEDREALITY_ACCOUNT_ID, + MIXEDREALITY_ACCOUNT_KEY +) + + +class ClientTests(AzureTestCase): + def __init__(self, *args, **kwargs): + super(ClientTests, self).__init__(*args, **kwargs) + self.account_domain = self.get_var('MIXEDREALITY_ACCOUNT_DOMAIN', MIXEDREALITY_ACCOUNT_DOMAIN) + self.account_id = self.get_var('MIXEDREALITY_ACCOUNT_ID', MIXEDREALITY_ACCOUNT_ID) + self.account_key = self.get_var('MIXEDREALITY_ACCOUNT_KEY', MIXEDREALITY_ACCOUNT_KEY) + self.key_credential = AzureKeyCredential(self.account_key) + + def setUp(self): + super(ClientTests, self).setUp() + + def tearDown(self): + super(ClientTests, self).tearDown() + + def get_var(self, variable_name, default_or_playback_value): + # type: (str, str) -> str + if self.is_live: + return os.environ.get(variable_name, default_or_playback_value) + + return default_or_playback_value + + def test_create_client(self): + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential) + + assert client is not None + + def test_create_client_custom_with_endpoint(self): + custom_endpoint_url = "https://my.custom.endpoint" + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential, + custom_endpoint_url=custom_endpoint_url) + + assert client._endpoint_url == custom_endpoint_url + + def test_create_client_with_credential(self): + token_credential = MixedRealityAccountKeyCredential(self.account_id, self.key_credential) + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=token_credential) + + assert client._credential == token_credential + + def test_create_client_with_invalid_arguments(self): + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=None, + account_domain=self.account_domain, + credential=self.key_credential) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=None, + credential=self.key_credential) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=None) + + with pytest.raises(ValueError): + MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential, + custom_endpoint_url="#") + + @AzureTestCase.await_prepared_test + async def test_get_token(self): + client = MixedRealityStsClient( + account_id=self.account_id, + account_domain=self.account_domain, + credential=self.key_credential) + + token = await client.get_token() + + assert token is not None + assert token.token is not None + assert token.expires_on is not None diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential.py new file mode 100644 index 000000000000..bb9b3b376c6a --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential.py @@ -0,0 +1,37 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from azure.core.credentials import AccessToken, AzureKeyCredential + +from azure.mixedreality.authentication._shared.mixed_reality_token_credential import get_mixedreality_credential, MixedRealityTokenCredential +from azure.mixedreality.authentication._shared.static_access_token_credential import StaticAccessTokenCredential +from azure.mixedreality.authentication._shared.mixedreality_account_key_credential import MixedRealityAccountKeyCredential + +class TestMixedRealityTokenCredential: + def test_get_mixedreality_credential_static_credential(self): + access_token = AccessToken("My access token", 0) + credential = StaticAccessTokenCredential(access_token) + + actualCredential = get_mixedreality_credential( + account_id="account_id", + account_domain="account_domain", + endpoint_url="http://my.endpoint.url", + credential=credential) + + assert credential == actualCredential + + def test_get_mixedreality_credential_other_credential(self): + keyCredential = AzureKeyCredential("my_account_key") + credential = MixedRealityAccountKeyCredential("account_id", keyCredential) + + actualCredential = get_mixedreality_credential( + account_id="account_id", + account_domain="account_domain", + endpoint_url="http://my.endpoint.url", + credential=credential) + + assert credential != actualCredential + assert isinstance(actualCredential, MixedRealityTokenCredential) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential_async.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential_async.py new file mode 100644 index 000000000000..a7b2e02dc793 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_mixed_reality_token_credential_async.py @@ -0,0 +1,37 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from azure.core.credentials import AccessToken, AzureKeyCredential + +from azure.mixedreality.authentication._shared.aio.mixed_reality_token_credential import get_mixedreality_credential, MixedRealityTokenCredential +from azure.mixedreality.authentication._shared.aio.static_access_token_credential import StaticAccessTokenCredential +from azure.mixedreality.authentication._shared.aio.mixedreality_account_key_credential import MixedRealityAccountKeyCredential + +class TestMixedRealityTokenCredential: + def test_get_mixedreality_credential_static_credential(self): + access_token = AccessToken("My access token", 0) + credential = StaticAccessTokenCredential(access_token) + + actualCredential = get_mixedreality_credential( + account_id="account_id", + account_domain="account_domain", + endpoint_url="http://my.endpoint.url", + credential=credential) + + assert credential == actualCredential + + def test_get_mixedreality_credential_other_credential(self): + keyCredential = AzureKeyCredential("my_account_key") + credential = MixedRealityAccountKeyCredential("account_id", keyCredential) + + actualCredential = get_mixedreality_credential( + account_id="account_id", + account_domain="account_domain", + endpoint_url="http://my.endpoint.url", + credential=credential) + + assert credential != actualCredential + assert isinstance(actualCredential, MixedRealityTokenCredential) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential.py new file mode 100644 index 000000000000..0511780951dd --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential.py @@ -0,0 +1,21 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from azure.core.credentials import AccessToken + +from azure.mixedreality.authentication._shared.static_access_token_credential import StaticAccessTokenCredential + +class TestStaticAccessTokenCredential: + def test_get_token(self): + token = "My access token" + expiration = 0 + + access_token = AccessToken(token=token, expires_on=expiration) + staticAccessToken = StaticAccessTokenCredential(access_token) + + actual = staticAccessToken.get_token() + + assert access_token == actual diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential_async.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential_async.py new file mode 100644 index 000000000000..f9b7171460fd --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_static_access_token_credential_async.py @@ -0,0 +1,23 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from azure.core.credentials import AccessToken +from devtools_testutils import AzureTestCase + +from azure.mixedreality.authentication._shared.aio.static_access_token_credential import StaticAccessTokenCredential + +class TestAsyncStaticAccessTokenCredential: + @AzureTestCase.await_prepared_test + async def test_get_token(self): + token = "My access token" + expiration = 0 + + access_token = AccessToken(token=token, expires_on=expiration) + staticAccessToken = StaticAccessTokenCredential(access_token) + + actual = await staticAccessToken.get_token() + + assert access_token == actual diff --git a/sdk/mixedreality/azure-mixedreality-authentication/tests/test_utils.py b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_utils.py new file mode 100644 index 000000000000..17b31bcb87fa --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-authentication/tests/test_utils.py @@ -0,0 +1,60 @@ +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +import pytest + +from azure.mixedreality.authentication._utils import generate_cv_base, retrieve_jwt_expiration_timestamp + + +class TestUtils: + def test_generate_cv_base(self): + cv = generate_cv_base() + + assert cv is not None + assert len(cv) == 22 + + def test_generate_cv_base_are_random(self): + cv1 = generate_cv_base() + cv2 = generate_cv_base() + + assert cv1 is not None + assert cv2 is not None + assert cv1 != cv2 + + def test_retrieve_jwt_expiration_timestamp(self): + # Note: The trailing "." on the end indicates an empty signature indicating that this JWT is not signed. + jwt_value = "eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTYxMDgxMjI1MCIsIm5iZiI6IjE2MTA4MTI1NTAiLCJleHAiOiIxNjEwODk4NjUwIn0=." + expected_expiration_timestamp = 1610898650 # 1/17/2021 3:50:50 PM UTC + + actual = retrieve_jwt_expiration_timestamp(jwt_value) + + assert actual is not None + assert actual == expected_expiration_timestamp + + def test_retrieve_jwt_expiration_timestamp_invalid_parameter(self): + with pytest.raises(ValueError): + retrieve_jwt_expiration_timestamp(None) + + def test_retrieve_jwt_expiration_timestamp_invalid_structure(self): + # JWT value with missing signature section on the end. + jwt_value = "eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTYxMDgxMjI1MCIsIm5iZiI6IjE2MTA4MTI1NTAiLCJleHAiOiIxNjEwODk4NjUwIn0=" + + with pytest.raises(ValueError): + retrieve_jwt_expiration_timestamp(jwt_value) + + def test_retrieve_jwt_expiration_timestamp_invalid_payload(self): + # JWT value with missing payload. + jwt_value = "eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.." + + with pytest.raises(ValueError): + retrieve_jwt_expiration_timestamp(jwt_value) + + def test_retrieve_jwt_expiration_timestamp_invalid_exp(self): + # JWT value with missing expiration field. + jwt_value = "eyJhbGciOiJub25lIiwidHlwIjoiSldUIn0.eyJlbWFpbCI6IkJvYkBjb250b3NvLmNvbSIsImdpdmVuX25hbWUiOiJCb2IiLCJpc3MiOiJodHRwOi8vRGVmYXVsdC5Jc3N1ZXIuY29tIiwiYXVkIjoiaHR0cDovL0RlZmF1bHQuQXVkaWVuY2UuY29tIiwiaWF0IjoiMTYxMDgxMjI1MCIsIm5iZiI6IjE2MTA4MTI1NTAifQ==." + + with pytest.raises(ValueError): + retrieve_jwt_expiration_timestamp(jwt_value) diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/CHANGELOG.md b/sdk/mixedreality/azure-mixedreality-nspkg/CHANGELOG.md new file mode 100644 index 000000000000..627c355468b5 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/CHANGELOG.md @@ -0,0 +1,5 @@ +# Release History + +## 1.0.0 (Unreleased) + +- Initial release diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/MANIFEST.in b/sdk/mixedreality/azure-mixedreality-nspkg/MANIFEST.in new file mode 100644 index 000000000000..092b64f9159b --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/MANIFEST.in @@ -0,0 +1,3 @@ +include *.md +include azure/__init__.py +include azure/mixedreality/__init__.py \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/README.md b/sdk/mixedreality/azure-mixedreality-nspkg/README.md new file mode 100644 index 000000000000..995038c70840 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/README.md @@ -0,0 +1,11 @@ +# Microsoft Azure Mixed Reality SDK for Python + +This is the Microsoft Azure Mixed Reality namespace package. + +This package is not intended to be installed directly by the end user. + +It provides the necessary files for other packages to extend the +azure.mixedreality namespace. + +The complete list of available packages can be found at: +https://aka.ms/azsdk/python/all diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/azure/__init__.py b/sdk/mixedreality/azure-mixedreality-nspkg/azure/__init__.py new file mode 100644 index 000000000000..69e3be50dac4 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/azure/__init__.py @@ -0,0 +1 @@ +__path__ = __import__('pkgutil').extend_path(__path__, __name__) diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/azure/mixedreality/__init__.py b/sdk/mixedreality/azure-mixedreality-nspkg/azure/mixedreality/__init__.py new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/setup.cfg b/sdk/mixedreality/azure-mixedreality-nspkg/setup.cfg new file mode 100644 index 000000000000..3480374bc2f2 --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/setup.cfg @@ -0,0 +1,2 @@ +[bdist_wheel] +universal=1 \ No newline at end of file diff --git a/sdk/mixedreality/azure-mixedreality-nspkg/setup.py b/sdk/mixedreality/azure-mixedreality-nspkg/setup.py new file mode 100644 index 000000000000..a80cc7d1344c --- /dev/null +++ b/sdk/mixedreality/azure-mixedreality-nspkg/setup.py @@ -0,0 +1,41 @@ +#!/usr/bin/env python + +# ------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# -------------------------------------------------------------------------- + +from setuptools import setup + +setup( + name='azure-mixedreality-nspkg', + version='1.0.0', + description='Microsoft Azure Mixed Reality Namespace Package [Internal]', + long_description=open('README.md', 'r').read(), + license='MIT License', + author='Microsoft Corporation', + author_email='azurepysdk@microsoft.com', + url='https://github.com/Azure/azure-sdk-for-python/', + classifiers=[ + 'Development Status :: 5 - Production/Stable', + + 'Programming Language :: Python', + 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3', + 'Programming Language :: Python :: 3.5', + 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: 3.9', + 'License :: OSI Approved :: MIT License', + ], + zip_safe=False, + packages=[ + 'azure.mixedreality', + ], + install_requires=[ + 'azure-nspkg>=2.0.0', + ] +) \ No newline at end of file diff --git a/sdk/mixedreality/ci.yml b/sdk/mixedreality/ci.yml index 991d84a936a7..f3ae04fd79eb 100644 --- a/sdk/mixedreality/ci.yml +++ b/sdk/mixedreality/ci.yml @@ -28,5 +28,9 @@ extends: parameters: ServiceDirectory: mixedreality Artifacts: + - name: azure_mixedreality_nspkg + safeName: azuremixedrealitynspkg - name: azure_mgmt_mixedreality safeName: azuremgmtmixedreality + - name: azure_mixedreality_authentication + safeName: azuremixedrealityauthentication diff --git a/sdk/mixedreality/test-resources.json b/sdk/mixedreality/test-resources.json new file mode 100644 index 000000000000..30e81531cdfd --- /dev/null +++ b/sdk/mixedreality/test-resources.json @@ -0,0 +1,141 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "baseName": { + "type": "string", + "defaultValue": "[resourceGroup().name]", + "metadata": { + "description": "The base resource name." + } + }, + "tenantId": { + "type": "string", + "defaultValue": "72f988bf-86f1-41af-91ab-2d7cd011db47", + "metadata": { + "description": "The tenant ID to which the application and resources belong." + } + }, + "location": { + "type": "string", + "defaultValue": "[resourceGroup().location]", + "metadata": { + "description": "The location of the resource. By default, this is the same as the resource group." + } + }, + "baseTime": { + "type": "string", + "defaultValue": "[utcNow('u')]" + } + }, + "variables": { + "apiVersion": "2020-05-01", + "asaAccountName": "[concat(parameters('baseName'), '-asa-account')]", + "arrApiVersion": "2020-04-06-preview", + "arrAccountName": "[concat(parameters('baseName'), '-arr-account')]", + "storageApiVersion": "2019-06-01", + "storageAccountName": "[parameters('baseName')]", + "blobContainerName": "test", + "blobContainerResourceName": "[concat(variables('storageAccountName'), '/default/', variables('blobContainerName'))]", + "sasProperties": { + "signedPermission": "rwl", + "signedExpiry": "[dateTimeAdd(parameters('baseTime'), 'P1D')]", + "signedResource": "c", + "canonicalizedResource": "[concat('/blob/', variables('storageAccountName'), '/', variables('blobContainerName'))]" + } + }, + "resources": [ + { + "type": "Microsoft.MixedReality/spatialAnchorsAccounts", + "name": "[variables('asaAccountName')]", + "apiVersion": "[variables('apiVersion')]", + "location": "[parameters('location')]", + "properties": {} + }, + { + "type": "Microsoft.MixedReality/remoteRenderingAccounts", + "name": "[variables('arrAccountName')]", + "apiVersion": "[variables('arrApiVersion')]", + "location": "[parameters('location')]", + "properties": {}, + "identity": { "type": "systemAssigned" } + }, + { + "type": "Microsoft.Storage/storageAccounts", + "apiVersion": "[variables('storageApiVersion')]", + "name": "[variables('storageAccountName')]", + "location": "[parameters('location')]", + "sku": { + "name": "Standard_RAGRS", + "tier": "Standard" + }, + "kind": "StorageV2", + "properties": { + "supportsHttpsTrafficOnly": true, + "encryption": { + "keySource": "Microsoft.Storage", + "services": { + "blob": { + "enabled": true + } + }, + }, + "accessTier": "Hot" + } + }, + { + "type": "Microsoft.Storage/storageAccounts/blobServices/containers", + "apiVersion": "[variables('storageApiVersion')]", + "name": "[variables('blobContainerResourceName')]", + "dependsOn": [ + "[variables('storageAccountName')]" + ] + } + ], + "outputs": { + "MIXEDREALITY_ACCOUNT_ID": { + "type": "string", + "value": "[reference(variables('asaAccountName')).accountId]" + }, + "MIXEDREALITY_ACCOUNT_DOMAIN": { + "type": "string", + "value": "[reference(variables('asaAccountName')).accountDomain]" + }, + "MIXEDREALITY_ACCOUNT_KEY": { + "type": "string", + "value": "[listKeys(resourceId('Microsoft.MixedReality/spatialAnchorsAccounts', variables('asaAccountName')), variables('apiVersion')).primaryKey]" + }, + "MIXEDREALITY_ARR_ACCOUNT_ID": { + "type": "string", + "value": "[reference(variables('arrAccountName')).accountId]" + }, + "MIXEDREALITY_ARR_ACCOUNT_DOMAIN": { + "type": "string", + "value": "[reference(variables('arrAccountName')).accountDomain]" + }, + "MIXEDREALITY_ARR_ACCOUNT_KEY": { + "type": "string", + "value": "[listKeys(resourceId('Microsoft.MixedReality/remoteRenderingAccounts', variables('arrAccountName')), variables('arrApiVersion')).primaryKey]" + }, + "MIXEDREALITY_ARR_STORAGE_ACCOUNT_NAME": { + "type": "string", + "value": "[variables('storageAccountName')]" + }, + "MIXEDREALITY_ARR_STORAGE_ACCOUNT_KEY": { + "type": "string", + "value": "[listKeys(resourceId('Microsoft.Storage/storageAccounts', variables('storageAccountName')), variables('storageApiVersion')).keys[0].value]" + }, + "MIXEDREALITY_ARR_BLOB_CONTAINER_NAME": { + "type": "string", + "value": "[variables('blobContainerName')]" + }, + "MIXEDREALITY_ARR_SAS_TOKEN": { + "type": "string", + "value": "[listServiceSas(variables('storageAccountName'), variables('storageApiVersion'), variables('sasProperties')).serviceSasToken]" + }, + "MIXEDREALITY_ARR_SERVICE_ENDPOINT": { + "type": "string", + "value": "[concat('https://remoterendering.', parameters('location'), '.mixedreality.azure.com')]" + } + } +} \ No newline at end of file diff --git a/sdk/mixedreality/tests.yml b/sdk/mixedreality/tests.yml new file mode 100644 index 000000000000..8755e0615f27 --- /dev/null +++ b/sdk/mixedreality/tests.yml @@ -0,0 +1,13 @@ +trigger: none + +stages: + - template: ../../eng/pipelines/templates/stages/archetype-sdk-tests.yml + parameters: + AllocateResourceGroup: false + ServiceDirectory: mixedreality + DeployArmTemplate: true + EnvVars: + AZURE_CLIENT_ID: $(aad-azure-sdk-test-client-id) + AZURE_CLIENT_SECRET: $(aad-azure-sdk-test-client-secret) + AZURE_TENANT_ID: $(aad-azure-sdk-test-tenant-id) + TEST_MODE: 'RunLiveNoRecord' \ No newline at end of file diff --git a/shared_requirements.txt b/shared_requirements.txt index 37e9dbf4621d..a9cffd7596bc 100644 --- a/shared_requirements.txt +++ b/shared_requirements.txt @@ -84,6 +84,7 @@ azure-mgmt-storage~=2.0 azure-mgmt-subscription~=0.2.0 azure-mgmt-trafficmanager~=0.50.0 azure-mgmt-web~=0.35.0 +azure-mixedreality-nspkg azure-nspkg azure-keyvault-nspkg azure-media-nspkg From 264543c7b7b34fe6c5913619b9df4954dfb5d8ff Mon Sep 17 00:00:00 2001 From: iscai-msft <43154838+iscai-msft@users.noreply.github.com> Date: Wed, 24 Feb 2021 12:01:21 -0500 Subject: [PATCH 03/30] [text analytics] fix docs and samples for UX study (#16894) --- .../azure-ai-textanalytics/README.md | 2 +- .../azure/ai/textanalytics/_models.py | 5 +- .../textanalytics/_text_analytics_client.py | 4 + .../aio/_text_analytics_client_async.py | 4 + ...ample_analyze_healthcare_entities_async.py | 89 +++++++++++++------ .../sample_analyze_healthcare_entities.py | 85 +++++++++++++----- 6 files changed, 136 insertions(+), 53 deletions(-) diff --git a/sdk/textanalytics/azure-ai-textanalytics/README.md b/sdk/textanalytics/azure-ai-textanalytics/README.md index fd6c76a48ab3..dc39ce76e2be 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/README.md +++ b/sdk/textanalytics/azure-ai-textanalytics/README.md @@ -458,7 +458,7 @@ text_analytics_client = TextAnalyticsClient(endpoint, credential) documents = ["Subject is taking 100mg of ibuprofen twice daily"] -poller = text_analytics_client.begin_analyze_healthcare_entities(documents, show_stats=True) +poller = text_analytics_client.begin_analyze_healthcare_entities(documents) result = poller.result() docs = [doc for doc in result if not doc.is_error] diff --git a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_models.py b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_models.py index 45329686fe30..890db922a094 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_models.py +++ b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_models.py @@ -422,8 +422,9 @@ class HealthcareEntity(DictMixin): This value depends on the value of the `string_index_type` parameter specified in the original request, which is UnicodeCodePoints by default. :ivar related_entities: Other healthcare entities that are related to this - specific entity. - :vartype related_entities: list[~azure.ai.textanalytics.HealthcareEntity] + specific entity. It is represented as a dict, mapping all of the related entities + to how they are related + :vartype related_entities: dict[~azure.ai.textanalytics.HealthcareEntity, str] :ivar float confidence_score: Confidence score between 0 and 1 of the extracted entity. :ivar data_sources: A collection of entity references in known data sources. diff --git a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_text_analytics_client.py b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_text_analytics_client.py index d49b070b9f98..b478de60043f 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_text_analytics_client.py +++ b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/_text_analytics_client.py @@ -457,6 +457,10 @@ def begin_analyze_healthcare_entities( # type: ignore ): # type: (...) -> LROPoller[ItemPaged[AnalyzeHealthcareEntitiesResultItem]] """Analyze healthcare entities and identify relationships between these entities in a batch of documents. + NOTE: this endpoint is currently in gated preview, meaning your subscription needs to be allow-listed + for you to use this endpoint. More information about that here: + https://aka.ms/text-analytics-health-request-access + Entities are associated with references that can be found in existing knowledge bases, such as UMLS, CHV, MSH, etc. diff --git a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/aio/_text_analytics_client_async.py b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/aio/_text_analytics_client_async.py index 93c555367928..eba1acb4cd27 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/aio/_text_analytics_client_async.py +++ b/sdk/textanalytics/azure-ai-textanalytics/azure/ai/textanalytics/aio/_text_analytics_client_async.py @@ -615,6 +615,10 @@ async def begin_analyze_healthcare_entities( # type: ignore ): # type: (...) -> AsyncLROPoller[AsyncItemPaged[AnalyzeHealthcareEntitiesResultItem]] """Analyze healthcare entities and identify relationships between these entities in a batch of documents. + NOTE: this endpoint is currently in gated preview, meaning your subscription needs to be allow-listed + for you to use this endpoint. More information about that here: + https://aka.ms/text-analytics-health-request-access + Entities are associated with references that can be found in existing knowledge bases, such as UMLS, CHV, MSH, etc. diff --git a/sdk/textanalytics/azure-ai-textanalytics/samples/async_samples/sample_analyze_healthcare_entities_async.py b/sdk/textanalytics/azure-ai-textanalytics/samples/async_samples/sample_analyze_healthcare_entities_async.py index 550547608591..66852a29d2b5 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/samples/async_samples/sample_analyze_healthcare_entities_async.py +++ b/sdk/textanalytics/azure-ai-textanalytics/samples/async_samples/sample_analyze_healthcare_entities_async.py @@ -11,8 +11,14 @@ DESCRIPTION: This sample demonstrates how to detect healthcare entities in a batch of documents. - Each entity found in the document will have a link associated with it from a - data source. Relations between entities will also be included in the response. + + In this sample we will be a newly-hired engineer working in a pharmacy. We are going to + comb through all of the prescriptions our pharmacy has fulfilled so we can catalog how + much inventory we have. + + As a usage note: healthcare is currently in gated preview. Your subscription needs to + be allow-listed before you can use this endpoint. More information about that here: + https://aka.ms/text-analytics-health-request-access USAGE: python sample_analyze_healthcare_entities_async.py @@ -30,9 +36,21 @@ class AnalyzeHealthcareEntitiesSampleAsync(object): async def analyze_healthcare_entities_async(self): + + print( + "In this sample we will be combing through the prescriptions our pharmacy has fulfilled " + "so we can catalog how much inventory we have" + ) + print( + "We start out with a list of prescription documents. " + "To simplify matters, we will assume all dosages are in units of mg." + ) + # [START analyze_healthcare_entities_async] + import re from azure.core.credentials import AzureKeyCredential from azure.ai.textanalytics.aio import TextAnalyticsClient + from collections import defaultdict endpoint = os.environ["AZURE_TEXT_ANALYTICS_ENDPOINT"] key = os.environ["AZURE_TEXT_ANALYTICS_KEY"] @@ -43,7 +61,13 @@ async def analyze_healthcare_entities_async(self): ) documents = [ - "Subject is taking 100mg of ibuprofen twice daily" + """ + Patient needs to take 100 mg of ibuprofen, and 3 mg of potassium. Also needs to take + 10 mg of Zocor. + """, + """ + Patient needs to take 50 mg of ibuprofen, and 2 mg of Coumadin. + """ ] async with text_analytics_client: @@ -51,30 +75,43 @@ async def analyze_healthcare_entities_async(self): result = await poller.result() docs = [doc async for doc in result if not doc.is_error] - print("Results of Healthcare Entities Analysis:") - for idx, doc in enumerate(docs): - print("Document text: {}\n".format(documents[idx])) - for entity in doc.entities: - print("Entity: {}".format(entity.text)) - print("...Category: {}".format(entity.category)) - print("...Subcategory: {}".format(entity.subcategory)) - print("...Offset: {}".format(entity.offset)) - print("...Confidence score: {}".format(entity.confidence_score)) - if entity.data_sources is not None: - print("...Data Sources:") - for data_source in entity.data_sources: - print("......Entity ID: {}".format(data_source.entity_id)) - print("......Name: {}".format(data_source.name)) - if len(entity.related_entities) > 0: - print("...Related Entities:") - for related_entity, relation_type in entity.related_entities.items(): - print("......Entity Text: {}".format(related_entity.text)) - print("......Relation Type: {}".format(relation_type)) - print("------------------------------------------") - + print( + "In order to find the total dosage for every mentioned medication, " + "let's create a dict, mapping medication name -> total dosage. " + ) + + medication_to_dosage = defaultdict(int) + + print( + "We will start off by extracting all of the dosage entities." + ) + + dosage_entities = [ + entity + for doc in docs + for entity in doc.entities + if entity.category == "Dosage" + ] + + print( + "Now we traverse the related entities of each dosage entity. " + "We are looking for entities that are related by 'DosageOfMedication'. " + "After that, we're done!" + ) + for dosage in dosage_entities: + dosage_value = int(re.findall(r"\d+", dosage.text)[0]) # we find the numbers in the dosage + for related_entity, relation_type in dosage.related_entities.items(): + if relation_type == "DosageOfMedication": + medication_to_dosage[related_entity.text] += dosage_value + + [ + print("We have fulfilled '{}' total mg of '{}'".format( + dosage, medication + )) + for medication, dosage in medication_to_dosage.items() + ] # [END analyze_healthcare_entities_async] - async def main(): sample = AnalyzeHealthcareEntitiesSampleAsync() await sample.analyze_healthcare_entities_async() @@ -83,5 +120,3 @@ async def main(): if __name__ == '__main__': loop = asyncio.get_event_loop() loop.run_until_complete(main()) - - diff --git a/sdk/textanalytics/azure-ai-textanalytics/samples/sample_analyze_healthcare_entities.py b/sdk/textanalytics/azure-ai-textanalytics/samples/sample_analyze_healthcare_entities.py index 7755438c1180..5ab7e7216058 100644 --- a/sdk/textanalytics/azure-ai-textanalytics/samples/sample_analyze_healthcare_entities.py +++ b/sdk/textanalytics/azure-ai-textanalytics/samples/sample_analyze_healthcare_entities.py @@ -11,8 +11,14 @@ DESCRIPTION: This sample demonstrates how to detect healthcare entities in a batch of documents. - Each entity found in the document will have a link associated with it from a - data source. Relations between entities will also be included in the response. + + In this sample we will be a newly-hired engineer working in a pharmacy. We are going to + comb through all of the prescriptions our pharmacy has fulfilled so we can catalog how + much inventory we have. + + As a usage note: healthcare is currently in gated preview. Your subscription needs to + be allow-listed before you can use this endpoint. More information about that here: + https://aka.ms/text-analytics-health-request-access USAGE: python sample_analyze_healthcare_entities.py @@ -29,9 +35,21 @@ class AnalyzeHealthcareEntitiesSample(object): def analyze_healthcare_entities(self): + + print( + "In this sample we will be combing through the prescriptions our pharmacy has fulfilled " + "so we can catalog how much inventory we have" + ) + print( + "We start out with a list of prescription documents. " + "To simplify matters, we will assume all dosages are in units of mg." + ) + # [START analyze_healthcare_entities] + import re from azure.core.credentials import AzureKeyCredential from azure.ai.textanalytics import TextAnalyticsClient + from collections import defaultdict endpoint = os.environ["AZURE_TEXT_ANALYTICS_ENDPOINT"] key = os.environ["AZURE_TEXT_ANALYTICS_KEY"] @@ -42,34 +60,55 @@ def analyze_healthcare_entities(self): ) documents = [ - "Subject is taking 100mg of ibuprofen twice daily" + """ + Patient needs to take 100 mg of ibuprofen, and 3 mg of potassium. Also needs to take + 10 mg of Zocor. + """, + """ + Patient needs to take 50 mg of ibuprofen, and 2 mg of Coumadin. + """ ] - poller = text_analytics_client.begin_analyze_healthcare_entities(documents, show_stats=True) + poller = text_analytics_client.begin_analyze_healthcare_entities(documents) result = poller.result() docs = [doc for doc in result if not doc.is_error] - print("Results of Healthcare Entities Analysis:") - for idx, doc in enumerate(docs): - for entity in doc.entities: - print("Entity: {}".format(entity.text)) - print("...Category: {}".format(entity.category)) - print("...Subcategory: {}".format(entity.subcategory)) - print("...Offset: {}".format(entity.offset)) - print("...Confidence score: {}".format(entity.confidence_score)) - if entity.data_sources is not None: - print("...Data Sources:") - for data_source in entity.data_sources: - print("......Entity ID: {}".format(data_source.entity_id)) - print("......Name: {}".format(data_source.name)) - if len(entity.related_entities) > 0: - print("...Related Entities:") - for related_entity, relation_type in entity.related_entities.items(): - print("......Entity Text: {}".format(related_entity.text)) - print("......Relation Type: {}".format(relation_type)) - print("------------------------------------------") + print( + "In order to find the total dosage for every mentioned medication, " + "let's create a dict, mapping medication name -> total dosage. " + ) + + medication_to_dosage = defaultdict(int) + + print( + "We will start off by extracting all of the dosage entities." + ) + dosage_entities = [ + entity + for doc in docs + for entity in doc.entities + if entity.category == "Dosage" + ] + + print( + "Now we traverse the related entities of each dosage entity. " + "We are looking for entities that are related by 'DosageOfMedication'. " + "After that, we're done!" + ) + for dosage in dosage_entities: + dosage_value = int(re.findall(r"\d+", dosage.text)[0]) # we find the numbers in the dosage + for related_entity, relation_type in dosage.related_entities.items(): + if relation_type == "DosageOfMedication": + medication_to_dosage[related_entity.text] += dosage_value + + [ + print("We have fulfilled '{}' total mg of '{}'".format( + dosage, medication + )) + for medication, dosage in medication_to_dosage.items() + ] # [END analyze_healthcare_entities] if __name__ == "__main__": From 1bfb95af60f2857a85f26a2a210277535532d73a Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Wed, 24 Feb 2021 10:17:06 -0800 Subject: [PATCH 04/30] [EventHubs] no-op instead of raising error when sending out empty event data batch (#16638) * better error message * remove extra blank line * should be a no-op instead of raising error * update changelog * fix pylint * fix pytest * fix async test * Update sdk/eventhub/azure-eventhub/CHANGELOG.md Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> --- sdk/eventhub/azure-eventhub/CHANGELOG.md | 3 +++ .../azure-eventhub/azure/eventhub/_producer_client.py | 4 ++++ .../azure/eventhub/aio/_producer_client_async.py | 3 +++ .../tests/livetest/asynctests/test_send_async.py | 5 +++-- .../azure-eventhub/tests/livetest/synctests/test_send.py | 5 +++-- 5 files changed, 16 insertions(+), 4 deletions(-) diff --git a/sdk/eventhub/azure-eventhub/CHANGELOG.md b/sdk/eventhub/azure-eventhub/CHANGELOG.md index 62a3a3f29edf..e0393ac54699 100644 --- a/sdk/eventhub/azure-eventhub/CHANGELOG.md +++ b/sdk/eventhub/azure-eventhub/CHANGELOG.md @@ -2,6 +2,9 @@ ## 5.3.1 (Unreleased) +**Bug fixes** + +- Sending empty `event_data_batch` will be a no-op now instead of raising error. ## 5.3.0 (2021-02-08) diff --git a/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py b/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py index 03e2d032ab18..5f704fd7fce8 100644 --- a/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py +++ b/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py @@ -255,6 +255,10 @@ def send_batch(self, event_data_batch, **kwargs): partition_id = ( to_send_batch._partition_id or ALL_PARTITIONS # pylint:disable=protected-access ) + + if len(to_send_batch) == 0: + return + send_timeout = kwargs.pop("timeout", None) try: cast(EventHubProducer, self._producers[partition_id]).send( diff --git a/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py b/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py index aa4409614f38..3cd964093745 100644 --- a/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py +++ b/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py @@ -284,6 +284,9 @@ async def send_batch( to_send_batch = await self.create_batch(partition_id=partition_id, partition_key=partition_key) to_send_batch._load_events(event_data_batch) # pylint:disable=protected-access + if len(to_send_batch) == 0: + return + partition_id = ( to_send_batch._partition_id or ALL_PARTITIONS # pylint:disable=protected-access ) diff --git a/sdk/eventhub/azure-eventhub/tests/livetest/asynctests/test_send_async.py b/sdk/eventhub/azure-eventhub/tests/livetest/asynctests/test_send_async.py index 851eec7e30a5..f182a9043e25 100644 --- a/sdk/eventhub/azure-eventhub/tests/livetest/asynctests/test_send_async.py +++ b/sdk/eventhub/azure-eventhub/tests/livetest/asynctests/test_send_async.py @@ -30,6 +30,8 @@ async def test_send_with_partition_key_async(connstr_receivers): data_val += 1 await client.send_batch(batch) + await client.send_batch(await client.create_batch()) + found_partition_keys = {} for index, partition in enumerate(receivers): received = partition.receive_message_batch(timeout=5000) @@ -202,8 +204,7 @@ async def test_send_list_partition_async(connstr_receivers): @pytest.mark.parametrize("to_send, exception_type", - [([], EventDataSendError), - ([EventData("A"*1024)]*1100, ValueError), + [([EventData("A"*1024)]*1100, ValueError), ("any str", AttributeError) ]) @pytest.mark.liveTest diff --git a/sdk/eventhub/azure-eventhub/tests/livetest/synctests/test_send.py b/sdk/eventhub/azure-eventhub/tests/livetest/synctests/test_send.py index d3790df006d5..c5a406a49be3 100644 --- a/sdk/eventhub/azure-eventhub/tests/livetest/synctests/test_send.py +++ b/sdk/eventhub/azure-eventhub/tests/livetest/synctests/test_send.py @@ -28,6 +28,8 @@ def test_send_with_partition_key(connstr_receivers): data_val += 1 client.send_batch(batch) + client.send_batch(client.create_batch()) + found_partition_keys = {} for index, partition in enumerate(receivers): received = partition.receive_message_batch(timeout=5000) @@ -209,8 +211,7 @@ def test_send_list_partition(connstr_receivers): @pytest.mark.parametrize("to_send, exception_type", - [([], EventDataSendError), - ([EventData("A"*1024)]*1100, ValueError), + [([EventData("A"*1024)]*1100, ValueError), ("any str", AttributeError) ]) @pytest.mark.liveTest From 40f61d5df5edaa5fb53bbd1a24241e14db38dbd1 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Wed, 24 Feb 2021 11:38:51 -0800 Subject: [PATCH 05/30] [EventHubs] Warning partition key type (#16909) * add warning in the docs on partition key accepted type * address feedback --- .../azure-eventhub/azure/eventhub/_producer_client.py | 4 ++++ .../azure/eventhub/aio/_producer_client_async.py | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py b/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py index 5f704fd7fce8..c3f139337eb9 100644 --- a/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py +++ b/sdk/eventhub/azure-eventhub/azure/eventhub/_producer_client.py @@ -222,6 +222,8 @@ def send_batch(self, event_data_batch, **kwargs): A `TypeError` will be raised if partition_key is specified and event_data_batch is an `EventDataBatch` because `EventDataBatch` itself has partition_key. If both partition_id and partition_key are provided, the partition_id will take precedence. + **WARNING: Please DO NOT pass a partition_key of non-string type. The Event Hub service ignores partition_key + of non-string type, in which case events will be assigned to all partitions using round-robin.** :rtype: None :raises: :class:`AuthenticationError` :class:`ConnectError` @@ -281,6 +283,8 @@ def create_batch(self, **kwargs): :keyword str partition_key: With the given partition_key, event data will be sent to a particular partition of the Event Hub decided by the service. If both partition_id and partition_key are provided, the partition_id will take precedence. + **WARNING: Please DO NOT pass a partition_key of non-string type. The Event Hub service ignores partition_key + of non-string type, in which case events will be assigned to all partitions using round-robin.** :keyword int max_size_in_bytes: The maximum size of bytes data that an EventDataBatch object can hold. By default, the value is determined by your Event Hubs tier. :rtype: ~azure.eventhub.EventDataBatch diff --git a/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py b/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py index 3cd964093745..6caa8e9f5144 100644 --- a/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py +++ b/sdk/eventhub/azure-eventhub/azure/eventhub/aio/_producer_client_async.py @@ -253,6 +253,8 @@ async def send_batch( A `TypeError` will be raised if partition_key is specified and event_data_batch is an `EventDataBatch` because `EventDataBatch` itself has partition_key. If both partition_id and partition_key are provided, the partition_id will take precedence. + **WARNING: Please DO NOT pass a partition_key of non-string type. The Event Hub service ignores partition_key + of non-string type, in which case events will be assigned to all partitions using round-robin.** :rtype: None :raises: :class:`AuthenticationError` :class:`ConnectError` @@ -316,6 +318,8 @@ async def create_batch( :param str partition_key: With the given partition_key, event data will be sent to a particular partition of the Event Hub decided by the service. If both partition_id and partition_key are provided, the partition_id will take precedence. + **WARNING: Please DO NOT pass a partition_key of non-string type. The Event Hub service ignores partition_key + of non-string type, in which case events will be assigned to all partitions using round-robin.** :param int max_size_in_bytes: The maximum size of bytes data that an EventDataBatch object can hold. By default, the value is determined by your Event Hubs tier. :rtype: ~azure.eventhub.EventDataBatch From aff466438094d2719739e8c5c590fb5840e00171 Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Wed, 24 Feb 2021 11:39:29 -0800 Subject: [PATCH 06/30] [EventHubs] Doc warning on changing the value of the instance variable EventDataBatch.max_size_in_bytes (#16644) * add warning on max_size_in_bytes in the docstring of EventDataBatch * Update sdk/eventhub/azure-eventhub/azure/eventhub/_common.py * Update sdk/eventhub/azure-eventhub/azure/eventhub/_common.py Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> * fix markdown syntaxt Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> --- sdk/eventhub/azure-eventhub/azure/eventhub/_common.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/sdk/eventhub/azure-eventhub/azure/eventhub/_common.py b/sdk/eventhub/azure-eventhub/azure/eventhub/_common.py index ff3d910d815a..d15196dd8cf3 100644 --- a/sdk/eventhub/azure-eventhub/azure/eventhub/_common.py +++ b/sdk/eventhub/azure-eventhub/azure/eventhub/_common.py @@ -338,6 +338,10 @@ class EventDataBatch(object): **Please use the create_batch method of EventHubProducerClient to create an EventDataBatch object instead of instantiating an EventDataBatch object directly.** + **WARNING: Updating the value of the instance variable max_size_in_bytes on an instantiated EventDataBatch object + is HIGHLY DISCOURAGED. The updated max_size_in_bytes value may conflict with the maximum size of events allowed + by the Event Hubs service and result in a sending failure.** + :param int max_size_in_bytes: The maximum size of bytes data that an EventDataBatch object can hold. :param str partition_id: The specific partition ID to send to. :param str partition_key: With the given partition_key, event data will be sent to a particular partition of the From d3a02d9b18566d3bfcb7bcaa38a76670993ce32b Mon Sep 17 00:00:00 2001 From: msyyc <70930885+msyyc@users.noreply.github.com> Date: Thu, 25 Feb 2021 14:07:02 +0800 Subject: [PATCH 07/30] Update auto_package.py (#16927) --- tools/azure-sdk-tools/packaging_tools/auto_package.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tools/azure-sdk-tools/packaging_tools/auto_package.py b/tools/azure-sdk-tools/packaging_tools/auto_package.py index 52f633ff105b..c483c779f39f 100644 --- a/tools/azure-sdk-tools/packaging_tools/auto_package.py +++ b/tools/azure-sdk-tools/packaging_tools/auto_package.py @@ -74,6 +74,8 @@ def main(generate_input, generate_output): "lite": f"pip install {package_name}" } package["result"]: "success" + # to distinguish with track1 + package['packageName'] = 'track2_' + package['packageName'] result['packages'].append(package) with open(generate_output, "w") as writer: From d616d4efe01abaef4efb4d09b5df218222740270 Mon Sep 17 00:00:00 2001 From: Scott Beddall <45376673+scbedd@users.noreply.github.com> Date: Thu, 25 Feb 2021 05:01:36 -0800 Subject: [PATCH 08/30] adjust the filecount in integration stage so we don't attempt to push non-alpha packages (#16925) --- eng/pipelines/templates/stages/archetype-python-release.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/eng/pipelines/templates/stages/archetype-python-release.yml b/eng/pipelines/templates/stages/archetype-python-release.yml index ba80cecf9a23..8e2a3748f908 100644 --- a/eng/pipelines/templates/stages/archetype-python-release.yml +++ b/eng/pipelines/templates/stages/archetype-python-release.yml @@ -286,7 +286,8 @@ stages: $packageDirectory = "${{artifact.name}}".Replace("_", "-") echo "##vso[task.setvariable variable=Package.Name]$packageDirectory" - pwsh: | - $fileCount = (Get-ChildItem $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$packageDirectory | Measure-Object).Count + $fileCount = (Get-ChildItem $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$packageDirectory -Filter $packageDirectory-[0-9]*.[0-9]*.[0-9]*a[0-9]* | Measure-Object).Count + if ($fileCount -eq 0) { Write-Host "No alpha packages for ${{artifact.safeName}} to publish." exit 0 From 9cd02ef0ced1da9bd78bf1a1a4152567802cdb1a Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Thu, 25 Feb 2021 09:17:17 -0800 Subject: [PATCH 09/30] Continue On Error to unblock people fixing other issues. (#16918) --- eng/pipelines/aggregate-reports.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/eng/pipelines/aggregate-reports.yml b/eng/pipelines/aggregate-reports.yml index 15b36a18cdbe..b96c1c74d047 100644 --- a/eng/pipelines/aggregate-reports.yml +++ b/eng/pipelines/aggregate-reports.yml @@ -54,6 +54,7 @@ jobs: # Used for generating baseline file. # GdnBreakOutputBaselineFile: python # GdnBreakOutputBaseline: baseline + continueOnError: true - task: securedevelopmentteam.vss-secure-development-tools.build-task-publishsecurityanalysislogs.PublishSecurityAnalysisLogs@3 displayName: 'Publish Security Analysis Logs' continueOnError: true From e093f3e2158ed4bb53f7b896ab1d88292d9c86e8 Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Thu, 25 Feb 2021 09:18:42 -0800 Subject: [PATCH 10/30] Added main branch in ci yaml files (#16867) --- ci_template.yml | 2 ++ sdk/advisor/ci.yml | 2 ++ sdk/aks/ci.yml | 2 ++ sdk/alertsmanagement/ci.yml | 2 ++ sdk/anomalydetector/ci.yml | 2 ++ sdk/apimanagement/ci.yml | 2 ++ sdk/appconfiguration/ci.yml | 2 ++ sdk/applicationinsights/ci.yml | 2 ++ sdk/appplatform/ci.yml | 2 ++ sdk/appservice/ci.yml | 2 ++ sdk/attestation/ci.yml | 2 ++ sdk/authorization/ci.yml | 2 ++ sdk/automanage/ci.yml | 2 ++ sdk/automation/ci.yml | 2 ++ sdk/azureadb2c/ci.yml | 2 ++ sdk/azurestack/ci.yml | 2 ++ sdk/azurestackhci/ci.yml | 2 ++ sdk/baremetalinfrastructure/ci.yml | 2 ++ sdk/batch/ci.yml | 2 ++ sdk/billing/ci.yml | 2 ++ sdk/botservice/ci.yml | 2 ++ sdk/cdn/ci.yml | 2 ++ sdk/cognitiveservices/ci.yml | 2 ++ sdk/commerce/ci.yml | 2 ++ sdk/communication/ci.yml | 2 ++ sdk/compute/ci.yml | 2 ++ sdk/confluent/ci.yml | 2 ++ sdk/consumption/ci.yml | 2 ++ sdk/containerinstance/ci.yml | 2 ++ sdk/containerregistry/ci.yml | 2 ++ sdk/containerservice/ci.yml | 2 ++ sdk/core/ci.yml | 2 ++ sdk/cosmos/ci.yml | 2 ++ sdk/costmanagement/ci.yml | 2 ++ sdk/customproviders/ci.yml | 2 ++ sdk/databox/ci.yml | 2 ++ sdk/databoxedge/ci.yml | 2 ++ sdk/databricks/ci.yml | 2 ++ sdk/datadog/ci.yml | 2 ++ sdk/datafactory/ci.yml | 2 ++ sdk/datalake/ci.yml | 2 ++ sdk/datamigration/ci.yml | 2 ++ sdk/datashare/ci.yml | 2 ++ sdk/deploymentmanager/ci.yml | 2 ++ sdk/devtestlabs/ci.yml | 2 ++ sdk/digitaltwins/ci.yml | 2 ++ sdk/edgegateway/ci.yml | 2 ++ sdk/eventgrid/ci.yml | 2 ++ sdk/eventhub/ci.yml | 2 ++ sdk/formrecognizer/ci.yml | 2 ++ sdk/graphrbac/ci.yml | 2 ++ sdk/hanaonazure/ci.yml | 2 ++ sdk/hdinsight/ci.yml | 2 ++ sdk/healthbot/ci.yml | 2 ++ sdk/healthcareapis/ci.yml | 2 ++ sdk/hybridcompute/ci.yml | 2 ++ sdk/hybridkubernetes/ci.yml | 2 ++ sdk/identity/ci.yml | 2 ++ sdk/iothub/ci.yml | 2 ++ sdk/keyvault/ci.yml | 2 ++ sdk/kubernetesconfiguration/ci.yml | 2 ++ sdk/kusto/ci.yml | 2 ++ sdk/labservices/ci.yml | 2 ++ sdk/loganalytics/ci.yml | 2 ++ sdk/logic/ci.yml | 2 ++ sdk/machinelearning/ci.yml | 2 ++ sdk/maintenance/ci.yml | 2 ++ sdk/managedservices/ci.yml | 2 ++ sdk/managementgroups/ci.yml | 2 ++ sdk/managementpartner/ci.yml | 2 ++ sdk/maps/ci.yml | 2 ++ sdk/marketplaceordering/ci.yml | 2 ++ sdk/media/ci.yml | 2 ++ sdk/metricsadvisor/ci.yml | 2 ++ sdk/mixedreality/ci.yml | 2 ++ sdk/monitor/ci.yml | 2 ++ sdk/netapp/ci.yml | 2 ++ sdk/network/ci.yml | 2 ++ sdk/notificationhubs/ci.yml | 2 ++ sdk/operationsmanagement/ci.yml | 2 ++ sdk/peering/ci.yml | 2 ++ sdk/policyinsights/ci.yml | 2 ++ sdk/portal/ci.yml | 2 ++ sdk/powerbidedicated/ci.yml | 2 ++ sdk/powerbiembedded/ci.yml | 2 ++ sdk/purview/ci.yml | 2 ++ sdk/quantum/ci.yml | 2 ++ sdk/rdbms/ci.yml | 2 ++ sdk/recoveryservices/ci.yml | 2 ++ sdk/redhatopenshift/ci.yml | 2 ++ sdk/redis/ci.yml | 2 ++ sdk/redisenterprise/ci.yml | 2 ++ sdk/regionmove/ci.yml | 2 ++ sdk/relay/ci.yml | 2 ++ sdk/reservations/ci.yml | 2 ++ sdk/resourcemover/ci.yml | 2 ++ sdk/resources/ci.yml | 2 ++ sdk/scheduler/ci.yml | 2 ++ sdk/schemaregistry/ci.yml | 2 ++ sdk/search/ci.yml | 2 ++ sdk/security/ci.yml | 2 ++ sdk/securityinsight/ci.yml | 2 ++ sdk/serialconsole/ci.yml | 2 ++ sdk/servermanager/ci.yml | 2 ++ sdk/servicebus/ci.yml | 2 ++ sdk/servicefabric/ci.yml | 2 ++ sdk/signalr/ci.yml | 2 ++ sdk/sql/ci.yml | 2 ++ sdk/storage/ci.yml | 2 ++ sdk/streamanalytics/ci.yml | 2 ++ sdk/subscription/ci.yml | 2 ++ sdk/support/ci.yml | 2 ++ sdk/synapse/ci.yml | 2 ++ sdk/tables/ci.yml | 2 ++ sdk/template/ci.yml | 2 ++ sdk/textanalytics/ci.yml | 2 ++ sdk/timeseriesinsights/ci.yml | 2 ++ sdk/trafficmanager/ci.yml | 2 ++ sdk/workloadmonitor/ci.yml | 2 ++ 119 files changed, 238 insertions(+) diff --git a/ci_template.yml b/ci_template.yml index 18a73a5fc69e..08284003ec83 100644 --- a/ci_template.yml +++ b/ci_template.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/advisor/ci.yml b/sdk/advisor/ci.yml index 1de69ccfc421..484d45ab1d52 100644 --- a/sdk/advisor/ci.yml +++ b/sdk/advisor/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/aks/ci.yml b/sdk/aks/ci.yml index c5860d4b0b70..f084ee6825b6 100644 --- a/sdk/aks/ci.yml +++ b/sdk/aks/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/alertsmanagement/ci.yml b/sdk/alertsmanagement/ci.yml index f5982f943675..cf3ac534c892 100644 --- a/sdk/alertsmanagement/ci.yml +++ b/sdk/alertsmanagement/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/anomalydetector/ci.yml b/sdk/anomalydetector/ci.yml index fc5aa41ede7f..965ab965e396 100644 --- a/sdk/anomalydetector/ci.yml +++ b/sdk/anomalydetector/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -17,6 +18,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/apimanagement/ci.yml b/sdk/apimanagement/ci.yml index d98441ab4c6f..c8c6d3965f8a 100644 --- a/sdk/apimanagement/ci.yml +++ b/sdk/apimanagement/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/appconfiguration/ci.yml b/sdk/appconfiguration/ci.yml index ec644e8ce1cd..f888cf049d15 100644 --- a/sdk/appconfiguration/ci.yml +++ b/sdk/appconfiguration/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/applicationinsights/ci.yml b/sdk/applicationinsights/ci.yml index 5c8988902bd4..bd1691374bf1 100644 --- a/sdk/applicationinsights/ci.yml +++ b/sdk/applicationinsights/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/appplatform/ci.yml b/sdk/appplatform/ci.yml index 666e9e8d4129..55e8e42c8ce8 100644 --- a/sdk/appplatform/ci.yml +++ b/sdk/appplatform/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/appservice/ci.yml b/sdk/appservice/ci.yml index 8d2568465d5c..b60e2c0cc304 100644 --- a/sdk/appservice/ci.yml +++ b/sdk/appservice/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/attestation/ci.yml b/sdk/attestation/ci.yml index c2d3d018417c..f5ee58bb076f 100644 --- a/sdk/attestation/ci.yml +++ b/sdk/attestation/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/authorization/ci.yml b/sdk/authorization/ci.yml index 2e8996d3decc..893ff37cede0 100644 --- a/sdk/authorization/ci.yml +++ b/sdk/authorization/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/automanage/ci.yml b/sdk/automanage/ci.yml index ee8774e96be4..32c7bfcce150 100644 --- a/sdk/automanage/ci.yml +++ b/sdk/automanage/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/automation/ci.yml b/sdk/automation/ci.yml index 8c62497d1e2a..bb08c209a5c1 100644 --- a/sdk/automation/ci.yml +++ b/sdk/automation/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/azureadb2c/ci.yml b/sdk/azureadb2c/ci.yml index 11d39a1f7f3f..83b34e2714c2 100644 --- a/sdk/azureadb2c/ci.yml +++ b/sdk/azureadb2c/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/azurestack/ci.yml b/sdk/azurestack/ci.yml index 52e74fb7d926..44effd5859da 100644 --- a/sdk/azurestack/ci.yml +++ b/sdk/azurestack/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/azurestackhci/ci.yml b/sdk/azurestackhci/ci.yml index cc5492e9c3ec..ac79c252ccb4 100644 --- a/sdk/azurestackhci/ci.yml +++ b/sdk/azurestackhci/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/baremetalinfrastructure/ci.yml b/sdk/baremetalinfrastructure/ci.yml index a3306064d521..f94c9759d33a 100644 --- a/sdk/baremetalinfrastructure/ci.yml +++ b/sdk/baremetalinfrastructure/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/batch/ci.yml b/sdk/batch/ci.yml index 7a866d35397e..9ad68b47746e 100644 --- a/sdk/batch/ci.yml +++ b/sdk/batch/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/billing/ci.yml b/sdk/billing/ci.yml index 75649b447fc7..e3d8012ff277 100644 --- a/sdk/billing/ci.yml +++ b/sdk/billing/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/botservice/ci.yml b/sdk/botservice/ci.yml index ebd2e2536797..d50704597579 100644 --- a/sdk/botservice/ci.yml +++ b/sdk/botservice/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/cdn/ci.yml b/sdk/cdn/ci.yml index a65de72c4c67..dc816176bb8c 100644 --- a/sdk/cdn/ci.yml +++ b/sdk/cdn/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/cognitiveservices/ci.yml b/sdk/cognitiveservices/ci.yml index a43ceb156a07..ff08adb2cf32 100644 --- a/sdk/cognitiveservices/ci.yml +++ b/sdk/cognitiveservices/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/commerce/ci.yml b/sdk/commerce/ci.yml index cb92fe6131a7..8e153bd391b1 100644 --- a/sdk/commerce/ci.yml +++ b/sdk/commerce/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/communication/ci.yml b/sdk/communication/ci.yml index e617b73fc7ea..7da66af48f93 100644 --- a/sdk/communication/ci.yml +++ b/sdk/communication/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/compute/ci.yml b/sdk/compute/ci.yml index a5b673b3109e..1c77423efa0d 100644 --- a/sdk/compute/ci.yml +++ b/sdk/compute/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/confluent/ci.yml b/sdk/confluent/ci.yml index 2cca31e83178..bbe639270074 100644 --- a/sdk/confluent/ci.yml +++ b/sdk/confluent/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/consumption/ci.yml b/sdk/consumption/ci.yml index 9910c5223246..f9a59ec3c6be 100644 --- a/sdk/consumption/ci.yml +++ b/sdk/consumption/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/containerinstance/ci.yml b/sdk/containerinstance/ci.yml index e0f0f191484b..91085e95f306 100644 --- a/sdk/containerinstance/ci.yml +++ b/sdk/containerinstance/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/containerregistry/ci.yml b/sdk/containerregistry/ci.yml index 34a0699c0b11..8c896c311252 100644 --- a/sdk/containerregistry/ci.yml +++ b/sdk/containerregistry/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/containerservice/ci.yml b/sdk/containerservice/ci.yml index d9d920d2882a..af4bdb5a2a1f 100644 --- a/sdk/containerservice/ci.yml +++ b/sdk/containerservice/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/core/ci.yml b/sdk/core/ci.yml index 01d0d5665b94..265c0c2bef98 100644 --- a/sdk/core/ci.yml +++ b/sdk/core/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -17,6 +18,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/cosmos/ci.yml b/sdk/cosmos/ci.yml index e1ab974e44f7..5313ad801515 100644 --- a/sdk/cosmos/ci.yml +++ b/sdk/cosmos/ci.yml @@ -3,6 +3,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/costmanagement/ci.yml b/sdk/costmanagement/ci.yml index b20de777438a..3875531bf8b0 100644 --- a/sdk/costmanagement/ci.yml +++ b/sdk/costmanagement/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/customproviders/ci.yml b/sdk/customproviders/ci.yml index 76f8fa58dcb1..5fb434bb4699 100644 --- a/sdk/customproviders/ci.yml +++ b/sdk/customproviders/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/databox/ci.yml b/sdk/databox/ci.yml index bea9658daf21..6cb49337e724 100644 --- a/sdk/databox/ci.yml +++ b/sdk/databox/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/databoxedge/ci.yml b/sdk/databoxedge/ci.yml index b2d2c8d042d6..72348b4e27ef 100644 --- a/sdk/databoxedge/ci.yml +++ b/sdk/databoxedge/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/databricks/ci.yml b/sdk/databricks/ci.yml index 07aba7052b0a..7919863afc3a 100644 --- a/sdk/databricks/ci.yml +++ b/sdk/databricks/ci.yml @@ -3,6 +3,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -14,6 +15,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/datadog/ci.yml b/sdk/datadog/ci.yml index adc25fafe584..d34129ec6fbd 100644 --- a/sdk/datadog/ci.yml +++ b/sdk/datadog/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/datafactory/ci.yml b/sdk/datafactory/ci.yml index b836d5151858..84bd6cbc3a82 100644 --- a/sdk/datafactory/ci.yml +++ b/sdk/datafactory/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/datalake/ci.yml b/sdk/datalake/ci.yml index 7660e35173b2..3e070b94584c 100644 --- a/sdk/datalake/ci.yml +++ b/sdk/datalake/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/datamigration/ci.yml b/sdk/datamigration/ci.yml index 577288b3fbe2..06b965559c1f 100644 --- a/sdk/datamigration/ci.yml +++ b/sdk/datamigration/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/datashare/ci.yml b/sdk/datashare/ci.yml index d0e741c9352f..227d17092961 100644 --- a/sdk/datashare/ci.yml +++ b/sdk/datashare/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/deploymentmanager/ci.yml b/sdk/deploymentmanager/ci.yml index 44efee8085c5..94d2e95df611 100644 --- a/sdk/deploymentmanager/ci.yml +++ b/sdk/deploymentmanager/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/devtestlabs/ci.yml b/sdk/devtestlabs/ci.yml index 4b42e00a1d68..66668ab8b6f8 100644 --- a/sdk/devtestlabs/ci.yml +++ b/sdk/devtestlabs/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/digitaltwins/ci.yml b/sdk/digitaltwins/ci.yml index 23197e107178..9b515ba05d61 100644 --- a/sdk/digitaltwins/ci.yml +++ b/sdk/digitaltwins/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/edgegateway/ci.yml b/sdk/edgegateway/ci.yml index 02e13e3d82f3..3c4c077000a2 100644 --- a/sdk/edgegateway/ci.yml +++ b/sdk/edgegateway/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/eventgrid/ci.yml b/sdk/eventgrid/ci.yml index ef518abd365d..7ee3449a9a1a 100644 --- a/sdk/eventgrid/ci.yml +++ b/sdk/eventgrid/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/eventhub/ci.yml b/sdk/eventhub/ci.yml index 16d7ba56991d..8452ae61ccf7 100644 --- a/sdk/eventhub/ci.yml +++ b/sdk/eventhub/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/formrecognizer/ci.yml b/sdk/formrecognizer/ci.yml index 21adc294cd89..b2041a301bc2 100644 --- a/sdk/formrecognizer/ci.yml +++ b/sdk/formrecognizer/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - feature/* - release/* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/graphrbac/ci.yml b/sdk/graphrbac/ci.yml index e6285e40f165..d30a11d7b983 100644 --- a/sdk/graphrbac/ci.yml +++ b/sdk/graphrbac/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/hanaonazure/ci.yml b/sdk/hanaonazure/ci.yml index e203f4f6b1dd..1125f64f018f 100644 --- a/sdk/hanaonazure/ci.yml +++ b/sdk/hanaonazure/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/hdinsight/ci.yml b/sdk/hdinsight/ci.yml index 42357e82c8bd..03b2dc4615f9 100644 --- a/sdk/hdinsight/ci.yml +++ b/sdk/hdinsight/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/healthbot/ci.yml b/sdk/healthbot/ci.yml index c93881d090b5..e071c6c560b9 100644 --- a/sdk/healthbot/ci.yml +++ b/sdk/healthbot/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/healthcareapis/ci.yml b/sdk/healthcareapis/ci.yml index ade8967508df..2f828d664645 100644 --- a/sdk/healthcareapis/ci.yml +++ b/sdk/healthcareapis/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/hybridcompute/ci.yml b/sdk/hybridcompute/ci.yml index c53d291beaaa..455014658c5e 100644 --- a/sdk/hybridcompute/ci.yml +++ b/sdk/hybridcompute/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/hybridkubernetes/ci.yml b/sdk/hybridkubernetes/ci.yml index 7827cde32abe..49ea1e32e3c1 100644 --- a/sdk/hybridkubernetes/ci.yml +++ b/sdk/hybridkubernetes/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/identity/ci.yml b/sdk/identity/ci.yml index 8f8bcd0a0ca7..a7ab1143ad51 100644 --- a/sdk/identity/ci.yml +++ b/sdk/identity/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/iothub/ci.yml b/sdk/iothub/ci.yml index a8a117296a6c..73fd61008666 100644 --- a/sdk/iothub/ci.yml +++ b/sdk/iothub/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/keyvault/ci.yml b/sdk/keyvault/ci.yml index e1c1f3b392eb..1b4180c9ece5 100644 --- a/sdk/keyvault/ci.yml +++ b/sdk/keyvault/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/kubernetesconfiguration/ci.yml b/sdk/kubernetesconfiguration/ci.yml index 7a8aa6f9f48a..33c69669ff03 100644 --- a/sdk/kubernetesconfiguration/ci.yml +++ b/sdk/kubernetesconfiguration/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/kusto/ci.yml b/sdk/kusto/ci.yml index 90d1a2983c61..344bb5104404 100644 --- a/sdk/kusto/ci.yml +++ b/sdk/kusto/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/labservices/ci.yml b/sdk/labservices/ci.yml index 142daa2e659d..7f9b5f1d65e6 100644 --- a/sdk/labservices/ci.yml +++ b/sdk/labservices/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/loganalytics/ci.yml b/sdk/loganalytics/ci.yml index 7555967f7d52..e9332752b346 100644 --- a/sdk/loganalytics/ci.yml +++ b/sdk/loganalytics/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/logic/ci.yml b/sdk/logic/ci.yml index d516fbc1f2b9..78c7d7d184f0 100644 --- a/sdk/logic/ci.yml +++ b/sdk/logic/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/machinelearning/ci.yml b/sdk/machinelearning/ci.yml index 72dc185fd1e1..4edecf39ece9 100644 --- a/sdk/machinelearning/ci.yml +++ b/sdk/machinelearning/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/maintenance/ci.yml b/sdk/maintenance/ci.yml index 276441a757d0..ba3de7e1dbdf 100644 --- a/sdk/maintenance/ci.yml +++ b/sdk/maintenance/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/managedservices/ci.yml b/sdk/managedservices/ci.yml index ecf42501c5dc..b8c94e644d18 100644 --- a/sdk/managedservices/ci.yml +++ b/sdk/managedservices/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/managementgroups/ci.yml b/sdk/managementgroups/ci.yml index 1bd118d62f42..333f103e22e4 100644 --- a/sdk/managementgroups/ci.yml +++ b/sdk/managementgroups/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/managementpartner/ci.yml b/sdk/managementpartner/ci.yml index 99aeee9eb9a4..b3bd142313ec 100644 --- a/sdk/managementpartner/ci.yml +++ b/sdk/managementpartner/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/maps/ci.yml b/sdk/maps/ci.yml index 4f82483bee0b..fbab36a41127 100644 --- a/sdk/maps/ci.yml +++ b/sdk/maps/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/marketplaceordering/ci.yml b/sdk/marketplaceordering/ci.yml index 25b5699ae272..415e48ef706f 100644 --- a/sdk/marketplaceordering/ci.yml +++ b/sdk/marketplaceordering/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/media/ci.yml b/sdk/media/ci.yml index 0c7d86d0ada9..968468bdd24c 100644 --- a/sdk/media/ci.yml +++ b/sdk/media/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/metricsadvisor/ci.yml b/sdk/metricsadvisor/ci.yml index 7712f0c78fda..c303b8cd1952 100644 --- a/sdk/metricsadvisor/ci.yml +++ b/sdk/metricsadvisor/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -17,6 +18,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/mixedreality/ci.yml b/sdk/mixedreality/ci.yml index f3ae04fd79eb..65ea95807e9d 100644 --- a/sdk/mixedreality/ci.yml +++ b/sdk/mixedreality/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/monitor/ci.yml b/sdk/monitor/ci.yml index 4efd84b0a3ba..3be7f7851d88 100644 --- a/sdk/monitor/ci.yml +++ b/sdk/monitor/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/netapp/ci.yml b/sdk/netapp/ci.yml index 059569196cc2..7c2b5db7ac7c 100644 --- a/sdk/netapp/ci.yml +++ b/sdk/netapp/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/network/ci.yml b/sdk/network/ci.yml index 310670fc8151..779327581aab 100644 --- a/sdk/network/ci.yml +++ b/sdk/network/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/notificationhubs/ci.yml b/sdk/notificationhubs/ci.yml index 4dc9202e89e2..5265499b9008 100644 --- a/sdk/notificationhubs/ci.yml +++ b/sdk/notificationhubs/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/operationsmanagement/ci.yml b/sdk/operationsmanagement/ci.yml index 78574d66b112..300f1216b07b 100644 --- a/sdk/operationsmanagement/ci.yml +++ b/sdk/operationsmanagement/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/peering/ci.yml b/sdk/peering/ci.yml index 3405caa53f55..dd1a701a6e19 100644 --- a/sdk/peering/ci.yml +++ b/sdk/peering/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/policyinsights/ci.yml b/sdk/policyinsights/ci.yml index dcc111469723..231d43ab1e9f 100644 --- a/sdk/policyinsights/ci.yml +++ b/sdk/policyinsights/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/portal/ci.yml b/sdk/portal/ci.yml index b4fe71ff72ea..86e818fce7cd 100644 --- a/sdk/portal/ci.yml +++ b/sdk/portal/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/powerbidedicated/ci.yml b/sdk/powerbidedicated/ci.yml index 9ac744822c5a..15ee93692b63 100644 --- a/sdk/powerbidedicated/ci.yml +++ b/sdk/powerbidedicated/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/powerbiembedded/ci.yml b/sdk/powerbiembedded/ci.yml index e2067042cb8f..0c65205ef3dc 100644 --- a/sdk/powerbiembedded/ci.yml +++ b/sdk/powerbiembedded/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/purview/ci.yml b/sdk/purview/ci.yml index cbca1962b45c..48e54471ee73 100644 --- a/sdk/purview/ci.yml +++ b/sdk/purview/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/quantum/ci.yml b/sdk/quantum/ci.yml index b5af5f81f21f..a2d528192817 100644 --- a/sdk/quantum/ci.yml +++ b/sdk/quantum/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/rdbms/ci.yml b/sdk/rdbms/ci.yml index 837352c9c9f8..217ca2e6170c 100644 --- a/sdk/rdbms/ci.yml +++ b/sdk/rdbms/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/recoveryservices/ci.yml b/sdk/recoveryservices/ci.yml index 7adcceccaea7..600008a356bc 100644 --- a/sdk/recoveryservices/ci.yml +++ b/sdk/recoveryservices/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/redhatopenshift/ci.yml b/sdk/redhatopenshift/ci.yml index 4815effaf1e7..4984368e4080 100644 --- a/sdk/redhatopenshift/ci.yml +++ b/sdk/redhatopenshift/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/redis/ci.yml b/sdk/redis/ci.yml index c60b71c27694..9a0b034e87f1 100644 --- a/sdk/redis/ci.yml +++ b/sdk/redis/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/redisenterprise/ci.yml b/sdk/redisenterprise/ci.yml index d116bc28e65b..0da1e32b87c8 100644 --- a/sdk/redisenterprise/ci.yml +++ b/sdk/redisenterprise/ci.yml @@ -5,6 +5,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/regionmove/ci.yml b/sdk/regionmove/ci.yml index 0cbb10d557b4..1c7563bc0054 100644 --- a/sdk/regionmove/ci.yml +++ b/sdk/regionmove/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/relay/ci.yml b/sdk/relay/ci.yml index d03cf2eb387a..cd750880b2fe 100644 --- a/sdk/relay/ci.yml +++ b/sdk/relay/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/reservations/ci.yml b/sdk/reservations/ci.yml index ea521550edc2..a613feddeee1 100644 --- a/sdk/reservations/ci.yml +++ b/sdk/reservations/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/resourcemover/ci.yml b/sdk/resourcemover/ci.yml index 94d51e98375d..4bdadd09b6d0 100644 --- a/sdk/resourcemover/ci.yml +++ b/sdk/resourcemover/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/resources/ci.yml b/sdk/resources/ci.yml index ea383e74e98c..1fc881a802c3 100644 --- a/sdk/resources/ci.yml +++ b/sdk/resources/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/scheduler/ci.yml b/sdk/scheduler/ci.yml index e952a0c5272c..1ec409d9db76 100644 --- a/sdk/scheduler/ci.yml +++ b/sdk/scheduler/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/schemaregistry/ci.yml b/sdk/schemaregistry/ci.yml index 07ac07773862..dd855c6e23df 100644 --- a/sdk/schemaregistry/ci.yml +++ b/sdk/schemaregistry/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/search/ci.yml b/sdk/search/ci.yml index 7f3ef37472b7..2822e74c5f7b 100644 --- a/sdk/search/ci.yml +++ b/sdk/search/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/security/ci.yml b/sdk/security/ci.yml index 08e2b9d3220c..a0b60ac43414 100644 --- a/sdk/security/ci.yml +++ b/sdk/security/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/securityinsight/ci.yml b/sdk/securityinsight/ci.yml index 4090887ed753..cf92b983d224 100644 --- a/sdk/securityinsight/ci.yml +++ b/sdk/securityinsight/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/serialconsole/ci.yml b/sdk/serialconsole/ci.yml index 495a72461d79..4f8d977971f4 100644 --- a/sdk/serialconsole/ci.yml +++ b/sdk/serialconsole/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/servermanager/ci.yml b/sdk/servermanager/ci.yml index f6093cc14305..317e6b47c354 100644 --- a/sdk/servermanager/ci.yml +++ b/sdk/servermanager/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/servicebus/ci.yml b/sdk/servicebus/ci.yml index 47fdaf2c29a0..af8479f7bcbc 100644 --- a/sdk/servicebus/ci.yml +++ b/sdk/servicebus/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/servicefabric/ci.yml b/sdk/servicefabric/ci.yml index f3c9824ebf26..57df107b61cf 100644 --- a/sdk/servicefabric/ci.yml +++ b/sdk/servicefabric/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/signalr/ci.yml b/sdk/signalr/ci.yml index 368bdd2aca14..3cf8a8fdad91 100644 --- a/sdk/signalr/ci.yml +++ b/sdk/signalr/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/sql/ci.yml b/sdk/sql/ci.yml index 5bd82121cf21..1578559c71dd 100644 --- a/sdk/sql/ci.yml +++ b/sdk/sql/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/storage/ci.yml b/sdk/storage/ci.yml index 3796300ccc89..8ab121b9e4a0 100644 --- a/sdk/storage/ci.yml +++ b/sdk/storage/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/streamanalytics/ci.yml b/sdk/streamanalytics/ci.yml index ad08f64827ec..c059d69e9084 100644 --- a/sdk/streamanalytics/ci.yml +++ b/sdk/streamanalytics/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/subscription/ci.yml b/sdk/subscription/ci.yml index 4df043ccb87e..4fec3042fbab 100644 --- a/sdk/subscription/ci.yml +++ b/sdk/subscription/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/support/ci.yml b/sdk/support/ci.yml index 9d04577caa69..865c07fc60d9 100644 --- a/sdk/support/ci.yml +++ b/sdk/support/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/synapse/ci.yml b/sdk/synapse/ci.yml index b35a4b5ceed7..bcdaa4aff1db 100644 --- a/sdk/synapse/ci.yml +++ b/sdk/synapse/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/tables/ci.yml b/sdk/tables/ci.yml index eaf37c65f1bc..516b3facdb27 100644 --- a/sdk/tables/ci.yml +++ b/sdk/tables/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -18,6 +19,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/template/ci.yml b/sdk/template/ci.yml index 169b6b1e02b9..cab2b74d9ce8 100644 --- a/sdk/template/ci.yml +++ b/sdk/template/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/textanalytics/ci.yml b/sdk/textanalytics/ci.yml index 00842af2116b..736d27a73d58 100644 --- a/sdk/textanalytics/ci.yml +++ b/sdk/textanalytics/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -16,6 +17,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/timeseriesinsights/ci.yml b/sdk/timeseriesinsights/ci.yml index c1aa0f2f3d3a..c6e7ff9a8883 100644 --- a/sdk/timeseriesinsights/ci.yml +++ b/sdk/timeseriesinsights/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/trafficmanager/ci.yml b/sdk/trafficmanager/ci.yml index 903dc59851cd..28dc7f988c09 100644 --- a/sdk/trafficmanager/ci.yml +++ b/sdk/trafficmanager/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* diff --git a/sdk/workloadmonitor/ci.yml b/sdk/workloadmonitor/ci.yml index 446d16921461..85aa18705531 100644 --- a/sdk/workloadmonitor/ci.yml +++ b/sdk/workloadmonitor/ci.yml @@ -4,6 +4,7 @@ trigger: branches: include: - master + - main - hotfix/* - release/* - restapi* @@ -15,6 +16,7 @@ pr: branches: include: - master + - main - feature/* - hotfix/* - release/* From f84913bd7715efa21e6ccdf9d1e9d626060f2686 Mon Sep 17 00:00:00 2001 From: Scott Beddall <45376673+scbedd@users.noreply.github.com> Date: Thu, 25 Feb 2021 13:17:51 -0800 Subject: [PATCH 11/30] Update get_package_properties to also return path to setup.py (#16946) * return package path alongside rest of the tuple in common_tasks.py::get_package_properties --- eng/scripts/Language-Settings.ps1 | 2 +- scripts/devops_tasks/common_tasks.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/eng/scripts/Language-Settings.ps1 b/eng/scripts/Language-Settings.ps1 index 5b7044afee3e..7dff11c4541c 100644 --- a/eng/scripts/Language-Settings.ps1 +++ b/eng/scripts/Language-Settings.ps1 @@ -22,7 +22,7 @@ function Get-python-PackageInfoFromRepo ($pkgPath, $serviceDirectory, $pkgName) $setupProps = $null try{ pip install packaging==20.4 -q -I - $setupProps = (python -c "import sys; import os; sys.path.append(os.path.join('scripts', 'devops_tasks')); from common_tasks import get_package_properties; obj=get_package_properties('$setupLocation'); print('{0},{1},{2}'.format(obj[0], obj[1], obj[2]));") -split "," + $setupProps = (python -c "import sys; import os; sys.path.append(os.path.join('scripts', 'devops_tasks')); from common_tasks import get_package_properties; obj=get_package_properties('$setupLocation'); print('{0},{1},{2},{3}'.format(obj[0], obj[1], obj[2], obj[3]));") -split "," } catch { diff --git a/scripts/devops_tasks/common_tasks.py b/scripts/devops_tasks/common_tasks.py index 1ec5d86cdbf3..733a53c00b88 100644 --- a/scripts/devops_tasks/common_tasks.py +++ b/scripts/devops_tasks/common_tasks.py @@ -475,4 +475,4 @@ def get_package_properties(setup_py_path): """ pkgName, version, _, requires = parse_setup(setup_py_path) is_new_sdk = pkgName in NEW_REQ_PACKAGES or any(map(lambda x: (parse_require(x)[0] in NEW_REQ_PACKAGES), requires)) - return pkgName, version, is_new_sdk + return pkgName, version, is_new_sdk, setup_py_path From ffba8cca81a4ef185be77e737d9219e284520a24 Mon Sep 17 00:00:00 2001 From: Krista Pratico Date: Thu, 25 Feb 2021 15:03:34 -0800 Subject: [PATCH 12/30] temp fix for canary tests (#16945) --- .../azure-ai-formrecognizer/tests/test_custom_forms_from_url.py | 2 +- .../tests/test_custom_forms_from_url_async.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url.py b/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url.py index 1e293390f575..957b650b85b6 100644 --- a/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url.py +++ b/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url.py @@ -80,7 +80,7 @@ def test_custom_form_bad_url(self, client, formrecognizer_storage_container_sas_ form_url="https://badurl.jpg" ) form = poller.result() - self.assertEqual(e.value.error.code, "2003") + # self.assertEqual(e.value.error.code, "2003") FIXME: this is returning 1001 in canary self.assertIsNotNone(e.value.error.message) @FormRecognizerPreparer() diff --git a/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url_async.py b/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url_async.py index 11c210abe483..6d6e5e1bc27f 100644 --- a/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url_async.py +++ b/sdk/formrecognizer/azure-ai-formrecognizer/tests/test_custom_forms_from_url_async.py @@ -102,7 +102,7 @@ async def test_form_bad_url(self, client, formrecognizer_storage_container_sas_u form_url="https://badurl.jpg" ) result = await poller.result() - self.assertEqual(e.value.error.code, "2003") + # self.assertEqual(e.value.error.code, "2003") FIXME: this is returning 1001 in canary self.assertIsNotNone(e.value.error.message) @FormRecognizerPreparer() From 5e6e0b4aa144332356f6859135c71e64cbca8b6a Mon Sep 17 00:00:00 2001 From: Rakshith Bhyravabhotla Date: Thu, 25 Feb 2021 16:42:27 -0800 Subject: [PATCH 13/30] Add perf tests for eventgrid (#16949) * initialize * implementation * Update sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/README.md * comments --- .../tests/perfstress_tests/README.md | 48 ++++++++++++ .../tests/perfstress_tests/__init__.py | 0 .../tests/perfstress_tests/send.py | 73 +++++++++++++++++++ 3 files changed, 121 insertions(+) create mode 100644 sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/README.md create mode 100644 sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/__init__.py create mode 100644 sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/send.py diff --git a/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/README.md b/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/README.md new file mode 100644 index 000000000000..7e51435d647f --- /dev/null +++ b/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/README.md @@ -0,0 +1,48 @@ +# EventGrid Performance Tests + +In order to run the performance tests, the `azure-devtools` package must be installed. This is done as part of the `dev_requirements`. +Start by creating a new virtual environment for your perf tests. This will need to be a Python 3 environment, preferably >=3.7. + +### Setup for test resources + +These tests will run against a pre-configured Eventgrid topic. The following environment variable will need to be set for the tests to access the live resources: +``` +EG_ACCESS_KEY= +EG_TOPIC_HOSTNAME= +``` + +### Setup for perf test runs + +```cmd +(env) ~/azure-eventgrid> pip install -r dev_requirements.txt +(env) ~/azure-eventgrid> pip install -e . +``` + +## Test commands + +```cmd +(env) ~/azure-eventgrid> cd tests +(env) ~/azure-eventgrid/tests> perfstress +``` + +### Common perf command line options +These options are available for all perf tests: +- `--duration=10` Number of seconds to run as many operations (the "run" function) as possible. Default is 10. +- `--iterations=1` Number of test iterations to run. Default is 1. +- `--parallel=1` Number of tests to run in parallel. Default is 1. +- `--warm-up=5` Number of seconds to spend warming up the connection before measuring begins. Default is 5. +- `--sync` Whether to run the tests in sync or async. Default is False (async). +- `--no-cleanup` Whether to keep newly created resources after test run. Default is False (resources will be deleted). + +### EventGrid Test options +These options are available for all eventgrid perf tests: +- `--num-events` Number of events to be published using the send method. + +### T2 Tests +The tests currently written for the T2 SDK: +- `EventGridPerfTest` Publishes a list of eventgrid events. + +## Example command +```cmd +(env) ~/azure-eventgrid/tests> perfstress EventGridPerfTest --num-events=100 +``` diff --git a/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/__init__.py b/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/__init__.py new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/send.py b/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/send.py new file mode 100644 index 000000000000..4f13b3c39cfe --- /dev/null +++ b/sdk/eventgrid/azure-eventgrid/tests/perfstress_tests/send.py @@ -0,0 +1,73 @@ +#------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +#-------------------------------------------------------------------------- + +import asyncio +from azure_devtools.perfstress_tests import PerfStressTest + +from azure.eventgrid import EventGridPublisherClient as SyncPublisherClient, EventGridEvent +from azure.eventgrid.aio import EventGridPublisherClient as AsyncPublisherClient + +from azure.core.credentials import AzureKeyCredential + +class EventGridPerfTest(PerfStressTest): + def __init__(self, arguments): + super().__init__(arguments) + + # auth configuration + topic_key = self.get_from_env("EG_ACCESS_KEY") + endpoint = self.get_from_env("EG_TOPIC_HOSTNAME") + + # Create clients + self.publisher_client = SyncPublisherClient( + endpoint=endpoint, + credential=AzureKeyCredential(topic_key) + ) + self.async_publisher_client = AsyncPublisherClient( + endpoint=endpoint, + credential=AzureKeyCredential(topic_key) + ) + + self.event_list = [] + for _ in range(self.args.num_events): + self.event_list.append(EventGridEvent( + event_type="Contoso.Items.ItemReceived", + data={ + "services": ["EventGrid", "ServiceBus", "EventHubs", "Storage"] + }, + subject="Door1", + data_version="2.0" + )) + + async def close(self): + """This is run after cleanup. + + Use this to close any open handles or clients. + """ + await self.async_publisher_client.close() + await super().close() + + def run_sync(self): + """The synchronous perf test. + + Try to keep this minimal and focused. Using only a single client API. + Avoid putting any ancilliary logic (e.g. generating UUIDs), and put this in the setup/init instead + so that we're only measuring the client API call. + """ + self.publisher_client.send(self.event_list) + + async def run_async(self): + """The asynchronous perf test. + + Try to keep this minimal and focused. Using only a single client API. + Avoid putting any ancilliary logic (e.g. generating UUIDs), and put this in the setup/init instead + so that we're only measuring the client API call. + """ + await self.async_publisher_client.send(self.event_list) + + @staticmethod + def add_arguments(parser): + super(EventGridPerfTest, EventGridPerfTest).add_arguments(parser) + parser.add_argument('-n', '--num-events', nargs='?', type=int, help='Number of events to be sent. Defaults to 100', default=100) From d69860285b5a9642b0f8bff289d10b89dfb66855 Mon Sep 17 00:00:00 2001 From: Craig Treasure Date: Thu, 25 Feb 2021 19:40:34 -0800 Subject: [PATCH 14/30] Adding azure-devtools to mr-auth dev_requirements (#16953) - This is the only difference I can spot with other libraries. I'm going to add it to see if it solves the problem with running the tests. --- .../azure-mixedreality-authentication/dev_requirements.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt b/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt index d9b5454b3434..fbdc760e9b29 100644 --- a/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt +++ b/sdk/mixedreality/azure-mixedreality-authentication/dev_requirements.txt @@ -2,3 +2,4 @@ ../azure-mixedreality-nspkg ../../core/azure-core aiohttp>=3.0; python_version >= '3.5' +-e ../../../tools/azure-devtools From 7b2720016db4c7769d9bcca3d0cf92cee9dab829 Mon Sep 17 00:00:00 2001 From: Craig Treasure Date: Thu, 25 Feb 2021 20:01:18 -0800 Subject: [PATCH 15/30] Change test pipeline to run in eastus2 (#16950) - The test resources rely on an ASA account, which isn't available in westus2, the default region. So, i've adjusted the region to eastus2. --- sdk/mixedreality/tests.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/sdk/mixedreality/tests.yml b/sdk/mixedreality/tests.yml index 8755e0615f27..c630efffdeff 100644 --- a/sdk/mixedreality/tests.yml +++ b/sdk/mixedreality/tests.yml @@ -6,6 +6,7 @@ stages: AllocateResourceGroup: false ServiceDirectory: mixedreality DeployArmTemplate: true + Location: eastus2 EnvVars: AZURE_CLIENT_ID: $(aad-azure-sdk-test-client-id) AZURE_CLIENT_SECRET: $(aad-azure-sdk-test-client-secret) From 8e64146addf6410d5d83e3650ac4c44897d17a89 Mon Sep 17 00:00:00 2001 From: "Kaihui (Kerwin) Sun" Date: Fri, 26 Feb 2021 14:31:38 +0800 Subject: [PATCH 16/30] T2 web 2021 02 24 (#16901) * release web 2020-09-01 * fix changelog --- sdk/appservice/azure-mgmt-web/CHANGELOG.md | 161 + .../azure/mgmt/web/_operations_mixin.py | 142 +- .../azure-mgmt-web/azure/mgmt/web/_version.py | 10 +- .../mgmt/web/_web_site_management_client.py | 100 +- .../azure/mgmt/web/aio/_operations_mixin.py | 142 +- .../web/aio/_web_site_management_client.py | 100 +- .../azure-mgmt-web/azure/mgmt/web/models.py | 2 +- .../azure/mgmt/web/v2015_04_01/__init__.py | 3 - .../mgmt/web/v2015_04_01/_configuration.py | 3 +- .../web/v2015_04_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2015_08_01/__init__.py | 3 - .../mgmt/web/v2015_08_01/_configuration.py | 3 +- .../web/v2015_08_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2016_03_01/__init__.py | 3 - .../mgmt/web/v2016_03_01/_configuration.py | 3 +- .../web/v2016_03_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2016_08_01/__init__.py | 3 - .../mgmt/web/v2016_08_01/_configuration.py | 3 +- .../web/v2016_08_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2016_09_01/__init__.py | 3 - .../mgmt/web/v2016_09_01/_configuration.py | 3 +- .../azure/mgmt/web/v2016_09_01/_version.py | 9 - .../web/v2016_09_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2018_02_01/__init__.py | 3 - .../mgmt/web/v2018_02_01/_configuration.py | 3 +- .../azure/mgmt/web/v2018_02_01/_version.py | 9 - .../web/v2018_02_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2018_11_01/__init__.py | 3 - .../mgmt/web/v2018_11_01/_configuration.py | 3 +- .../azure/mgmt/web/v2018_11_01/_version.py | 9 - .../web/v2018_11_01/aio/_configuration.py | 3 +- .../azure/mgmt/web/v2019_08_01/__init__.py | 3 - .../mgmt/web/v2019_08_01/_configuration.py | 3 +- .../azure/mgmt/web/v2019_08_01/_version.py | 9 - .../web/v2019_08_01/aio/_configuration.py | 3 +- .../_version.py => v2020_06_01/__init__.py} | 9 +- .../mgmt/web/v2020_06_01/_configuration.py | 70 + .../azure/mgmt/web/v2020_06_01/_metadata.json | 267 + .../_web_site_management_client.py | 141 + .../aio/__init__.py} | 3 +- .../web/v2020_06_01/aio/_configuration.py | 66 + .../aio/_web_site_management_client.py | 135 + .../v2020_06_01/aio/operations/__init__.py | 43 + ...p_service_certificate_orders_operations.py | 1491 + .../_app_service_environments_operations.py | 3246 ++ .../_app_service_plans_operations.py | 2007 ++ ...ficate_registration_provider_operations.py | 108 + .../operations/_certificates_operations.py | 441 + .../_deleted_web_apps_operations.py | 245 + .../aio/operations/_diagnostics_operations.py | 1774 + ...domain_registration_provider_operations.py | 108 + .../aio/operations/_domains_operations.py | 1119 + .../aio/operations/_provider_operations.py | 252 + .../operations/_recommendations_operations.py | 1109 + .../_resource_health_metadata_operations.py | 471 + .../operations/_static_sites_operations.py | 1913 + .../_top_level_domains_operations.py | 252 + .../aio/operations/_web_apps_operations.py | 28546 +++++++++++++++ .../_web_site_management_client_operations.py | 1059 + .../mgmt/web/v2020_06_01/models/__init__.py | 1199 + .../mgmt/web/v2020_06_01/models/_models.py | 16943 +++++++++ .../web/v2020_06_01/models/_models_py3.py | 18799 ++++++++++ .../_web_site_management_client_enums.py | 751 + .../web/v2020_06_01/operations/__init__.py | 43 + ...p_service_certificate_orders_operations.py | 1517 + .../_app_service_environments_operations.py | 3293 ++ .../_app_service_plans_operations.py | 2039 ++ ...ficate_registration_provider_operations.py | 113 + .../operations/_certificates_operations.py | 451 + .../_deleted_web_apps_operations.py | 252 + .../operations/_diagnostics_operations.py | 1800 + ...domain_registration_provider_operations.py | 113 + .../operations/_domains_operations.py | 1139 + .../operations/_provider_operations.py | 259 + .../operations/_recommendations_operations.py | 1128 + .../_resource_health_metadata_operations.py | 481 + .../operations/_static_sites_operations.py | 1944 ++ .../_top_level_domains_operations.py | 259 + .../operations/_web_apps_operations.py | 28958 ++++++++++++++++ .../_web_site_management_client_operations.py | 1079 + .../azure/mgmt/web/v2020_06_01/py.typed | 1 + .../_version.py => v2020_09_01/__init__.py} | 9 +- .../mgmt/web/v2020_09_01/_configuration.py | 70 + .../azure/mgmt/web/v2020_09_01/_metadata.json | 279 + .../_web_site_management_client.py | 141 + .../aio/__init__.py} | 3 +- .../web/v2020_09_01/aio/_configuration.py | 66 + .../aio/_web_site_management_client.py | 135 + .../v2020_09_01/aio/operations/__init__.py | 43 + ...p_service_certificate_orders_operations.py | 1491 + .../_app_service_environments_operations.py | 3246 ++ .../_app_service_plans_operations.py | 2007 ++ ...ficate_registration_provider_operations.py | 108 + .../operations/_certificates_operations.py | 441 + .../_deleted_web_apps_operations.py | 245 + .../aio/operations/_diagnostics_operations.py | 1774 + ...domain_registration_provider_operations.py | 108 + .../aio/operations/_domains_operations.py | 1119 + .../aio/operations/_provider_operations.py | 252 + .../operations/_recommendations_operations.py | 1109 + .../_resource_health_metadata_operations.py | 471 + .../operations/_static_sites_operations.py | 1913 + .../_top_level_domains_operations.py | 252 + .../aio/operations/_web_apps_operations.py | 28546 +++++++++++++++ .../_web_site_management_client_operations.py | 1121 + .../mgmt/web/v2020_09_01/models/__init__.py | 1210 + .../mgmt/web/v2020_09_01/models/_models.py | 17635 ++++++++++ .../web/v2020_09_01/models/_models_py3.py | 19507 +++++++++++ .../_web_site_management_client_enums.py | 760 + .../web/v2020_09_01/operations/__init__.py | 43 + ...p_service_certificate_orders_operations.py | 1517 + .../_app_service_environments_operations.py | 3293 ++ .../_app_service_plans_operations.py | 2039 ++ ...ficate_registration_provider_operations.py | 113 + .../operations/_certificates_operations.py | 451 + .../_deleted_web_apps_operations.py | 252 + .../operations/_diagnostics_operations.py | 1800 + ...domain_registration_provider_operations.py | 113 + .../operations/_domains_operations.py | 1139 + .../operations/_provider_operations.py | 259 + .../operations/_recommendations_operations.py | 1128 + .../_resource_health_metadata_operations.py | 481 + .../operations/_static_sites_operations.py | 1944 ++ .../_top_level_domains_operations.py | 259 + .../operations/_web_apps_operations.py | 28958 ++++++++++++++++ .../_web_site_management_client_operations.py | 1142 + .../azure/mgmt/web/v2020_09_01/py.typed | 1 + ...gmt_app_service.test_app_service_plan.yaml | 45 +- ...cli_mgmt_static_site.test_static_site.yaml | 56 +- .../test_cli_mgmt_web_app.test_web_app.yaml | 217 +- ...st_cli_mgmt_web_app.test_web_app_slot.yaml | 213 +- 131 files changed, 257284 insertions(+), 441 deletions(-) delete mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_version.py delete mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_version.py delete mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_version.py delete mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_version.py rename sdk/appservice/azure-mgmt-web/azure/mgmt/web/{v2016_03_01/_version.py => v2020_06_01/__init__.py} (69%) create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_configuration.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_metadata.json create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_web_site_management_client.py rename sdk/appservice/azure-mgmt-web/azure/mgmt/web/{v2015_04_01/_version.py => v2020_06_01/aio/__init__.py} (81%) create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_configuration.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_web_site_management_client.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_certificate_orders_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_environments_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_plans_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificate_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificates_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_deleted_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_diagnostics_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domain_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_recommendations_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_resource_health_metadata_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_static_sites_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_top_level_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_site_management_client_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models_py3.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_web_site_management_client_enums.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_certificate_orders_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_environments_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_plans_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificate_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificates_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_deleted_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_diagnostics_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domain_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_recommendations_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_resource_health_metadata_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_static_sites_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_top_level_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_site_management_client_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/py.typed rename sdk/appservice/azure-mgmt-web/azure/mgmt/web/{v2016_08_01/_version.py => v2020_09_01/__init__.py} (69%) create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_configuration.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_metadata.json create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_web_site_management_client.py rename sdk/appservice/azure-mgmt-web/azure/mgmt/web/{v2015_08_01/_version.py => v2020_09_01/aio/__init__.py} (81%) create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_configuration.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_web_site_management_client.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_certificate_orders_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_environments_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_plans_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificate_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificates_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_deleted_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_diagnostics_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domain_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_recommendations_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_resource_health_metadata_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_static_sites_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_top_level_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_site_management_client_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models_py3.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_web_site_management_client_enums.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/__init__.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_certificate_orders_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_environments_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_plans_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificate_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificates_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_deleted_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_diagnostics_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domain_registration_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_provider_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_recommendations_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_resource_health_metadata_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_static_sites_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_top_level_domains_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_apps_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_site_management_client_operations.py create mode 100644 sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/py.typed diff --git a/sdk/appservice/azure-mgmt-web/CHANGELOG.md b/sdk/appservice/azure-mgmt-web/CHANGELOG.md index 3b85ed038260..20ba0c77003e 100644 --- a/sdk/appservice/azure-mgmt-web/CHANGELOG.md +++ b/sdk/appservice/azure-mgmt-web/CHANGELOG.md @@ -1,7 +1,168 @@ # Release History +## 2.0.0 (2021-02-25) + +**Features** + + - Model Usage has a new parameter system_data + - Model StaticSiteFunctionOverviewARMResource has a new parameter system_data + - Model HybridConnection has a new parameter system_data + - Model GeoRegion has a new parameter system_data + - Model IpSecurityRestriction has a new parameter headers + - Model StaticSiteBuildARMResource has a new parameter system_data + - Model PushSettings has a new parameter system_data + - Model SlotDifference has a new parameter system_data + - Model AppServiceCertificatePatchResource has a new parameter system_data + - Model DiagnosticDetectorResponse has a new parameter system_data + - Model MetricSpecification has a new parameter supported_aggregation_types + - Model PremierAddOnPatchResource has a new parameter system_data + - Model SitePatchResource has a new parameter custom_domain_verification_id + - Model SitePatchResource has a new parameter system_data + - Model SitePatchResource has a new parameter client_cert_mode + - Model HostNameBinding has a new parameter system_data + - Model CustomHostnameAnalysisResult has a new parameter system_data + - Model VnetGateway has a new parameter system_data + - Model MSDeployLog has a new parameter system_data + - Model Site has a new parameter custom_domain_verification_id + - Model Site has a new parameter system_data + - Model Site has a new parameter client_cert_mode + - Model PrivateEndpointConnectionResource has a new parameter system_data + - Model ResourceHealthMetadata has a new parameter system_data + - Model CertificatePatchResource has a new parameter system_data + - Model WorkerPoolResource has a new parameter system_data + - Model AppServiceEnvironmentResource has a new parameter system_data + - Model DetectorResponse has a new parameter system_data + - Model TriggeredWebJob has a new parameter system_data + - Model SiteSourceControl has a new parameter is_git_hub_action + - Model SiteSourceControl has a new parameter system_data + - Model MSDeploy has a new parameter system_data + - Model TriggeredJobHistory has a new parameter system_data + - Model SiteConfigResource has a new parameter vnet_route_all_enabled + - Model SiteConfigResource has a new parameter system_data + - Model SiteConfigResource has a new parameter scm_min_tls_version + - Model SiteConfigResource has a new parameter vnet_private_ports_count + - Model BackupRequest has a new parameter system_data + - Model DeletedSite has a new parameter system_data + - Model RenewCertificateOrderRequest has a new parameter system_data + - Model StorageMigrationResponse has a new parameter system_data + - Model CsmPublishingCredentialsPoliciesCollection has a new parameter system_data + - Model AddressResponse has a new parameter system_data + - Model BillingMeter has a new parameter system_data + - Model Deployment has a new parameter system_data + - Model ProcessModuleInfo has a new parameter system_data + - Model CertificateEmail has a new parameter system_data + - Model Certificate has a new parameter system_data + - Model StaticSitePatchResource has a new parameter system_data + - Model SitePhpErrorLogFlag has a new parameter system_data + - Model CsmPublishingCredentialsPoliciesEntity has a new parameter system_data + - Model SwiftVirtualNetwork has a new parameter system_data + - Model VnetRoute has a new parameter system_data + - Model ConnectionStringDictionary has a new parameter system_data + - Model WebSiteInstanceStatus has a new parameter system_data + - Model WebSiteInstanceStatus has a new parameter health_check_url + - Model HybridConnectionKey has a new parameter system_data + - Model PremierAddOnOffer has a new parameter system_data + - Model ContinuousWebJob has a new parameter system_data + - Model SnapshotRestoreRequest has a new parameter system_data + - Model SiteAuthSettings has a new parameter git_hub_client_id + - Model SiteAuthSettings has a new parameter microsoft_account_client_secret_setting_name + - Model SiteAuthSettings has a new parameter git_hub_client_secret + - Model SiteAuthSettings has a new parameter is_auth_from_file + - Model SiteAuthSettings has a new parameter auth_file_path + - Model SiteAuthSettings has a new parameter google_client_secret_setting_name + - Model SiteAuthSettings has a new parameter git_hub_client_secret_setting_name + - Model SiteAuthSettings has a new parameter aad_claims_authorization + - Model SiteAuthSettings has a new parameter system_data + - Model SiteAuthSettings has a new parameter git_hub_o_auth_scopes + - Model SiteAuthSettings has a new parameter client_secret_setting_name + - Model SiteAuthSettings has a new parameter twitter_consumer_secret_setting_name + - Model SiteAuthSettings has a new parameter facebook_app_secret_setting_name + - Model DetectorDefinition has a new parameter system_data + - Model SiteConfigurationSnapshotInfo has a new parameter system_data + - Model PublicCertificate has a new parameter system_data + - Model DomainOwnershipIdentifier has a new parameter system_data + - Model StringDictionary has a new parameter system_data + - Model PrivateLinkConnectionApprovalRequestResource has a new parameter system_data + - Model SlotConfigNamesResource has a new parameter system_data + - Model WebJob has a new parameter system_data + - Model ApplicationStackResource has a new parameter system_data + - Model ReissueCertificateOrderRequest has a new parameter system_data + - Model User has a new parameter system_data + - Model RestoreRequest has a new parameter system_data + - Model StaticSiteUserInvitationRequestResource has a new parameter system_data + - Model StorageMigrationOptions has a new parameter system_data + - Model HybridConnectionLimits has a new parameter system_data + - Model StaticSiteUserARMResource has a new parameter system_data + - Model AppServiceCertificateResource has a new parameter system_data + - Model AnalysisDefinition has a new parameter system_data + - Model VnetInfo has a new parameter system_data + - Model DomainPatchResource has a new parameter system_data + - Model MSDeployStatus has a new parameter system_data + - Model MigrateMySqlRequest has a new parameter system_data + - Model Identifier has a new parameter system_data + - Model SiteLogsConfig has a new parameter system_data + - Model AppServiceCertificateOrder has a new parameter system_data + - Model BackupItem has a new parameter system_data + - Model ProcessInfo has a new parameter system_data + - Model MigrateMySqlStatus has a new parameter system_data + - Model StaticSiteResetPropertiesARMResource has a new parameter system_data + - Model NetworkFeatures has a new parameter system_data + - Model Recommendation has a new parameter system_data + - Model ProcessThreadInfo has a new parameter system_data + - Model AzureStoragePropertyDictionaryResource has a new parameter system_data + - Model Domain has a new parameter system_data + - Model StaticSiteARMResource has a new parameter system_data + - Model ResourceMetricDefinition has a new parameter system_data + - Model VnetValidationTestFailure has a new parameter system_data + - Model StaticSiteUserInvitationResponseResource has a new parameter system_data + - Model PrivateAccess has a new parameter system_data + - Model SiteConfig has a new parameter vnet_route_all_enabled + - Model SiteConfig has a new parameter vnet_private_ports_count + - Model SiteConfig has a new parameter scm_min_tls_version + - Model FunctionEnvelope has a new parameter system_data + - Model TopLevelDomain has a new parameter system_data + - Model RecommendationRule has a new parameter system_data + - Model RelayServiceConnectionEntity has a new parameter system_data + - Model ProxyOnlyResource has a new parameter system_data + - Model Snapshot has a new parameter system_data + - Model VnetParameters has a new parameter system_data + - Model DiagnosticAnalysis has a new parameter system_data + - Model CertificateOrderAction has a new parameter system_data + - Model DeletedAppRestoreRequest has a new parameter system_data + - Model AppServicePlan has a new parameter system_data + - Model Resource has a new parameter system_data + - Model StaticSiteCustomDomainOverviewARMResource has a new parameter system_data + - Model PremierAddOn has a new parameter system_data + - Model TriggeredJobRun has a new parameter system_data + - Model LogSpecification has a new parameter log_filter_pattern + - Model DiagnosticCategory has a new parameter system_data + - Model SourceControl has a new parameter system_data + - Model VnetValidationFailureDetails has a new parameter system_data + - Model AppServiceEnvironmentPatchResource has a new parameter system_data + - Model AppServiceCertificateOrderPatchResource has a new parameter system_data + - Model SiteExtensionInfo has a new parameter system_data + - Model AppServicePlanPatchResource has a new parameter system_data + - Added operation WebAppsOperations.update_auth_settings_v2 + - Added operation WebAppsOperations.update_auth_settings_v2_slot + - Added operation WebAppsOperations.get_auth_settings_v2 + - Added operation WebAppsOperations.get_auth_settings_v2_slot + - Added operation StaticSitesOperations.preview_workflow + - Added operation WebSiteManagementClientOperationsMixin.generate_github_access_token_for_appservice_cli_async + +**Breaking changes** + + - Model SiteConfigResource no longer has parameter acr_use_managed_identity_creds + - Model SiteConfigResource no longer has parameter acr_user_managed_identity_id + - Model SiteConfig no longer has parameter acr_use_managed_identity_creds + - Model SiteConfig no longer has parameter acr_user_managed_identity_id + - Model FunctionSecrets has a new signature + - Removed operation WebAppsOperations.get_app_settings_key_vault_references + - Removed operation WebAppsOperations.get_app_setting_key_vault_reference + ## 1.0.0 (2020-11-23) +- GA release + ## 1.0.0b1 (2020-10-13) This is beta preview version. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_operations_mixin.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_operations_mixin.py index 3ea29b98ed99..4dc9bde189d6 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_operations_mixin.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_operations_mixin.py @@ -39,12 +39,12 @@ def check_name_availability( :param name: Resource name to verify. :type name: str :param type: Resource type used for verification. - :type type: str or ~azure.mgmt.web.v2019_08_01.models.CheckNameResourceTypes + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes :param is_fqdn: Is fully qualified domain name. :type is_fqdn: bool :keyword callable cls: A custom type or function that will be passed the direct response :return: ResourceNameAvailability, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.ResourceNameAvailability + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('check_name_availability') @@ -54,6 +54,10 @@ def check_name_availability( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'check_name_availability'".format(api_version)) mixin_instance = OperationClass() @@ -64,6 +68,38 @@ def check_name_availability( mixin_instance._deserialize = Deserializer(self._models_dict(api_version)) return mixin_instance.check_name_availability(name, type, is_fqdn, **kwargs) + def generate_github_access_token_for_appservice_cli_async( + self, + code, # type: str + state, # type: str + **kwargs # type: Any + ): + """Exchange code for GitHub access token for AppService CLI. + + Description for Exchange code for GitHub access token for AppService CLI. + + :param code: Code string to exchange for Github Access token. + :type code: str + :param state: State string used for verification. + :type state: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppserviceGithubToken, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken + :raises: ~azure.core.exceptions.HttpResponseError + """ + api_version = self._get_api_version('generate_github_access_token_for_appservice_cli_async') + if api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + else: + raise ValueError("API version {} does not have operation 'generate_github_access_token_for_appservice_cli_async'".format(api_version)) + mixin_instance = OperationClass() + mixin_instance._client = self._client + mixin_instance._config = self._config + mixin_instance._serialize = Serializer(self._models_dict(api_version)) + mixin_instance._serialize.client_side_validation = False + mixin_instance._deserialize = Deserializer(self._models_dict(api_version)) + return mixin_instance.generate_github_access_token_for_appservice_cli_async(code, state, **kwargs) + def get_publishing_user( self, **kwargs # type: Any @@ -74,7 +110,7 @@ def get_publishing_user( :keyword callable cls: A custom type or function that will be passed the direct response :return: User, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.User + :rtype: ~azure.mgmt.web.v2020_09_01.models.User :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_publishing_user') @@ -84,6 +120,10 @@ def get_publishing_user( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_publishing_user'".format(api_version)) mixin_instance = OperationClass() @@ -107,7 +147,7 @@ def get_source_control( :type source_control_type: str :keyword callable cls: A custom type or function that will be passed the direct response :return: SourceControl, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_source_control') @@ -117,6 +157,10 @@ def get_source_control( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_source_control'".format(api_version)) mixin_instance = OperationClass() @@ -137,7 +181,7 @@ def get_subscription_deployment_locations( :keyword callable cls: A custom type or function that will be passed the direct response :return: DeploymentLocations, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.DeploymentLocations + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_subscription_deployment_locations') @@ -147,6 +191,10 @@ def get_subscription_deployment_locations( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_subscription_deployment_locations'".format(api_version)) mixin_instance = OperationClass() @@ -173,7 +221,7 @@ def list_billing_meters( :type os_type: str :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2019_08_01.models.BillingMeterCollection] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_billing_meters') @@ -181,6 +229,10 @@ def list_billing_meters( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_billing_meters'".format(api_version)) mixin_instance = OperationClass() @@ -204,7 +256,7 @@ def list_geo_regions( Description for Get a list of available geographical regions. :param sku: Name of SKU used to filter the regions. - :type sku: str or ~azure.mgmt.web.v2019_08_01.models.SkuName + :type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName :param linux_workers_enabled: Specify :code:`true` if you want to filter to only regions that support Linux workers. :type linux_workers_enabled: bool @@ -216,7 +268,7 @@ def list_geo_regions( :type linux_dynamic_workers_enabled: bool :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2019_08_01.models.GeoRegionCollection] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_geo_regions') @@ -226,6 +278,10 @@ def list_geo_regions( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_geo_regions'".format(api_version)) mixin_instance = OperationClass() @@ -246,7 +302,7 @@ def list_premier_add_on_offers( :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2019_08_01.models.PremierAddOnOfferCollection] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_premier_add_on_offers') @@ -256,6 +312,10 @@ def list_premier_add_on_offers( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_premier_add_on_offers'".format(api_version)) mixin_instance = OperationClass() @@ -276,10 +336,10 @@ def list_site_identifiers_assigned_to_host_name( Description for List all apps that are assigned to a hostname. :param name_identifier: Hostname information. - :type name_identifier: ~azure.mgmt.web.v2019_08_01.models.NameIdentifier + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either IdentifierCollection or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2019_08_01.models.IdentifierCollection] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_site_identifiers_assigned_to_host_name') @@ -289,6 +349,10 @@ def list_site_identifiers_assigned_to_host_name( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_site_identifiers_assigned_to_host_name'".format(api_version)) mixin_instance = OperationClass() @@ -309,7 +373,7 @@ def list_skus( :keyword callable cls: A custom type or function that will be passed the direct response :return: SkuInfos, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SkuInfos + :rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_skus') @@ -319,6 +383,10 @@ def list_skus( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_skus'".format(api_version)) mixin_instance = OperationClass() @@ -339,7 +407,7 @@ def list_source_controls( :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either SourceControlCollection or the result of cls(response) - :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2019_08_01.models.SourceControlCollection] + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_source_controls') @@ -349,6 +417,10 @@ def list_source_controls( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_source_controls'".format(api_version)) mixin_instance = OperationClass() @@ -372,7 +444,7 @@ def move( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param move_resource_envelope: Object that represents the resource to move. - :type move_resource_envelope: ~azure.mgmt.web.v2019_08_01.models.CsmMoveResourceEnvelope + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope :keyword callable cls: A custom type or function that will be passed the direct response :return: None, or the result of cls(response) :rtype: None @@ -385,6 +457,10 @@ def move( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'move'".format(api_version)) mixin_instance = OperationClass() @@ -405,10 +481,10 @@ def update_publishing_user( Description for Updates publishing user. :param user_details: Details of publishing user. - :type user_details: ~azure.mgmt.web.v2019_08_01.models.User + :type user_details: ~azure.mgmt.web.v2020_09_01.models.User :keyword callable cls: A custom type or function that will be passed the direct response :return: User, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.User + :rtype: ~azure.mgmt.web.v2020_09_01.models.User :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('update_publishing_user') @@ -418,6 +494,10 @@ def update_publishing_user( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'update_publishing_user'".format(api_version)) mixin_instance = OperationClass() @@ -441,10 +521,10 @@ def update_source_control( :param source_control_type: Type of source control. :type source_control_type: str :param request_message: Source control token information. - :type request_message: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl :keyword callable cls: A custom type or function that will be passed the direct response :return: SourceControl, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('update_source_control') @@ -454,6 +534,10 @@ def update_source_control( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'update_source_control'".format(api_version)) mixin_instance = OperationClass() @@ -477,10 +561,10 @@ def validate( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param validate_request: Request with the resources to validate. - :type validate_request: ~azure.mgmt.web.v2019_08_01.models.ValidateRequest + :type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest :keyword callable cls: A custom type or function that will be passed the direct response :return: ValidateResponse, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.ValidateResponse + :rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('validate') @@ -490,6 +574,10 @@ def validate( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'validate'".format(api_version)) mixin_instance = OperationClass() @@ -545,7 +633,7 @@ def validate_move( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param move_resource_envelope: Object that represents the resource to move. - :type move_resource_envelope: ~azure.mgmt.web.v2019_08_01.models.CsmMoveResourceEnvelope + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope :keyword callable cls: A custom type or function that will be passed the direct response :return: None, or the result of cls(response) :rtype: None @@ -558,6 +646,10 @@ def validate_move( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'validate_move'".format(api_version)) mixin_instance = OperationClass() @@ -579,10 +671,10 @@ def verify_hosting_environment_vnet( analyzing the Network Security Group rules. :param parameters: VNET information. - :type parameters: ~azure.mgmt.web.v2019_08_01.models.VnetParameters + :type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters :keyword callable cls: A custom type or function that will be passed the direct response :return: VnetValidationFailureDetails, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.VnetValidationFailureDetails + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('verify_hosting_environment_vnet') @@ -592,6 +684,10 @@ def verify_hosting_environment_vnet( from .v2018_02_01.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'verify_hosting_environment_vnet'".format(api_version)) mixin_instance = OperationClass() diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_version.py index a39916c162ce..48944bf3938a 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_version.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_version.py @@ -1,13 +1,9 @@ # coding=utf-8 # -------------------------------------------------------------------------- # Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. See License.txt in the project root for -# license information. -# +# Licensed under the MIT License. See License.txt in the project root for license information. # Code generated by Microsoft (R) AutoRest Code Generator. -# Changes may cause incorrect behavior and will be lost if the code is -# regenerated. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- -VERSION = "1.0.0" - +VERSION = "2.0.0" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_web_site_management_client.py index a0c8927b2b7f..8a2f3426aed5 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_web_site_management_client.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/_web_site_management_client.py @@ -46,7 +46,7 @@ class WebSiteManagementClient(WebSiteManagementClientOperationsMixin, MultiApiCl :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2019-08-01' + DEFAULT_API_VERSION = '2020-09-01' _PROFILE_TAG = "azure.mgmt.web.WebSiteManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -91,6 +91,8 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2018-02-01: :mod:`v2018_02_01.models` * 2018-11-01: :mod:`v2018_11_01.models` * 2019-08-01: :mod:`v2019_08_01.models` + * 2020-06-01: :mod:`v2020_06_01.models` + * 2020-09-01: :mod:`v2020_09_01.models` """ if api_version == '2015-04-01': from .v2015_04_01 import models @@ -116,6 +118,12 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2019-08-01': from .v2019_08_01 import models return models + elif api_version == '2020-06-01': + from .v2020_06_01 import models + return models + elif api_version == '2020-09-01': + from .v2020_09_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -125,6 +133,8 @@ def app_service_certificate_orders(self): * 2015-08-01: :class:`AppServiceCertificateOrdersOperations` * 2018-02-01: :class:`AppServiceCertificateOrdersOperations` * 2019-08-01: :class:`AppServiceCertificateOrdersOperations` + * 2020-06-01: :class:`AppServiceCertificateOrdersOperations` + * 2020-09-01: :class:`AppServiceCertificateOrdersOperations` """ api_version = self._get_api_version('app_service_certificate_orders') if api_version == '2015-08-01': @@ -133,6 +143,10 @@ def app_service_certificate_orders(self): from .v2018_02_01.operations import AppServiceCertificateOrdersOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import AppServiceCertificateOrdersOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import AppServiceCertificateOrdersOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import AppServiceCertificateOrdersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_certificate_orders'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -144,6 +158,8 @@ def app_service_environments(self): * 2016-09-01: :class:`AppServiceEnvironmentsOperations` * 2018-02-01: :class:`AppServiceEnvironmentsOperations` * 2019-08-01: :class:`AppServiceEnvironmentsOperations` + * 2020-06-01: :class:`AppServiceEnvironmentsOperations` + * 2020-09-01: :class:`AppServiceEnvironmentsOperations` """ api_version = self._get_api_version('app_service_environments') if api_version == '2016-09-01': @@ -152,6 +168,10 @@ def app_service_environments(self): from .v2018_02_01.operations import AppServiceEnvironmentsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import AppServiceEnvironmentsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import AppServiceEnvironmentsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import AppServiceEnvironmentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_environments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -163,6 +183,8 @@ def app_service_plans(self): * 2016-09-01: :class:`AppServicePlansOperations` * 2018-02-01: :class:`AppServicePlansOperations` * 2019-08-01: :class:`AppServicePlansOperations` + * 2020-06-01: :class:`AppServicePlansOperations` + * 2020-09-01: :class:`AppServicePlansOperations` """ api_version = self._get_api_version('app_service_plans') if api_version == '2016-09-01': @@ -171,6 +193,10 @@ def app_service_plans(self): from .v2018_02_01.operations import AppServicePlansOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import AppServicePlansOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import AppServicePlansOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import AppServicePlansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_plans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -195,6 +221,8 @@ def certificate_registration_provider(self): * 2015-08-01: :class:`CertificateRegistrationProviderOperations` * 2018-02-01: :class:`CertificateRegistrationProviderOperations` * 2019-08-01: :class:`CertificateRegistrationProviderOperations` + * 2020-06-01: :class:`CertificateRegistrationProviderOperations` + * 2020-09-01: :class:`CertificateRegistrationProviderOperations` """ api_version = self._get_api_version('certificate_registration_provider') if api_version == '2015-08-01': @@ -203,6 +231,10 @@ def certificate_registration_provider(self): from .v2018_02_01.operations import CertificateRegistrationProviderOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import CertificateRegistrationProviderOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import CertificateRegistrationProviderOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import CertificateRegistrationProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'certificate_registration_provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -215,6 +247,8 @@ def certificates(self): * 2018-02-01: :class:`CertificatesOperations` * 2018-11-01: :class:`CertificatesOperations` * 2019-08-01: :class:`CertificatesOperations` + * 2020-06-01: :class:`CertificatesOperations` + * 2020-09-01: :class:`CertificatesOperations` """ api_version = self._get_api_version('certificates') if api_version == '2016-03-01': @@ -225,6 +259,10 @@ def certificates(self): from .v2018_11_01.operations import CertificatesOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import CertificatesOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import CertificatesOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import CertificatesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'certificates'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -236,6 +274,8 @@ def deleted_web_apps(self): * 2016-03-01: :class:`DeletedWebAppsOperations` * 2018-02-01: :class:`DeletedWebAppsOperations` * 2019-08-01: :class:`DeletedWebAppsOperations` + * 2020-06-01: :class:`DeletedWebAppsOperations` + * 2020-09-01: :class:`DeletedWebAppsOperations` """ api_version = self._get_api_version('deleted_web_apps') if api_version == '2016-03-01': @@ -244,6 +284,10 @@ def deleted_web_apps(self): from .v2018_02_01.operations import DeletedWebAppsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import DeletedWebAppsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import DeletedWebAppsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import DeletedWebAppsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deleted_web_apps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -255,6 +299,8 @@ def diagnostics(self): * 2016-03-01: :class:`DiagnosticsOperations` * 2018-02-01: :class:`DiagnosticsOperations` * 2019-08-01: :class:`DiagnosticsOperations` + * 2020-06-01: :class:`DiagnosticsOperations` + * 2020-09-01: :class:`DiagnosticsOperations` """ api_version = self._get_api_version('diagnostics') if api_version == '2016-03-01': @@ -263,6 +309,10 @@ def diagnostics(self): from .v2018_02_01.operations import DiagnosticsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import DiagnosticsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import DiagnosticsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import DiagnosticsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'diagnostics'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -274,6 +324,8 @@ def domain_registration_provider(self): * 2015-04-01: :class:`DomainRegistrationProviderOperations` * 2018-02-01: :class:`DomainRegistrationProviderOperations` * 2019-08-01: :class:`DomainRegistrationProviderOperations` + * 2020-06-01: :class:`DomainRegistrationProviderOperations` + * 2020-09-01: :class:`DomainRegistrationProviderOperations` """ api_version = self._get_api_version('domain_registration_provider') if api_version == '2015-04-01': @@ -282,6 +334,10 @@ def domain_registration_provider(self): from .v2018_02_01.operations import DomainRegistrationProviderOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import DomainRegistrationProviderOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import DomainRegistrationProviderOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import DomainRegistrationProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'domain_registration_provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -293,6 +349,8 @@ def domains(self): * 2015-04-01: :class:`DomainsOperations` * 2018-02-01: :class:`DomainsOperations` * 2019-08-01: :class:`DomainsOperations` + * 2020-06-01: :class:`DomainsOperations` + * 2020-09-01: :class:`DomainsOperations` """ api_version = self._get_api_version('domains') if api_version == '2015-04-01': @@ -301,6 +359,10 @@ def domains(self): from .v2018_02_01.operations import DomainsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import DomainsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import DomainsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import DomainsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'domains'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -312,6 +374,8 @@ def provider(self): * 2016-03-01: :class:`ProviderOperations` * 2018-02-01: :class:`ProviderOperations` * 2019-08-01: :class:`ProviderOperations` + * 2020-06-01: :class:`ProviderOperations` + * 2020-09-01: :class:`ProviderOperations` """ api_version = self._get_api_version('provider') if api_version == '2016-03-01': @@ -320,6 +384,10 @@ def provider(self): from .v2018_02_01.operations import ProviderOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import ProviderOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import ProviderOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import ProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -331,6 +399,8 @@ def recommendations(self): * 2016-03-01: :class:`RecommendationsOperations` * 2018-02-01: :class:`RecommendationsOperations` * 2019-08-01: :class:`RecommendationsOperations` + * 2020-06-01: :class:`RecommendationsOperations` + * 2020-09-01: :class:`RecommendationsOperations` """ api_version = self._get_api_version('recommendations') if api_version == '2016-03-01': @@ -339,6 +409,10 @@ def recommendations(self): from .v2018_02_01.operations import RecommendationsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import RecommendationsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import RecommendationsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import RecommendationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'recommendations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -350,6 +424,8 @@ def resource_health_metadata(self): * 2016-03-01: :class:`ResourceHealthMetadataOperations` * 2018-02-01: :class:`ResourceHealthMetadataOperations` * 2019-08-01: :class:`ResourceHealthMetadataOperations` + * 2020-06-01: :class:`ResourceHealthMetadataOperations` + * 2020-09-01: :class:`ResourceHealthMetadataOperations` """ api_version = self._get_api_version('resource_health_metadata') if api_version == '2016-03-01': @@ -358,6 +434,10 @@ def resource_health_metadata(self): from .v2018_02_01.operations import ResourceHealthMetadataOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import ResourceHealthMetadataOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import ResourceHealthMetadataOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import ResourceHealthMetadataOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_health_metadata'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -367,10 +447,16 @@ def static_sites(self): """Instance depends on the API version: * 2019-08-01: :class:`StaticSitesOperations` + * 2020-06-01: :class:`StaticSitesOperations` + * 2020-09-01: :class:`StaticSitesOperations` """ api_version = self._get_api_version('static_sites') if api_version == '2019-08-01': from .v2019_08_01.operations import StaticSitesOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import StaticSitesOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import StaticSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'static_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -382,6 +468,8 @@ def top_level_domains(self): * 2015-04-01: :class:`TopLevelDomainsOperations` * 2018-02-01: :class:`TopLevelDomainsOperations` * 2019-08-01: :class:`TopLevelDomainsOperations` + * 2020-06-01: :class:`TopLevelDomainsOperations` + * 2020-09-01: :class:`TopLevelDomainsOperations` """ api_version = self._get_api_version('top_level_domains') if api_version == '2015-04-01': @@ -390,6 +478,10 @@ def top_level_domains(self): from .v2018_02_01.operations import TopLevelDomainsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import TopLevelDomainsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import TopLevelDomainsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import TopLevelDomainsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'top_level_domains'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -401,6 +493,8 @@ def web_apps(self): * 2016-08-01: :class:`WebAppsOperations` * 2018-02-01: :class:`WebAppsOperations` * 2019-08-01: :class:`WebAppsOperations` + * 2020-06-01: :class:`WebAppsOperations` + * 2020-09-01: :class:`WebAppsOperations` """ api_version = self._get_api_version('web_apps') if api_version == '2016-08-01': @@ -409,6 +503,10 @@ def web_apps(self): from .v2018_02_01.operations import WebAppsOperations as OperationClass elif api_version == '2019-08-01': from .v2019_08_01.operations import WebAppsOperations as OperationClass + elif api_version == '2020-06-01': + from .v2020_06_01.operations import WebAppsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import WebAppsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_apps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_operations_mixin.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_operations_mixin.py index 68afcbfab5a3..c960e8f7d65c 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_operations_mixin.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_operations_mixin.py @@ -35,12 +35,12 @@ async def check_name_availability( :param name: Resource name to verify. :type name: str :param type: Resource type used for verification. - :type type: str or ~azure.mgmt.web.v2019_08_01.models.CheckNameResourceTypes + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes :param is_fqdn: Is fully qualified domain name. :type is_fqdn: bool :keyword callable cls: A custom type or function that will be passed the direct response :return: ResourceNameAvailability, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.ResourceNameAvailability + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('check_name_availability') @@ -50,6 +50,10 @@ async def check_name_availability( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'check_name_availability'".format(api_version)) mixin_instance = OperationClass() @@ -60,6 +64,38 @@ async def check_name_availability( mixin_instance._deserialize = Deserializer(self._models_dict(api_version)) return await mixin_instance.check_name_availability(name, type, is_fqdn, **kwargs) + async def generate_github_access_token_for_appservice_cli_async( + self, + code: str, + state: str, + **kwargs + ) -> "_models.AppserviceGithubToken": + """Exchange code for GitHub access token for AppService CLI. + + Description for Exchange code for GitHub access token for AppService CLI. + + :param code: Code string to exchange for Github Access token. + :type code: str + :param state: State string used for verification. + :type state: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppserviceGithubToken, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken + :raises: ~azure.core.exceptions.HttpResponseError + """ + api_version = self._get_api_version('generate_github_access_token_for_appservice_cli_async') + if api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + else: + raise ValueError("API version {} does not have operation 'generate_github_access_token_for_appservice_cli_async'".format(api_version)) + mixin_instance = OperationClass() + mixin_instance._client = self._client + mixin_instance._config = self._config + mixin_instance._serialize = Serializer(self._models_dict(api_version)) + mixin_instance._serialize.client_side_validation = False + mixin_instance._deserialize = Deserializer(self._models_dict(api_version)) + return await mixin_instance.generate_github_access_token_for_appservice_cli_async(code, state, **kwargs) + async def get_publishing_user( self, **kwargs @@ -70,7 +106,7 @@ async def get_publishing_user( :keyword callable cls: A custom type or function that will be passed the direct response :return: User, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.User + :rtype: ~azure.mgmt.web.v2020_09_01.models.User :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_publishing_user') @@ -80,6 +116,10 @@ async def get_publishing_user( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_publishing_user'".format(api_version)) mixin_instance = OperationClass() @@ -103,7 +143,7 @@ async def get_source_control( :type source_control_type: str :keyword callable cls: A custom type or function that will be passed the direct response :return: SourceControl, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_source_control') @@ -113,6 +153,10 @@ async def get_source_control( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_source_control'".format(api_version)) mixin_instance = OperationClass() @@ -133,7 +177,7 @@ async def get_subscription_deployment_locations( :keyword callable cls: A custom type or function that will be passed the direct response :return: DeploymentLocations, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.DeploymentLocations + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('get_subscription_deployment_locations') @@ -143,6 +187,10 @@ async def get_subscription_deployment_locations( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'get_subscription_deployment_locations'".format(api_version)) mixin_instance = OperationClass() @@ -169,7 +217,7 @@ def list_billing_meters( :type os_type: str :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2019_08_01.models.BillingMeterCollection] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_billing_meters') @@ -177,6 +225,10 @@ def list_billing_meters( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_billing_meters'".format(api_version)) mixin_instance = OperationClass() @@ -200,7 +252,7 @@ def list_geo_regions( Description for Get a list of available geographical regions. :param sku: Name of SKU used to filter the regions. - :type sku: str or ~azure.mgmt.web.v2019_08_01.models.SkuName + :type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName :param linux_workers_enabled: Specify :code:`true` if you want to filter to only regions that support Linux workers. :type linux_workers_enabled: bool @@ -212,7 +264,7 @@ def list_geo_regions( :type linux_dynamic_workers_enabled: bool :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2019_08_01.models.GeoRegionCollection] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_geo_regions') @@ -222,6 +274,10 @@ def list_geo_regions( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_geo_regions'".format(api_version)) mixin_instance = OperationClass() @@ -242,7 +298,7 @@ def list_premier_add_on_offers( :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2019_08_01.models.PremierAddOnOfferCollection] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_premier_add_on_offers') @@ -252,6 +308,10 @@ def list_premier_add_on_offers( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_premier_add_on_offers'".format(api_version)) mixin_instance = OperationClass() @@ -272,10 +332,10 @@ def list_site_identifiers_assigned_to_host_name( Description for List all apps that are assigned to a hostname. :param name_identifier: Hostname information. - :type name_identifier: ~azure.mgmt.web.v2019_08_01.models.NameIdentifier + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either IdentifierCollection or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2019_08_01.models.IdentifierCollection] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_site_identifiers_assigned_to_host_name') @@ -285,6 +345,10 @@ def list_site_identifiers_assigned_to_host_name( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_site_identifiers_assigned_to_host_name'".format(api_version)) mixin_instance = OperationClass() @@ -305,7 +369,7 @@ async def list_skus( :keyword callable cls: A custom type or function that will be passed the direct response :return: SkuInfos, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SkuInfos + :rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_skus') @@ -315,6 +379,10 @@ async def list_skus( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_skus'".format(api_version)) mixin_instance = OperationClass() @@ -335,7 +403,7 @@ def list_source_controls( :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either SourceControlCollection or the result of cls(response) - :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2019_08_01.models.SourceControlCollection] + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection] :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('list_source_controls') @@ -345,6 +413,10 @@ def list_source_controls( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'list_source_controls'".format(api_version)) mixin_instance = OperationClass() @@ -368,7 +440,7 @@ async def move( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param move_resource_envelope: Object that represents the resource to move. - :type move_resource_envelope: ~azure.mgmt.web.v2019_08_01.models.CsmMoveResourceEnvelope + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope :keyword callable cls: A custom type or function that will be passed the direct response :return: None, or the result of cls(response) :rtype: None @@ -381,6 +453,10 @@ async def move( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'move'".format(api_version)) mixin_instance = OperationClass() @@ -401,10 +477,10 @@ async def update_publishing_user( Description for Updates publishing user. :param user_details: Details of publishing user. - :type user_details: ~azure.mgmt.web.v2019_08_01.models.User + :type user_details: ~azure.mgmt.web.v2020_09_01.models.User :keyword callable cls: A custom type or function that will be passed the direct response :return: User, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.User + :rtype: ~azure.mgmt.web.v2020_09_01.models.User :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('update_publishing_user') @@ -414,6 +490,10 @@ async def update_publishing_user( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'update_publishing_user'".format(api_version)) mixin_instance = OperationClass() @@ -437,10 +517,10 @@ async def update_source_control( :param source_control_type: Type of source control. :type source_control_type: str :param request_message: Source control token information. - :type request_message: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl :keyword callable cls: A custom type or function that will be passed the direct response :return: SourceControl, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.SourceControl + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('update_source_control') @@ -450,6 +530,10 @@ async def update_source_control( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'update_source_control'".format(api_version)) mixin_instance = OperationClass() @@ -473,10 +557,10 @@ async def validate( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param validate_request: Request with the resources to validate. - :type validate_request: ~azure.mgmt.web.v2019_08_01.models.ValidateRequest + :type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest :keyword callable cls: A custom type or function that will be passed the direct response :return: ValidateResponse, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.ValidateResponse + :rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('validate') @@ -486,6 +570,10 @@ async def validate( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'validate'".format(api_version)) mixin_instance = OperationClass() @@ -541,7 +629,7 @@ async def validate_move( :param resource_group_name: Name of the resource group to which the resource belongs. :type resource_group_name: str :param move_resource_envelope: Object that represents the resource to move. - :type move_resource_envelope: ~azure.mgmt.web.v2019_08_01.models.CsmMoveResourceEnvelope + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope :keyword callable cls: A custom type or function that will be passed the direct response :return: None, or the result of cls(response) :rtype: None @@ -554,6 +642,10 @@ async def validate_move( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'validate_move'".format(api_version)) mixin_instance = OperationClass() @@ -575,10 +667,10 @@ async def verify_hosting_environment_vnet( analyzing the Network Security Group rules. :param parameters: VNET information. - :type parameters: ~azure.mgmt.web.v2019_08_01.models.VnetParameters + :type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters :keyword callable cls: A custom type or function that will be passed the direct response :return: VnetValidationFailureDetails, or the result of cls(response) - :rtype: ~azure.mgmt.web.v2019_08_01.models.VnetValidationFailureDetails + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails :raises: ~azure.core.exceptions.HttpResponseError """ api_version = self._get_api_version('verify_hosting_environment_vnet') @@ -588,6 +680,10 @@ async def verify_hosting_environment_vnet( from ..v2018_02_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebSiteManagementClientOperationsMixin as OperationClass else: raise ValueError("API version {} does not have operation 'verify_hosting_environment_vnet'".format(api_version)) mixin_instance = OperationClass() diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_web_site_management_client.py index 888fdd9272f0..3c0a3f9de7d7 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_web_site_management_client.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/aio/_web_site_management_client.py @@ -46,7 +46,7 @@ class WebSiteManagementClient(WebSiteManagementClientOperationsMixin, MultiApiCl :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2019-08-01' + DEFAULT_API_VERSION = '2020-09-01' _PROFILE_TAG = "azure.mgmt.web.WebSiteManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -91,6 +91,8 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2018-02-01: :mod:`v2018_02_01.models` * 2018-11-01: :mod:`v2018_11_01.models` * 2019-08-01: :mod:`v2019_08_01.models` + * 2020-06-01: :mod:`v2020_06_01.models` + * 2020-09-01: :mod:`v2020_09_01.models` """ if api_version == '2015-04-01': from ..v2015_04_01 import models @@ -116,6 +118,12 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2019-08-01': from ..v2019_08_01 import models return models + elif api_version == '2020-06-01': + from ..v2020_06_01 import models + return models + elif api_version == '2020-09-01': + from ..v2020_09_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -125,6 +133,8 @@ def app_service_certificate_orders(self): * 2015-08-01: :class:`AppServiceCertificateOrdersOperations` * 2018-02-01: :class:`AppServiceCertificateOrdersOperations` * 2019-08-01: :class:`AppServiceCertificateOrdersOperations` + * 2020-06-01: :class:`AppServiceCertificateOrdersOperations` + * 2020-09-01: :class:`AppServiceCertificateOrdersOperations` """ api_version = self._get_api_version('app_service_certificate_orders') if api_version == '2015-08-01': @@ -133,6 +143,10 @@ def app_service_certificate_orders(self): from ..v2018_02_01.aio.operations import AppServiceCertificateOrdersOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import AppServiceCertificateOrdersOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import AppServiceCertificateOrdersOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import AppServiceCertificateOrdersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_certificate_orders'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -144,6 +158,8 @@ def app_service_environments(self): * 2016-09-01: :class:`AppServiceEnvironmentsOperations` * 2018-02-01: :class:`AppServiceEnvironmentsOperations` * 2019-08-01: :class:`AppServiceEnvironmentsOperations` + * 2020-06-01: :class:`AppServiceEnvironmentsOperations` + * 2020-09-01: :class:`AppServiceEnvironmentsOperations` """ api_version = self._get_api_version('app_service_environments') if api_version == '2016-09-01': @@ -152,6 +168,10 @@ def app_service_environments(self): from ..v2018_02_01.aio.operations import AppServiceEnvironmentsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import AppServiceEnvironmentsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import AppServiceEnvironmentsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import AppServiceEnvironmentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_environments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -163,6 +183,8 @@ def app_service_plans(self): * 2016-09-01: :class:`AppServicePlansOperations` * 2018-02-01: :class:`AppServicePlansOperations` * 2019-08-01: :class:`AppServicePlansOperations` + * 2020-06-01: :class:`AppServicePlansOperations` + * 2020-09-01: :class:`AppServicePlansOperations` """ api_version = self._get_api_version('app_service_plans') if api_version == '2016-09-01': @@ -171,6 +193,10 @@ def app_service_plans(self): from ..v2018_02_01.aio.operations import AppServicePlansOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import AppServicePlansOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import AppServicePlansOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import AppServicePlansOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'app_service_plans'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -195,6 +221,8 @@ def certificate_registration_provider(self): * 2015-08-01: :class:`CertificateRegistrationProviderOperations` * 2018-02-01: :class:`CertificateRegistrationProviderOperations` * 2019-08-01: :class:`CertificateRegistrationProviderOperations` + * 2020-06-01: :class:`CertificateRegistrationProviderOperations` + * 2020-09-01: :class:`CertificateRegistrationProviderOperations` """ api_version = self._get_api_version('certificate_registration_provider') if api_version == '2015-08-01': @@ -203,6 +231,10 @@ def certificate_registration_provider(self): from ..v2018_02_01.aio.operations import CertificateRegistrationProviderOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import CertificateRegistrationProviderOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import CertificateRegistrationProviderOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import CertificateRegistrationProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'certificate_registration_provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -215,6 +247,8 @@ def certificates(self): * 2018-02-01: :class:`CertificatesOperations` * 2018-11-01: :class:`CertificatesOperations` * 2019-08-01: :class:`CertificatesOperations` + * 2020-06-01: :class:`CertificatesOperations` + * 2020-09-01: :class:`CertificatesOperations` """ api_version = self._get_api_version('certificates') if api_version == '2016-03-01': @@ -225,6 +259,10 @@ def certificates(self): from ..v2018_11_01.aio.operations import CertificatesOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import CertificatesOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import CertificatesOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import CertificatesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'certificates'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -236,6 +274,8 @@ def deleted_web_apps(self): * 2016-03-01: :class:`DeletedWebAppsOperations` * 2018-02-01: :class:`DeletedWebAppsOperations` * 2019-08-01: :class:`DeletedWebAppsOperations` + * 2020-06-01: :class:`DeletedWebAppsOperations` + * 2020-09-01: :class:`DeletedWebAppsOperations` """ api_version = self._get_api_version('deleted_web_apps') if api_version == '2016-03-01': @@ -244,6 +284,10 @@ def deleted_web_apps(self): from ..v2018_02_01.aio.operations import DeletedWebAppsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import DeletedWebAppsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import DeletedWebAppsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import DeletedWebAppsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deleted_web_apps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -255,6 +299,8 @@ def diagnostics(self): * 2016-03-01: :class:`DiagnosticsOperations` * 2018-02-01: :class:`DiagnosticsOperations` * 2019-08-01: :class:`DiagnosticsOperations` + * 2020-06-01: :class:`DiagnosticsOperations` + * 2020-09-01: :class:`DiagnosticsOperations` """ api_version = self._get_api_version('diagnostics') if api_version == '2016-03-01': @@ -263,6 +309,10 @@ def diagnostics(self): from ..v2018_02_01.aio.operations import DiagnosticsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import DiagnosticsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import DiagnosticsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import DiagnosticsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'diagnostics'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -274,6 +324,8 @@ def domain_registration_provider(self): * 2015-04-01: :class:`DomainRegistrationProviderOperations` * 2018-02-01: :class:`DomainRegistrationProviderOperations` * 2019-08-01: :class:`DomainRegistrationProviderOperations` + * 2020-06-01: :class:`DomainRegistrationProviderOperations` + * 2020-09-01: :class:`DomainRegistrationProviderOperations` """ api_version = self._get_api_version('domain_registration_provider') if api_version == '2015-04-01': @@ -282,6 +334,10 @@ def domain_registration_provider(self): from ..v2018_02_01.aio.operations import DomainRegistrationProviderOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import DomainRegistrationProviderOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import DomainRegistrationProviderOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import DomainRegistrationProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'domain_registration_provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -293,6 +349,8 @@ def domains(self): * 2015-04-01: :class:`DomainsOperations` * 2018-02-01: :class:`DomainsOperations` * 2019-08-01: :class:`DomainsOperations` + * 2020-06-01: :class:`DomainsOperations` + * 2020-09-01: :class:`DomainsOperations` """ api_version = self._get_api_version('domains') if api_version == '2015-04-01': @@ -301,6 +359,10 @@ def domains(self): from ..v2018_02_01.aio.operations import DomainsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import DomainsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import DomainsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import DomainsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'domains'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -312,6 +374,8 @@ def provider(self): * 2016-03-01: :class:`ProviderOperations` * 2018-02-01: :class:`ProviderOperations` * 2019-08-01: :class:`ProviderOperations` + * 2020-06-01: :class:`ProviderOperations` + * 2020-09-01: :class:`ProviderOperations` """ api_version = self._get_api_version('provider') if api_version == '2016-03-01': @@ -320,6 +384,10 @@ def provider(self): from ..v2018_02_01.aio.operations import ProviderOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import ProviderOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import ProviderOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import ProviderOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'provider'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -331,6 +399,8 @@ def recommendations(self): * 2016-03-01: :class:`RecommendationsOperations` * 2018-02-01: :class:`RecommendationsOperations` * 2019-08-01: :class:`RecommendationsOperations` + * 2020-06-01: :class:`RecommendationsOperations` + * 2020-09-01: :class:`RecommendationsOperations` """ api_version = self._get_api_version('recommendations') if api_version == '2016-03-01': @@ -339,6 +409,10 @@ def recommendations(self): from ..v2018_02_01.aio.operations import RecommendationsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import RecommendationsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import RecommendationsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import RecommendationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'recommendations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -350,6 +424,8 @@ def resource_health_metadata(self): * 2016-03-01: :class:`ResourceHealthMetadataOperations` * 2018-02-01: :class:`ResourceHealthMetadataOperations` * 2019-08-01: :class:`ResourceHealthMetadataOperations` + * 2020-06-01: :class:`ResourceHealthMetadataOperations` + * 2020-09-01: :class:`ResourceHealthMetadataOperations` """ api_version = self._get_api_version('resource_health_metadata') if api_version == '2016-03-01': @@ -358,6 +434,10 @@ def resource_health_metadata(self): from ..v2018_02_01.aio.operations import ResourceHealthMetadataOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import ResourceHealthMetadataOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import ResourceHealthMetadataOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import ResourceHealthMetadataOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_health_metadata'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -367,10 +447,16 @@ def static_sites(self): """Instance depends on the API version: * 2019-08-01: :class:`StaticSitesOperations` + * 2020-06-01: :class:`StaticSitesOperations` + * 2020-09-01: :class:`StaticSitesOperations` """ api_version = self._get_api_version('static_sites') if api_version == '2019-08-01': from ..v2019_08_01.aio.operations import StaticSitesOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import StaticSitesOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import StaticSitesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'static_sites'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -382,6 +468,8 @@ def top_level_domains(self): * 2015-04-01: :class:`TopLevelDomainsOperations` * 2018-02-01: :class:`TopLevelDomainsOperations` * 2019-08-01: :class:`TopLevelDomainsOperations` + * 2020-06-01: :class:`TopLevelDomainsOperations` + * 2020-09-01: :class:`TopLevelDomainsOperations` """ api_version = self._get_api_version('top_level_domains') if api_version == '2015-04-01': @@ -390,6 +478,10 @@ def top_level_domains(self): from ..v2018_02_01.aio.operations import TopLevelDomainsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import TopLevelDomainsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import TopLevelDomainsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import TopLevelDomainsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'top_level_domains'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -401,6 +493,8 @@ def web_apps(self): * 2016-08-01: :class:`WebAppsOperations` * 2018-02-01: :class:`WebAppsOperations` * 2019-08-01: :class:`WebAppsOperations` + * 2020-06-01: :class:`WebAppsOperations` + * 2020-09-01: :class:`WebAppsOperations` """ api_version = self._get_api_version('web_apps') if api_version == '2016-08-01': @@ -409,6 +503,10 @@ def web_apps(self): from ..v2018_02_01.aio.operations import WebAppsOperations as OperationClass elif api_version == '2019-08-01': from ..v2019_08_01.aio.operations import WebAppsOperations as OperationClass + elif api_version == '2020-06-01': + from ..v2020_06_01.aio.operations import WebAppsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import WebAppsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'web_apps'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/models.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/models.py index f7ccf42a3554..af31b0624539 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/models.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/models.py @@ -6,4 +6,4 @@ # -------------------------------------------------------------------------- from .v2016_03_01.models import * from .v2018_02_01.models import * -from .v2019_08_01.models import * +from .v2020_09_01.models import * diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_configuration.py index 0c813892959a..d21cdef02387 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/aio/_configuration.py index 4ef3d8640866..05de4e5e0cb5 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_configuration.py index ee2eeb612b3a..8c2d65eb1b5e 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/aio/_configuration.py index f7000d37df1b..bbaa147a6b73 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_configuration.py index 7c90c5f7b8fc..f48d49366b26 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/aio/_configuration.py index 80c223878906..ec6b4f114182 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_configuration.py index 34859d13f251..3911ab48338c 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/aio/_configuration.py index 86a3e099a91f..4a83888832e6 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_configuration.py index 7fd05d3967f8..870caf551976 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_version.py deleted file mode 100644 index 5c14e0d8303d..000000000000 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/_version.py +++ /dev/null @@ -1,9 +0,0 @@ -# coding=utf-8 -# -------------------------------------------------------------------------- -# Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. See License.txt in the project root for license information. -# Code generated by Microsoft (R) AutoRest Code Generator. -# Changes may cause incorrect behavior and will be lost if the code is regenerated. -# -------------------------------------------------------------------------- - -VERSION = "0.42.0" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/aio/_configuration.py index 7a0b7491a6a3..8952108d56f0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_09_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_configuration.py index 20b106b6e2da..c39f12853558 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_version.py deleted file mode 100644 index 5c14e0d8303d..000000000000 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/_version.py +++ /dev/null @@ -1,9 +0,0 @@ -# coding=utf-8 -# -------------------------------------------------------------------------- -# Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. See License.txt in the project root for license information. -# Code generated by Microsoft (R) AutoRest Code Generator. -# Changes may cause incorrect behavior and will be lost if the code is regenerated. -# -------------------------------------------------------------------------- - -VERSION = "0.42.0" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/aio/_configuration.py index af56b6258589..80c3cb9d30c4 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_02_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_configuration.py index 93ee893dbacc..f2fea06223e9 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_version.py deleted file mode 100644 index 5c14e0d8303d..000000000000 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/_version.py +++ /dev/null @@ -1,9 +0,0 @@ -# coding=utf-8 -# -------------------------------------------------------------------------- -# Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. See License.txt in the project root for license information. -# Code generated by Microsoft (R) AutoRest Code Generator. -# Changes may cause incorrect behavior and will be lost if the code is regenerated. -# -------------------------------------------------------------------------- - -VERSION = "0.42.0" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/aio/_configuration.py index 34b940936229..912eceb9824b 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2018_11_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/__init__.py index 45c59c58316a..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/__init__.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/__init__.py @@ -7,9 +7,6 @@ # -------------------------------------------------------------------------- from ._web_site_management_client import WebSiteManagementClient -from ._version import VERSION - -__version__ = VERSION __all__ = ['WebSiteManagementClient'] try: diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_configuration.py index ac656a9a822f..6352cef88fde 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_configuration.py @@ -12,14 +12,13 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from ._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from typing import Any from azure.core.credentials import TokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_version.py deleted file mode 100644 index 5c14e0d8303d..000000000000 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/_version.py +++ /dev/null @@ -1,9 +0,0 @@ -# coding=utf-8 -# -------------------------------------------------------------------------- -# Copyright (c) Microsoft Corporation. All rights reserved. -# Licensed under the MIT License. See License.txt in the project root for license information. -# Code generated by Microsoft (R) AutoRest Code Generator. -# Changes may cause incorrect behavior and will be lost if the code is regenerated. -# -------------------------------------------------------------------------- - -VERSION = "0.42.0" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/aio/_configuration.py index 823ae878264f..8fef553016cc 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/aio/_configuration.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2019_08_01/aio/_configuration.py @@ -12,12 +12,11 @@ from azure.core.pipeline import policies from azure.mgmt.core.policies import ARMHttpLoggingPolicy -from .._version import VERSION - if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials_async import AsyncTokenCredential +VERSION = "unknown" class WebSiteManagementClientConfiguration(Configuration): """Configuration for WebSiteManagementClient. diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/__init__.py similarity index 69% rename from sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_version.py rename to sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/__init__.py index 5c14e0d8303d..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_03_01/_version.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/__init__.py @@ -6,4 +6,11 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- -VERSION = "0.42.0" +from ._web_site_management_client import WebSiteManagementClient +__all__ = ['WebSiteManagementClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_configuration.py new file mode 100644 index 000000000000..7d9ffea3ff94 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_configuration.py @@ -0,0 +1,70 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + + from azure.core.credentials import TokenCredential + +VERSION = "unknown" + +class WebSiteManagementClientConfiguration(Configuration): + """Configuration for WebSiteManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(WebSiteManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-06-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-web/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_metadata.json b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_metadata.json new file mode 100644 index 000000000000..6ff75acaaea6 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_metadata.json @@ -0,0 +1,267 @@ +{ + "chosen_version": "2020-06-01", + "total_api_version_list": ["2020-06-01"], + "client": { + "name": "WebSiteManagementClient", + "filename": "_web_site_management_client", + "description": "WebSite Management Client.", + "base_url": "\u0027https://management.azure.com\u0027", + "custom_base_url": null, + "azure_arm": true, + "has_lro_operations": true, + "client_side_validation": false + }, + "global_parameters": { + "sync": { + "credential": { + "signature": "credential, # type: \"TokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials.TokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000).", + "docstring_type": "str", + "required": true + } + }, + "async": { + "credential": { + "signature": "credential, # type: \"AsyncTokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000).", + "docstring_type": "str", + "required": true + } + }, + "constant": { + }, + "call": "credential, subscription_id" + }, + "config": { + "credential": true, + "credential_scopes": ["https://management.azure.com/.default"], + "credential_default_policy_type": "BearerTokenCredentialPolicy", + "credential_default_policy_type_has_async_version": true, + "credential_key_header_name": null + }, + "operation_groups": { + "app_service_certificate_orders": "AppServiceCertificateOrdersOperations", + "certificate_registration_provider": "CertificateRegistrationProviderOperations", + "domains": "DomainsOperations", + "top_level_domains": "TopLevelDomainsOperations", + "domain_registration_provider": "DomainRegistrationProviderOperations", + "certificates": "CertificatesOperations", + "deleted_web_apps": "DeletedWebAppsOperations", + "diagnostics": "DiagnosticsOperations", + "provider": "ProviderOperations", + "recommendations": "RecommendationsOperations", + "web_apps": "WebAppsOperations", + "static_sites": "StaticSitesOperations", + "app_service_environments": "AppServiceEnvironmentsOperations", + "app_service_plans": "AppServicePlansOperations", + "resource_health_metadata": "ResourceHealthMetadataOperations" + }, + "operation_mixins": { + "get_publishing_user" : { + "sync": { + "signature": "def get_publishing_user(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets publishing user.\n\nDescription for Gets publishing user.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_publishing_user(\n self,\n **kwargs\n) -\u003e \"_models.User\":\n", + "doc": "\"\"\"Gets publishing user.\n\nDescription for Gets publishing user.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "update_publishing_user" : { + "sync": { + "signature": "def update_publishing_user(\n self,\n user_details, # type: \"_models.User\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Updates publishing user.\n\nDescription for Updates publishing user.\n\n:param user_details: Details of publishing user.\n:type user_details: ~azure.mgmt.web.v2020_06_01.models.User\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def update_publishing_user(\n self,\n user_details: \"_models.User\",\n **kwargs\n) -\u003e \"_models.User\":\n", + "doc": "\"\"\"Updates publishing user.\n\nDescription for Updates publishing user.\n\n:param user_details: Details of publishing user.\n:type user_details: ~azure.mgmt.web.v2020_06_01.models.User\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "user_details" + }, + "list_source_controls" : { + "sync": { + "signature": "def list_source_controls(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets the source controls available for Azure websites.\n\nDescription for Gets the source controls available for Azure websites.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either SourceControlCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SourceControlCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_source_controls(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.SourceControlCollection\"]:\n", + "doc": "\"\"\"Gets the source controls available for Azure websites.\n\nDescription for Gets the source controls available for Azure websites.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either SourceControlCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SourceControlCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "get_source_control" : { + "sync": { + "signature": "def get_source_control(\n self,\n source_control_type, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets source control token.\n\nDescription for Gets source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_source_control(\n self,\n source_control_type: str,\n **kwargs\n) -\u003e \"_models.SourceControl\":\n", + "doc": "\"\"\"Gets source control token.\n\nDescription for Gets source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "source_control_type" + }, + "update_source_control" : { + "sync": { + "signature": "def update_source_control(\n self,\n source_control_type, # type: str\n request_message, # type: \"_models.SourceControl\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Updates source control token.\n\nDescription for Updates source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:param request_message: Source control token information.\n:type request_message: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def update_source_control(\n self,\n source_control_type: str,\n request_message: \"_models.SourceControl\",\n **kwargs\n) -\u003e \"_models.SourceControl\":\n", + "doc": "\"\"\"Updates source control token.\n\nDescription for Updates source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:param request_message: Source control token information.\n:type request_message: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "source_control_type, request_message" + }, + "list_billing_meters" : { + "sync": { + "signature": "def list_billing_meters(\n self,\n billing_location=None, # type: Optional[str]\n os_type=None, # type: Optional[str]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets a list of meters for a given location.\n\nDescription for Gets a list of meters for a given location.\n\n:param billing_location: Azure Location of billable resource.\n:type billing_location: str\n:param os_type: App Service OS type meters used for.\n:type os_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BillingMeterCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BillingMeterCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_billing_meters(\n self,\n billing_location: Optional[str] = None,\n os_type: Optional[str] = None,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.BillingMeterCollection\"]:\n", + "doc": "\"\"\"Gets a list of meters for a given location.\n\nDescription for Gets a list of meters for a given location.\n\n:param billing_location: Azure Location of billable resource.\n:type billing_location: str\n:param os_type: App Service OS type meters used for.\n:type os_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BillingMeterCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BillingMeterCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "billing_location, os_type" + }, + "check_name_availability" : { + "sync": { + "signature": "def check_name_availability(\n self,\n name, # type: str\n type, # type: Union[str, \"_models.CheckNameResourceTypes\"]\n is_fqdn=None, # type: Optional[bool]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Check if a resource name is available.\n\nDescription for Check if a resource name is available.\n\n:param name: Resource name to verify.\n:type name: str\n:param type: Resource type used for verification.\n:type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes\n:param is_fqdn: Is fully qualified domain name.\n:type is_fqdn: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ResourceNameAvailability, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceNameAvailability\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def check_name_availability(\n self,\n name: str,\n type: Union[str, \"_models.CheckNameResourceTypes\"],\n is_fqdn: Optional[bool] = None,\n **kwargs\n) -\u003e \"_models.ResourceNameAvailability\":\n", + "doc": "\"\"\"Check if a resource name is available.\n\nDescription for Check if a resource name is available.\n\n:param name: Resource name to verify.\n:type name: str\n:param type: Resource type used for verification.\n:type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes\n:param is_fqdn: Is fully qualified domain name.\n:type is_fqdn: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ResourceNameAvailability, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceNameAvailability\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "name, type, is_fqdn" + }, + "get_subscription_deployment_locations" : { + "sync": { + "signature": "def get_subscription_deployment_locations(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets list of available geo regions plus ministamps.\n\nDescription for Gets list of available geo regions plus ministamps.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DeploymentLocations, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.DeploymentLocations\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_subscription_deployment_locations(\n self,\n **kwargs\n) -\u003e \"_models.DeploymentLocations\":\n", + "doc": "\"\"\"Gets list of available geo regions plus ministamps.\n\nDescription for Gets list of available geo regions plus ministamps.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DeploymentLocations, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.DeploymentLocations\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "list_geo_regions" : { + "sync": { + "signature": "def list_geo_regions(\n self,\n sku=None, # type: Optional[Union[str, \"_models.SkuName\"]]\n linux_workers_enabled=None, # type: Optional[bool]\n xenon_workers_enabled=None, # type: Optional[bool]\n linux_dynamic_workers_enabled=None, # type: Optional[bool]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Get a list of available geographical regions.\n\nDescription for Get a list of available geographical regions.\n\n:param sku: Name of SKU used to filter the regions.\n:type sku: str or ~azure.mgmt.web.v2020_06_01.models.SkuName\n:param linux_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Linux workers.\n:type linux_workers_enabled: bool\n:param xenon_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Xenon workers.\n:type xenon_workers_enabled: bool\n:param linux_dynamic_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter\n to only regions that support Linux Consumption Workers.\n:type linux_dynamic_workers_enabled: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either GeoRegionCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.GeoRegionCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_geo_regions(\n self,\n sku: Optional[Union[str, \"_models.SkuName\"]] = None,\n linux_workers_enabled: Optional[bool] = None,\n xenon_workers_enabled: Optional[bool] = None,\n linux_dynamic_workers_enabled: Optional[bool] = None,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.GeoRegionCollection\"]:\n", + "doc": "\"\"\"Get a list of available geographical regions.\n\nDescription for Get a list of available geographical regions.\n\n:param sku: Name of SKU used to filter the regions.\n:type sku: str or ~azure.mgmt.web.v2020_06_01.models.SkuName\n:param linux_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Linux workers.\n:type linux_workers_enabled: bool\n:param xenon_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Xenon workers.\n:type xenon_workers_enabled: bool\n:param linux_dynamic_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter\n to only regions that support Linux Consumption Workers.\n:type linux_dynamic_workers_enabled: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either GeoRegionCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.GeoRegionCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "sku, linux_workers_enabled, xenon_workers_enabled, linux_dynamic_workers_enabled" + }, + "list_site_identifiers_assigned_to_host_name" : { + "sync": { + "signature": "def list_site_identifiers_assigned_to_host_name(\n self,\n name_identifier, # type: \"_models.NameIdentifier\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all apps that are assigned to a hostname.\n\nDescription for List all apps that are assigned to a hostname.\n\n:param name_identifier: Hostname information.\n:type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either IdentifierCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_site_identifiers_assigned_to_host_name(\n self,\n name_identifier: \"_models.NameIdentifier\",\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.IdentifierCollection\"]:\n", + "doc": "\"\"\"List all apps that are assigned to a hostname.\n\nDescription for List all apps that are assigned to a hostname.\n\n:param name_identifier: Hostname information.\n:type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either IdentifierCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "name_identifier" + }, + "list_premier_add_on_offers" : { + "sync": { + "signature": "def list_premier_add_on_offers(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all premier add-on offers.\n\nDescription for List all premier add-on offers.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOfferCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_premier_add_on_offers(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.PremierAddOnOfferCollection\"]:\n", + "doc": "\"\"\"List all premier add-on offers.\n\nDescription for List all premier add-on offers.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOfferCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "list_skus" : { + "sync": { + "signature": "def list_skus(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all SKUs.\n\nDescription for List all SKUs.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SkuInfos, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SkuInfos\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def list_skus(\n self,\n **kwargs\n) -\u003e \"_models.SkuInfos\":\n", + "doc": "\"\"\"List all SKUs.\n\nDescription for List all SKUs.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SkuInfos, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.SkuInfos\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "verify_hosting_environment_vnet" : { + "sync": { + "signature": "def verify_hosting_environment_vnet(\n self,\n parameters, # type: \"_models.VnetParameters\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules.\n\nDescription for Verifies if this VNET is compatible with an App Service Environment by\nanalyzing the Network Security Group rules.\n\n:param parameters: VNET information.\n:type parameters: ~azure.mgmt.web.v2020_06_01.models.VnetParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VnetValidationFailureDetails, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.VnetValidationFailureDetails\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def verify_hosting_environment_vnet(\n self,\n parameters: \"_models.VnetParameters\",\n **kwargs\n) -\u003e \"_models.VnetValidationFailureDetails\":\n", + "doc": "\"\"\"Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules.\n\nDescription for Verifies if this VNET is compatible with an App Service Environment by\nanalyzing the Network Security Group rules.\n\n:param parameters: VNET information.\n:type parameters: ~azure.mgmt.web.v2020_06_01.models.VnetParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VnetValidationFailureDetails, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.VnetValidationFailureDetails\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "parameters" + }, + "move" : { + "sync": { + "signature": "def move(\n self,\n resource_group_name, # type: str\n move_resource_envelope, # type: \"_models.CsmMoveResourceEnvelope\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Move resources between resource groups.\n\nDescription for Move resources between resource groups.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def move(\n self,\n resource_group_name: str,\n move_resource_envelope: \"_models.CsmMoveResourceEnvelope\",\n **kwargs\n) -\u003e None:\n", + "doc": "\"\"\"Move resources between resource groups.\n\nDescription for Move resources between resource groups.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, move_resource_envelope" + }, + "validate" : { + "sync": { + "signature": "def validate(\n self,\n resource_group_name, # type: str\n validate_request, # type: \"_models.ValidateRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Validate if a resource can be created.\n\nDescription for Validate if a resource can be created.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param validate_request: Request with the resources to validate.\n:type validate_request: ~azure.mgmt.web.v2020_06_01.models.ValidateRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ValidateResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.ValidateResponse\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def validate(\n self,\n resource_group_name: str,\n validate_request: \"_models.ValidateRequest\",\n **kwargs\n) -\u003e \"_models.ValidateResponse\":\n", + "doc": "\"\"\"Validate if a resource can be created.\n\nDescription for Validate if a resource can be created.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param validate_request: Request with the resources to validate.\n:type validate_request: ~azure.mgmt.web.v2020_06_01.models.ValidateRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ValidateResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_06_01.models.ValidateResponse\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, validate_request" + }, + "validate_move" : { + "sync": { + "signature": "def validate_move(\n self,\n resource_group_name, # type: str\n move_resource_envelope, # type: \"_models.CsmMoveResourceEnvelope\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Validate whether a resource can be moved.\n\nDescription for Validate whether a resource can be moved.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def validate_move(\n self,\n resource_group_name: str,\n move_resource_envelope: \"_models.CsmMoveResourceEnvelope\",\n **kwargs\n) -\u003e None:\n", + "doc": "\"\"\"Validate whether a resource can be moved.\n\nDescription for Validate whether a resource can be moved.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, move_resource_envelope" + } + }, + "sync_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"HttpRequest\", \"HttpResponse\"], \"azure.core.paging\": [\"ItemPaged\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"Callable\", \"Dict\", \"Generic\", \"Iterable\", \"Optional\", \"TypeVar\", \"Union\"]}}}", + "async_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"AsyncHttpResponse\", \"HttpRequest\"], \"azure.core.async_paging\": [\"AsyncItemPaged\", \"AsyncList\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"AsyncIterable\", \"Callable\", \"Dict\", \"Generic\", \"Optional\", \"TypeVar\", \"Union\"]}}}" +} \ No newline at end of file diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_web_site_management_client.py new file mode 100644 index 000000000000..54fa56f31e5e --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/_web_site_management_client.py @@ -0,0 +1,141 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.mgmt.core import ARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + + from azure.core.credentials import TokenCredential + +from ._configuration import WebSiteManagementClientConfiguration +from .operations import AppServiceCertificateOrdersOperations +from .operations import CertificateRegistrationProviderOperations +from .operations import DomainsOperations +from .operations import TopLevelDomainsOperations +from .operations import DomainRegistrationProviderOperations +from .operations import CertificatesOperations +from .operations import DeletedWebAppsOperations +from .operations import DiagnosticsOperations +from .operations import ProviderOperations +from .operations import RecommendationsOperations +from .operations import WebSiteManagementClientOperationsMixin +from .operations import WebAppsOperations +from .operations import StaticSitesOperations +from .operations import AppServiceEnvironmentsOperations +from .operations import AppServicePlansOperations +from .operations import ResourceHealthMetadataOperations +from . import models + + +class WebSiteManagementClient(WebSiteManagementClientOperationsMixin): + """WebSite Management Client. + + :ivar app_service_certificate_orders: AppServiceCertificateOrdersOperations operations + :vartype app_service_certificate_orders: azure.mgmt.web.v2020_06_01.operations.AppServiceCertificateOrdersOperations + :ivar certificate_registration_provider: CertificateRegistrationProviderOperations operations + :vartype certificate_registration_provider: azure.mgmt.web.v2020_06_01.operations.CertificateRegistrationProviderOperations + :ivar domains: DomainsOperations operations + :vartype domains: azure.mgmt.web.v2020_06_01.operations.DomainsOperations + :ivar top_level_domains: TopLevelDomainsOperations operations + :vartype top_level_domains: azure.mgmt.web.v2020_06_01.operations.TopLevelDomainsOperations + :ivar domain_registration_provider: DomainRegistrationProviderOperations operations + :vartype domain_registration_provider: azure.mgmt.web.v2020_06_01.operations.DomainRegistrationProviderOperations + :ivar certificates: CertificatesOperations operations + :vartype certificates: azure.mgmt.web.v2020_06_01.operations.CertificatesOperations + :ivar deleted_web_apps: DeletedWebAppsOperations operations + :vartype deleted_web_apps: azure.mgmt.web.v2020_06_01.operations.DeletedWebAppsOperations + :ivar diagnostics: DiagnosticsOperations operations + :vartype diagnostics: azure.mgmt.web.v2020_06_01.operations.DiagnosticsOperations + :ivar provider: ProviderOperations operations + :vartype provider: azure.mgmt.web.v2020_06_01.operations.ProviderOperations + :ivar recommendations: RecommendationsOperations operations + :vartype recommendations: azure.mgmt.web.v2020_06_01.operations.RecommendationsOperations + :ivar web_apps: WebAppsOperations operations + :vartype web_apps: azure.mgmt.web.v2020_06_01.operations.WebAppsOperations + :ivar static_sites: StaticSitesOperations operations + :vartype static_sites: azure.mgmt.web.v2020_06_01.operations.StaticSitesOperations + :ivar app_service_environments: AppServiceEnvironmentsOperations operations + :vartype app_service_environments: azure.mgmt.web.v2020_06_01.operations.AppServiceEnvironmentsOperations + :ivar app_service_plans: AppServicePlansOperations operations + :vartype app_service_plans: azure.mgmt.web.v2020_06_01.operations.AppServicePlansOperations + :ivar resource_health_metadata: ResourceHealthMetadataOperations operations + :vartype resource_health_metadata: azure.mgmt.web.v2020_06_01.operations.ResourceHealthMetadataOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://management.azure.com' + self._config = WebSiteManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + self.app_service_certificate_orders = AppServiceCertificateOrdersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificate_registration_provider = CertificateRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domains = DomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.top_level_domains = TopLevelDomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domain_registration_provider = DomainRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificates = CertificatesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deleted_web_apps = DeletedWebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.diagnostics = DiagnosticsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider = ProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.recommendations = RecommendationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_apps = WebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.static_sites = StaticSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_environments = AppServiceEnvironmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_plans = AppServicePlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_health_metadata = ResourceHealthMetadataOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> WebSiteManagementClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/__init__.py similarity index 81% rename from sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_version.py rename to sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/__init__.py index 5c14e0d8303d..fc106a4f3d78 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_04_01/_version.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/__init__.py @@ -6,4 +6,5 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- -VERSION = "0.42.0" +from ._web_site_management_client import WebSiteManagementClient +__all__ = ['WebSiteManagementClient'] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_configuration.py new file mode 100644 index 000000000000..59a16dc32a16 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_configuration.py @@ -0,0 +1,66 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +VERSION = "unknown" + +class WebSiteManagementClientConfiguration(Configuration): + """Configuration for WebSiteManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + **kwargs: Any + ) -> None: + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(WebSiteManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-06-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-web/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_web_site_management_client.py new file mode 100644 index 000000000000..bfd495d2cbfd --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/_web_site_management_client.py @@ -0,0 +1,135 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional, TYPE_CHECKING + +from azure.mgmt.core import AsyncARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +from ._configuration import WebSiteManagementClientConfiguration +from .operations import AppServiceCertificateOrdersOperations +from .operations import CertificateRegistrationProviderOperations +from .operations import DomainsOperations +from .operations import TopLevelDomainsOperations +from .operations import DomainRegistrationProviderOperations +from .operations import CertificatesOperations +from .operations import DeletedWebAppsOperations +from .operations import DiagnosticsOperations +from .operations import ProviderOperations +from .operations import RecommendationsOperations +from .operations import WebSiteManagementClientOperationsMixin +from .operations import WebAppsOperations +from .operations import StaticSitesOperations +from .operations import AppServiceEnvironmentsOperations +from .operations import AppServicePlansOperations +from .operations import ResourceHealthMetadataOperations +from .. import models + + +class WebSiteManagementClient(WebSiteManagementClientOperationsMixin): + """WebSite Management Client. + + :ivar app_service_certificate_orders: AppServiceCertificateOrdersOperations operations + :vartype app_service_certificate_orders: azure.mgmt.web.v2020_06_01.aio.operations.AppServiceCertificateOrdersOperations + :ivar certificate_registration_provider: CertificateRegistrationProviderOperations operations + :vartype certificate_registration_provider: azure.mgmt.web.v2020_06_01.aio.operations.CertificateRegistrationProviderOperations + :ivar domains: DomainsOperations operations + :vartype domains: azure.mgmt.web.v2020_06_01.aio.operations.DomainsOperations + :ivar top_level_domains: TopLevelDomainsOperations operations + :vartype top_level_domains: azure.mgmt.web.v2020_06_01.aio.operations.TopLevelDomainsOperations + :ivar domain_registration_provider: DomainRegistrationProviderOperations operations + :vartype domain_registration_provider: azure.mgmt.web.v2020_06_01.aio.operations.DomainRegistrationProviderOperations + :ivar certificates: CertificatesOperations operations + :vartype certificates: azure.mgmt.web.v2020_06_01.aio.operations.CertificatesOperations + :ivar deleted_web_apps: DeletedWebAppsOperations operations + :vartype deleted_web_apps: azure.mgmt.web.v2020_06_01.aio.operations.DeletedWebAppsOperations + :ivar diagnostics: DiagnosticsOperations operations + :vartype diagnostics: azure.mgmt.web.v2020_06_01.aio.operations.DiagnosticsOperations + :ivar provider: ProviderOperations operations + :vartype provider: azure.mgmt.web.v2020_06_01.aio.operations.ProviderOperations + :ivar recommendations: RecommendationsOperations operations + :vartype recommendations: azure.mgmt.web.v2020_06_01.aio.operations.RecommendationsOperations + :ivar web_apps: WebAppsOperations operations + :vartype web_apps: azure.mgmt.web.v2020_06_01.aio.operations.WebAppsOperations + :ivar static_sites: StaticSitesOperations operations + :vartype static_sites: azure.mgmt.web.v2020_06_01.aio.operations.StaticSitesOperations + :ivar app_service_environments: AppServiceEnvironmentsOperations operations + :vartype app_service_environments: azure.mgmt.web.v2020_06_01.aio.operations.AppServiceEnvironmentsOperations + :ivar app_service_plans: AppServicePlansOperations operations + :vartype app_service_plans: azure.mgmt.web.v2020_06_01.aio.operations.AppServicePlansOperations + :ivar resource_health_metadata: ResourceHealthMetadataOperations operations + :vartype resource_health_metadata: azure.mgmt.web.v2020_06_01.aio.operations.ResourceHealthMetadataOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://management.azure.com' + self._config = WebSiteManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + self.app_service_certificate_orders = AppServiceCertificateOrdersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificate_registration_provider = CertificateRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domains = DomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.top_level_domains = TopLevelDomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domain_registration_provider = DomainRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificates = CertificatesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deleted_web_apps = DeletedWebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.diagnostics = DiagnosticsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider = ProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.recommendations = RecommendationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_apps = WebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.static_sites = StaticSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_environments = AppServiceEnvironmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_plans = AppServicePlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_health_metadata = ResourceHealthMetadataOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "WebSiteManagementClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/__init__.py new file mode 100644 index 000000000000..8f414125deed --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/__init__.py @@ -0,0 +1,43 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._app_service_certificate_orders_operations import AppServiceCertificateOrdersOperations +from ._certificate_registration_provider_operations import CertificateRegistrationProviderOperations +from ._domains_operations import DomainsOperations +from ._top_level_domains_operations import TopLevelDomainsOperations +from ._domain_registration_provider_operations import DomainRegistrationProviderOperations +from ._certificates_operations import CertificatesOperations +from ._deleted_web_apps_operations import DeletedWebAppsOperations +from ._diagnostics_operations import DiagnosticsOperations +from ._provider_operations import ProviderOperations +from ._recommendations_operations import RecommendationsOperations +from ._web_site_management_client_operations import WebSiteManagementClientOperationsMixin +from ._web_apps_operations import WebAppsOperations +from ._static_sites_operations import StaticSitesOperations +from ._app_service_environments_operations import AppServiceEnvironmentsOperations +from ._app_service_plans_operations import AppServicePlansOperations +from ._resource_health_metadata_operations import ResourceHealthMetadataOperations + +__all__ = [ + 'AppServiceCertificateOrdersOperations', + 'CertificateRegistrationProviderOperations', + 'DomainsOperations', + 'TopLevelDomainsOperations', + 'DomainRegistrationProviderOperations', + 'CertificatesOperations', + 'DeletedWebAppsOperations', + 'DiagnosticsOperations', + 'ProviderOperations', + 'RecommendationsOperations', + 'WebSiteManagementClientOperationsMixin', + 'WebAppsOperations', + 'StaticSitesOperations', + 'AppServiceEnvironmentsOperations', + 'AppServicePlansOperations', + 'ResourceHealthMetadataOperations', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_certificate_orders_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_certificate_orders_operations.py new file mode 100644 index 000000000000..2a81d852adf7 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_certificate_orders_operations.py @@ -0,0 +1,1491 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceCertificateOrdersOperations: + """AppServiceCertificateOrdersOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateOrderCollection"]: + """List all certificate orders in a subscription. + + Description for List all certificate orders in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + async def validate_purchase_information( + self, + app_service_certificate_order: "_models.AppServiceCertificateOrder", + **kwargs + ) -> None: + """Validate information for a certificate order. + + Description for Validate information for a certificate order. + + :param app_service_certificate_order: Information for a certificate order. + :type app_service_certificate_order: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_purchase_information.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_certificate_order, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_purchase_information.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/validateCertificateRegistrationInformation'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateOrderCollection"]: + """Get certificate orders in a resource group. + + Description for Get certificate orders in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + async def get( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> "_models.AppServiceCertificateOrder": + """Get a certificate order. + + Description for Get a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order.. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrder", + **kwargs + ) -> "_models.AppServiceCertificateOrder": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrder", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceCertificateOrder"]: + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceCertificateOrder or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + certificate_distinguished_name=certificate_distinguished_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Delete an existing certificate order. + + Description for Delete an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrderPatchResource", + **kwargs + ) -> "_models.AppServiceCertificateOrder": + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrderPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def list_certificates( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateCollection"]: + """List all certificates associated with a certificate order. + + Description for List all certificates associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates'} # type: ignore + + async def get_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + **kwargs + ) -> "_models.AppServiceCertificateResource": + """Get the certificate associated with a certificate order. + + Description for Get the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def _create_or_update_certificate_initial( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificateResource", + **kwargs + ) -> "_models.AppServiceCertificateResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_certificate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificateResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_certificate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def begin_create_or_update_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificateResource", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceCertificateResource"]: + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceCertificateResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_certificate_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + name=name, + key_vault_certificate=key_vault_certificate, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def delete_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + **kwargs + ) -> None: + """Delete the certificate associated with a certificate order. + + Description for Delete the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def update_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificatePatchResource", + **kwargs + ) -> "_models.AppServiceCertificateResource": + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def reissue( + self, + resource_group_name: str, + certificate_order_name: str, + reissue_certificate_order_request: "_models.ReissueCertificateOrderRequest", + **kwargs + ) -> None: + """Reissue an existing certificate order. + + Description for Reissue an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param reissue_certificate_order_request: Parameters for the reissue. + :type reissue_certificate_order_request: ~azure.mgmt.web.v2020_06_01.models.ReissueCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reissue.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reissue_certificate_order_request, 'ReissueCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reissue.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/reissue'} # type: ignore + + async def renew( + self, + resource_group_name: str, + certificate_order_name: str, + renew_certificate_order_request: "_models.RenewCertificateOrderRequest", + **kwargs + ) -> None: + """Renew an existing certificate order. + + Description for Renew an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param renew_certificate_order_request: Renew parameters. + :type renew_certificate_order_request: ~azure.mgmt.web.v2020_06_01.models.RenewCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(renew_certificate_order_request, 'RenewCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/renew'} # type: ignore + + async def resend_email( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Resend certificate email. + + Description for Resend certificate email. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.resend_email.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_email.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendEmail'} # type: ignore + + async def resend_request_emails( + self, + resource_group_name: str, + certificate_order_name: str, + name_identifier: "_models.NameIdentifier", + **kwargs + ) -> None: + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name_identifier: Email address. + :type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.resend_request_emails.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_request_emails.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendRequestEmails'} # type: ignore + + async def retrieve_site_seal( + self, + resource_group_name: str, + certificate_order_name: str, + site_seal_request: "_models.SiteSealRequest", + **kwargs + ) -> "_models.SiteSeal": + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param site_seal_request: Site seal request. + :type site_seal_request: ~azure.mgmt.web.v2020_06_01.models.SiteSealRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSeal, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSeal + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSeal"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.retrieve_site_seal.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_seal_request, 'SiteSealRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteSeal', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_site_seal.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/retrieveSiteSeal'} # type: ignore + + async def verify_domain_ownership( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.verify_domain_ownership.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + verify_domain_ownership.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/verifyDomainOwnership'} # type: ignore + + async def retrieve_certificate_actions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.CertificateOrderAction"]: + """Retrieve the list of certificate actions. + + Description for Retrieve the list of certificate actions. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateOrderAction, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.CertificateOrderAction] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateOrderAction"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_actions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateOrderAction]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_actions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveCertificateActions'} # type: ignore + + async def retrieve_certificate_email_history( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.CertificateEmail"]: + """Retrieve email history. + + Description for Retrieve email history. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateEmail, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.CertificateEmail] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateEmail"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_email_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateEmail]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_email_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveEmailHistory'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_environments_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_environments_operations.py new file mode 100644 index 000000000000..2fc42e2c999f --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_environments_operations.py @@ -0,0 +1,3246 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceEnvironmentsOperations: + """AppServiceEnvironmentsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.AppServiceEnvironmentCollection"]: + """Get all App Service Environments for a subscription. + + Description for Get all App Service Environments for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceEnvironmentCollection"]: + """Get all App Service Environments in a resource group. + + Description for Get all App Service Environments in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + """Get the properties of an App Service Environment. + + Description for Get the properties of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentResource", + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentResource", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceEnvironmentResource"]: + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceEnvironmentResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + hosting_environment_envelope=hosting_environment_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + name: str, + force_delete: Optional[bool] = None, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_delete is not None: + query_parameters['forceDelete'] = self._serialize.query("force_delete", force_delete, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + name: str, + force_delete: Optional[bool] = None, + **kwargs + ) -> AsyncLROPoller[None]: + """Delete an App Service Environment. + + Description for Delete an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param force_delete: Specify :code:`true` to force the deletion even if the App + Service Environment contains resources. The default is :code:`false`. + :type force_delete: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + name=name, + force_delete=force_delete, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentPatchResource", + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def list_capacities( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StampCapacityCollection"]: + """Get the used, available, and total worker capacity an App Service Environment. + + Description for Get the used, available, and total worker capacity an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StampCapacityCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StampCapacityCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StampCapacityCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_capacities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StampCapacityCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_capacities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/compute'} # type: ignore + + async def get_vip_info( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AddressResponse": + """Get IP addresses assigned to an App Service Environment. + + Description for Get IP addresses assigned to an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AddressResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AddressResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AddressResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vip_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AddressResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vip_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/virtualip'} # type: ignore + + async def _change_vnet_initial( + self, + resource_group_name: str, + name: str, + vnet_info: "_models.VirtualNetworkProfile", + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._change_vnet_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _change_vnet_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + async def begin_change_vnet( + self, + resource_group_name: str, + name: str, + vnet_info: "_models.VirtualNetworkProfile", + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Move an App Service Environment to a different VNET. + + Description for Move an App Service Environment to a different VNET. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param vnet_info: Details for the new virtual network. + :type vnet_info: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.change_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._change_vnet_initial( + resource_group_name=resource_group_name, + name=name, + vnet_info=vnet_info, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_change_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + async def list_diagnostics( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.HostingEnvironmentDiagnostics"]: + """Get diagnostic information for an App Service Environment. + + Description for Get diagnostic information for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDiagnostics] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.HostingEnvironmentDiagnostics"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_diagnostics.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[HostingEnvironmentDiagnostics]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_diagnostics.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics'} # type: ignore + + async def get_diagnostics_item( + self, + resource_group_name: str, + name: str, + diagnostics_name: str, + **kwargs + ) -> "_models.HostingEnvironmentDiagnostics": + """Get a diagnostics item for an App Service Environment. + + Description for Get a diagnostics item for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param diagnostics_name: Name of the diagnostics item. + :type diagnostics_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDiagnostics + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostingEnvironmentDiagnostics"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostics_item.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'diagnosticsName': self._serialize.url("diagnostics_name", diagnostics_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostingEnvironmentDiagnostics', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostics_item.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics/{diagnosticsName}'} # type: ignore + + def get_inbound_network_dependencies_endpoints( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.InboundEnvironmentEndpointCollection"]: + """Get the network endpoints of all inbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all inbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.InboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_inbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('InboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_inbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/inboundNetworkDependenciesEndpoints'} # type: ignore + + def list_multi_role_pools( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WorkerPoolCollection"]: + """Get all multi-role pools. + + Description for Get all multi-role pools. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools'} # type: ignore + + async def get_multi_role_pool( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WorkerPoolResource": + """Get properties of a multi-role pool. + + Description for Get properties of a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def _create_or_update_multi_role_pool_initial( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_multi_role_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_multi_role_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def begin_create_or_update_multi_role_pool( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> AsyncLROPoller["_models.WorkerPoolResource"]: + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_multi_role_pool_initial( + resource_group_name=resource_group_name, + name=name, + multi_role_pool_envelope=multi_role_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def update_multi_role_pool( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def list_multi_role_pool_instance_metric_definitions( + self, + resource_group_name: str, + name: str, + instance: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a specific instance of a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a multi-role pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param instance: Name of the instance in the multi-role pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/instances/{instance}/metricdefinitions'} # type: ignore + + def list_multi_role_metric_definitions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/metricdefinitions'} # type: ignore + + def list_multi_role_pool_skus( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SkuInfoCollection"]: + """Get available SKUs for scaling a multi-role pool. + + Description for Get available SKUs for scaling a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/skus'} # type: ignore + + def list_multi_role_usages( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.UsageCollection"]: + """Get usage metrics for a multi-role pool of an App Service Environment. + + Description for Get usage metrics for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/usages'} # type: ignore + + async def list_operations( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.Operation"]: + """List all currently running operations on the App Service Environment. + + Description for List all currently running operations on the App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Operation, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.Operation] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Operation"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Operation]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_operations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/operations'} # type: ignore + + def get_outbound_network_dependencies_endpoints( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.OutboundEnvironmentEndpointCollection"]: + """Get the network endpoints of all outbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all outbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OutboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.OutboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_outbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('OutboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_outbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/outboundNetworkDependenciesEndpoints'} # type: ignore + + async def reboot( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Reboot all machines in an App Service Environment. + + Description for Reboot all machines in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reboot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/reboot'} # type: ignore + + async def _resume_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._resume_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _resume_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + async def begin_resume( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Resume an App Service Environment. + + Description for Resume an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.resume.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._resume_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_resume.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def list_app_service_plans( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans in an App Service Environment. + + Description for Get all App Service plans in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_app_service_plans.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_app_service_plans.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/serverfarms'} # type: ignore + + def list_web_apps( + self, + resource_group_name: str, + name: str, + properties_to_include: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps in an App Service Environment. + + Description for Get all apps in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param properties_to_include: Comma separated list of app properties to include. + :type properties_to_include: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if properties_to_include is not None: + query_parameters['propertiesToInclude'] = self._serialize.query("properties_to_include", properties_to_include, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/sites'} # type: ignore + + async def _suspend_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._suspend_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _suspend_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + async def begin_suspend( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Suspend an App Service Environment. + + Description for Suspend an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.suspend.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._suspend_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_suspend.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Get global usage metrics of an App Service Environment. + + Description for Get global usage metrics of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/usages'} # type: ignore + + def list_worker_pools( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WorkerPoolCollection"]: + """Get all worker pools of an App Service Environment. + + Description for Get all worker pools of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools'} # type: ignore + + async def get_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> "_models.WorkerPoolResource": + """Get properties of a worker pool. + + Description for Get properties of a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def _create_or_update_worker_pool_initial( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_worker_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_worker_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def begin_create_or_update_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> AsyncLROPoller["_models.WorkerPoolResource"]: + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_worker_pool_initial( + resource_group_name=resource_group_name, + name=name, + worker_pool_name=worker_pool_name, + worker_pool_envelope=worker_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def update_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def list_worker_pool_instance_metric_definitions( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + instance: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a specific instance of a worker pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a worker pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param instance: Name of the instance in the worker pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/instances/{instance}/metricdefinitions'} # type: ignore + + def list_web_worker_metric_definitions( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a worker pool of an App Service Environment. + + Description for Get metric definitions for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_worker_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/metricdefinitions'} # type: ignore + + def list_worker_pool_skus( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.SkuInfoCollection"]: + """Get available SKUs for scaling a worker pool. + + Description for Get available SKUs for scaling a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/skus'} # type: ignore + + def list_web_worker_usages( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.UsageCollection"]: + """Get usage metrics for a worker pool of an App Service Environment. + + Description for Get usage metrics for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_worker_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/usages'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_plans_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_plans_operations.py new file mode 100644 index 000000000000..839b52cb3628 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_app_service_plans_operations.py @@ -0,0 +1,2007 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServicePlansOperations: + """AppServicePlansOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + detailed: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans for a subscription. + + Description for Get all App Service plans for a subscription. + + :param detailed: Specify :code:`true` to return all App Service plan properties. + The default is :code:`false`, which returns a subset of the properties. + Retrieval of all properties may increase the API latency. + :type detailed: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if detailed is not None: + query_parameters['detailed'] = self._serialize.query("detailed", detailed, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans in a resource group. + + Description for Get all App Service plans in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.AppServicePlan"]: + """Get an App Service plan. + + Description for Get an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AppServicePlan"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlan", + **kwargs + ) -> "_models.AppServicePlan": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlan') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlan", + **kwargs + ) -> AsyncLROPoller["_models.AppServicePlan"]: + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServicePlan or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.AppServicePlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + app_service_plan=app_service_plan, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Delete an App Service plan. + + Description for Delete an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlanPatchResource", + **kwargs + ) -> "_models.AppServicePlan": + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_06_01.models.AppServicePlanPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlanPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def list_capabilities( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.Capability"]: + """List all capabilities of an App Service plan. + + Description for List all capabilities of an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Capability, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.Capability] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Capability"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_capabilities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Capability]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_capabilities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/capabilities'} # type: ignore + + async def get_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieve a Hybrid Connection in use in an App Service plan. + + Description for Retrieve a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> None: + """Delete a Hybrid Connection in use in an App Service plan. + + Description for Delete a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connection_keys( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnectionKey": + """Get the send key name and value of a Hybrid Connection. + + Description for Get the send key name and value of a Hybrid Connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: The name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionKey, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnectionKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connection_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connection_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/listKeys'} # type: ignore + + def list_web_apps_by_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceCollection"]: + """Get all apps that use a Hybrid Connection in an App Service Plan. + + Description for Get all apps that use a Hybrid Connection in an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Hybrid Connection namespace. + :type namespace_name: str + :param relay_name: Name of the Hybrid Connection relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps_by_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps_by_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/sites'} # type: ignore + + async def get_hybrid_connection_plan_limit( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HybridConnectionLimits": + """Get the maximum number of Hybrid Connections allowed in an App Service plan. + + Description for Get the maximum number of Hybrid Connections allowed in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionLimits, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnectionLimits + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionLimits"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_plan_limit.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionLimits', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_plan_limit.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionPlanLimits/limit'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.HybridConnectionCollection"]: + """Retrieve all Hybrid Connections in use in an App Service plan. + + Description for Retrieve all Hybrid Connections in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HybridConnectionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.HybridConnectionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HybridConnectionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionRelays'} # type: ignore + + async def restart_web_apps( + self, + resource_group_name: str, + name: str, + soft_restart: Optional[bool] = None, + **kwargs + ) -> None: + """Restart all apps in an App Service plan. + + Description for Restart all apps in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param soft_restart: Specify :code:`true` to perform a soft restart, applies the + configuration settings and restarts the apps if necessary. The default is + :code:`false`, which always restarts and reprovisions the apps. + :type soft_restart: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/restartSites'} # type: ignore + + def list_web_apps( + self, + resource_group_name: str, + name: str, + skip_token: Optional[str] = None, + filter: Optional[str] = None, + top: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps associated with an App Service plan. + + Description for Get all apps associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param skip_token: Skip to a web app in the list of webapps associated with app service plan. + If specified, the resulting list will contain web apps starting from (including) the skipToken. + Otherwise, the resulting list contains web apps from the start of the list. + :type skip_token: str + :param filter: Supported filter: $filter=state eq running. Returns only web apps that are + currently running. + :type filter: str + :param top: List page size. If specified, results are paged. + :type top: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if skip_token is not None: + query_parameters['$skipToken'] = self._serialize.query("skip_token", skip_token, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/sites'} # type: ignore + + async def get_server_farm_skus( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> object: + """Gets all selectable SKUs for a given App Service Plan. + + Description for Gets all selectable SKUs for a given App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: object, or the result of cls(response) + :rtype: object + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_server_farm_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_server_farm_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/skus'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets server farm usage information. + + Description for Gets server farm usage information. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2'). + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/usages'} # type: ignore + + async def list_vnets( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Get all Virtual Networks associated with an App Service plan. + + Description for Get all Virtual Networks associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_from_server_farm( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> Optional["_models.VnetInfo"]: + """Get a Virtual Network associated with an App Service plan. + + Description for Get a Virtual Network associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_from_server_farm.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_from_server_farm.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + **kwargs + ) -> "_models.VnetGateway": + """Get a Virtual Network gateway. + + Description for Get a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Update a Virtual Network gateway. + + Description for Update a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :param connection_envelope: Definition of the gateway. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def list_routes_for_vnet( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> List["_models.VnetRoute"]: + """Get all routes that are associated with a Virtual Network in an App Service plan. + + Description for Get all routes that are associated with a Virtual Network in an App Service + plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_routes_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_routes_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes'} # type: ignore + + async def get_route_for_vnet( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + **kwargs + ) -> Optional[List["_models.VnetRoute"]]: + """Get a Virtual Network route in an App Service plan. + + Description for Get a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[List["_models.VnetRoute"]]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_route_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_route_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def create_or_update_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + route: "_models.VnetRoute", + **kwargs + ) -> Optional["_models.VnetRoute"]: + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_06_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def delete_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + **kwargs + ) -> None: + """Delete a Virtual Network route in an App Service plan. + + Description for Delete a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def update_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + route: "_models.VnetRoute", + **kwargs + ) -> Optional["_models.VnetRoute"]: + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_06_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def reboot_worker( + self, + resource_group_name: str, + name: str, + worker_name: str, + **kwargs + ) -> None: + """Reboot a worker machine in an App Service plan. + + Description for Reboot a worker machine in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param worker_name: Name of worker machine, which typically starts with RD. + :type worker_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reboot_worker.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerName': self._serialize.url("worker_name", worker_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot_worker.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/workers/{workerName}/reboot'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificate_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificate_registration_provider_operations.py new file mode 100644 index 000000000000..9c37dd92c6b1 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificate_registration_provider_operations.py @@ -0,0 +1,108 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class CertificateRegistrationProviderOperations: + """CertificateRegistrationProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.CertificateRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificates_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificates_operations.py new file mode 100644 index 000000000000..e0fbf6dbd315 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_certificates_operations.py @@ -0,0 +1,441 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class CertificatesOperations: + """CertificatesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.CertificateCollection"]: + """Get all certificates for a subscription. + + Description for Get all certificates for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/certificates'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.CertificateCollection"]: + """Get all certificates in a resource group. + + Description for Get all certificates in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.Certificate": + """Get a certificate. + + Description for Get a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + name: str, + certificate_envelope: "_models.Certificate", + **kwargs + ) -> "_models.Certificate": + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_06_01.models.Certificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'Certificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Delete a certificate. + + Description for Delete a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + certificate_envelope: "_models.CertificatePatchResource", + **kwargs + ) -> "_models.Certificate": + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_06_01.models.CertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'CertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_deleted_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_deleted_web_apps_operations.py new file mode 100644 index 000000000000..ea7bc96b055c --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_deleted_web_apps_operations.py @@ -0,0 +1,245 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DeletedWebAppsOperations: + """DeletedWebAppsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.DeletedWebAppCollection"]: + """Get all deleted apps for a subscription. + + Description for Get all deleted apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deletedSites'} # type: ignore + + def list_by_location( + self, + location: str, + **kwargs + ) -> AsyncIterable["_models.DeletedWebAppCollection"]: + """Get all deleted apps for a subscription at location. + + Description for Get all deleted apps for a subscription at location. + + :param location: + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites'} # type: ignore + + async def get_deleted_web_app_by_location( + self, + location: str, + deleted_site_id: str, + **kwargs + ) -> "_models.DeletedSite": + """Get deleted app for a subscription at location. + + Description for Get deleted app for a subscription at location. + + :param location: + :type location: str + :param deleted_site_id: The numeric ID of the deleted app, e.g. 12345. + :type deleted_site_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeletedSite, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DeletedSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deleted_web_app_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'deletedSiteId': self._serialize.url("deleted_site_id", deleted_site_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeletedSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deleted_web_app_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites/{deletedSiteId}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_diagnostics_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_diagnostics_operations.py new file mode 100644 index 000000000000..f9da6107d42c --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_diagnostics_operations.py @@ -0,0 +1,1774 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +import datetime +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DiagnosticsOperations: + """DiagnosticsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_hosting_environment_detector_responses( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Hosting Environment Detector Responses. + + Description for List Hosting Environment Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hosting_environment_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_hosting_environment_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors'} # type: ignore + + async def get_hosting_environment_detector_response( + self, + resource_group_name: str, + name: str, + detector_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get Hosting Environment Detector Response. + + Description for Get Hosting Environment Detector Response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: App Service Environment Name. + :type name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hosting_environment_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hosting_environment_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors/{detectorName}'} # type: ignore + + def list_site_detector_responses( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors'} # type: ignore + + async def get_site_detector_response( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticCategoryCollection"]: + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics'} # type: ignore + + async def get_site_diagnostic_category( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> "_models.DiagnosticCategory": + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticAnalysisCollection"]: + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_analyses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + async def get_site_analysis( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + **kwargs + ) -> "_models.AnalysisDefinition": + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + async def execute_site_analysis( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticAnalysis": + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticDetectorCollection"]: + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detectors.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + async def get_site_detector( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + detector_name: str, + **kwargs + ) -> "_models.DetectorDefinition": + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + async def execute_site_detector( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + diagnostic_category: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticDetectorResponse": + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore + + def list_site_detector_responses_slot( + self, + resource_group_name: str, + site_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detector_responses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors'} # type: ignore + + async def get_site_detector_response_slot( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories_slot( + self, + resource_group_name: str, + site_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticCategoryCollection"]: + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics'} # type: ignore + + async def get_site_diagnostic_category_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> "_models.DiagnosticCategory": + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticAnalysisCollection"]: + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_analyses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + async def get_site_analysis_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + slot: str, + **kwargs + ) -> "_models.AnalysisDefinition": + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :param slot: Slot - optional. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + async def execute_site_analysis_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticAnalysis": + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticDetectorCollection"]: + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detectors_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + async def get_site_detector_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + detector_name: str, + slot: str, + **kwargs + ) -> "_models.DetectorDefinition": + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + async def execute_site_detector_slot( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + diagnostic_category: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticDetectorResponse": + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domain_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domain_registration_provider_operations.py new file mode 100644 index 000000000000..bb3043ec7a35 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domain_registration_provider_operations.py @@ -0,0 +1,108 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DomainRegistrationProviderOperations: + """DomainRegistrationProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.DomainRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domains_operations.py new file mode 100644 index 000000000000..adac89038081 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_domains_operations.py @@ -0,0 +1,1119 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DomainsOperations: + """DomainsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def check_availability( + self, + identifier: "_models.NameIdentifier", + **kwargs + ) -> "_models.DomainAvailabilityCheckResult": + """Check if a domain is available for registration. + + Description for Check if a domain is available for registration. + + :param identifier: Name of the domain. + :type identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainAvailabilityCheckResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainAvailabilityCheckResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainAvailabilityCheckResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainAvailabilityCheckResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/checkDomainAvailability'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.DomainCollection"]: + """Get all domains in a subscription. + + Description for Get all domains in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + async def get_control_center_sso_request( + self, + **kwargs + ) -> "_models.DomainControlCenterSsoRequest": + """Generate a single sign-on request for the domain management portal. + + Description for Generate a single sign-on request for the domain management portal. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainControlCenterSsoRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainControlCenterSsoRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainControlCenterSsoRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_control_center_sso_request.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainControlCenterSsoRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_control_center_sso_request.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/generateSsoRequest'} # type: ignore + + def list_recommendations( + self, + parameters: "_models.DomainRecommendationSearchParameters", + **kwargs + ) -> AsyncIterable["_models.NameIdentifierCollection"]: + """Get domain name recommendations based on keywords. + + Description for Get domain name recommendations based on keywords. + + :param parameters: Search parameters for domain name recommendations. + :type parameters: ~azure.mgmt.web.v2020_06_01.models.DomainRecommendationSearchParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NameIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.NameIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NameIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommendations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NameIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommendations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/listDomainRecommendations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.DomainCollection"]: + """Get all domains in a resource group. + + Description for Get all domains in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + async def get( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> "_models.Domain": + """Get a domain. + + Description for Get a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.Domain", + **kwargs + ) -> "_models.Domain": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'Domain') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.Domain", + **kwargs + ) -> AsyncLROPoller["_models.Domain"]: + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_06_01.models.Domain + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Domain or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.Domain] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + domain_name=domain_name, + domain=domain, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + domain_name: str, + force_hard_delete_domain: Optional[bool] = None, + **kwargs + ) -> None: + """Delete a domain. + + Description for Delete a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param force_hard_delete_domain: Specify :code:`true` to delete the domain + immediately. The default is :code:`false` which deletes the domain after 24 hours. + :type force_hard_delete_domain: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_hard_delete_domain is not None: + query_parameters['forceHardDeleteDomain'] = self._serialize.query("force_hard_delete_domain", force_hard_delete_domain, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.DomainPatchResource", + **kwargs + ) -> "_models.Domain": + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_06_01.models.DomainPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'DomainPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def list_ownership_identifiers( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> AsyncIterable["_models.DomainOwnershipIdentifierCollection"]: + """Lists domain ownership identifiers. + + Description for Lists domain ownership identifiers. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainOwnershipIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainOwnershipIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers'} # type: ignore + + async def get_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Get ownership identifier for domain. + + Description for Get ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def create_or_update_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + domain_ownership_identifier: "_models.DomainOwnershipIdentifier", + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def delete_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + **kwargs + ) -> None: + """Delete ownership identifier for domain. + + Description for Delete ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def update_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + domain_ownership_identifier: "_models.DomainOwnershipIdentifier", + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def renew( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> None: + """Renew a domain. + + Description for Renew a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/renew'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_provider_operations.py new file mode 100644 index 000000000000..77e77cd8e645 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_provider_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ProviderOperations: + """ProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_available_stacks( + self, + os_type_selected: Optional[Union[str, "_models.Enum4"]] = None, + **kwargs + ) -> AsyncIterable["_models.ApplicationStackCollection"]: + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_06_01.models.Enum4 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_available_stacks.metadata = {'url': '/providers/Microsoft.Web/availableStacks'} # type: ignore + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Gets all available operations for the Microsoft.Web resource provider. Also exposes resource metric definitions. + + Description for Gets all available operations for the Microsoft.Web resource provider. Also + exposes resource metric definitions. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Web/operations'} # type: ignore + + def get_available_stacks_on_prem( + self, + os_type_selected: Optional[Union[str, "_models.Enum5"]] = None, + **kwargs + ) -> AsyncIterable["_models.ApplicationStackCollection"]: + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_06_01.models.Enum5 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks_on_prem.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_available_stacks_on_prem.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/availableStacks'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_recommendations_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_recommendations_operations.py new file mode 100644 index 000000000000..28d69824079b --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_recommendations_operations.py @@ -0,0 +1,1109 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class RecommendationsOperations: + """RecommendationsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """List all recommendations for a subscription. + + Description for List all recommendations for a subscription. + + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations'} # type: ignore + + async def reset_all_filters( + self, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for a subscription. + + Description for Reset all recommendation opt-out settings for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/reset'} # type: ignore + + async def disable_recommendation_for_subscription( + self, + name: str, + **kwargs + ) -> None: + """Disables the specified rule so it will not apply to a subscription in the future. + + Description for Disables the specified rule so it will not apply to a subscription in the + future. + + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/{name}/disable'} # type: ignore + + def list_history_for_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + expired_only: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_history_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get all recommendations for a hosting environment. + + Description for Get all recommendations for a hosting environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the app. + :type hosting_environment_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations'} # type: ignore + + async def disable_all_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/disable'} # type: ignore + + async def reset_all_filters_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/reset'} # type: ignore + + async def get_rule_details_by_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + name: str, + update_seen: Optional[bool] = None, + recommendation_id: Optional[str] = None, + **kwargs + ) -> "_models.RecommendationRule": + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}'} # type: ignore + + async def disable_recommendation_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Site name. + :type environment_name: str + :param name: Rule name. + :type name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}/disable'} # type: ignore + + def list_history_for_web_app( + self, + resource_group_name: str, + site_name: str, + expired_only: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_history_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_web_app( + self, + resource_group_name: str, + site_name: str, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get all recommendations for an app. + + Description for Get all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations'} # type: ignore + + async def disable_all_for_web_app( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> None: + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/disable'} # type: ignore + + async def reset_all_filters_for_web_app( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/reset'} # type: ignore + + async def get_rule_details_by_web_app( + self, + resource_group_name: str, + site_name: str, + name: str, + update_seen: Optional[bool] = None, + recommendation_id: Optional[str] = None, + **kwargs + ) -> "_models.RecommendationRule": + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}'} # type: ignore + + async def disable_recommendation_for_site( + self, + resource_group_name: str, + site_name: str, + name: str, + **kwargs + ) -> None: + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site name. + :type site_name: str + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}/disable'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_resource_health_metadata_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_resource_health_metadata_operations.py new file mode 100644 index 000000000000..d932503b923f --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_resource_health_metadata_operations.py @@ -0,0 +1,471 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ResourceHealthMetadataOperations: + """ResourceHealthMetadataOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """List all ResourceHealthMetadata for all sites in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """List all ResourceHealthMetadata for all sites in the resource group in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the resource group in the + subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata'} # type: ignore + + async def get_by_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.ResourceHealthMetadata": + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata/default'} # type: ignore + + def list_by_site_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata'} # type: ignore + + async def get_by_site_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.ResourceHealthMetadata": + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata/default'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_static_sites_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_static_sites_operations.py new file mode 100644 index 000000000000..3ced26168c40 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_static_sites_operations.py @@ -0,0 +1,1913 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class StaticSitesOperations: + """StaticSitesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def preview_workflow( + self, + location: str, + static_sites_workflow_preview_request: "_models.StaticSitesWorkflowPreviewRequest", + **kwargs + ) -> "_models.StaticSitesWorkflowPreview": + """Generates a preview workflow file for the static site. + + Description for Generates a preview workflow file for the static site. + + :param location: Location where you plan to create the static site. + :type location: str + :param static_sites_workflow_preview_request: A JSON representation of the + StaticSitesWorkflowPreviewRequest properties. See example. + :type static_sites_workflow_preview_request: ~azure.mgmt.web.v2020_06_01.models.StaticSitesWorkflowPreviewRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSitesWorkflowPreview, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSitesWorkflowPreview + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSitesWorkflowPreview"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.preview_workflow.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_sites_workflow_preview_request, 'StaticSitesWorkflowPreviewRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSitesWorkflowPreview', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + preview_workflow.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/previewStaticSiteWorkflowFile'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCollection"]: + """Get all Static Sites for a subscription. + + Description for Get all Static Sites for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_sites_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCollection"]: + """Gets all static sites in the specified resource group. + + Description for Gets all static sites in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_sites_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_static_sites_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites'} # type: ignore + + async def get_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StaticSiteARMResource": + """Gets the details of a static site. + + Description for Gets the details of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def create_or_update_static_site( + self, + resource_group_name: str, + name: str, + static_site_envelope: "_models.StaticSiteARMResource", + **kwargs + ) -> "_models.StaticSiteARMResource": + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSiteARMResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def delete_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes a static site. + + Description for Deletes a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to delete. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def update_static_site( + self, + resource_group_name: str, + name: str, + static_site_envelope: "_models.StaticSitePatchResource", + **kwargs + ) -> "_models.StaticSiteARMResource": + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def list_static_site_users( + self, + resource_group_name: str, + name: str, + authprovider: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteUserCollection"]: + """Gets the list of users of a static site. + + Description for Gets the list of users of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for the users. + :type authprovider: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteUserCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteUserCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_users.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteUserCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_users.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/listUsers'} # type: ignore + + async def delete_static_site_user( + self, + resource_group_name: str, + name: str, + authprovider: str, + userid: str, + **kwargs + ) -> None: + """Deletes the user entry from the static site. + + Description for Deletes the user entry from the static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the staticsite. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + async def update_static_site_user( + self, + resource_group_name: str, + name: str, + authprovider: str, + userid: str, + static_site_user_envelope: "_models.StaticSiteUserARMResource", + **kwargs + ) -> "_models.StaticSiteUserARMResource": + """Updates a user entry with the listed roles. + + Description for Updates a user entry with the listed roles. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :param static_site_user_envelope: A JSON representation of the StaticSiteUser properties. See + example. + :type static_site_user_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_envelope, 'StaticSiteUserARMResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def get_static_site_builds( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteBuildCollection"]: + """Gets all static site builds for a particular static site. + + Description for Gets all static site builds for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteBuildCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_site_builds.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteBuildCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_static_site_builds.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds'} # type: ignore + + async def get_static_site_build( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> "_models.StaticSiteBuildARMResource": + """Gets the details of a static site build. + + Description for Gets the details of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteBuildARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteBuildARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + async def delete_static_site_build( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> None: + """Deletes a static site build. + + Description for Deletes a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + async def create_or_update_static_site_build_function_app_settings( + self, + resource_group_name: str, + name: str, + pr_id: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Creates or updates the function app settings of a static site build. + + Description for Creates or updates the function app settings of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/config/functionappsettings'} # type: ignore + + def list_static_site_build_functions( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteFunctionOverviewCollection"]: + """Gets the functions of a particular static site build. + + Description for Gets the functions of a particular static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_build_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_build_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/functions'} # type: ignore + + async def list_static_site_build_function_app_settings( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/listFunctionAppSettings'} # type: ignore + + async def create_or_update_static_site_function_app_settings( + self, + resource_group_name: str, + name: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Creates or updates the function app settings of a static site. + + Description for Creates or updates the function app settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/config/functionappsettings'} # type: ignore + + async def create_user_roles_invitation_link( + self, + resource_group_name: str, + name: str, + static_site_user_roles_invitation_envelope: "_models.StaticSiteUserInvitationRequestResource", + **kwargs + ) -> "_models.StaticSiteUserInvitationResponseResource": + """Creates an invitation link for a user with the role. + + Description for Creates an invitation link for a user with the role. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param static_site_user_roles_invitation_envelope: + :type static_site_user_roles_invitation_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserInvitationRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserInvitationResponseResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserInvitationResponseResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserInvitationResponseResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_user_roles_invitation_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_roles_invitation_envelope, 'StaticSiteUserInvitationRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserInvitationResponseResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_user_roles_invitation_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/createUserInvitation'} # type: ignore + + def list_static_site_custom_domains( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCustomDomainOverviewCollection"]: + """Gets all static site custom domains for a particular static site. + + Description for Gets all static site custom domains for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site resource to search in. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCustomDomainOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_custom_domains.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCustomDomainOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_custom_domains.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains'} # type: ignore + + async def create_or_update_static_site_custom_domain( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> "_models.StaticSiteCustomDomainOverviewARMResource": + """Creates a new static site custom domain in an existing resource group and static site. + + Description for Creates a new static site custom domain in an existing resource group and + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to create. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteCustomDomainOverviewARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + async def delete_static_site_custom_domain( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> None: + """Deletes a custom domain. + + Description for Deletes a custom domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to delete. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + async def validate_custom_domain_can_be_added_to_static_site( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> None: + """Validates a particular custom domain can be added to a static site. + + Description for Validates a particular custom domain can be added to a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to validate. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.validate_custom_domain_can_be_added_to_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_custom_domain_can_be_added_to_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}/validate'} # type: ignore + + async def detach_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Detaches a static site. + + Description for Detaches a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to detach. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.detach_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + detach_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/detach'} # type: ignore + + def list_static_site_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteFunctionOverviewCollection"]: + """Gets the functions of a static site. + + Description for Gets the functions of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/functions'} # type: ignore + + async def list_static_site_function_app_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listFunctionAppSettings'} # type: ignore + + async def list_static_site_secrets( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Lists the secrets for an existing static site. + + Description for Lists the secrets for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listSecrets'} # type: ignore + + async def reset_static_site_api_key( + self, + resource_group_name: str, + name: str, + reset_properties_envelope: "_models.StaticSiteResetPropertiesARMResource", + **kwargs + ) -> None: + """Resets the api key for an existing static site. + + Description for Resets the api key for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param reset_properties_envelope: + :type reset_properties_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteResetPropertiesARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reset_static_site_api_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reset_properties_envelope, 'StaticSiteResetPropertiesARMResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_static_site_api_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/resetapikey'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_top_level_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_top_level_domains_operations.py new file mode 100644 index 000000000000..260d00029530 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_top_level_domains_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class TopLevelDomainsOperations: + """TopLevelDomainsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.TopLevelDomainCollection"]: + """Get all top-level domains supported for registration. + + Description for Get all top-level domains supported for registration. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TopLevelDomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TopLevelDomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TopLevelDomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains'} # type: ignore + + async def get( + self, + name: str, + **kwargs + ) -> "_models.TopLevelDomain": + """Get details of a top-level domain. + + Description for Get details of a top-level domain. + + :param name: Name of the top-level domain. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TopLevelDomain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TopLevelDomain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TopLevelDomain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}'} # type: ignore + + def list_agreements( + self, + name: str, + agreement_option: "_models.TopLevelDomainAgreementOption", + **kwargs + ) -> AsyncIterable["_models.TldLegalAgreementCollection"]: + """Gets all legal agreements that user needs to accept before purchasing a domain. + + Description for Gets all legal agreements that user needs to accept before purchasing a domain. + + :param name: Name of the top-level domain. + :type name: str + :param agreement_option: Domain agreement options. + :type agreement_option: ~azure.mgmt.web.v2020_06_01.models.TopLevelDomainAgreementOption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TldLegalAgreementCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TldLegalAgreementCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TldLegalAgreementCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_agreements.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TldLegalAgreementCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_agreements.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}/listAgreements'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_apps_operations.py new file mode 100644 index 000000000000..4adb40f2092d --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_apps_operations.py @@ -0,0 +1,28546 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, IO, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class WebAppsOperations: + """WebAppsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps for a subscription. + + Description for Get all apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/sites'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + include_slots: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Gets all web, mobile, and API apps in the specified resource group. + + Description for Gets all web, mobile, and API apps in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param include_slots: Specify :code:`true` to include deployment slots in + results. The default is false, which only gives you the production slot of all apps. + :type include_slots: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if include_slots is not None: + query_parameters['includeSlots'] = self._serialize.query("include_slots", include_slots, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.Site"]: + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.Site", + **kwargs + ) -> "_models.Site": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.Site", + **kwargs + ) -> AsyncLROPoller["_models.Site"]: + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + delete_metrics: Optional[bool] = None, + delete_empty_server_farm: Optional[bool] = None, + **kwargs + ) -> None: + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify false if you want to keep empty App Service plan. By + default, empty App Service plan is deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.SitePatchResource", + **kwargs + ) -> "_models.Site": + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def analyze_custom_hostname( + self, + resource_group_name: str, + name: str, + host_name: Optional[str] = None, + **kwargs + ) -> "_models.CustomHostnameAnalysisResult": + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/analyzeCustomHostname'} # type: ignore + + async def apply_slot_config_to_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_config_to_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_config_to_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/applySlotConfig'} # type: ignore + + async def backup( + self, + resource_group_name: str, + name: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backup'} # type: ignore + + def list_backups( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups'} # type: ignore + + async def get_backup_status( + self, + resource_group_name: str, + name: str, + backup_id: str, + **kwargs + ) -> "_models.BackupItem": + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + async def delete_backup( + self, + resource_group_name: str, + name: str, + backup_id: str, + **kwargs + ) -> None: + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + async def list_backup_status_secrets( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/list'} # type: ignore + + async def _restore_initial( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + async def begin_restore( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + async def get_basic_publishing_credentials_policies( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesCollection": + """Returns whether Scm basic auth is allowed and whether Ftp is allowed for a given site. + + Description for Returns whether Scm basic auth is allowed and whether Ftp is allowed for a + given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesCollection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesCollection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_basic_publishing_credentials_policies.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_basic_publishing_credentials_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies'} # type: ignore + + async def get_ftp_allowed( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Returns whether FTP is allowed on the site or not. + + Description for Returns whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + async def update_ftp_allowed( + self, + resource_group_name: str, + name: str, + csm_publishing_access_policies_entity: "_models.CsmPublishingCredentialsPoliciesEntity", + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Updates whether FTP is allowed on the site or not. + + Description for Updates whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + async def get_scm_allowed( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Returns whether Scm basic auth is allowed on the site or not. + + Description for Returns whether Scm basic auth is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + async def update_scm_allowed( + self, + resource_group_name: str, + name: str, + csm_publishing_access_policies_entity: "_models.CsmPublishingCredentialsPoliciesEntity", + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Updates whether user publishing credentials are allowed on the site or not. + + Description for Updates whether user publishing credentials are allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def list_configurations( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigResourceCollection"]: + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config'} # type: ignore + + async def update_application_settings( + self, + resource_group_name: str, + name: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings'} # type: ignore + + async def list_application_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings/list'} # type: ignore + + async def update_auth_settings( + self, + resource_group_name: str, + name: str, + site_auth_settings: "_models.SiteAuthSettings", + **kwargs + ) -> "_models.SiteAuthSettings": + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings'} # type: ignore + + async def get_auth_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteAuthSettings": + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings/list'} # type: ignore + + async def update_auth_settings_v2( + self, + resource_group_name: str, + name: str, + site_auth_settings_v2: "_models.SiteAuthSettingsV2", + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2'} # type: ignore + + async def get_auth_settings_v2( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2/list'} # type: ignore + + async def update_azure_storage_accounts( + self, + resource_group_name: str, + name: str, + azure_storage_accounts: "_models.AzureStoragePropertyDictionaryResource", + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts'} # type: ignore + + async def list_azure_storage_accounts( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts/list'} # type: ignore + + async def update_backup_configuration( + self, + resource_group_name: str, + name: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupRequest": + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + async def delete_backup_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + async def get_backup_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.BackupRequest": + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup/list'} # type: ignore + + async def update_connection_strings( + self, + resource_group_name: str, + name: str, + connection_strings: "_models.ConnectionStringDictionary", + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings'} # type: ignore + + async def list_connection_strings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings/list'} # type: ignore + + async def get_diagnostic_logs_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteLogsConfig": + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + async def update_diagnostic_logs_config( + self, + resource_group_name: str, + name: str, + site_logs_config: "_models.SiteLogsConfig", + **kwargs + ) -> "_models.SiteLogsConfig": + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + async def update_metadata( + self, + resource_group_name: str, + name: str, + metadata: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata'} # type: ignore + + async def list_metadata( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata/list'} # type: ignore + + async def _list_publishing_credentials_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.User": + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + async def begin_list_publishing_credentials( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller["_models.User"]: + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._list_publishing_credentials_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + async def update_site_push_settings( + self, + resource_group_name: str, + name: str, + push_settings: "_models.PushSettings", + **kwargs + ) -> "_models.PushSettings": + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings'} # type: ignore + + async def list_site_push_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PushSettings": + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings/list'} # type: ignore + + async def list_slot_configuration_names( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SlotConfigNamesResource": + """Gets the names of app settings and connection strings that stick to the slot (not swapped). + + Description for Gets the names of app settings and connection strings that stick to the slot + (not swapped). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + async def update_slot_configuration_names( + self, + resource_group_name: str, + name: str, + slot_config_names: "_models.SlotConfigNamesResource", + **kwargs + ) -> "_models.SlotConfigNamesResource": + """Updates the names of application settings and connection string that remain with the slot during swap operation. + + Description for Updates the names of application settings and connection string that remain + with the slot during swap operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_config_names: Names of application settings and connection strings. See example. + :type slot_config_names: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_config_names, 'SlotConfigNamesResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + async def get_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + async def create_or_update_configuration( + self, + resource_group_name: str, + name: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + async def update_configuration( + self, + resource_group_name: str, + name: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def list_configuration_snapshot_info( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigurationSnapshotInfoCollection"]: + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots'} # type: ignore + + async def get_configuration_snapshot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}'} # type: ignore + + async def recover_site_configuration_snapshot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + **kwargs + ) -> None: + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + async def get_web_site_container_logs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional[IO]: + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs'} # type: ignore + + async def get_container_logs_zip( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional[IO]: + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ContinuousWebJobCollection"]: + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs'} # type: ignore + + async def get_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> Optional["_models.ContinuousWebJob"]: + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + async def delete_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + async def start_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/start'} # type: ignore + + async def stop_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.DeploymentCollection"]: + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_deployments.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments'} # type: ignore + + async def get_deployment( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> "_models.Deployment": + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def create_deployment( + self, + resource_group_name: str, + name: str, + id: str, + deployment: "_models.Deployment", + **kwargs + ) -> "_models.Deployment": + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_06_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def delete_deployment( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> None: + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def list_deployment_log( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> "_models.Deployment": + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}/log'} # type: ignore + + async def discover_backup( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> "_models.RestoreRequest": + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers'} # type: ignore + + async def get_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + **kwargs + ) -> "_models.Identifier": + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def create_or_update_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def delete_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + **kwargs + ) -> None: + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def update_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def get_ms_deploy_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def _create_ms_deploy_operation_initial( + self, + resource_group_name: str, + name: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def begin_create_ms_deploy_operation( + self, + resource_group_name: str, + name: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def get_ms_deploy_log( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy/log'} # type: ignore + + def list_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.FunctionEnvelopeCollection"]: + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions'} # type: ignore + + async def get_functions_admin_token( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> str: + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/admin/token'} # type: ignore + + async def get_function( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> Optional["_models.FunctionEnvelope"]: + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def _create_function_initial( + self, + resource_group_name: str, + name: str, + function_name: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> "_models.FunctionEnvelope": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_function_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_function_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def begin_create_function( + self, + resource_group_name: str, + name: str, + function_name: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> AsyncLROPoller["_models.FunctionEnvelope"]: + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_function_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def delete_function( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> None: + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def create_or_update_function_secret( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def delete_function_secret( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + **kwargs + ) -> None: + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def list_function_keys( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> "_models.StringDictionary": + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listkeys'} # type: ignore + + async def list_function_secrets( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> "_models.FunctionSecrets": + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listsecrets'} # type: ignore + + async def list_host_keys( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HostKeys": + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listkeys'} # type: ignore + + async def list_sync_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listsyncstatus'} # type: ignore + + async def sync_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/sync'} # type: ignore + + async def create_or_update_host_secret( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + async def delete_host_secret( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + **kwargs + ) -> None: + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.HostNameBindingCollection"]: + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_host_name_bindings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings'} # type: ignore + + async def get_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + **kwargs + ) -> "_models.HostNameBinding": + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def create_or_update_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + host_name_binding: "_models.HostNameBinding", + **kwargs + ) -> "_models.HostNameBinding": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def delete_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def get_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def create_or_update_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> None: + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def update_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionRelays'} # type: ignore + + async def list_relay_service_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection'} # type: ignore + + async def get_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def create_or_update_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def delete_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + **kwargs + ) -> None: + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def update_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebAppInstanceStatusCollection"]: + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances'} # type: ignore + + async def get_instance_info( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> "_models.WebSiteInstanceStatus": + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}'} # type: ignore + + async def get_instance_ms_deploy_status( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def _create_instance_ms_deploy_operation_initial( + self, + resource_group_name: str, + name: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def begin_create_instance_ms_deploy_operation( + self, + resource_group_name: str, + name: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def get_instance_ms_deploy_log( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes'} # type: ignore + + async def get_instance_process( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def delete_instance_process( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def get_instance_process_dump( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + async def get_instance_process_module( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + async def is_cloneable( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteCloneability": + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/iscloneable'} # type: ignore + + def list_site_backups( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listbackups'} # type: ignore + + async def list_sync_function_triggers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.FunctionSecrets": + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listsyncfunctiontriggerstatus'} # type: ignore + + async def _migrate_storage_initial( + self, + subscription_name: str, + resource_group_name: str, + name: str, + migration_options: "_models.StorageMigrationOptions", + **kwargs + ) -> "_models.StorageMigrationResponse": + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_storage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['subscriptionName'] = self._serialize.query("subscription_name", subscription_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_options, 'StorageMigrationOptions') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_storage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + async def begin_migrate_storage( + self, + subscription_name: str, + resource_group_name: str, + name: str, + migration_options: "_models.StorageMigrationOptions", + **kwargs + ) -> AsyncLROPoller["_models.StorageMigrationResponse"]: + """Restores a web app. + + Description for Restores a web app. + + :param subscription_name: Azure subscription. + :type subscription_name: str + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_options: Migration migrationOptions. + :type migration_options: ~azure.mgmt.web.v2020_06_01.models.StorageMigrationOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either StorageMigrationResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.StorageMigrationResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._migrate_storage_initial( + subscription_name=subscription_name, + resource_group_name=resource_group_name, + name=name, + migration_options=migration_options, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_storage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + async def _migrate_my_sql_initial( + self, + resource_group_name: str, + name: str, + migration_request_envelope: "_models.MigrateMySqlRequest", + **kwargs + ) -> "_models.Operation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_my_sql_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_request_envelope, 'MigrateMySqlRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_my_sql_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + async def begin_migrate_my_sql( + self, + resource_group_name: str, + name: str, + migration_request_envelope: "_models.MigrateMySqlRequest", + **kwargs + ) -> AsyncLROPoller["_models.Operation"]: + """Migrates a local (in-app) MySql database to a remote MySql database. + + Description for Migrates a local (in-app) MySql database to a remote MySql database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_request_envelope: MySql migration options. + :type migration_request_envelope: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Operation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.Operation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._migrate_my_sql_initial( + resource_group_name=resource_group_name, + name=name, + migration_request_envelope=migration_request_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_my_sql.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + async def get_migrate_my_sql_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.MigrateMySqlStatus": + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql/status'} # type: ignore + + async def get_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def create_or_update_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def delete_swift_virtual_network( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def update_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def list_network_features( + self, + resource_group_name: str, + name: str, + view: str, + **kwargs + ) -> Optional["_models.NetworkFeatures"]: + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkFeatures/{view}'} # type: ignore + + async def get_network_trace_operation( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/operationresults/{operationId}'} # type: ignore + + async def start_web_site_network_trace( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> str: + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/start'} # type: ignore + + async def _start_web_site_network_trace_operation_initial( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + async def begin_start_web_site_network_trace_operation( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_web_site_network_trace_operation_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + async def stop_web_site_network_trace( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/stop'} # type: ignore + + async def get_network_traces( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/{operationId}'} # type: ignore + + async def get_network_trace_operation_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + async def get_network_traces_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/{operationId}'} # type: ignore + + async def generate_new_site_publishing_password( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/newpassword'} # type: ignore + + def list_perf_mon_counters( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PerfMonCounterCollection"]: + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_perf_mon_counters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/perfcounters'} # type: ignore + + async def get_site_php_error_log_flag( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SitePhpErrorLogFlag": + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/phplogging'} # type: ignore + + async def list_premier_add_ons( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons'} # type: ignore + + async def get_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def add_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + premier_add_on: "_models.PremierAddOn", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def delete_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + **kwargs + ) -> None: + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def update_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + premier_add_on: "_models.PremierAddOnPatchResource", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def get_private_access( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PrivateAccess": + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + async def put_private_access_vnet( + self, + resource_group_name: str, + name: str, + access: "_models.PrivateAccess", + **kwargs + ) -> "_models.PrivateAccess": + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def list_processes( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes'} # type: ignore + + async def get_process( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + async def delete_process( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + async def get_process_dump( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/dump'} # type: ignore + + def list_process_modules( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules'} # type: ignore + + async def get_process_module( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.PublicCertificateCollection"]: + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_public_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates'} # type: ignore + + async def get_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + **kwargs + ) -> "_models.PublicCertificate": + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def create_or_update_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + public_certificate: "_models.PublicCertificate", + **kwargs + ) -> "_models.PublicCertificate": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def delete_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def list_publishing_profile_xml_with_secrets( + self, + resource_group_name: str, + name: str, + publishing_profile_options: "_models.CsmPublishingProfileOptions", + **kwargs + ) -> IO: + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publishxml'} # type: ignore + + async def reset_production_slot_config( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_production_slot_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_production_slot_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resetSlotConfig'} # type: ignore + + async def restart( + self, + resource_group_name: str, + name: str, + soft_restart: Optional[bool] = None, + synchronous: Optional[bool] = None, + **kwargs + ) -> None: + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restart'} # type: ignore + + async def _restore_from_backup_blob_initial( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + async def begin_restore_from_backup_blob( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_backup_blob_initial( + resource_group_name=resource_group_name, + name=name, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + async def _restore_from_deleted_app_initial( + self, + resource_group_name: str, + name: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + async def begin_restore_from_deleted_app( + self, + resource_group_name: str, + name: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_deleted_app_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + async def _restore_snapshot_initial( + self, + resource_group_name: str, + name: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + async def begin_restore_snapshot( + self, + resource_group_name: str, + name: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_snapshot_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def list_site_extensions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteExtensionInfoCollection"]: + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_extensions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions'} # type: ignore + + async def get_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _install_site_extension_initial( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def begin_install_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> AsyncLROPoller["_models.SiteExtensionInfo"]: + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._install_site_extension_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def delete_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> None: + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _copy_production_slot_initial( + self, + resource_group_name: str, + name: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_production_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_production_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + async def begin_copy_production_slot( + self, + resource_group_name: str, + name: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_06_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._copy_production_slot_initial( + resource_group_name=resource_group_name, + name=name, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_production_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def list_slots( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Gets an app's deployment slots. + + Description for Gets an app's deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots'} # type: ignore + + async def get_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional["_models.Site"]: + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def _create_or_update_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.Site", + **kwargs + ) -> "_models.Site": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def begin_create_or_update_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.Site", + **kwargs + ) -> AsyncLROPoller["_models.Site"]: + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def delete_slot( + self, + resource_group_name: str, + name: str, + slot: str, + delete_metrics: Optional[bool] = None, + delete_empty_server_farm: Optional[bool] = None, + **kwargs + ) -> None: + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param slot: Name of the deployment slot to delete. By default, the API deletes the production + slot. + :type slot: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify true if the App Service plan will be empty after app + deletion and you want to delete the empty App Service plan. By default, the empty App Service + plan is not deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def update_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.SitePatchResource", + **kwargs + ) -> "_models.Site": + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def analyze_custom_hostname_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: Optional[str] = None, + **kwargs + ) -> "_models.CustomHostnameAnalysisResult": + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/analyzeCustomHostname'} # type: ignore + + async def apply_slot_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/applySlotConfig'} # type: ignore + + async def backup_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + backup for the production slot. + :type slot: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backup'} # type: ignore + + def list_backups_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups'} # type: ignore + + async def get_backup_status_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + **kwargs + ) -> "_models.BackupItem": + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a backup + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + async def delete_backup_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + **kwargs + ) -> None: + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + backup of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + async def list_backup_status_secrets_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/list'} # type: ignore + + async def _restore_slot_initial( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + async def begin_restore_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_slot_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def list_configurations_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigResourceCollection"]: + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configurations_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config'} # type: ignore + + async def update_application_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + application settings for the production slot. + :type slot: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings'} # type: ignore + + async def list_application_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + application settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings/list'} # type: ignore + + async def update_auth_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_auth_settings: "_models.SiteAuthSettings", + **kwargs + ) -> "_models.SiteAuthSettings": + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings'} # type: ignore + + async def get_auth_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteAuthSettings": + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings/list'} # type: ignore + + async def update_auth_settings_v2_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_auth_settings_v2: "_models.SiteAuthSettingsV2", + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2'} # type: ignore + + async def get_auth_settings_v2_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2/list'} # type: ignore + + async def update_azure_storage_accounts_slot( + self, + resource_group_name: str, + name: str, + slot: str, + azure_storage_accounts: "_models.AzureStoragePropertyDictionaryResource", + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts'} # type: ignore + + async def list_azure_storage_accounts_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts/list'} # type: ignore + + async def update_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupRequest": + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + backup configuration for the production slot. + :type slot: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + async def delete_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + async def get_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.BackupRequest": + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup/list'} # type: ignore + + async def update_connection_strings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_strings: "_models.ConnectionStringDictionary", + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + connection settings for the production slot. + :type slot: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings'} # type: ignore + + async def list_connection_strings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + connection settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings/list'} # type: ignore + + async def get_diagnostic_logs_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteLogsConfig": + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + logging configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + async def update_diagnostic_logs_config_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_logs_config: "_models.SiteLogsConfig", + **kwargs + ) -> "_models.SiteLogsConfig": + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + logging configuration for the production slot. + :type slot: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + async def update_metadata_slot( + self, + resource_group_name: str, + name: str, + slot: str, + metadata: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + metadata for the production slot. + :type slot: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata'} # type: ignore + + async def list_metadata_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + metadata for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata/list'} # type: ignore + + async def _list_publishing_credentials_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.User": + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + async def begin_list_publishing_credentials_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncLROPoller["_models.User"]: + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing credentials for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._list_publishing_credentials_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + async def update_site_push_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + push_settings: "_models.PushSettings", + **kwargs + ) -> "_models.PushSettings": + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings'} # type: ignore + + async def list_site_push_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PushSettings": + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings/list'} # type: ignore + + async def get_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + async def create_or_update_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + async def update_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def list_configuration_snapshot_info_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigurationSnapshotInfoCollection"]: + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots'} # type: ignore + + async def get_configuration_snapshot_slot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + slot: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}'} # type: ignore + + async def recover_site_configuration_snapshot_slot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + slot: str, + **kwargs + ) -> None: + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + async def get_web_site_container_logs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs'} # type: ignore + + async def get_container_logs_zip_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ContinuousWebJobCollection"]: + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs'} # type: ignore + + async def get_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> Optional["_models.ContinuousWebJob"]: + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + async def delete_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + async def start_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/start'} # type: ignore + + async def stop_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DeploymentCollection"]: + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_deployments_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments'} # type: ignore + + async def get_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> "_models.Deployment": + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets a deployment + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def create_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + deployment: "_models.Deployment", + **kwargs + ) -> "_models.Deployment": + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API creates a + deployment for the production slot. + :type slot: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_06_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def delete_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> None: + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def list_deployment_log_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> "_models.Deployment": + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}/log'} # type: ignore + + async def discover_backup_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> "_models.RestoreRequest": + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will perform + discovery for the production slot. + :type slot: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers'} # type: ignore + + async def get_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + **kwargs + ) -> "_models.Identifier": + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def create_or_update_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def delete_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def update_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def get_ms_deploy_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def _create_ms_deploy_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def begin_create_ms_deploy_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def get_ms_deploy_log_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_functions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.FunctionEnvelopeCollection"]: + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions'} # type: ignore + + async def get_functions_admin_token_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> str: + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/admin/token'} # type: ignore + + async def get_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> Optional["_models.FunctionEnvelope"]: + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def _create_instance_function_slot_initial( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> "_models.FunctionEnvelope": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_function_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_function_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def begin_create_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> AsyncLROPoller["_models.FunctionEnvelope"]: + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_function_slot_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + slot=slot, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def delete_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def create_or_update_function_secret_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + slot: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def delete_function_secret_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def list_function_keys_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listkeys'} # type: ignore + + async def list_function_secrets_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> "_models.FunctionSecrets": + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listsecrets'} # type: ignore + + async def list_host_keys_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.HostKeys": + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listkeys'} # type: ignore + + async def list_sync_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listsyncstatus'} # type: ignore + + async def sync_functions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/sync'} # type: ignore + + async def create_or_update_host_secret_slot( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + slot: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + async def delete_host_secret_slot( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.HostNameBindingCollection"]: + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_host_name_bindings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings'} # type: ignore + + async def get_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: str, + **kwargs + ) -> "_models.HostNameBinding": + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def create_or_update_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + host_name: str, + slot: str, + host_name_binding: "_models.HostNameBinding", + **kwargs + ) -> "_models.HostNameBinding": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def delete_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def get_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def create_or_update_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + **kwargs + ) -> None: + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def update_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionRelays'} # type: ignore + + async def list_relay_service_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get hybrid + connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection'} # type: ignore + + async def get_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a hybrid + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def create_or_update_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def delete_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + hybrid connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def update_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.WebAppInstanceStatusCollection"]: + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances'} # type: ignore + + async def get_instance_info_slot( + self, + resource_group_name: str, + name: str, + instance_id: str, + slot: str, + **kwargs + ) -> "_models.WebSiteInstanceStatus": + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}'} # type: ignore + + async def get_instance_ms_deploy_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def _create_instance_ms_deploy_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def begin_create_instance_ms_deploy_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def get_instance_ms_deploy_log_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes'} # type: ignore + + async def get_instance_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def delete_instance_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def get_instance_process_dump_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + async def get_instance_process_module_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + async def is_cloneable_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteCloneability": + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns information on the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/iscloneable'} # type: ignore + + def list_site_backups_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listbackups'} # type: ignore + + async def list_sync_function_triggers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.FunctionSecrets": + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listsyncfunctiontriggerstatus'} # type: ignore + + async def get_migrate_my_sql_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.MigrateMySqlStatus": + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/migratemysql/status'} # type: ignore + + async def get_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def create_or_update_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def delete_swift_virtual_network_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def update_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def list_network_features_slot( + self, + resource_group_name: str, + name: str, + view: str, + slot: str, + **kwargs + ) -> Optional["_models.NetworkFeatures"]: + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get network + features for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkFeatures/{view}'} # type: ignore + + async def get_network_trace_operation_slot( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/operationresults/{operationId}'} # type: ignore + + async def start_web_site_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> str: + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/start'} # type: ignore + + async def _start_web_site_network_trace_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + async def begin_start_web_site_network_trace_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_web_site_network_trace_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + async def stop_web_site_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/stop'} # type: ignore + + async def get_network_traces_slot( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/{operationId}'} # type: ignore + + async def get_network_trace_operation_slot_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + async def get_network_traces_slot_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/{operationId}'} # type: ignore + + async def generate_new_site_publishing_password_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API generate a new + publishing password for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/newpassword'} # type: ignore + + def list_perf_mon_counters_slot( + self, + resource_group_name: str, + name: str, + slot: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PerfMonCounterCollection"]: + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_perf_mon_counters_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/perfcounters'} # type: ignore + + async def get_site_php_error_log_flag_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SitePhpErrorLogFlag": + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/phplogging'} # type: ignore + + async def list_premier_add_ons_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + premier add-ons for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons'} # type: ignore + + async def get_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def add_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + premier_add_on: "_models.PremierAddOn", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def delete_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def update_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + premier_add_on: "_models.PremierAddOnPatchResource", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def get_private_access_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PrivateAccess": + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + async def put_private_access_vnet_slot( + self, + resource_group_name: str, + name: str, + slot: str, + access: "_models.PrivateAccess", + **kwargs + ) -> "_models.PrivateAccess": + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + async def get_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> "_models.PrivateEndpointConnectionResource": + """Gets a private endpoint connection. + + Description for Gets a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnectionResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateEndpointConnectionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def _approve_or_reject_private_endpoint_connection_initial( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + private_endpoint_wrapper: "_models.PrivateLinkConnectionApprovalRequestResource", + **kwargs + ) -> "_models.PrivateEndpointConnectionResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._approve_or_reject_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(private_endpoint_wrapper, 'PrivateLinkConnectionApprovalRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _approve_or_reject_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def begin_approve_or_reject_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + private_endpoint_wrapper: "_models.PrivateLinkConnectionApprovalRequestResource", + **kwargs + ) -> AsyncLROPoller["_models.PrivateEndpointConnectionResource"]: + """Approves or rejects a private endpoint connection. + + Description for Approves or rejects a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :param private_endpoint_wrapper: + :type private_endpoint_wrapper: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionApprovalRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either PrivateEndpointConnectionResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.PrivateEndpointConnectionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._approve_or_reject_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + private_endpoint_wrapper=private_endpoint_wrapper, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_approve_or_reject_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def _delete_private_endpoint_connection_initial( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> object: + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._delete_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 204: + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def begin_delete_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> AsyncLROPoller[object]: + """Deletes a private endpoint connection. + + Description for Deletes a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either object or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[object] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[object] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def get_private_link_resources( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PrivateLinkResourcesWrapper": + """Gets the private link resources. + + Description for Gets the private link resources. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkResourcesWrapper, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkResourcesWrapper + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkResourcesWrapper"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_link_resources.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkResourcesWrapper', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_link_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateLinkResources'} # type: ignore + + def list_processes_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes'} # type: ignore + + async def get_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + async def delete_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + async def get_process_dump_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/dump'} # type: ignore + + def list_process_modules_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules'} # type: ignore + + async def get_process_module_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + slot: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.PublicCertificateCollection"]: + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_public_certificates_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates'} # type: ignore + + async def get_public_certificate_slot( + self, + resource_group_name: str, + name: str, + slot: str, + public_certificate_name: str, + **kwargs + ) -> "_models.PublicCertificate": + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def create_or_update_public_certificate_slot( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + slot: str, + public_certificate: "_models.PublicCertificate", + **kwargs + ) -> "_models.PublicCertificate": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def delete_public_certificate_slot( + self, + resource_group_name: str, + name: str, + slot: str, + public_certificate_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def list_publishing_profile_xml_with_secrets_slot( + self, + resource_group_name: str, + name: str, + slot: str, + publishing_profile_options: "_models.CsmPublishingProfileOptions", + **kwargs + ) -> IO: + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing profile for the production slot. + :type slot: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publishxml'} # type: ignore + + async def reset_slot_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API resets + configuration settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resetSlotConfig'} # type: ignore + + async def restart_slot( + self, + resource_group_name: str, + name: str, + slot: str, + soft_restart: Optional[bool] = None, + synchronous: Optional[bool] = None, + **kwargs + ) -> None: + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restart the + production slot. + :type slot: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restart'} # type: ignore + + async def _restore_from_backup_blob_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + async def begin_restore_from_backup_blob_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_backup_blob_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + async def _restore_from_deleted_app_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + async def begin_restore_from_deleted_app_slot( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_deleted_app_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + async def _restore_snapshot_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + async def begin_restore_snapshot_slot( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_snapshot_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def list_site_extensions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteExtensionInfoCollection"]: + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_extensions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions'} # type: ignore + + async def get_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _install_site_extension_slot_initial( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def begin_install_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> AsyncLROPoller["_models.SiteExtensionInfo"]: + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._install_site_extension_slot_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def delete_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> None: + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _copy_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + async def begin_copy_slot( + self, + resource_group_name: str, + name: str, + slot: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_06_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._copy_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def list_slot_differences_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncIterable["_models.SlotDifferenceCollection"]: + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slot_differences_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsdiffs'} # type: ignore + + async def _swap_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + async def begin_swap_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._swap_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def list_snapshots_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshotsdr'} # type: ignore + + async def get_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteSourceControl": + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def _create_or_update_source_control_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def begin_create_or_update_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> AsyncLROPoller["_models.SiteSourceControl"]: + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_source_control_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def delete_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def update_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def start_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will start the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/start'} # type: ignore + + async def _start_network_trace_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + async def begin_start_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_network_trace_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + async def stop_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will stop the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stop'} # type: ignore + + async def stop_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stopNetworkTrace'} # type: ignore + + async def sync_repository_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sync'} # type: ignore + + async def sync_function_triggers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredWebJobCollection"]: + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs'} # type: ignore + + async def get_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> Optional["_models.TriggeredWebJob"]: + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + async def delete_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes web job + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredJobHistoryCollection"]: + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + async def get_triggered_web_job_history_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + id: str, + slot: str, + **kwargs + ) -> Optional["_models.TriggeredJobHistory"]: + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + async def run_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages_slot( + self, + resource_group_name: str, + name: str, + slot: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get quota + information of the production slot. + :type slot: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/usages'} # type: ignore + + async def list_vnet_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get virtual + network connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + **kwargs + ) -> "_models.VnetInfo": + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named virtual network for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def create_or_update_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def delete_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def update_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + **kwargs + ) -> Optional["_models.VnetGateway"]: + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def create_or_update_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.WebJobCollection"]: + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs'} # type: ignore + + async def get_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> "_models.WebJob": + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs/{webJobName}'} # type: ignore + + def list_slot_differences_from_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncIterable["_models.SlotDifferenceCollection"]: + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_from_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slot_differences_from_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsdiffs'} # type: ignore + + async def _swap_slot_with_production_initial( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_with_production_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_with_production_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + async def begin_swap_slot_with_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._swap_slot_with_production_initial( + resource_group_name=resource_group_name, + name=name, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot_with_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def list_snapshots( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshotsdr'} # type: ignore + + async def get_source_control( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteSourceControl": + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def _create_or_update_source_control_initial( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def begin_create_or_update_source_control( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> AsyncLROPoller["_models.SiteSourceControl"]: + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_06_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_source_control_initial( + resource_group_name=resource_group_name, + name=name, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def delete_source_control( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def update_source_control( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def start( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/start'} # type: ignore + + async def _start_network_trace_initial( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + async def begin_start_network_trace( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_network_trace_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + async def stop( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stop'} # type: ignore + + async def stop_network_trace( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stopNetworkTrace'} # type: ignore + + async def sync_repository( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sync'} # type: ignore + + async def sync_function_triggers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredWebJobCollection"]: + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs'} # type: ignore + + async def get_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> Optional["_models.TriggeredWebJob"]: + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + async def delete_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredJobHistoryCollection"]: + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + async def get_triggered_web_job_history( + self, + resource_group_name: str, + name: str, + web_job_name: str, + id: str, + **kwargs + ) -> Optional["_models.TriggeredJobHistory"]: + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + async def run_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/usages'} # type: ignore + + async def list_vnet_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> "_models.VnetInfo": + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def create_or_update_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def delete_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> None: + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def update_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + **kwargs + ) -> Optional["_models.VnetGateway"]: + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def create_or_update_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebJobCollection"]: + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs'} # type: ignore + + async def get_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> "_models.WebJob": + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs/{webJobName}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_site_management_client_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_site_management_client_operations.py new file mode 100644 index 000000000000..196b138db9f1 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/aio/operations/_web_site_management_client_operations.py @@ -0,0 +1,1059 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class WebSiteManagementClientOperationsMixin: + + async def get_publishing_user( + self, + **kwargs + ) -> "_models.User": + """Gets publishing user. + + Description for Gets publishing user. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + async def update_publishing_user( + self, + user_details: "_models.User", + **kwargs + ) -> "_models.User": + """Updates publishing user. + + Description for Updates publishing user. + + :param user_details: Details of publishing user. + :type user_details: ~azure.mgmt.web.v2020_06_01.models.User + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(user_details, 'User') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def list_source_controls( + self, + **kwargs + ) -> AsyncIterable["_models.SourceControlCollection"]: + """Gets the source controls available for Azure websites. + + Description for Gets the source controls available for Azure websites. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SourceControlCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.SourceControlCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControlCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_source_controls.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SourceControlCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_source_controls.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols'} # type: ignore + + async def get_source_control( + self, + source_control_type: str, + **kwargs + ) -> "_models.SourceControl": + """Gets source control token. + + Description for Gets source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + async def update_source_control( + self, + source_control_type: str, + request_message: "_models.SourceControl", + **kwargs + ) -> "_models.SourceControl": + """Updates source control token. + + Description for Updates source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :param request_message: Source control token information. + :type request_message: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request_message, 'SourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def list_billing_meters( + self, + billing_location: Optional[str] = None, + os_type: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.BillingMeterCollection"]: + """Gets a list of meters for a given location. + + Description for Gets a list of meters for a given location. + + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param os_type: App Service OS type meters used for. + :type os_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.BillingMeterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BillingMeterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_billing_meters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if billing_location is not None: + query_parameters['billingLocation'] = self._serialize.query("billing_location", billing_location, 'str') + if os_type is not None: + query_parameters['osType'] = self._serialize.query("os_type", os_type, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BillingMeterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_billing_meters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/billingMeters'} # type: ignore + + async def check_name_availability( + self, + name: str, + type: Union[str, "_models.CheckNameResourceTypes"], + is_fqdn: Optional[bool] = None, + **kwargs + ) -> "_models.ResourceNameAvailability": + """Check if a resource name is available. + + Description for Check if a resource name is available. + + :param name: Resource name to verify. + :type name: str + :param type: Resource type used for verification. + :type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNameAvailability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceNameAvailability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNameAvailability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.ResourceNameAvailabilityRequest(name=name, type=type, is_fqdn=is_fqdn) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_name_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'ResourceNameAvailabilityRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceNameAvailability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/checknameavailability'} # type: ignore + + async def get_subscription_deployment_locations( + self, + **kwargs + ) -> "_models.DeploymentLocations": + """Gets list of available geo regions plus ministamps. + + Description for Gets list of available geo regions plus ministamps. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentLocations, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DeploymentLocations + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentLocations"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_subscription_deployment_locations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentLocations', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_subscription_deployment_locations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deploymentLocations'} # type: ignore + + def list_geo_regions( + self, + sku: Optional[Union[str, "_models.SkuName"]] = None, + linux_workers_enabled: Optional[bool] = None, + xenon_workers_enabled: Optional[bool] = None, + linux_dynamic_workers_enabled: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.GeoRegionCollection"]: + """Get a list of available geographical regions. + + Description for Get a list of available geographical regions. + + :param sku: Name of SKU used to filter the regions. + :type sku: str or ~azure.mgmt.web.v2020_06_01.models.SkuName + :param linux_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Linux workers. + :type linux_workers_enabled: bool + :param xenon_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Xenon workers. + :type xenon_workers_enabled: bool + :param linux_dynamic_workers_enabled: Specify :code:`true` if you want to filter + to only regions that support Linux Consumption Workers. + :type linux_dynamic_workers_enabled: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.GeoRegionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GeoRegionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_geo_regions.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if sku is not None: + query_parameters['sku'] = self._serialize.query("sku", sku, 'str') + if linux_workers_enabled is not None: + query_parameters['linuxWorkersEnabled'] = self._serialize.query("linux_workers_enabled", linux_workers_enabled, 'bool') + if xenon_workers_enabled is not None: + query_parameters['xenonWorkersEnabled'] = self._serialize.query("xenon_workers_enabled", xenon_workers_enabled, 'bool') + if linux_dynamic_workers_enabled is not None: + query_parameters['linuxDynamicWorkersEnabled'] = self._serialize.query("linux_dynamic_workers_enabled", linux_dynamic_workers_enabled, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('GeoRegionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_geo_regions.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/geoRegions'} # type: ignore + + def list_site_identifiers_assigned_to_host_name( + self, + name_identifier: "_models.NameIdentifier", + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """List all apps that are assigned to a hostname. + + Description for List all apps that are assigned to a hostname. + + :param name_identifier: Hostname information. + :type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_identifiers_assigned_to_host_name.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_identifiers_assigned_to_host_name.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/listSitesAssignedToHostName'} # type: ignore + + def list_premier_add_on_offers( + self, + **kwargs + ) -> AsyncIterable["_models.PremierAddOnOfferCollection"]: + """List all premier add-on offers. + + Description for List all premier add-on offers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOfferCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOnOfferCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_premier_add_on_offers.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PremierAddOnOfferCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_premier_add_on_offers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/premieraddonoffers'} # type: ignore + + async def list_skus( + self, + **kwargs + ) -> "_models.SkuInfos": + """List all SKUs. + + Description for List all SKUs. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SkuInfos, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SkuInfos + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfos"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SkuInfos', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_skus.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/skus'} # type: ignore + + async def verify_hosting_environment_vnet( + self, + parameters: "_models.VnetParameters", + **kwargs + ) -> "_models.VnetValidationFailureDetails": + """Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules. + + Description for Verifies if this VNET is compatible with an App Service Environment by + analyzing the Network Security Group rules. + + :param parameters: VNET information. + :type parameters: ~azure.mgmt.web.v2020_06_01.models.VnetParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetValidationFailureDetails, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetValidationFailureDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetValidationFailureDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.verify_hosting_environment_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'VnetParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetValidationFailureDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + verify_hosting_environment_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/verifyHostingEnvironmentVnet'} # type: ignore + + async def move( + self, + resource_group_name: str, + move_resource_envelope: "_models.CsmMoveResourceEnvelope", + **kwargs + ) -> None: + """Move resources between resource groups. + + Description for Move resources between resource groups. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/moveResources'} # type: ignore + + async def validate( + self, + resource_group_name: str, + validate_request: "_models.ValidateRequest", + **kwargs + ) -> "_models.ValidateResponse": + """Validate if a resource can be created. + + Description for Validate if a resource can be created. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param validate_request: Request with the resources to validate. + :type validate_request: ~azure.mgmt.web.v2020_06_01.models.ValidateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ValidateResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ValidateResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ValidateResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(validate_request, 'ValidateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ValidateResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/validate'} # type: ignore + + async def validate_move( + self, + resource_group_name: str, + move_resource_envelope: "_models.CsmMoveResourceEnvelope", + **kwargs + ) -> None: + """Validate whether a resource can be moved. + + Description for Validate whether a resource can be moved. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/validateMoveResources'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/__init__.py new file mode 100644 index 000000000000..897de4ac0ea2 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/__init__.py @@ -0,0 +1,1199 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import AbnormalTimePeriod + from ._models_py3 import Address + from ._models_py3 import AddressResponse + from ._models_py3 import AllowedAudiencesValidation + from ._models_py3 import AnalysisData + from ._models_py3 import AnalysisDefinition + from ._models_py3 import ApiDefinitionInfo + from ._models_py3 import ApiManagementConfig + from ._models_py3 import AppRegistration + from ._models_py3 import AppServiceCertificate + from ._models_py3 import AppServiceCertificateCollection + from ._models_py3 import AppServiceCertificateOrder + from ._models_py3 import AppServiceCertificateOrderCollection + from ._models_py3 import AppServiceCertificateOrderPatchResource + from ._models_py3 import AppServiceCertificatePatchResource + from ._models_py3 import AppServiceCertificateResource + from ._models_py3 import AppServiceEnvironment + from ._models_py3 import AppServiceEnvironmentCollection + from ._models_py3 import AppServiceEnvironmentPatchResource + from ._models_py3 import AppServiceEnvironmentResource + from ._models_py3 import AppServicePlan + from ._models_py3 import AppServicePlanCollection + from ._models_py3 import AppServicePlanPatchResource + from ._models_py3 import ApplicationLogsConfig + from ._models_py3 import ApplicationStack + from ._models_py3 import ApplicationStackCollection + from ._models_py3 import ApplicationStackResource + from ._models_py3 import ArmIdWrapper + from ._models_py3 import AuthPlatform + from ._models_py3 import AutoHealActions + from ._models_py3 import AutoHealCustomAction + from ._models_py3 import AutoHealRules + from ._models_py3 import AutoHealTriggers + from ._models_py3 import AzureActiveDirectory + from ._models_py3 import AzureActiveDirectoryLogin + from ._models_py3 import AzureActiveDirectoryRegistration + from ._models_py3 import AzureActiveDirectoryValidation + from ._models_py3 import AzureBlobStorageApplicationLogsConfig + from ._models_py3 import AzureBlobStorageHttpLogsConfig + from ._models_py3 import AzureStorageInfoValue + from ._models_py3 import AzureStoragePropertyDictionaryResource + from ._models_py3 import AzureTableStorageApplicationLogsConfig + from ._models_py3 import BackupItem + from ._models_py3 import BackupItemCollection + from ._models_py3 import BackupRequest + from ._models_py3 import BackupSchedule + from ._models_py3 import BillingMeter + from ._models_py3 import BillingMeterCollection + from ._models_py3 import BlobStorageTokenStore + from ._models_py3 import Capability + from ._models_py3 import Certificate + from ._models_py3 import CertificateCollection + from ._models_py3 import CertificateDetails + from ._models_py3 import CertificateEmail + from ._models_py3 import CertificateOrderAction + from ._models_py3 import CertificatePatchResource + from ._models_py3 import ClientRegistration + from ._models_py3 import CloningInfo + from ._models_py3 import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties + from ._models_py3 import ConnStringInfo + from ._models_py3 import ConnStringValueTypePair + from ._models_py3 import ConnectionStringDictionary + from ._models_py3 import Contact + from ._models_py3 import ContainerCpuStatistics + from ._models_py3 import ContainerCpuUsage + from ._models_py3 import ContainerInfo + from ._models_py3 import ContainerMemoryStatistics + from ._models_py3 import ContainerNetworkInterfaceStatistics + from ._models_py3 import ContainerThrottlingData + from ._models_py3 import ContinuousWebJob + from ._models_py3 import ContinuousWebJobCollection + from ._models_py3 import CookieExpiration + from ._models_py3 import CorsSettings + from ._models_py3 import CsmCopySlotEntity + from ._models_py3 import CsmMoveResourceEnvelope + from ._models_py3 import CsmOperationCollection + from ._models_py3 import CsmOperationDescription + from ._models_py3 import CsmOperationDescriptionProperties + from ._models_py3 import CsmOperationDisplay + from ._models_py3 import CsmPublishingCredentialsPoliciesCollection + from ._models_py3 import CsmPublishingCredentialsPoliciesEntity + from ._models_py3 import CsmPublishingProfileOptions + from ._models_py3 import CsmSlotEntity + from ._models_py3 import CsmUsageQuota + from ._models_py3 import CsmUsageQuotaCollection + from ._models_py3 import CustomHostnameAnalysisResult + from ._models_py3 import CustomOpenIdConnectProvider + from ._models_py3 import DataSource + from ._models_py3 import DataTableResponseColumn + from ._models_py3 import DataTableResponseObject + from ._models_py3 import DatabaseBackupSetting + from ._models_py3 import DefaultErrorResponse + from ._models_py3 import DefaultErrorResponseError + from ._models_py3 import DefaultErrorResponseErrorDetailsItem + from ._models_py3 import DeletedAppRestoreRequest + from ._models_py3 import DeletedSite + from ._models_py3 import DeletedWebAppCollection + from ._models_py3 import Deployment + from ._models_py3 import DeploymentCollection + from ._models_py3 import DeploymentLocations + from ._models_py3 import DetectorAbnormalTimePeriod + from ._models_py3 import DetectorDefinition + from ._models_py3 import DetectorInfo + from ._models_py3 import DetectorResponse + from ._models_py3 import DetectorResponseCollection + from ._models_py3 import DiagnosticAnalysis + from ._models_py3 import DiagnosticAnalysisCollection + from ._models_py3 import DiagnosticCategory + from ._models_py3 import DiagnosticCategoryCollection + from ._models_py3 import DiagnosticData + from ._models_py3 import DiagnosticDetectorCollection + from ._models_py3 import DiagnosticDetectorResponse + from ._models_py3 import DiagnosticMetricSample + from ._models_py3 import DiagnosticMetricSet + from ._models_py3 import Dimension + from ._models_py3 import Domain + from ._models_py3 import DomainAvailabilityCheckResult + from ._models_py3 import DomainCollection + from ._models_py3 import DomainControlCenterSsoRequest + from ._models_py3 import DomainOwnershipIdentifier + from ._models_py3 import DomainOwnershipIdentifierCollection + from ._models_py3 import DomainPatchResource + from ._models_py3 import DomainPurchaseConsent + from ._models_py3 import DomainRecommendationSearchParameters + from ._models_py3 import EnabledConfig + from ._models_py3 import EndpointDependency + from ._models_py3 import EndpointDetail + from ._models_py3 import ErrorEntity + from ._models_py3 import Experiments + from ._models_py3 import Facebook + from ._models_py3 import FileSystemApplicationLogsConfig + from ._models_py3 import FileSystemHttpLogsConfig + from ._models_py3 import FileSystemTokenStore + from ._models_py3 import ForwardProxy + from ._models_py3 import FunctionEnvelope + from ._models_py3 import FunctionEnvelopeCollection + from ._models_py3 import FunctionSecrets + from ._models_py3 import GeoRegion + from ._models_py3 import GeoRegionCollection + from ._models_py3 import GitHub + from ._models_py3 import GlobalCsmSkuDescription + from ._models_py3 import GlobalValidation + from ._models_py3 import Google + from ._models_py3 import HandlerMapping + from ._models_py3 import HostKeys + from ._models_py3 import HostName + from ._models_py3 import HostNameBinding + from ._models_py3 import HostNameBindingCollection + from ._models_py3 import HostNameSslState + from ._models_py3 import HostingEnvironmentDeploymentInfo + from ._models_py3 import HostingEnvironmentDiagnostics + from ._models_py3 import HostingEnvironmentProfile + from ._models_py3 import HttpLogsConfig + from ._models_py3 import HttpSettings + from ._models_py3 import HttpSettingsRoutes + from ._models_py3 import HybridConnection + from ._models_py3 import HybridConnectionCollection + from ._models_py3 import HybridConnectionKey + from ._models_py3 import HybridConnectionLimits + from ._models_py3 import Identifier + from ._models_py3 import IdentifierCollection + from ._models_py3 import IdentityProviders + from ._models_py3 import InboundEnvironmentEndpoint + from ._models_py3 import InboundEnvironmentEndpointCollection + from ._models_py3 import IpSecurityRestriction + from ._models_py3 import JwtClaimChecks + from ._models_py3 import KeyInfo + from ._models_py3 import LocalizableString + from ._models_py3 import LogSpecification + from ._models_py3 import Login + from ._models_py3 import LoginRoutes + from ._models_py3 import LoginScopes + from ._models_py3 import MSDeploy + from ._models_py3 import MSDeployLog + from ._models_py3 import MSDeployLogEntry + from ._models_py3 import MSDeployStatus + from ._models_py3 import ManagedServiceIdentity + from ._models_py3 import MetricAvailability + from ._models_py3 import MetricSpecification + from ._models_py3 import MigrateMySqlRequest + from ._models_py3 import MigrateMySqlStatus + from ._models_py3 import NameIdentifier + from ._models_py3 import NameIdentifierCollection + from ._models_py3 import NameValuePair + from ._models_py3 import NetworkAccessControlEntry + from ._models_py3 import NetworkFeatures + from ._models_py3 import NetworkTrace + from ._models_py3 import Nonce + from ._models_py3 import OpenIdConnectClientCredential + from ._models_py3 import OpenIdConnectConfig + from ._models_py3 import OpenIdConnectLogin + from ._models_py3 import OpenIdConnectRegistration + from ._models_py3 import Operation + from ._models_py3 import OutboundEnvironmentEndpoint + from ._models_py3 import OutboundEnvironmentEndpointCollection + from ._models_py3 import PerfMonCounterCollection + from ._models_py3 import PerfMonResponse + from ._models_py3 import PerfMonSample + from ._models_py3 import PerfMonSet + from ._models_py3 import PremierAddOn + from ._models_py3 import PremierAddOnOffer + from ._models_py3 import PremierAddOnOfferCollection + from ._models_py3 import PremierAddOnPatchResource + from ._models_py3 import PrivateAccess + from ._models_py3 import PrivateAccessSubnet + from ._models_py3 import PrivateAccessVirtualNetwork + from ._models_py3 import PrivateEndpointConnectionResource + from ._models_py3 import PrivateLinkConnectionApprovalRequestResource + from ._models_py3 import PrivateLinkConnectionState + from ._models_py3 import PrivateLinkResource + from ._models_py3 import PrivateLinkResourceProperties + from ._models_py3 import PrivateLinkResourcesWrapper + from ._models_py3 import ProcessInfo + from ._models_py3 import ProcessInfoCollection + from ._models_py3 import ProcessModuleInfo + from ._models_py3 import ProcessModuleInfoCollection + from ._models_py3 import ProcessThreadInfo + from ._models_py3 import ProcessThreadInfoCollection + from ._models_py3 import ProxyOnlyResource + from ._models_py3 import PublicCertificate + from ._models_py3 import PublicCertificateCollection + from ._models_py3 import PushSettings + from ._models_py3 import RampUpRule + from ._models_py3 import Recommendation + from ._models_py3 import RecommendationCollection + from ._models_py3 import RecommendationRule + from ._models_py3 import ReissueCertificateOrderRequest + from ._models_py3 import RelayServiceConnectionEntity + from ._models_py3 import Rendering + from ._models_py3 import RenewCertificateOrderRequest + from ._models_py3 import RequestsBasedTrigger + from ._models_py3 import Resource + from ._models_py3 import ResourceCollection + from ._models_py3 import ResourceHealthMetadata + from ._models_py3 import ResourceHealthMetadataCollection + from ._models_py3 import ResourceMetricAvailability + from ._models_py3 import ResourceMetricDefinition + from ._models_py3 import ResourceMetricDefinitionCollection + from ._models_py3 import ResourceNameAvailability + from ._models_py3 import ResourceNameAvailabilityRequest + from ._models_py3 import ResponseMetaData + from ._models_py3 import RestoreRequest + from ._models_py3 import ServiceSpecification + from ._models_py3 import Site + from ._models_py3 import SiteAuthSettings + from ._models_py3 import SiteAuthSettingsV2 + from ._models_py3 import SiteCloneability + from ._models_py3 import SiteCloneabilityCriterion + from ._models_py3 import SiteConfig + from ._models_py3 import SiteConfigResource + from ._models_py3 import SiteConfigResourceCollection + from ._models_py3 import SiteConfigurationSnapshotInfo + from ._models_py3 import SiteConfigurationSnapshotInfoCollection + from ._models_py3 import SiteExtensionInfo + from ._models_py3 import SiteExtensionInfoCollection + from ._models_py3 import SiteLimits + from ._models_py3 import SiteLogsConfig + from ._models_py3 import SiteMachineKey + from ._models_py3 import SitePatchResource + from ._models_py3 import SitePhpErrorLogFlag + from ._models_py3 import SiteSeal + from ._models_py3 import SiteSealRequest + from ._models_py3 import SiteSourceControl + from ._models_py3 import SkuCapacity + from ._models_py3 import SkuDescription + from ._models_py3 import SkuInfo + from ._models_py3 import SkuInfoCollection + from ._models_py3 import SkuInfos + from ._models_py3 import SlotConfigNamesResource + from ._models_py3 import SlotDifference + from ._models_py3 import SlotDifferenceCollection + from ._models_py3 import SlotSwapStatus + from ._models_py3 import SlowRequestsBasedTrigger + from ._models_py3 import Snapshot + from ._models_py3 import SnapshotCollection + from ._models_py3 import SnapshotRecoverySource + from ._models_py3 import SnapshotRestoreRequest + from ._models_py3 import Solution + from ._models_py3 import SourceControl + from ._models_py3 import SourceControlCollection + from ._models_py3 import StackMajorVersion + from ._models_py3 import StackMinorVersion + from ._models_py3 import StampCapacity + from ._models_py3 import StampCapacityCollection + from ._models_py3 import StaticSiteARMResource + from ._models_py3 import StaticSiteBuildARMResource + from ._models_py3 import StaticSiteBuildCollection + from ._models_py3 import StaticSiteBuildProperties + from ._models_py3 import StaticSiteCollection + from ._models_py3 import StaticSiteCustomDomainOverviewARMResource + from ._models_py3 import StaticSiteCustomDomainOverviewCollection + from ._models_py3 import StaticSiteFunctionOverviewARMResource + from ._models_py3 import StaticSiteFunctionOverviewCollection + from ._models_py3 import StaticSitePatchResource + from ._models_py3 import StaticSiteResetPropertiesARMResource + from ._models_py3 import StaticSiteUserARMResource + from ._models_py3 import StaticSiteUserCollection + from ._models_py3 import StaticSiteUserInvitationRequestResource + from ._models_py3 import StaticSiteUserInvitationResponseResource + from ._models_py3 import StaticSitesWorkflowPreview + from ._models_py3 import StaticSitesWorkflowPreviewRequest + from ._models_py3 import StatusCodesBasedTrigger + from ._models_py3 import StorageMigrationOptions + from ._models_py3 import StorageMigrationResponse + from ._models_py3 import StringDictionary + from ._models_py3 import SwiftVirtualNetwork + from ._models_py3 import TldLegalAgreement + from ._models_py3 import TldLegalAgreementCollection + from ._models_py3 import TokenStore + from ._models_py3 import TopLevelDomain + from ._models_py3 import TopLevelDomainAgreementOption + from ._models_py3 import TopLevelDomainCollection + from ._models_py3 import TriggeredJobHistory + from ._models_py3 import TriggeredJobHistoryCollection + from ._models_py3 import TriggeredJobRun + from ._models_py3 import TriggeredWebJob + from ._models_py3 import TriggeredWebJobCollection + from ._models_py3 import Twitter + from ._models_py3 import TwitterRegistration + from ._models_py3 import Usage + from ._models_py3 import UsageCollection + from ._models_py3 import User + from ._models_py3 import ValidateRequest + from ._models_py3 import ValidateResponse + from ._models_py3 import ValidateResponseError + from ._models_py3 import VirtualApplication + from ._models_py3 import VirtualDirectory + from ._models_py3 import VirtualIPMapping + from ._models_py3 import VirtualNetworkProfile + from ._models_py3 import VnetGateway + from ._models_py3 import VnetInfo + from ._models_py3 import VnetParameters + from ._models_py3 import VnetRoute + from ._models_py3 import VnetValidationFailureDetails + from ._models_py3 import VnetValidationTestFailure + from ._models_py3 import WebAppCollection + from ._models_py3 import WebAppInstanceStatusCollection + from ._models_py3 import WebJob + from ._models_py3 import WebJobCollection + from ._models_py3 import WebSiteInstanceStatus + from ._models_py3 import WorkerPool + from ._models_py3 import WorkerPoolCollection + from ._models_py3 import WorkerPoolResource +except (SyntaxError, ImportError): + from ._models import AbnormalTimePeriod # type: ignore + from ._models import Address # type: ignore + from ._models import AddressResponse # type: ignore + from ._models import AllowedAudiencesValidation # type: ignore + from ._models import AnalysisData # type: ignore + from ._models import AnalysisDefinition # type: ignore + from ._models import ApiDefinitionInfo # type: ignore + from ._models import ApiManagementConfig # type: ignore + from ._models import AppRegistration # type: ignore + from ._models import AppServiceCertificate # type: ignore + from ._models import AppServiceCertificateCollection # type: ignore + from ._models import AppServiceCertificateOrder # type: ignore + from ._models import AppServiceCertificateOrderCollection # type: ignore + from ._models import AppServiceCertificateOrderPatchResource # type: ignore + from ._models import AppServiceCertificatePatchResource # type: ignore + from ._models import AppServiceCertificateResource # type: ignore + from ._models import AppServiceEnvironment # type: ignore + from ._models import AppServiceEnvironmentCollection # type: ignore + from ._models import AppServiceEnvironmentPatchResource # type: ignore + from ._models import AppServiceEnvironmentResource # type: ignore + from ._models import AppServicePlan # type: ignore + from ._models import AppServicePlanCollection # type: ignore + from ._models import AppServicePlanPatchResource # type: ignore + from ._models import ApplicationLogsConfig # type: ignore + from ._models import ApplicationStack # type: ignore + from ._models import ApplicationStackCollection # type: ignore + from ._models import ApplicationStackResource # type: ignore + from ._models import ArmIdWrapper # type: ignore + from ._models import AuthPlatform # type: ignore + from ._models import AutoHealActions # type: ignore + from ._models import AutoHealCustomAction # type: ignore + from ._models import AutoHealRules # type: ignore + from ._models import AutoHealTriggers # type: ignore + from ._models import AzureActiveDirectory # type: ignore + from ._models import AzureActiveDirectoryLogin # type: ignore + from ._models import AzureActiveDirectoryRegistration # type: ignore + from ._models import AzureActiveDirectoryValidation # type: ignore + from ._models import AzureBlobStorageApplicationLogsConfig # type: ignore + from ._models import AzureBlobStorageHttpLogsConfig # type: ignore + from ._models import AzureStorageInfoValue # type: ignore + from ._models import AzureStoragePropertyDictionaryResource # type: ignore + from ._models import AzureTableStorageApplicationLogsConfig # type: ignore + from ._models import BackupItem # type: ignore + from ._models import BackupItemCollection # type: ignore + from ._models import BackupRequest # type: ignore + from ._models import BackupSchedule # type: ignore + from ._models import BillingMeter # type: ignore + from ._models import BillingMeterCollection # type: ignore + from ._models import BlobStorageTokenStore # type: ignore + from ._models import Capability # type: ignore + from ._models import Certificate # type: ignore + from ._models import CertificateCollection # type: ignore + from ._models import CertificateDetails # type: ignore + from ._models import CertificateEmail # type: ignore + from ._models import CertificateOrderAction # type: ignore + from ._models import CertificatePatchResource # type: ignore + from ._models import ClientRegistration # type: ignore + from ._models import CloningInfo # type: ignore + from ._models import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties # type: ignore + from ._models import ConnStringInfo # type: ignore + from ._models import ConnStringValueTypePair # type: ignore + from ._models import ConnectionStringDictionary # type: ignore + from ._models import Contact # type: ignore + from ._models import ContainerCpuStatistics # type: ignore + from ._models import ContainerCpuUsage # type: ignore + from ._models import ContainerInfo # type: ignore + from ._models import ContainerMemoryStatistics # type: ignore + from ._models import ContainerNetworkInterfaceStatistics # type: ignore + from ._models import ContainerThrottlingData # type: ignore + from ._models import ContinuousWebJob # type: ignore + from ._models import ContinuousWebJobCollection # type: ignore + from ._models import CookieExpiration # type: ignore + from ._models import CorsSettings # type: ignore + from ._models import CsmCopySlotEntity # type: ignore + from ._models import CsmMoveResourceEnvelope # type: ignore + from ._models import CsmOperationCollection # type: ignore + from ._models import CsmOperationDescription # type: ignore + from ._models import CsmOperationDescriptionProperties # type: ignore + from ._models import CsmOperationDisplay # type: ignore + from ._models import CsmPublishingCredentialsPoliciesCollection # type: ignore + from ._models import CsmPublishingCredentialsPoliciesEntity # type: ignore + from ._models import CsmPublishingProfileOptions # type: ignore + from ._models import CsmSlotEntity # type: ignore + from ._models import CsmUsageQuota # type: ignore + from ._models import CsmUsageQuotaCollection # type: ignore + from ._models import CustomHostnameAnalysisResult # type: ignore + from ._models import CustomOpenIdConnectProvider # type: ignore + from ._models import DataSource # type: ignore + from ._models import DataTableResponseColumn # type: ignore + from ._models import DataTableResponseObject # type: ignore + from ._models import DatabaseBackupSetting # type: ignore + from ._models import DefaultErrorResponse # type: ignore + from ._models import DefaultErrorResponseError # type: ignore + from ._models import DefaultErrorResponseErrorDetailsItem # type: ignore + from ._models import DeletedAppRestoreRequest # type: ignore + from ._models import DeletedSite # type: ignore + from ._models import DeletedWebAppCollection # type: ignore + from ._models import Deployment # type: ignore + from ._models import DeploymentCollection # type: ignore + from ._models import DeploymentLocations # type: ignore + from ._models import DetectorAbnormalTimePeriod # type: ignore + from ._models import DetectorDefinition # type: ignore + from ._models import DetectorInfo # type: ignore + from ._models import DetectorResponse # type: ignore + from ._models import DetectorResponseCollection # type: ignore + from ._models import DiagnosticAnalysis # type: ignore + from ._models import DiagnosticAnalysisCollection # type: ignore + from ._models import DiagnosticCategory # type: ignore + from ._models import DiagnosticCategoryCollection # type: ignore + from ._models import DiagnosticData # type: ignore + from ._models import DiagnosticDetectorCollection # type: ignore + from ._models import DiagnosticDetectorResponse # type: ignore + from ._models import DiagnosticMetricSample # type: ignore + from ._models import DiagnosticMetricSet # type: ignore + from ._models import Dimension # type: ignore + from ._models import Domain # type: ignore + from ._models import DomainAvailabilityCheckResult # type: ignore + from ._models import DomainCollection # type: ignore + from ._models import DomainControlCenterSsoRequest # type: ignore + from ._models import DomainOwnershipIdentifier # type: ignore + from ._models import DomainOwnershipIdentifierCollection # type: ignore + from ._models import DomainPatchResource # type: ignore + from ._models import DomainPurchaseConsent # type: ignore + from ._models import DomainRecommendationSearchParameters # type: ignore + from ._models import EnabledConfig # type: ignore + from ._models import EndpointDependency # type: ignore + from ._models import EndpointDetail # type: ignore + from ._models import ErrorEntity # type: ignore + from ._models import Experiments # type: ignore + from ._models import Facebook # type: ignore + from ._models import FileSystemApplicationLogsConfig # type: ignore + from ._models import FileSystemHttpLogsConfig # type: ignore + from ._models import FileSystemTokenStore # type: ignore + from ._models import ForwardProxy # type: ignore + from ._models import FunctionEnvelope # type: ignore + from ._models import FunctionEnvelopeCollection # type: ignore + from ._models import FunctionSecrets # type: ignore + from ._models import GeoRegion # type: ignore + from ._models import GeoRegionCollection # type: ignore + from ._models import GitHub # type: ignore + from ._models import GlobalCsmSkuDescription # type: ignore + from ._models import GlobalValidation # type: ignore + from ._models import Google # type: ignore + from ._models import HandlerMapping # type: ignore + from ._models import HostKeys # type: ignore + from ._models import HostName # type: ignore + from ._models import HostNameBinding # type: ignore + from ._models import HostNameBindingCollection # type: ignore + from ._models import HostNameSslState # type: ignore + from ._models import HostingEnvironmentDeploymentInfo # type: ignore + from ._models import HostingEnvironmentDiagnostics # type: ignore + from ._models import HostingEnvironmentProfile # type: ignore + from ._models import HttpLogsConfig # type: ignore + from ._models import HttpSettings # type: ignore + from ._models import HttpSettingsRoutes # type: ignore + from ._models import HybridConnection # type: ignore + from ._models import HybridConnectionCollection # type: ignore + from ._models import HybridConnectionKey # type: ignore + from ._models import HybridConnectionLimits # type: ignore + from ._models import Identifier # type: ignore + from ._models import IdentifierCollection # type: ignore + from ._models import IdentityProviders # type: ignore + from ._models import InboundEnvironmentEndpoint # type: ignore + from ._models import InboundEnvironmentEndpointCollection # type: ignore + from ._models import IpSecurityRestriction # type: ignore + from ._models import JwtClaimChecks # type: ignore + from ._models import KeyInfo # type: ignore + from ._models import LocalizableString # type: ignore + from ._models import LogSpecification # type: ignore + from ._models import Login # type: ignore + from ._models import LoginRoutes # type: ignore + from ._models import LoginScopes # type: ignore + from ._models import MSDeploy # type: ignore + from ._models import MSDeployLog # type: ignore + from ._models import MSDeployLogEntry # type: ignore + from ._models import MSDeployStatus # type: ignore + from ._models import ManagedServiceIdentity # type: ignore + from ._models import MetricAvailability # type: ignore + from ._models import MetricSpecification # type: ignore + from ._models import MigrateMySqlRequest # type: ignore + from ._models import MigrateMySqlStatus # type: ignore + from ._models import NameIdentifier # type: ignore + from ._models import NameIdentifierCollection # type: ignore + from ._models import NameValuePair # type: ignore + from ._models import NetworkAccessControlEntry # type: ignore + from ._models import NetworkFeatures # type: ignore + from ._models import NetworkTrace # type: ignore + from ._models import Nonce # type: ignore + from ._models import OpenIdConnectClientCredential # type: ignore + from ._models import OpenIdConnectConfig # type: ignore + from ._models import OpenIdConnectLogin # type: ignore + from ._models import OpenIdConnectRegistration # type: ignore + from ._models import Operation # type: ignore + from ._models import OutboundEnvironmentEndpoint # type: ignore + from ._models import OutboundEnvironmentEndpointCollection # type: ignore + from ._models import PerfMonCounterCollection # type: ignore + from ._models import PerfMonResponse # type: ignore + from ._models import PerfMonSample # type: ignore + from ._models import PerfMonSet # type: ignore + from ._models import PremierAddOn # type: ignore + from ._models import PremierAddOnOffer # type: ignore + from ._models import PremierAddOnOfferCollection # type: ignore + from ._models import PremierAddOnPatchResource # type: ignore + from ._models import PrivateAccess # type: ignore + from ._models import PrivateAccessSubnet # type: ignore + from ._models import PrivateAccessVirtualNetwork # type: ignore + from ._models import PrivateEndpointConnectionResource # type: ignore + from ._models import PrivateLinkConnectionApprovalRequestResource # type: ignore + from ._models import PrivateLinkConnectionState # type: ignore + from ._models import PrivateLinkResource # type: ignore + from ._models import PrivateLinkResourceProperties # type: ignore + from ._models import PrivateLinkResourcesWrapper # type: ignore + from ._models import ProcessInfo # type: ignore + from ._models import ProcessInfoCollection # type: ignore + from ._models import ProcessModuleInfo # type: ignore + from ._models import ProcessModuleInfoCollection # type: ignore + from ._models import ProcessThreadInfo # type: ignore + from ._models import ProcessThreadInfoCollection # type: ignore + from ._models import ProxyOnlyResource # type: ignore + from ._models import PublicCertificate # type: ignore + from ._models import PublicCertificateCollection # type: ignore + from ._models import PushSettings # type: ignore + from ._models import RampUpRule # type: ignore + from ._models import Recommendation # type: ignore + from ._models import RecommendationCollection # type: ignore + from ._models import RecommendationRule # type: ignore + from ._models import ReissueCertificateOrderRequest # type: ignore + from ._models import RelayServiceConnectionEntity # type: ignore + from ._models import Rendering # type: ignore + from ._models import RenewCertificateOrderRequest # type: ignore + from ._models import RequestsBasedTrigger # type: ignore + from ._models import Resource # type: ignore + from ._models import ResourceCollection # type: ignore + from ._models import ResourceHealthMetadata # type: ignore + from ._models import ResourceHealthMetadataCollection # type: ignore + from ._models import ResourceMetricAvailability # type: ignore + from ._models import ResourceMetricDefinition # type: ignore + from ._models import ResourceMetricDefinitionCollection # type: ignore + from ._models import ResourceNameAvailability # type: ignore + from ._models import ResourceNameAvailabilityRequest # type: ignore + from ._models import ResponseMetaData # type: ignore + from ._models import RestoreRequest # type: ignore + from ._models import ServiceSpecification # type: ignore + from ._models import Site # type: ignore + from ._models import SiteAuthSettings # type: ignore + from ._models import SiteAuthSettingsV2 # type: ignore + from ._models import SiteCloneability # type: ignore + from ._models import SiteCloneabilityCriterion # type: ignore + from ._models import SiteConfig # type: ignore + from ._models import SiteConfigResource # type: ignore + from ._models import SiteConfigResourceCollection # type: ignore + from ._models import SiteConfigurationSnapshotInfo # type: ignore + from ._models import SiteConfigurationSnapshotInfoCollection # type: ignore + from ._models import SiteExtensionInfo # type: ignore + from ._models import SiteExtensionInfoCollection # type: ignore + from ._models import SiteLimits # type: ignore + from ._models import SiteLogsConfig # type: ignore + from ._models import SiteMachineKey # type: ignore + from ._models import SitePatchResource # type: ignore + from ._models import SitePhpErrorLogFlag # type: ignore + from ._models import SiteSeal # type: ignore + from ._models import SiteSealRequest # type: ignore + from ._models import SiteSourceControl # type: ignore + from ._models import SkuCapacity # type: ignore + from ._models import SkuDescription # type: ignore + from ._models import SkuInfo # type: ignore + from ._models import SkuInfoCollection # type: ignore + from ._models import SkuInfos # type: ignore + from ._models import SlotConfigNamesResource # type: ignore + from ._models import SlotDifference # type: ignore + from ._models import SlotDifferenceCollection # type: ignore + from ._models import SlotSwapStatus # type: ignore + from ._models import SlowRequestsBasedTrigger # type: ignore + from ._models import Snapshot # type: ignore + from ._models import SnapshotCollection # type: ignore + from ._models import SnapshotRecoverySource # type: ignore + from ._models import SnapshotRestoreRequest # type: ignore + from ._models import Solution # type: ignore + from ._models import SourceControl # type: ignore + from ._models import SourceControlCollection # type: ignore + from ._models import StackMajorVersion # type: ignore + from ._models import StackMinorVersion # type: ignore + from ._models import StampCapacity # type: ignore + from ._models import StampCapacityCollection # type: ignore + from ._models import StaticSiteARMResource # type: ignore + from ._models import StaticSiteBuildARMResource # type: ignore + from ._models import StaticSiteBuildCollection # type: ignore + from ._models import StaticSiteBuildProperties # type: ignore + from ._models import StaticSiteCollection # type: ignore + from ._models import StaticSiteCustomDomainOverviewARMResource # type: ignore + from ._models import StaticSiteCustomDomainOverviewCollection # type: ignore + from ._models import StaticSiteFunctionOverviewARMResource # type: ignore + from ._models import StaticSiteFunctionOverviewCollection # type: ignore + from ._models import StaticSitePatchResource # type: ignore + from ._models import StaticSiteResetPropertiesARMResource # type: ignore + from ._models import StaticSiteUserARMResource # type: ignore + from ._models import StaticSiteUserCollection # type: ignore + from ._models import StaticSiteUserInvitationRequestResource # type: ignore + from ._models import StaticSiteUserInvitationResponseResource # type: ignore + from ._models import StaticSitesWorkflowPreview # type: ignore + from ._models import StaticSitesWorkflowPreviewRequest # type: ignore + from ._models import StatusCodesBasedTrigger # type: ignore + from ._models import StorageMigrationOptions # type: ignore + from ._models import StorageMigrationResponse # type: ignore + from ._models import StringDictionary # type: ignore + from ._models import SwiftVirtualNetwork # type: ignore + from ._models import TldLegalAgreement # type: ignore + from ._models import TldLegalAgreementCollection # type: ignore + from ._models import TokenStore # type: ignore + from ._models import TopLevelDomain # type: ignore + from ._models import TopLevelDomainAgreementOption # type: ignore + from ._models import TopLevelDomainCollection # type: ignore + from ._models import TriggeredJobHistory # type: ignore + from ._models import TriggeredJobHistoryCollection # type: ignore + from ._models import TriggeredJobRun # type: ignore + from ._models import TriggeredWebJob # type: ignore + from ._models import TriggeredWebJobCollection # type: ignore + from ._models import Twitter # type: ignore + from ._models import TwitterRegistration # type: ignore + from ._models import Usage # type: ignore + from ._models import UsageCollection # type: ignore + from ._models import User # type: ignore + from ._models import ValidateRequest # type: ignore + from ._models import ValidateResponse # type: ignore + from ._models import ValidateResponseError # type: ignore + from ._models import VirtualApplication # type: ignore + from ._models import VirtualDirectory # type: ignore + from ._models import VirtualIPMapping # type: ignore + from ._models import VirtualNetworkProfile # type: ignore + from ._models import VnetGateway # type: ignore + from ._models import VnetInfo # type: ignore + from ._models import VnetParameters # type: ignore + from ._models import VnetRoute # type: ignore + from ._models import VnetValidationFailureDetails # type: ignore + from ._models import VnetValidationTestFailure # type: ignore + from ._models import WebAppCollection # type: ignore + from ._models import WebAppInstanceStatusCollection # type: ignore + from ._models import WebJob # type: ignore + from ._models import WebJobCollection # type: ignore + from ._models import WebSiteInstanceStatus # type: ignore + from ._models import WorkerPool # type: ignore + from ._models import WorkerPoolCollection # type: ignore + from ._models import WorkerPoolResource # type: ignore + +from ._web_site_management_client_enums import ( + AccessControlEntryAction, + AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem, + AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem, + AppServicePlanRestrictions, + AutoHealActionType, + AzureResourceType, + AzureStorageState, + AzureStorageType, + BackupItemStatus, + BackupRestoreOperationType, + BuildStatus, + BuiltInAuthenticationProvider, + CertificateOrderActionType, + CertificateOrderStatus, + CertificateProductType, + Channels, + CheckNameResourceTypes, + ClientCertMode, + CloneAbilityResult, + ComputeModeOptions, + ConnectionStringType, + ContinuousWebJobStatus, + CookieExpirationConvention, + CustomHostNameDnsRecordType, + DatabaseType, + DnsType, + DnsVerificationTestResult, + DomainPatchResourcePropertiesDomainNotRenewableReasonsItem, + DomainPropertiesDomainNotRenewableReasonsItem, + DomainStatus, + DomainType, + Enum4, + Enum5, + ForwardProxyConvention, + FrequencyUnit, + FtpsState, + HostNameType, + HostType, + HostingEnvironmentStatus, + InAvailabilityReasonType, + IpFilterTag, + IssueType, + KeyVaultSecretStatus, + LoadBalancingMode, + LogLevel, + MSDeployLogEntryType, + MSDeployProvisioningState, + ManagedPipelineMode, + ManagedServiceIdentityType, + MySqlMigrationType, + NotificationLevel, + OperationStatus, + ProvisioningState, + PublicCertificateLocation, + PublishingProfileFormat, + RedundancyMode, + RenderingType, + ResourceScopeType, + RouteType, + ScmType, + SiteAvailabilityState, + SiteExtensionType, + SiteLoadBalancing, + SiteRuntimeState, + SkuName, + SolutionType, + SslState, + StatusOptions, + SupportedTlsVersions, + TriggerTypes, + TriggeredWebJobStatus, + UnauthenticatedClientAction, + UnauthenticatedClientActionV2, + UsageState, + ValidateResourceTypes, + WebJobType, + WorkerSizeOptions, +) + +__all__ = [ + 'AbnormalTimePeriod', + 'Address', + 'AddressResponse', + 'AllowedAudiencesValidation', + 'AnalysisData', + 'AnalysisDefinition', + 'ApiDefinitionInfo', + 'ApiManagementConfig', + 'AppRegistration', + 'AppServiceCertificate', + 'AppServiceCertificateCollection', + 'AppServiceCertificateOrder', + 'AppServiceCertificateOrderCollection', + 'AppServiceCertificateOrderPatchResource', + 'AppServiceCertificatePatchResource', + 'AppServiceCertificateResource', + 'AppServiceEnvironment', + 'AppServiceEnvironmentCollection', + 'AppServiceEnvironmentPatchResource', + 'AppServiceEnvironmentResource', + 'AppServicePlan', + 'AppServicePlanCollection', + 'AppServicePlanPatchResource', + 'ApplicationLogsConfig', + 'ApplicationStack', + 'ApplicationStackCollection', + 'ApplicationStackResource', + 'ArmIdWrapper', + 'AuthPlatform', + 'AutoHealActions', + 'AutoHealCustomAction', + 'AutoHealRules', + 'AutoHealTriggers', + 'AzureActiveDirectory', + 'AzureActiveDirectoryLogin', + 'AzureActiveDirectoryRegistration', + 'AzureActiveDirectoryValidation', + 'AzureBlobStorageApplicationLogsConfig', + 'AzureBlobStorageHttpLogsConfig', + 'AzureStorageInfoValue', + 'AzureStoragePropertyDictionaryResource', + 'AzureTableStorageApplicationLogsConfig', + 'BackupItem', + 'BackupItemCollection', + 'BackupRequest', + 'BackupSchedule', + 'BillingMeter', + 'BillingMeterCollection', + 'BlobStorageTokenStore', + 'Capability', + 'Certificate', + 'CertificateCollection', + 'CertificateDetails', + 'CertificateEmail', + 'CertificateOrderAction', + 'CertificatePatchResource', + 'ClientRegistration', + 'CloningInfo', + 'Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties', + 'ConnStringInfo', + 'ConnStringValueTypePair', + 'ConnectionStringDictionary', + 'Contact', + 'ContainerCpuStatistics', + 'ContainerCpuUsage', + 'ContainerInfo', + 'ContainerMemoryStatistics', + 'ContainerNetworkInterfaceStatistics', + 'ContainerThrottlingData', + 'ContinuousWebJob', + 'ContinuousWebJobCollection', + 'CookieExpiration', + 'CorsSettings', + 'CsmCopySlotEntity', + 'CsmMoveResourceEnvelope', + 'CsmOperationCollection', + 'CsmOperationDescription', + 'CsmOperationDescriptionProperties', + 'CsmOperationDisplay', + 'CsmPublishingCredentialsPoliciesCollection', + 'CsmPublishingCredentialsPoliciesEntity', + 'CsmPublishingProfileOptions', + 'CsmSlotEntity', + 'CsmUsageQuota', + 'CsmUsageQuotaCollection', + 'CustomHostnameAnalysisResult', + 'CustomOpenIdConnectProvider', + 'DataSource', + 'DataTableResponseColumn', + 'DataTableResponseObject', + 'DatabaseBackupSetting', + 'DefaultErrorResponse', + 'DefaultErrorResponseError', + 'DefaultErrorResponseErrorDetailsItem', + 'DeletedAppRestoreRequest', + 'DeletedSite', + 'DeletedWebAppCollection', + 'Deployment', + 'DeploymentCollection', + 'DeploymentLocations', + 'DetectorAbnormalTimePeriod', + 'DetectorDefinition', + 'DetectorInfo', + 'DetectorResponse', + 'DetectorResponseCollection', + 'DiagnosticAnalysis', + 'DiagnosticAnalysisCollection', + 'DiagnosticCategory', + 'DiagnosticCategoryCollection', + 'DiagnosticData', + 'DiagnosticDetectorCollection', + 'DiagnosticDetectorResponse', + 'DiagnosticMetricSample', + 'DiagnosticMetricSet', + 'Dimension', + 'Domain', + 'DomainAvailabilityCheckResult', + 'DomainCollection', + 'DomainControlCenterSsoRequest', + 'DomainOwnershipIdentifier', + 'DomainOwnershipIdentifierCollection', + 'DomainPatchResource', + 'DomainPurchaseConsent', + 'DomainRecommendationSearchParameters', + 'EnabledConfig', + 'EndpointDependency', + 'EndpointDetail', + 'ErrorEntity', + 'Experiments', + 'Facebook', + 'FileSystemApplicationLogsConfig', + 'FileSystemHttpLogsConfig', + 'FileSystemTokenStore', + 'ForwardProxy', + 'FunctionEnvelope', + 'FunctionEnvelopeCollection', + 'FunctionSecrets', + 'GeoRegion', + 'GeoRegionCollection', + 'GitHub', + 'GlobalCsmSkuDescription', + 'GlobalValidation', + 'Google', + 'HandlerMapping', + 'HostKeys', + 'HostName', + 'HostNameBinding', + 'HostNameBindingCollection', + 'HostNameSslState', + 'HostingEnvironmentDeploymentInfo', + 'HostingEnvironmentDiagnostics', + 'HostingEnvironmentProfile', + 'HttpLogsConfig', + 'HttpSettings', + 'HttpSettingsRoutes', + 'HybridConnection', + 'HybridConnectionCollection', + 'HybridConnectionKey', + 'HybridConnectionLimits', + 'Identifier', + 'IdentifierCollection', + 'IdentityProviders', + 'InboundEnvironmentEndpoint', + 'InboundEnvironmentEndpointCollection', + 'IpSecurityRestriction', + 'JwtClaimChecks', + 'KeyInfo', + 'LocalizableString', + 'LogSpecification', + 'Login', + 'LoginRoutes', + 'LoginScopes', + 'MSDeploy', + 'MSDeployLog', + 'MSDeployLogEntry', + 'MSDeployStatus', + 'ManagedServiceIdentity', + 'MetricAvailability', + 'MetricSpecification', + 'MigrateMySqlRequest', + 'MigrateMySqlStatus', + 'NameIdentifier', + 'NameIdentifierCollection', + 'NameValuePair', + 'NetworkAccessControlEntry', + 'NetworkFeatures', + 'NetworkTrace', + 'Nonce', + 'OpenIdConnectClientCredential', + 'OpenIdConnectConfig', + 'OpenIdConnectLogin', + 'OpenIdConnectRegistration', + 'Operation', + 'OutboundEnvironmentEndpoint', + 'OutboundEnvironmentEndpointCollection', + 'PerfMonCounterCollection', + 'PerfMonResponse', + 'PerfMonSample', + 'PerfMonSet', + 'PremierAddOn', + 'PremierAddOnOffer', + 'PremierAddOnOfferCollection', + 'PremierAddOnPatchResource', + 'PrivateAccess', + 'PrivateAccessSubnet', + 'PrivateAccessVirtualNetwork', + 'PrivateEndpointConnectionResource', + 'PrivateLinkConnectionApprovalRequestResource', + 'PrivateLinkConnectionState', + 'PrivateLinkResource', + 'PrivateLinkResourceProperties', + 'PrivateLinkResourcesWrapper', + 'ProcessInfo', + 'ProcessInfoCollection', + 'ProcessModuleInfo', + 'ProcessModuleInfoCollection', + 'ProcessThreadInfo', + 'ProcessThreadInfoCollection', + 'ProxyOnlyResource', + 'PublicCertificate', + 'PublicCertificateCollection', + 'PushSettings', + 'RampUpRule', + 'Recommendation', + 'RecommendationCollection', + 'RecommendationRule', + 'ReissueCertificateOrderRequest', + 'RelayServiceConnectionEntity', + 'Rendering', + 'RenewCertificateOrderRequest', + 'RequestsBasedTrigger', + 'Resource', + 'ResourceCollection', + 'ResourceHealthMetadata', + 'ResourceHealthMetadataCollection', + 'ResourceMetricAvailability', + 'ResourceMetricDefinition', + 'ResourceMetricDefinitionCollection', + 'ResourceNameAvailability', + 'ResourceNameAvailabilityRequest', + 'ResponseMetaData', + 'RestoreRequest', + 'ServiceSpecification', + 'Site', + 'SiteAuthSettings', + 'SiteAuthSettingsV2', + 'SiteCloneability', + 'SiteCloneabilityCriterion', + 'SiteConfig', + 'SiteConfigResource', + 'SiteConfigResourceCollection', + 'SiteConfigurationSnapshotInfo', + 'SiteConfigurationSnapshotInfoCollection', + 'SiteExtensionInfo', + 'SiteExtensionInfoCollection', + 'SiteLimits', + 'SiteLogsConfig', + 'SiteMachineKey', + 'SitePatchResource', + 'SitePhpErrorLogFlag', + 'SiteSeal', + 'SiteSealRequest', + 'SiteSourceControl', + 'SkuCapacity', + 'SkuDescription', + 'SkuInfo', + 'SkuInfoCollection', + 'SkuInfos', + 'SlotConfigNamesResource', + 'SlotDifference', + 'SlotDifferenceCollection', + 'SlotSwapStatus', + 'SlowRequestsBasedTrigger', + 'Snapshot', + 'SnapshotCollection', + 'SnapshotRecoverySource', + 'SnapshotRestoreRequest', + 'Solution', + 'SourceControl', + 'SourceControlCollection', + 'StackMajorVersion', + 'StackMinorVersion', + 'StampCapacity', + 'StampCapacityCollection', + 'StaticSiteARMResource', + 'StaticSiteBuildARMResource', + 'StaticSiteBuildCollection', + 'StaticSiteBuildProperties', + 'StaticSiteCollection', + 'StaticSiteCustomDomainOverviewARMResource', + 'StaticSiteCustomDomainOverviewCollection', + 'StaticSiteFunctionOverviewARMResource', + 'StaticSiteFunctionOverviewCollection', + 'StaticSitePatchResource', + 'StaticSiteResetPropertiesARMResource', + 'StaticSiteUserARMResource', + 'StaticSiteUserCollection', + 'StaticSiteUserInvitationRequestResource', + 'StaticSiteUserInvitationResponseResource', + 'StaticSitesWorkflowPreview', + 'StaticSitesWorkflowPreviewRequest', + 'StatusCodesBasedTrigger', + 'StorageMigrationOptions', + 'StorageMigrationResponse', + 'StringDictionary', + 'SwiftVirtualNetwork', + 'TldLegalAgreement', + 'TldLegalAgreementCollection', + 'TokenStore', + 'TopLevelDomain', + 'TopLevelDomainAgreementOption', + 'TopLevelDomainCollection', + 'TriggeredJobHistory', + 'TriggeredJobHistoryCollection', + 'TriggeredJobRun', + 'TriggeredWebJob', + 'TriggeredWebJobCollection', + 'Twitter', + 'TwitterRegistration', + 'Usage', + 'UsageCollection', + 'User', + 'ValidateRequest', + 'ValidateResponse', + 'ValidateResponseError', + 'VirtualApplication', + 'VirtualDirectory', + 'VirtualIPMapping', + 'VirtualNetworkProfile', + 'VnetGateway', + 'VnetInfo', + 'VnetParameters', + 'VnetRoute', + 'VnetValidationFailureDetails', + 'VnetValidationTestFailure', + 'WebAppCollection', + 'WebAppInstanceStatusCollection', + 'WebJob', + 'WebJobCollection', + 'WebSiteInstanceStatus', + 'WorkerPool', + 'WorkerPoolCollection', + 'WorkerPoolResource', + 'AccessControlEntryAction', + 'AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem', + 'AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem', + 'AppServicePlanRestrictions', + 'AutoHealActionType', + 'AzureResourceType', + 'AzureStorageState', + 'AzureStorageType', + 'BackupItemStatus', + 'BackupRestoreOperationType', + 'BuildStatus', + 'BuiltInAuthenticationProvider', + 'CertificateOrderActionType', + 'CertificateOrderStatus', + 'CertificateProductType', + 'Channels', + 'CheckNameResourceTypes', + 'ClientCertMode', + 'CloneAbilityResult', + 'ComputeModeOptions', + 'ConnectionStringType', + 'ContinuousWebJobStatus', + 'CookieExpirationConvention', + 'CustomHostNameDnsRecordType', + 'DatabaseType', + 'DnsType', + 'DnsVerificationTestResult', + 'DomainPatchResourcePropertiesDomainNotRenewableReasonsItem', + 'DomainPropertiesDomainNotRenewableReasonsItem', + 'DomainStatus', + 'DomainType', + 'Enum4', + 'Enum5', + 'ForwardProxyConvention', + 'FrequencyUnit', + 'FtpsState', + 'HostNameType', + 'HostType', + 'HostingEnvironmentStatus', + 'InAvailabilityReasonType', + 'IpFilterTag', + 'IssueType', + 'KeyVaultSecretStatus', + 'LoadBalancingMode', + 'LogLevel', + 'MSDeployLogEntryType', + 'MSDeployProvisioningState', + 'ManagedPipelineMode', + 'ManagedServiceIdentityType', + 'MySqlMigrationType', + 'NotificationLevel', + 'OperationStatus', + 'ProvisioningState', + 'PublicCertificateLocation', + 'PublishingProfileFormat', + 'RedundancyMode', + 'RenderingType', + 'ResourceScopeType', + 'RouteType', + 'ScmType', + 'SiteAvailabilityState', + 'SiteExtensionType', + 'SiteLoadBalancing', + 'SiteRuntimeState', + 'SkuName', + 'SolutionType', + 'SslState', + 'StatusOptions', + 'SupportedTlsVersions', + 'TriggerTypes', + 'TriggeredWebJobStatus', + 'UnauthenticatedClientAction', + 'UnauthenticatedClientActionV2', + 'UsageState', + 'ValidateResourceTypes', + 'WebJobType', + 'WorkerSizeOptions', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models.py new file mode 100644 index 000000000000..6b1ed1fdf867 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models.py @@ -0,0 +1,16943 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + + +class AbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period identified in diagnosis. + + :param start_time: Start time of the downtime. + :type start_time: ~datetime.datetime + :param end_time: End time of the downtime. + :type end_time: ~datetime.datetime + :param events: List of Possible Cause of downtime. + :type events: list[~azure.mgmt.web.v2020_06_01.models.DetectorAbnormalTimePeriod] + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_06_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'events': {'key': 'events', 'type': '[DetectorAbnormalTimePeriod]'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + **kwargs + ): + super(AbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.events = kwargs.get('events', None) + self.solutions = kwargs.get('solutions', None) + + +class Address(msrest.serialization.Model): + """Address information for domain registration. + + All required parameters must be populated in order to send to Azure. + + :param address1: Required. First line of an Address. + :type address1: str + :param address2: The second line of the Address. Optional. + :type address2: str + :param city: Required. The city for the address. + :type city: str + :param country: Required. The country for the address. + :type country: str + :param postal_code: Required. The postal code for the address. + :type postal_code: str + :param state: Required. The state or province for the address. + :type state: str + """ + + _validation = { + 'address1': {'required': True}, + 'city': {'required': True}, + 'country': {'required': True}, + 'postal_code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'address1': {'key': 'address1', 'type': 'str'}, + 'address2': {'key': 'address2', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + 'country': {'key': 'country', 'type': 'str'}, + 'postal_code': {'key': 'postalCode', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Address, self).__init__(**kwargs) + self.address1 = kwargs['address1'] + self.address2 = kwargs.get('address2', None) + self.city = kwargs['city'] + self.country = kwargs['country'] + self.postal_code = kwargs['postal_code'] + self.state = kwargs['state'] + + +class ProxyOnlyResource(msrest.serialization.Model): + """Azure proxy only resource. This resource is not tracked by Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProxyOnlyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kwargs.get('kind', None) + self.type = None + + +class AddressResponse(ProxyOnlyResource): + """Describes main public IP address and any extra virtual IPs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param service_ip_address: Main public virtual IP. + :type service_ip_address: str + :param internal_ip_address: Virtual Network internal IP address of the App Service Environment + if it is in internal load-balancing mode. + :type internal_ip_address: str + :param outbound_ip_addresses: IP addresses appearing on outbound connections. + :type outbound_ip_addresses: list[str] + :param vip_mappings: Additional virtual IPs. + :type vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_ip_address': {'key': 'properties.serviceIpAddress', 'type': 'str'}, + 'internal_ip_address': {'key': 'properties.internalIpAddress', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': '[str]'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + } + + def __init__( + self, + **kwargs + ): + super(AddressResponse, self).__init__(**kwargs) + self.service_ip_address = kwargs.get('service_ip_address', None) + self.internal_ip_address = kwargs.get('internal_ip_address', None) + self.outbound_ip_addresses = kwargs.get('outbound_ip_addresses', None) + self.vip_mappings = kwargs.get('vip_mappings', None) + + +class AllowedAudiencesValidation(ProxyOnlyResource): + """AllowedAudiencesValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AllowedAudiencesValidation, self).__init__(**kwargs) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + + +class AnalysisData(msrest.serialization.Model): + """Class Representing Detector Evidence used for analysis. + + :param source: Name of the Detector. + :type source: str + :param detector_definition: Detector Definition. + :type detector_definition: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :param metrics: Source Metrics. + :type metrics: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSet] + :param data: Additional Source Data. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param detector_meta_data: Detector Meta Data. + :type detector_meta_data: ~azure.mgmt.web.v2020_06_01.models.ResponseMetaData + """ + + _attribute_map = { + 'source': {'key': 'source', 'type': 'str'}, + 'detector_definition': {'key': 'detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'metrics', 'type': '[DiagnosticMetricSet]'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'detector_meta_data': {'key': 'detectorMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + **kwargs + ): + super(AnalysisData, self).__init__(**kwargs) + self.source = kwargs.get('source', None) + self.detector_definition = kwargs.get('detector_definition', None) + self.metrics = kwargs.get('metrics', None) + self.data = kwargs.get('data', None) + self.detector_meta_data = kwargs.get('detector_meta_data', None) + + +class AnalysisDefinition(ProxyOnlyResource): + """Definition of Analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Description of the Analysis. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AnalysisDefinition, self).__init__(**kwargs) + self.description = None + + +class ApiDefinitionInfo(msrest.serialization.Model): + """Information about the formal API definition for the app. + + :param url: The URL of the API definition. + :type url: str + """ + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiDefinitionInfo, self).__init__(**kwargs) + self.url = kwargs.get('url', None) + + +class ApiManagementConfig(msrest.serialization.Model): + """Azure API management (APIM) configuration linked to the app. + + :param id: APIM-Api Identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiManagementConfig, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class ApplicationLogsConfig(msrest.serialization.Model): + """Application logs configuration. + + :param file_system: Application logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemApplicationLogsConfig + :param azure_table_storage: Application logs to azure table storage configuration. + :type azure_table_storage: + ~azure.mgmt.web.v2020_06_01.models.AzureTableStorageApplicationLogsConfig + :param azure_blob_storage: Application logs to blob storage configuration. + :type azure_blob_storage: + ~azure.mgmt.web.v2020_06_01.models.AzureBlobStorageApplicationLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemApplicationLogsConfig'}, + 'azure_table_storage': {'key': 'azureTableStorage', 'type': 'AzureTableStorageApplicationLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageApplicationLogsConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationLogsConfig, self).__init__(**kwargs) + self.file_system = kwargs.get('file_system', None) + self.azure_table_storage = kwargs.get('azure_table_storage', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class ApplicationStack(msrest.serialization.Model): + """Application stack. + + :param name: Application stack name. + :type name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStack] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'str'}, + 'dependency': {'key': 'dependency', 'type': 'str'}, + 'major_versions': {'key': 'majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStack, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + self.dependency = kwargs.get('dependency', None) + self.major_versions = kwargs.get('major_versions', None) + self.frameworks = kwargs.get('frameworks', None) + + +class ApplicationStackCollection(msrest.serialization.Model): + """Collection of Application Stacks. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStackResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationStackResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStackCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ApplicationStackResource(ProxyOnlyResource): + """ARM resource for a ApplicationStack. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_properties_name: Application stack name. + :type name_properties_name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStack] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'display': {'key': 'properties.display', 'type': 'str'}, + 'dependency': {'key': 'properties.dependency', 'type': 'str'}, + 'major_versions': {'key': 'properties.majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'properties.frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStackResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.display = kwargs.get('display', None) + self.dependency = kwargs.get('dependency', None) + self.major_versions = kwargs.get('major_versions', None) + self.frameworks = kwargs.get('frameworks', None) + + +class AppRegistration(ProxyOnlyResource): + """AppRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param app_id: + :type app_id: str + :param app_secret_setting_name: + :type app_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'app_id': {'key': 'properties.appId', 'type': 'str'}, + 'app_secret_setting_name': {'key': 'properties.appSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppRegistration, self).__init__(**kwargs) + self.app_id = kwargs.get('app_id', None) + self.app_secret_setting_name = kwargs.get('app_secret_setting_name', None) + + +class AppServiceCertificate(msrest.serialization.Model): + """Key Vault container for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'key_vault_id': {'key': 'keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificate, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceCertificateCollection(msrest.serialization.Model): + """Collection of certificate order certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Resource(msrest.serialization.Model): + """Azure resource. This resource is tracked in Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kwargs.get('kind', None) + self.location = kwargs['location'] + self.type = None + self.tags = kwargs.get('tags', None) + + +class AppServiceCertificateOrder(Resource): + """SSL certificate purchase order. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrder, self).__init__(**kwargs) + self.certificates = kwargs.get('certificates', None) + self.distinguished_name = kwargs.get('distinguished_name', None) + self.domain_verification_token = None + self.validity_in_years = kwargs.get('validity_in_years', 1) + self.key_size = kwargs.get('key_size', 2048) + self.product_type = kwargs.get('product_type', None) + self.auto_renew = kwargs.get('auto_renew', True) + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = kwargs.get('csr', None) + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificateOrderCollection(msrest.serialization.Model): + """Collection of certificate orders. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateOrder]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrderCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServiceCertificateOrderPatchResource(ProxyOnlyResource): + """ARM resource for a certificate order that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrderPatchResource, self).__init__(**kwargs) + self.certificates = kwargs.get('certificates', None) + self.distinguished_name = kwargs.get('distinguished_name', None) + self.domain_verification_token = None + self.validity_in_years = kwargs.get('validity_in_years', 1) + self.key_size = kwargs.get('key_size', 2048) + self.product_type = kwargs.get('product_type', None) + self.auto_renew = kwargs.get('auto_renew', True) + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = kwargs.get('csr', None) + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificatePatchResource(ProxyOnlyResource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificatePatchResource, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceCertificateResource(Resource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateResource, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceEnvironment(msrest.serialization.Model): + """Description of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Name of the App Service Environment. + :type name: str + :param location: Required. Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Required. Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Required. Description of worker pools with worker size IDs, VM sizes, and + number of workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'name': {'required': True}, + 'location': {'required': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'virtual_network': {'required': True}, + 'worker_pools': {'required': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironment, self).__init__(**kwargs) + self.name = kwargs['name'] + self.location = kwargs['location'] + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs['virtual_network'] + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs['worker_pools'] + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppServiceEnvironmentCollection(msrest.serialization.Model): + """Collection of App Service Environments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceEnvironmentResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServiceEnvironmentPatchResource(ProxyOnlyResource): + """ARM resource for a app service environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location: Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentPatchResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.location = kwargs.get('location', None) + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs.get('virtual_network', None) + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs.get('worker_pools', None) + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppServiceEnvironmentResource(Resource): + """App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location_properties_location: Location of the App Service Environment, e.g. "West US". + :type location_properties_location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location_properties_location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.location_properties_location = kwargs.get('location_properties_location', None) + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs.get('virtual_network', None) + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs.get('worker_pools', None) + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppServicePlan(Resource): + """App Service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: If Linux app service plan :code:`true`, + :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlan, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.worker_tier_name = kwargs.get('worker_tier_name', None) + self.status = None + self.subscription = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = kwargs.get('per_site_scaling', False) + self.maximum_elastic_worker_count = kwargs.get('maximum_elastic_worker_count', None) + self.number_of_sites = None + self.is_spot = kwargs.get('is_spot', None) + self.spot_expiration_time = kwargs.get('spot_expiration_time', None) + self.free_offer_expiration_time = kwargs.get('free_offer_expiration_time', None) + self.resource_group = None + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.target_worker_count = kwargs.get('target_worker_count', None) + self.target_worker_size_id = kwargs.get('target_worker_size_id', None) + self.provisioning_state = None + + +class AppServicePlanCollection(msrest.serialization.Model): + """Collection of App Service plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServicePlan] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServicePlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlanCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServicePlanPatchResource(ProxyOnlyResource): + """ARM resource for a app service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: This needs to set to :code:`true` when creating a Linux App + Service Plan, along with :code:`kind` set to :code:`Linux`. It should + be :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlanPatchResource, self).__init__(**kwargs) + self.worker_tier_name = kwargs.get('worker_tier_name', None) + self.status = None + self.subscription = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = kwargs.get('per_site_scaling', False) + self.maximum_elastic_worker_count = kwargs.get('maximum_elastic_worker_count', None) + self.number_of_sites = None + self.is_spot = kwargs.get('is_spot', None) + self.spot_expiration_time = kwargs.get('spot_expiration_time', None) + self.free_offer_expiration_time = kwargs.get('free_offer_expiration_time', None) + self.resource_group = None + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.target_worker_count = kwargs.get('target_worker_count', None) + self.target_worker_size_id = kwargs.get('target_worker_size_id', None) + self.provisioning_state = None + + +class ArmIdWrapper(msrest.serialization.Model): + """A wrapper for an ARM resource id. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ArmIdWrapper, self).__init__(**kwargs) + self.id = None + + +class AuthPlatform(ProxyOnlyResource): + """AuthPlatform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param runtime_version: + :type runtime_version: str + :param config_file_path: + :type config_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'config_file_path': {'key': 'properties.configFilePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AuthPlatform, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.config_file_path = kwargs.get('config_file_path', None) + + +class AutoHealActions(msrest.serialization.Model): + """Actions which to take by the auto-heal module when a rule is triggered. + + :param action_type: Predefined action to be taken. Possible values include: "Recycle", + "LogEvent", "CustomAction". + :type action_type: str or ~azure.mgmt.web.v2020_06_01.models.AutoHealActionType + :param custom_action: Custom action to be taken. + :type custom_action: ~azure.mgmt.web.v2020_06_01.models.AutoHealCustomAction + :param min_process_execution_time: Minimum time the process must execute + before taking the action. + :type min_process_execution_time: str + """ + + _attribute_map = { + 'action_type': {'key': 'actionType', 'type': 'str'}, + 'custom_action': {'key': 'customAction', 'type': 'AutoHealCustomAction'}, + 'min_process_execution_time': {'key': 'minProcessExecutionTime', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealActions, self).__init__(**kwargs) + self.action_type = kwargs.get('action_type', None) + self.custom_action = kwargs.get('custom_action', None) + self.min_process_execution_time = kwargs.get('min_process_execution_time', None) + + +class AutoHealCustomAction(msrest.serialization.Model): + """Custom action to be executed +when an auto heal rule is triggered. + + :param exe: Executable to be run. + :type exe: str + :param parameters: Parameters for the executable. + :type parameters: str + """ + + _attribute_map = { + 'exe': {'key': 'exe', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealCustomAction, self).__init__(**kwargs) + self.exe = kwargs.get('exe', None) + self.parameters = kwargs.get('parameters', None) + + +class AutoHealRules(msrest.serialization.Model): + """Rules that can be defined for auto-heal. + + :param triggers: Conditions that describe when to execute the auto-heal actions. + :type triggers: ~azure.mgmt.web.v2020_06_01.models.AutoHealTriggers + :param actions: Actions to be executed when a rule is triggered. + :type actions: ~azure.mgmt.web.v2020_06_01.models.AutoHealActions + """ + + _attribute_map = { + 'triggers': {'key': 'triggers', 'type': 'AutoHealTriggers'}, + 'actions': {'key': 'actions', 'type': 'AutoHealActions'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealRules, self).__init__(**kwargs) + self.triggers = kwargs.get('triggers', None) + self.actions = kwargs.get('actions', None) + + +class AutoHealTriggers(msrest.serialization.Model): + """Triggers for auto-heal. + + :param requests: A rule based on total requests. + :type requests: ~azure.mgmt.web.v2020_06_01.models.RequestsBasedTrigger + :param private_bytes_in_kb: A rule based on private bytes. + :type private_bytes_in_kb: int + :param status_codes: A rule based on status codes. + :type status_codes: list[~azure.mgmt.web.v2020_06_01.models.StatusCodesBasedTrigger] + :param slow_requests: A rule based on request execution time. + :type slow_requests: ~azure.mgmt.web.v2020_06_01.models.SlowRequestsBasedTrigger + """ + + _attribute_map = { + 'requests': {'key': 'requests', 'type': 'RequestsBasedTrigger'}, + 'private_bytes_in_kb': {'key': 'privateBytesInKB', 'type': 'int'}, + 'status_codes': {'key': 'statusCodes', 'type': '[StatusCodesBasedTrigger]'}, + 'slow_requests': {'key': 'slowRequests', 'type': 'SlowRequestsBasedTrigger'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealTriggers, self).__init__(**kwargs) + self.requests = kwargs.get('requests', None) + self.private_bytes_in_kb = kwargs.get('private_bytes_in_kb', None) + self.status_codes = kwargs.get('status_codes', None) + self.slow_requests = kwargs.get('slow_requests', None) + + +class AzureActiveDirectory(ProxyOnlyResource): + """AzureActiveDirectory. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryLogin + :param validation: + :type validation: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryValidation + :param is_auto_provisioned: + :type is_auto_provisioned: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AzureActiveDirectoryRegistration'}, + 'login': {'key': 'properties.login', 'type': 'AzureActiveDirectoryLogin'}, + 'validation': {'key': 'properties.validation', 'type': 'AzureActiveDirectoryValidation'}, + 'is_auto_provisioned': {'key': 'properties.isAutoProvisioned', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + self.validation = kwargs.get('validation', None) + self.is_auto_provisioned = kwargs.get('is_auto_provisioned', None) + + +class AzureActiveDirectoryLogin(ProxyOnlyResource): + """AzureActiveDirectoryLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param disable_www_authenticate: + :type disable_www_authenticate: bool + :param login_parameters: + :type login_parameters: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'disable_www_authenticate': {'key': 'properties.disableWWWAuthenticate', 'type': 'bool'}, + 'login_parameters': {'key': 'properties.loginParameters', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryLogin, self).__init__(**kwargs) + self.disable_www_authenticate = kwargs.get('disable_www_authenticate', None) + self.login_parameters = kwargs.get('login_parameters', None) + + +class AzureActiveDirectoryRegistration(ProxyOnlyResource): + """AzureActiveDirectoryRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param open_id_issuer: + :type open_id_issuer: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: + :type client_secret_certificate_thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'open_id_issuer': {'key': 'properties.openIdIssuer', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryRegistration, self).__init__(**kwargs) + self.open_id_issuer = kwargs.get('open_id_issuer', None) + self.client_id = kwargs.get('client_id', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + self.client_secret_certificate_thumbprint = kwargs.get('client_secret_certificate_thumbprint', None) + + +class AzureActiveDirectoryValidation(ProxyOnlyResource): + """AzureActiveDirectoryValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param jwt_claim_checks: + :type jwt_claim_checks: ~azure.mgmt.web.v2020_06_01.models.JwtClaimChecks + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'jwt_claim_checks': {'key': 'properties.jwtClaimChecks', 'type': 'JwtClaimChecks'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryValidation, self).__init__(**kwargs) + self.jwt_claim_checks = kwargs.get('jwt_claim_checks', None) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + + +class AzureBlobStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs azure blob storage configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureBlobStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + self.sas_url = kwargs.get('sas_url', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + + +class AzureBlobStorageHttpLogsConfig(msrest.serialization.Model): + """Http logs to azure blob storage configuration. + + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureBlobStorageHttpLogsConfig, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + self.enabled = kwargs.get('enabled', None) + + +class AzureStorageInfoValue(msrest.serialization.Model): + """Azure Files or Blob Storage access information value for dictionary storage. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of storage. Possible values include: "AzureFiles", "AzureBlob". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.AzureStorageType + :param account_name: Name of the storage account. + :type account_name: str + :param share_name: Name of the file share (container name, for Blob storage). + :type share_name: str + :param access_key: Access key for the storage account. + :type access_key: str + :param mount_path: Path to mount the storage within the site's runtime environment. + :type mount_path: str + :ivar state: State of the storage account. Possible values include: "Ok", "InvalidCredentials", + "InvalidShare". + :vartype state: str or ~azure.mgmt.web.v2020_06_01.models.AzureStorageState + """ + + _validation = { + 'state': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'account_name': {'key': 'accountName', 'type': 'str'}, + 'share_name': {'key': 'shareName', 'type': 'str'}, + 'access_key': {'key': 'accessKey', 'type': 'str'}, + 'mount_path': {'key': 'mountPath', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureStorageInfoValue, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.account_name = kwargs.get('account_name', None) + self.share_name = kwargs.get('share_name', None) + self.access_key = kwargs.get('access_key', None) + self.mount_path = kwargs.get('mount_path', None) + self.state = None + + +class AzureStoragePropertyDictionaryResource(ProxyOnlyResource): + """AzureStorageInfo dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Azure storage accounts. + :type properties: dict[str, ~azure.mgmt.web.v2020_06_01.models.AzureStorageInfoValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{AzureStorageInfoValue}'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureStoragePropertyDictionaryResource, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class AzureTableStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs to Azure table storage configuration. + + All required parameters must be populated in order to send to Azure. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + :param sas_url: Required. SAS URL to an Azure table with add/query/delete permissions. + :type sas_url: str + """ + + _validation = { + 'sas_url': {'required': True}, + } + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureTableStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + self.sas_url = kwargs['sas_url'] + + +class BackupItem(ProxyOnlyResource): + """Backup description. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar backup_id: Id of the backup. + :vartype backup_id: int + :ivar storage_account_url: SAS URL for the storage account container which contains this + backup. + :vartype storage_account_url: str + :ivar blob_name: Name of the blob which contains data for this backup. + :vartype blob_name: str + :ivar name_properties_name: Name of this backup. + :vartype name_properties_name: str + :ivar status: Backup status. Possible values include: "InProgress", "Failed", "Succeeded", + "TimedOut", "Created", "Skipped", "PartiallySucceeded", "DeleteInProgress", "DeleteFailed", + "Deleted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.BackupItemStatus + :ivar size_in_bytes: Size of the backup in bytes. + :vartype size_in_bytes: long + :ivar created: Timestamp of the backup creation. + :vartype created: ~datetime.datetime + :ivar log: Details regarding this backup. Might contain an error message. + :vartype log: str + :ivar databases: List of databases included in the backup. + :vartype databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + :ivar scheduled: True if this backup has been created due to a schedule being triggered. + :vartype scheduled: bool + :ivar last_restore_time_stamp: Timestamp of a last restore operation which used this backup. + :vartype last_restore_time_stamp: ~datetime.datetime + :ivar finished_time_stamp: Timestamp when this backup finished. + :vartype finished_time_stamp: ~datetime.datetime + :ivar correlation_id: Unique correlation identifier. Please use this along with the timestamp + while communicating with Azure support. + :vartype correlation_id: str + :ivar website_size_in_bytes: Size of the original web app which has been backed up. + :vartype website_size_in_bytes: long + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'backup_id': {'readonly': True}, + 'storage_account_url': {'readonly': True}, + 'blob_name': {'readonly': True}, + 'name_properties_name': {'readonly': True}, + 'status': {'readonly': True}, + 'size_in_bytes': {'readonly': True}, + 'created': {'readonly': True}, + 'log': {'readonly': True}, + 'databases': {'readonly': True}, + 'scheduled': {'readonly': True}, + 'last_restore_time_stamp': {'readonly': True}, + 'finished_time_stamp': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'website_size_in_bytes': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backup_id': {'key': 'properties.id', 'type': 'int'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'size_in_bytes': {'key': 'properties.sizeInBytes', 'type': 'long'}, + 'created': {'key': 'properties.created', 'type': 'iso-8601'}, + 'log': {'key': 'properties.log', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'scheduled': {'key': 'properties.scheduled', 'type': 'bool'}, + 'last_restore_time_stamp': {'key': 'properties.lastRestoreTimeStamp', 'type': 'iso-8601'}, + 'finished_time_stamp': {'key': 'properties.finishedTimeStamp', 'type': 'iso-8601'}, + 'correlation_id': {'key': 'properties.correlationId', 'type': 'str'}, + 'website_size_in_bytes': {'key': 'properties.websiteSizeInBytes', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupItem, self).__init__(**kwargs) + self.backup_id = None + self.storage_account_url = None + self.blob_name = None + self.name_properties_name = None + self.status = None + self.size_in_bytes = None + self.created = None + self.log = None + self.databases = None + self.scheduled = None + self.last_restore_time_stamp = None + self.finished_time_stamp = None + self.correlation_id = None + self.website_size_in_bytes = None + + +class BackupItemCollection(msrest.serialization.Model): + """Collection of backup items. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.BackupItem] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackupItem]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupItemCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class BackupRequest(ProxyOnlyResource): + """Description of a backup which will be performed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param backup_name: Name of the backup. + :type backup_name: str + :param enabled: True if the backup schedule is enabled (must be included in that case), false + if the backup schedule should be disabled. + :type enabled: bool + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param backup_schedule: Schedule for the backup if it is executed periodically. + :type backup_schedule: ~azure.mgmt.web.v2020_06_01.models.BackupSchedule + :param databases: Databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backup_name': {'key': 'properties.backupName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'backup_schedule': {'key': 'properties.backupSchedule', 'type': 'BackupSchedule'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupRequest, self).__init__(**kwargs) + self.backup_name = kwargs.get('backup_name', None) + self.enabled = kwargs.get('enabled', None) + self.storage_account_url = kwargs.get('storage_account_url', None) + self.backup_schedule = kwargs.get('backup_schedule', None) + self.databases = kwargs.get('databases', None) + + +class BackupSchedule(msrest.serialization.Model): + """Description of a backup schedule. Describes how often should be the backup performed and what should be the retention policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param frequency_interval: Required. How often the backup should be executed (e.g. for weekly + backup, this should be set to 7 and FrequencyUnit should be set to Day). + :type frequency_interval: int + :param frequency_unit: Required. The unit of time for how often the backup should be executed + (e.g. for weekly backup, this should be set to Day and FrequencyInterval should be set to 7). + Possible values include: "Day", "Hour". Default value: "Day". + :type frequency_unit: str or ~azure.mgmt.web.v2020_06_01.models.FrequencyUnit + :param keep_at_least_one_backup: Required. True if the retention policy should always keep at + least one backup in the storage account, regardless how old it is; false otherwise. + :type keep_at_least_one_backup: bool + :param retention_period_in_days: Required. After how many days backups should be deleted. + :type retention_period_in_days: int + :param start_time: When the schedule should start working. + :type start_time: ~datetime.datetime + :ivar last_execution_time: Last time when this schedule was triggered. + :vartype last_execution_time: ~datetime.datetime + """ + + _validation = { + 'frequency_interval': {'required': True}, + 'frequency_unit': {'required': True}, + 'keep_at_least_one_backup': {'required': True}, + 'retention_period_in_days': {'required': True}, + 'last_execution_time': {'readonly': True}, + } + + _attribute_map = { + 'frequency_interval': {'key': 'frequencyInterval', 'type': 'int'}, + 'frequency_unit': {'key': 'frequencyUnit', 'type': 'str'}, + 'keep_at_least_one_backup': {'key': 'keepAtLeastOneBackup', 'type': 'bool'}, + 'retention_period_in_days': {'key': 'retentionPeriodInDays', 'type': 'int'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'last_execution_time': {'key': 'lastExecutionTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupSchedule, self).__init__(**kwargs) + self.frequency_interval = kwargs.get('frequency_interval', 7) + self.frequency_unit = kwargs.get('frequency_unit', "Day") + self.keep_at_least_one_backup = kwargs.get('keep_at_least_one_backup', True) + self.retention_period_in_days = kwargs.get('retention_period_in_days', 30) + self.start_time = kwargs.get('start_time', None) + self.last_execution_time = None + + +class BillingMeter(ProxyOnlyResource): + """App Service billing entity that contains information about meter which the Azure billing system utilizes to charge users for services. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param meter_id: Meter GUID onboarded in Commerce. + :type meter_id: str + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param short_name: Short Name from App Service Azure pricing Page. + :type short_name: str + :param friendly_name: Friendly name of the meter. + :type friendly_name: str + :param resource_type: App Service ResourceType meter used for. + :type resource_type: str + :param os_type: App Service OS type meter used for. + :type os_type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'meter_id': {'key': 'properties.meterId', 'type': 'str'}, + 'billing_location': {'key': 'properties.billingLocation', 'type': 'str'}, + 'short_name': {'key': 'properties.shortName', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'os_type': {'key': 'properties.osType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BillingMeter, self).__init__(**kwargs) + self.meter_id = kwargs.get('meter_id', None) + self.billing_location = kwargs.get('billing_location', None) + self.short_name = kwargs.get('short_name', None) + self.friendly_name = kwargs.get('friendly_name', None) + self.resource_type = kwargs.get('resource_type', None) + self.os_type = kwargs.get('os_type', None) + + +class BillingMeterCollection(msrest.serialization.Model): + """Collection of Billing Meters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.BillingMeter] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BillingMeter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BillingMeterCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class BlobStorageTokenStore(ProxyOnlyResource): + """BlobStorageTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sas_url_setting_name: + :type sas_url_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sas_url_setting_name': {'key': 'properties.sasUrlSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BlobStorageTokenStore, self).__init__(**kwargs) + self.sas_url_setting_name = kwargs.get('sas_url_setting_name', None) + + +class Capability(msrest.serialization.Model): + """Describes the capabilities/features allowed for a specific SKU. + + :param name: Name of the SKU capability. + :type name: str + :param value: Value of the SKU capability. + :type value: str + :param reason: Reason of the SKU capability. + :type reason: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + 'reason': {'key': 'reason', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Capability, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + self.reason = kwargs.get('reason', None) + + +class Certificate(Resource): + """SSL certificate for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Certificate, self).__init__(**kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = kwargs.get('host_names', None) + self.pfx_blob = kwargs.get('pfx_blob', None) + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = kwargs.get('password', None) + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.key_vault_secret_status = None + self.server_farm_id = kwargs.get('server_farm_id', None) + self.canonical_name = kwargs.get('canonical_name', None) + + +class CertificateCollection(msrest.serialization.Model): + """Collection of certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Certificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Certificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CertificateDetails(msrest.serialization.Model): + """SSL certificate details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar version: Certificate Version. + :vartype version: int + :ivar serial_number: Certificate Serial Number. + :vartype serial_number: str + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + :ivar subject: Certificate Subject. + :vartype subject: str + :ivar not_before: Date Certificate is valid from. + :vartype not_before: ~datetime.datetime + :ivar not_after: Date Certificate is valid to. + :vartype not_after: ~datetime.datetime + :ivar signature_algorithm: Certificate Signature algorithm. + :vartype signature_algorithm: str + :ivar issuer: Certificate Issuer. + :vartype issuer: str + :ivar raw_data: Raw certificate data. + :vartype raw_data: str + """ + + _validation = { + 'version': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'subject': {'readonly': True}, + 'not_before': {'readonly': True}, + 'not_after': {'readonly': True}, + 'signature_algorithm': {'readonly': True}, + 'issuer': {'readonly': True}, + 'raw_data': {'readonly': True}, + } + + _attribute_map = { + 'version': {'key': 'version', 'type': 'int'}, + 'serial_number': {'key': 'serialNumber', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'subject': {'key': 'subject', 'type': 'str'}, + 'not_before': {'key': 'notBefore', 'type': 'iso-8601'}, + 'not_after': {'key': 'notAfter', 'type': 'iso-8601'}, + 'signature_algorithm': {'key': 'signatureAlgorithm', 'type': 'str'}, + 'issuer': {'key': 'issuer', 'type': 'str'}, + 'raw_data': {'key': 'rawData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateDetails, self).__init__(**kwargs) + self.version = None + self.serial_number = None + self.thumbprint = None + self.subject = None + self.not_before = None + self.not_after = None + self.signature_algorithm = None + self.issuer = None + self.raw_data = None + + +class CertificateEmail(ProxyOnlyResource): + """SSL certificate email. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param email_id: Email id. + :type email_id: str + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'email_id': {'key': 'properties.emailId', 'type': 'str'}, + 'time_stamp': {'key': 'properties.timeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateEmail, self).__init__(**kwargs) + self.email_id = kwargs.get('email_id', None) + self.time_stamp = kwargs.get('time_stamp', None) + + +class CertificateOrderAction(ProxyOnlyResource): + """Certificate order action. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar action_type: Action type. Possible values include: "CertificateIssued", + "CertificateOrderCanceled", "CertificateOrderCreated", "CertificateRevoked", + "DomainValidationComplete", "FraudDetected", "OrgNameChange", "OrgValidationComplete", + "SanDrop", "FraudCleared", "CertificateExpired", "CertificateExpirationWarning", + "FraudDocumentationRequired", "Unknown". + :vartype action_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderActionType + :ivar created_at: Time at which the certificate action was performed. + :vartype created_at: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'action_type': {'readonly': True}, + 'created_at': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'action_type': {'key': 'properties.actionType', 'type': 'str'}, + 'created_at': {'key': 'properties.createdAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateOrderAction, self).__init__(**kwargs) + self.action_type = None + self.created_at = None + + +class CertificatePatchResource(ProxyOnlyResource): + """ARM resource for a certificate. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificatePatchResource, self).__init__(**kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = kwargs.get('host_names', None) + self.pfx_blob = kwargs.get('pfx_blob', None) + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = kwargs.get('password', None) + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.key_vault_secret_status = None + self.server_farm_id = kwargs.get('server_farm_id', None) + self.canonical_name = kwargs.get('canonical_name', None) + + +class ClientRegistration(ProxyOnlyResource): + """ClientRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ClientRegistration, self).__init__(**kwargs) + self.client_id = kwargs.get('client_id', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + + +class CloningInfo(msrest.serialization.Model): + """Information needed for cloning operation. + + All required parameters must be populated in order to send to Azure. + + :param correlation_id: Correlation ID of cloning operation. This ID ties multiple cloning + operations + together to use the same snapshot. + :type correlation_id: str + :param overwrite: :code:`true` to overwrite destination app; otherwise, + :code:`false`. + :type overwrite: bool + :param clone_custom_host_names: :code:`true` to clone custom hostnames from source + app; otherwise, :code:`false`. + :type clone_custom_host_names: bool + :param clone_source_control: :code:`true` to clone source control from source app; + otherwise, :code:`false`. + :type clone_source_control: bool + :param source_web_app_id: Required. ARM resource ID of the source app. App resource ID is of + the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type source_web_app_id: str + :param source_web_app_location: Location of source app ex: West US or North Europe. + :type source_web_app_location: str + :param hosting_environment: App Service Environment. + :type hosting_environment: str + :param app_settings_overrides: Application setting overrides for cloned app. If specified, + these settings override the settings cloned + from source app. Otherwise, application settings from source app are retained. + :type app_settings_overrides: dict[str, str] + :param configure_load_balancing: :code:`true` to configure load balancing for + source and destination app. + :type configure_load_balancing: bool + :param traffic_manager_profile_id: ARM resource ID of the Traffic Manager profile to use, if it + exists. Traffic Manager resource ID is of the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/trafficManagerProfiles/{profileName}. + :type traffic_manager_profile_id: str + :param traffic_manager_profile_name: Name of Traffic Manager profile to create. This is only + needed if Traffic Manager profile does not already exist. + :type traffic_manager_profile_name: str + """ + + _validation = { + 'source_web_app_id': {'required': True}, + } + + _attribute_map = { + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'overwrite': {'key': 'overwrite', 'type': 'bool'}, + 'clone_custom_host_names': {'key': 'cloneCustomHostNames', 'type': 'bool'}, + 'clone_source_control': {'key': 'cloneSourceControl', 'type': 'bool'}, + 'source_web_app_id': {'key': 'sourceWebAppId', 'type': 'str'}, + 'source_web_app_location': {'key': 'sourceWebAppLocation', 'type': 'str'}, + 'hosting_environment': {'key': 'hostingEnvironment', 'type': 'str'}, + 'app_settings_overrides': {'key': 'appSettingsOverrides', 'type': '{str}'}, + 'configure_load_balancing': {'key': 'configureLoadBalancing', 'type': 'bool'}, + 'traffic_manager_profile_id': {'key': 'trafficManagerProfileId', 'type': 'str'}, + 'traffic_manager_profile_name': {'key': 'trafficManagerProfileName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CloningInfo, self).__init__(**kwargs) + self.correlation_id = kwargs.get('correlation_id', None) + self.overwrite = kwargs.get('overwrite', None) + self.clone_custom_host_names = kwargs.get('clone_custom_host_names', None) + self.clone_source_control = kwargs.get('clone_source_control', None) + self.source_web_app_id = kwargs['source_web_app_id'] + self.source_web_app_location = kwargs.get('source_web_app_location', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + self.app_settings_overrides = kwargs.get('app_settings_overrides', None) + self.configure_load_balancing = kwargs.get('configure_load_balancing', None) + self.traffic_manager_profile_id = kwargs.get('traffic_manager_profile_id', None) + self.traffic_manager_profile_name = kwargs.get('traffic_manager_profile_name', None) + + +class Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties(msrest.serialization.Model): + """Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Principal Id of user assigned identity. + :vartype principal_id: str + :ivar client_id: Client Id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionStringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Connection strings. + :type properties: dict[str, ~azure.mgmt.web.v2020_06_01.models.ConnStringValueTypePair] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{ConnStringValueTypePair}'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionStringDictionary, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class ConnStringInfo(msrest.serialization.Model): + """Database connection string information. + + :param name: Name of connection string. + :type name: str + :param connection_string: Connection string value. + :type connection_string: str + :param type: Type of database. Possible values include: "MySql", "SQLServer", "SQLAzure", + "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", "RedisCache", + "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ConnectionStringType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnStringInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.connection_string = kwargs.get('connection_string', None) + self.type = kwargs.get('type', None) + + +class ConnStringValueTypePair(msrest.serialization.Model): + """Database connection string value to type pair. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Value of pair. + :type value: str + :param type: Required. Type of database. Possible values include: "MySql", "SQLServer", + "SQLAzure", "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", + "RedisCache", "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ConnectionStringType + """ + + _validation = { + 'value': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnStringValueTypePair, self).__init__(**kwargs) + self.value = kwargs['value'] + self.type = kwargs['type'] + + +class Contact(msrest.serialization.Model): + """Contact information for domain registration. If 'Domain Privacy' option is not selected then the contact information is made publicly available through the Whois +directories as per ICANN requirements. + + All required parameters must be populated in order to send to Azure. + + :param address_mailing: Mailing address. + :type address_mailing: ~azure.mgmt.web.v2020_06_01.models.Address + :param email: Required. Email address. + :type email: str + :param fax: Fax number. + :type fax: str + :param job_title: Job title. + :type job_title: str + :param name_first: Required. First name. + :type name_first: str + :param name_last: Required. Last name. + :type name_last: str + :param name_middle: Middle name. + :type name_middle: str + :param organization: Organization contact belongs to. + :type organization: str + :param phone: Required. Phone number. + :type phone: str + """ + + _validation = { + 'email': {'required': True}, + 'name_first': {'required': True}, + 'name_last': {'required': True}, + 'phone': {'required': True}, + } + + _attribute_map = { + 'address_mailing': {'key': 'addressMailing', 'type': 'Address'}, + 'email': {'key': 'email', 'type': 'str'}, + 'fax': {'key': 'fax', 'type': 'str'}, + 'job_title': {'key': 'jobTitle', 'type': 'str'}, + 'name_first': {'key': 'nameFirst', 'type': 'str'}, + 'name_last': {'key': 'nameLast', 'type': 'str'}, + 'name_middle': {'key': 'nameMiddle', 'type': 'str'}, + 'organization': {'key': 'organization', 'type': 'str'}, + 'phone': {'key': 'phone', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Contact, self).__init__(**kwargs) + self.address_mailing = kwargs.get('address_mailing', None) + self.email = kwargs['email'] + self.fax = kwargs.get('fax', None) + self.job_title = kwargs.get('job_title', None) + self.name_first = kwargs['name_first'] + self.name_last = kwargs['name_last'] + self.name_middle = kwargs.get('name_middle', None) + self.organization = kwargs.get('organization', None) + self.phone = kwargs['phone'] + + +class ContainerCpuStatistics(msrest.serialization.Model): + """ContainerCpuStatistics. + + :param cpu_usage: + :type cpu_usage: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuUsage + :param system_cpu_usage: + :type system_cpu_usage: long + :param online_cpu_count: + :type online_cpu_count: int + :param throttling_data: + :type throttling_data: ~azure.mgmt.web.v2020_06_01.models.ContainerThrottlingData + """ + + _attribute_map = { + 'cpu_usage': {'key': 'cpuUsage', 'type': 'ContainerCpuUsage'}, + 'system_cpu_usage': {'key': 'systemCpuUsage', 'type': 'long'}, + 'online_cpu_count': {'key': 'onlineCpuCount', 'type': 'int'}, + 'throttling_data': {'key': 'throttlingData', 'type': 'ContainerThrottlingData'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerCpuStatistics, self).__init__(**kwargs) + self.cpu_usage = kwargs.get('cpu_usage', None) + self.system_cpu_usage = kwargs.get('system_cpu_usage', None) + self.online_cpu_count = kwargs.get('online_cpu_count', None) + self.throttling_data = kwargs.get('throttling_data', None) + + +class ContainerCpuUsage(msrest.serialization.Model): + """ContainerCpuUsage. + + :param total_usage: + :type total_usage: long + :param per_cpu_usage: + :type per_cpu_usage: list[long] + :param kernel_mode_usage: + :type kernel_mode_usage: long + :param user_mode_usage: + :type user_mode_usage: long + """ + + _attribute_map = { + 'total_usage': {'key': 'totalUsage', 'type': 'long'}, + 'per_cpu_usage': {'key': 'perCpuUsage', 'type': '[long]'}, + 'kernel_mode_usage': {'key': 'kernelModeUsage', 'type': 'long'}, + 'user_mode_usage': {'key': 'userModeUsage', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerCpuUsage, self).__init__(**kwargs) + self.total_usage = kwargs.get('total_usage', None) + self.per_cpu_usage = kwargs.get('per_cpu_usage', None) + self.kernel_mode_usage = kwargs.get('kernel_mode_usage', None) + self.user_mode_usage = kwargs.get('user_mode_usage', None) + + +class ContainerInfo(msrest.serialization.Model): + """ContainerInfo. + + :param current_time_stamp: + :type current_time_stamp: ~datetime.datetime + :param previous_time_stamp: + :type previous_time_stamp: ~datetime.datetime + :param current_cpu_stats: + :type current_cpu_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuStatistics + :param previous_cpu_stats: + :type previous_cpu_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuStatistics + :param memory_stats: + :type memory_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerMemoryStatistics + :param name: + :type name: str + :param id: + :type id: str + :param eth0: + :type eth0: ~azure.mgmt.web.v2020_06_01.models.ContainerNetworkInterfaceStatistics + """ + + _attribute_map = { + 'current_time_stamp': {'key': 'currentTimeStamp', 'type': 'iso-8601'}, + 'previous_time_stamp': {'key': 'previousTimeStamp', 'type': 'iso-8601'}, + 'current_cpu_stats': {'key': 'currentCpuStats', 'type': 'ContainerCpuStatistics'}, + 'previous_cpu_stats': {'key': 'previousCpuStats', 'type': 'ContainerCpuStatistics'}, + 'memory_stats': {'key': 'memoryStats', 'type': 'ContainerMemoryStatistics'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'eth0': {'key': 'eth0', 'type': 'ContainerNetworkInterfaceStatistics'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerInfo, self).__init__(**kwargs) + self.current_time_stamp = kwargs.get('current_time_stamp', None) + self.previous_time_stamp = kwargs.get('previous_time_stamp', None) + self.current_cpu_stats = kwargs.get('current_cpu_stats', None) + self.previous_cpu_stats = kwargs.get('previous_cpu_stats', None) + self.memory_stats = kwargs.get('memory_stats', None) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.eth0 = kwargs.get('eth0', None) + + +class ContainerMemoryStatistics(msrest.serialization.Model): + """ContainerMemoryStatistics. + + :param usage: + :type usage: long + :param max_usage: + :type max_usage: long + :param limit: + :type limit: long + """ + + _attribute_map = { + 'usage': {'key': 'usage', 'type': 'long'}, + 'max_usage': {'key': 'maxUsage', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerMemoryStatistics, self).__init__(**kwargs) + self.usage = kwargs.get('usage', None) + self.max_usage = kwargs.get('max_usage', None) + self.limit = kwargs.get('limit', None) + + +class ContainerNetworkInterfaceStatistics(msrest.serialization.Model): + """ContainerNetworkInterfaceStatistics. + + :param rx_bytes: + :type rx_bytes: long + :param rx_packets: + :type rx_packets: long + :param rx_errors: + :type rx_errors: long + :param rx_dropped: + :type rx_dropped: long + :param tx_bytes: + :type tx_bytes: long + :param tx_packets: + :type tx_packets: long + :param tx_errors: + :type tx_errors: long + :param tx_dropped: + :type tx_dropped: long + """ + + _attribute_map = { + 'rx_bytes': {'key': 'rxBytes', 'type': 'long'}, + 'rx_packets': {'key': 'rxPackets', 'type': 'long'}, + 'rx_errors': {'key': 'rxErrors', 'type': 'long'}, + 'rx_dropped': {'key': 'rxDropped', 'type': 'long'}, + 'tx_bytes': {'key': 'txBytes', 'type': 'long'}, + 'tx_packets': {'key': 'txPackets', 'type': 'long'}, + 'tx_errors': {'key': 'txErrors', 'type': 'long'}, + 'tx_dropped': {'key': 'txDropped', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerNetworkInterfaceStatistics, self).__init__(**kwargs) + self.rx_bytes = kwargs.get('rx_bytes', None) + self.rx_packets = kwargs.get('rx_packets', None) + self.rx_errors = kwargs.get('rx_errors', None) + self.rx_dropped = kwargs.get('rx_dropped', None) + self.tx_bytes = kwargs.get('tx_bytes', None) + self.tx_packets = kwargs.get('tx_packets', None) + self.tx_errors = kwargs.get('tx_errors', None) + self.tx_dropped = kwargs.get('tx_dropped', None) + + +class ContainerThrottlingData(msrest.serialization.Model): + """ContainerThrottlingData. + + :param periods: + :type periods: int + :param throttled_periods: + :type throttled_periods: int + :param throttled_time: + :type throttled_time: int + """ + + _attribute_map = { + 'periods': {'key': 'periods', 'type': 'int'}, + 'throttled_periods': {'key': 'throttledPeriods', 'type': 'int'}, + 'throttled_time': {'key': 'throttledTime', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerThrottlingData, self).__init__(**kwargs) + self.periods = kwargs.get('periods', None) + self.throttled_periods = kwargs.get('throttled_periods', None) + self.throttled_time = kwargs.get('throttled_time', None) + + +class ContinuousWebJob(ProxyOnlyResource): + """Continuous Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param status: Job status. Possible values include: "Initializing", "Starting", "Running", + "PendingRestart", "Stopped". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobStatus + :param detailed_status: Detailed status. + :type detailed_status: str + :param log_url: Log URL. + :type log_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'detailed_status': {'key': 'properties.detailed_status', 'type': 'str'}, + 'log_url': {'key': 'properties.log_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(ContinuousWebJob, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.detailed_status = kwargs.get('detailed_status', None) + self.log_url = kwargs.get('log_url', None) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class ContinuousWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ContinuousWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ContinuousWebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CookieExpiration(ProxyOnlyResource): + """CookieExpiration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param convention: Possible values include: "FixedTime", "IdentityProviderDerived". + :type convention: str or ~azure.mgmt.web.v2020_06_01.models.CookieExpirationConvention + :param time_to_expiration: + :type time_to_expiration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'time_to_expiration': {'key': 'properties.timeToExpiration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CookieExpiration, self).__init__(**kwargs) + self.convention = kwargs.get('convention', None) + self.time_to_expiration = kwargs.get('time_to_expiration', None) + + +class CorsSettings(msrest.serialization.Model): + """Cross-Origin Resource Sharing (CORS) settings for the app. + + :param allowed_origins: Gets or sets the list of origins that should be allowed to make cross- + origin + calls (for example: http://example.com:12345). Use "*" to allow all. + :type allowed_origins: list[str] + :param support_credentials: Gets or sets whether CORS requests with credentials are allowed. + See + https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#Requests_with_credentials + for more details. + :type support_credentials: bool + """ + + _attribute_map = { + 'allowed_origins': {'key': 'allowedOrigins', 'type': '[str]'}, + 'support_credentials': {'key': 'supportCredentials', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CorsSettings, self).__init__(**kwargs) + self.allowed_origins = kwargs.get('allowed_origins', None) + self.support_credentials = kwargs.get('support_credentials', None) + + +class CsmCopySlotEntity(msrest.serialization.Model): + """Copy deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during copy operation. + :type target_slot: str + :param site_config: Required. The site object which will be merged with the source slot site + to produce new destination slot site object. + :code:`null` to just copy source slot content. Otherwise a + :code:`Site` + object with properties to override source slot site. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + """ + + _validation = { + 'target_slot': {'required': True}, + 'site_config': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'site_config': {'key': 'siteConfig', 'type': 'SiteConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmCopySlotEntity, self).__init__(**kwargs) + self.target_slot = kwargs['target_slot'] + self.site_config = kwargs['site_config'] + + +class CsmMoveResourceEnvelope(msrest.serialization.Model): + """Object with a list of the resources that need to be moved and the resource group they should be moved to. + + :param target_resource_group: + :type target_resource_group: str + :param resources: + :type resources: list[str] + """ + + _validation = { + 'target_resource_group': {'max_length': 90, 'min_length': 1, 'pattern': r' ^[-\w\._\(\)]+[^\.]$'}, + } + + _attribute_map = { + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'resources': {'key': 'resources', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmMoveResourceEnvelope, self).__init__(**kwargs) + self.target_resource_group = kwargs.get('target_resource_group', None) + self.resources = kwargs.get('resources', None) + + +class CsmOperationCollection(msrest.serialization.Model): + """Collection of Azure resource manager operation metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.CsmOperationDescription] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmOperationDescription]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CsmOperationDescription(msrest.serialization.Model): + """Description of an operation available for Microsoft.Web resource provider. + + :param name: + :type name: str + :param display: Meta data about operation used for display in portal. + :type display: ~azure.mgmt.web.v2020_06_01.models.CsmOperationDisplay + :param origin: + :type origin: str + :param properties: Properties available for a Microsoft.Web resource provider operation. + :type properties: ~azure.mgmt.web.v2020_06_01.models.CsmOperationDescriptionProperties + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'CsmOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'CsmOperationDescriptionProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + self.origin = kwargs.get('origin', None) + self.properties = kwargs.get('properties', None) + + +class CsmOperationDescriptionProperties(msrest.serialization.Model): + """Properties available for a Microsoft.Web resource provider operation. + + :param service_specification: Resource metrics service provided by Microsoft.Insights resource + provider. + :type service_specification: ~azure.mgmt.web.v2020_06_01.models.ServiceSpecification + """ + + _attribute_map = { + 'service_specification': {'key': 'serviceSpecification', 'type': 'ServiceSpecification'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDescriptionProperties, self).__init__(**kwargs) + self.service_specification = kwargs.get('service_specification', None) + + +class CsmOperationDisplay(msrest.serialization.Model): + """Meta data about operation used for display in portal. + + :param provider: + :type provider: str + :param resource: + :type resource: str + :param operation: + :type operation: str + :param description: + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDisplay, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + self.description = kwargs.get('description', None) + + +class CsmPublishingCredentialsPoliciesCollection(ProxyOnlyResource): + """Publishing Credentials Policies collection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param ftp: Whether FTP is allowed. + :type ftp: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :param scm: Whether Scm Basic Auth is allowed. + :type scm: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ftp': {'key': 'properties.ftp', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + 'scm': {'key': 'properties.scm', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesCollection, self).__init__(**kwargs) + self.ftp = kwargs.get('ftp', None) + self.scm = kwargs.get('scm', None) + + +class CsmPublishingCredentialsPoliciesEntity(ProxyOnlyResource): + """Publishing Credentials Policies parameters. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allow: :code:`true` to allow access to a publishing method; otherwise, + :code:`false`. + :type allow: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allow': {'key': 'properties.allow', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesEntity, self).__init__(**kwargs) + self.allow = kwargs.get('allow', None) + + +class CsmPublishingProfileOptions(msrest.serialization.Model): + """Publishing options for requested profile. + + :param format: Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp. Possible values include: "FileZilla3", "WebDeploy", "Ftp". + :type format: str or ~azure.mgmt.web.v2020_06_01.models.PublishingProfileFormat + :param include_disaster_recovery_endpoints: Include the DisasterRecover endpoint if true. + :type include_disaster_recovery_endpoints: bool + """ + + _attribute_map = { + 'format': {'key': 'format', 'type': 'str'}, + 'include_disaster_recovery_endpoints': {'key': 'includeDisasterRecoveryEndpoints', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingProfileOptions, self).__init__(**kwargs) + self.format = kwargs.get('format', None) + self.include_disaster_recovery_endpoints = kwargs.get('include_disaster_recovery_endpoints', None) + + +class CsmSlotEntity(msrest.serialization.Model): + """Deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during swap operation. + :type target_slot: str + :param preserve_vnet: Required. :code:`true` to preserve Virtual Network to the + slot during swap; otherwise, :code:`false`. + :type preserve_vnet: bool + """ + + _validation = { + 'target_slot': {'required': True}, + 'preserve_vnet': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'preserve_vnet': {'key': 'preserveVnet', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmSlotEntity, self).__init__(**kwargs) + self.target_slot = kwargs['target_slot'] + self.preserve_vnet = kwargs['preserve_vnet'] + + +class CsmUsageQuota(msrest.serialization.Model): + """Usage of the quota resource. + + :param unit: Units of measurement for the quota resource. + :type unit: str + :param next_reset_time: Next reset time for the resource counter. + :type next_reset_time: ~datetime.datetime + :param current_value: The current value of the resource counter. + :type current_value: long + :param limit: The resource limit. + :type limit: long + :param name: Quota name. + :type name: ~azure.mgmt.web.v2020_06_01.models.LocalizableString + """ + + _attribute_map = { + 'unit': {'key': 'unit', 'type': 'str'}, + 'next_reset_time': {'key': 'nextResetTime', 'type': 'iso-8601'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'LocalizableString'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmUsageQuota, self).__init__(**kwargs) + self.unit = kwargs.get('unit', None) + self.next_reset_time = kwargs.get('next_reset_time', None) + self.current_value = kwargs.get('current_value', None) + self.limit = kwargs.get('limit', None) + self.name = kwargs.get('name', None) + + +class CsmUsageQuotaCollection(msrest.serialization.Model): + """Collection of CSM usage quotas. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuota] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmUsageQuota]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmUsageQuotaCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CustomHostnameAnalysisResult(ProxyOnlyResource): + """Custom domain analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar is_hostname_already_verified: :code:`true` if hostname is already verified; + otherwise, :code:`false`. + :vartype is_hostname_already_verified: bool + :ivar custom_domain_verification_test: DNS verification test result. Possible values include: + "Passed", "Failed", "Skipped". + :vartype custom_domain_verification_test: str or + ~azure.mgmt.web.v2020_06_01.models.DnsVerificationTestResult + :ivar custom_domain_verification_failure_info: Raw failure information if DNS verification + fails. + :vartype custom_domain_verification_failure_info: + ~azure.mgmt.web.v2020_06_01.models.ErrorEntity + :ivar has_conflict_on_scale_unit: :code:`true` if there is a conflict on a scale + unit; otherwise, :code:`false`. + :vartype has_conflict_on_scale_unit: bool + :ivar has_conflict_across_subscription: :code:`true` if there is a conflict across + subscriptions; otherwise, :code:`false`. + :vartype has_conflict_across_subscription: bool + :ivar conflicting_app_resource_id: Name of the conflicting app on scale unit if it's within the + same subscription. + :vartype conflicting_app_resource_id: str + :param c_name_records: CName records controller can see for this hostname. + :type c_name_records: list[str] + :param txt_records: TXT records controller can see for this hostname. + :type txt_records: list[str] + :param a_records: A records controller can see for this hostname. + :type a_records: list[str] + :param alternate_c_name_records: Alternate CName records controller can see for this hostname. + :type alternate_c_name_records: list[str] + :param alternate_txt_records: Alternate TXT records controller can see for this hostname. + :type alternate_txt_records: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'is_hostname_already_verified': {'readonly': True}, + 'custom_domain_verification_test': {'readonly': True}, + 'custom_domain_verification_failure_info': {'readonly': True}, + 'has_conflict_on_scale_unit': {'readonly': True}, + 'has_conflict_across_subscription': {'readonly': True}, + 'conflicting_app_resource_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_hostname_already_verified': {'key': 'properties.isHostnameAlreadyVerified', 'type': 'bool'}, + 'custom_domain_verification_test': {'key': 'properties.customDomainVerificationTest', 'type': 'str'}, + 'custom_domain_verification_failure_info': {'key': 'properties.customDomainVerificationFailureInfo', 'type': 'ErrorEntity'}, + 'has_conflict_on_scale_unit': {'key': 'properties.hasConflictOnScaleUnit', 'type': 'bool'}, + 'has_conflict_across_subscription': {'key': 'properties.hasConflictAcrossSubscription', 'type': 'bool'}, + 'conflicting_app_resource_id': {'key': 'properties.conflictingAppResourceId', 'type': 'str'}, + 'c_name_records': {'key': 'properties.cNameRecords', 'type': '[str]'}, + 'txt_records': {'key': 'properties.txtRecords', 'type': '[str]'}, + 'a_records': {'key': 'properties.aRecords', 'type': '[str]'}, + 'alternate_c_name_records': {'key': 'properties.alternateCNameRecords', 'type': '[str]'}, + 'alternate_txt_records': {'key': 'properties.alternateTxtRecords', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomHostnameAnalysisResult, self).__init__(**kwargs) + self.is_hostname_already_verified = None + self.custom_domain_verification_test = None + self.custom_domain_verification_failure_info = None + self.has_conflict_on_scale_unit = None + self.has_conflict_across_subscription = None + self.conflicting_app_resource_id = None + self.c_name_records = kwargs.get('c_name_records', None) + self.txt_records = kwargs.get('txt_records', None) + self.a_records = kwargs.get('a_records', None) + self.alternate_c_name_records = kwargs.get('alternate_c_name_records', None) + self.alternate_txt_records = kwargs.get('alternate_txt_records', None) + + +class CustomOpenIdConnectProvider(ProxyOnlyResource): + """CustomOpenIdConnectProvider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectLogin + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'OpenIdConnectRegistration'}, + 'login': {'key': 'properties.login', 'type': 'OpenIdConnectLogin'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomOpenIdConnectProvider, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + + +class DatabaseBackupSetting(msrest.serialization.Model): + """Database backup settings. + + All required parameters must be populated in order to send to Azure. + + :param database_type: Required. Database type (e.g. SqlAzure / MySql). Possible values include: + "SqlAzure", "MySql", "LocalMySql", "PostgreSql". + :type database_type: str or ~azure.mgmt.web.v2020_06_01.models.DatabaseType + :param name: + :type name: str + :param connection_string_name: Contains a connection string name that is linked to the + SiteConfig.ConnectionStrings. + This is used during restore with overwrite connection strings options. + :type connection_string_name: str + :param connection_string: Contains a connection string to a database which is being backed up + or restored. If the restore should happen to a new database, the database name inside is the + new one. + :type connection_string: str + """ + + _validation = { + 'database_type': {'required': True}, + } + + _attribute_map = { + 'database_type': {'key': 'databaseType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string_name': {'key': 'connectionStringName', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DatabaseBackupSetting, self).__init__(**kwargs) + self.database_type = kwargs['database_type'] + self.name = kwargs.get('name', None) + self.connection_string_name = kwargs.get('connection_string_name', None) + self.connection_string = kwargs.get('connection_string', None) + + +class DataSource(msrest.serialization.Model): + """Class representing data source used by the detectors. + + :param instructions: Instructions if any for the data source. + :type instructions: list[str] + :param data_source_uri: Datasource Uri Links. + :type data_source_uri: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + """ + + _attribute_map = { + 'instructions': {'key': 'instructions', 'type': '[str]'}, + 'data_source_uri': {'key': 'dataSourceUri', 'type': '[NameValuePair]'}, + } + + def __init__( + self, + **kwargs + ): + super(DataSource, self).__init__(**kwargs) + self.instructions = kwargs.get('instructions', None) + self.data_source_uri = kwargs.get('data_source_uri', None) + + +class DataTableResponseColumn(msrest.serialization.Model): + """Column definition. + + :param column_name: Name of the column. + :type column_name: str + :param data_type: Data type which looks like 'String' or 'Int32'. + :type data_type: str + :param column_type: Column Type. + :type column_type: str + """ + + _attribute_map = { + 'column_name': {'key': 'columnName', 'type': 'str'}, + 'data_type': {'key': 'dataType', 'type': 'str'}, + 'column_type': {'key': 'columnType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DataTableResponseColumn, self).__init__(**kwargs) + self.column_name = kwargs.get('column_name', None) + self.data_type = kwargs.get('data_type', None) + self.column_type = kwargs.get('column_type', None) + + +class DataTableResponseObject(msrest.serialization.Model): + """Data Table which defines columns and raw row values. + + :param table_name: Name of the table. + :type table_name: str + :param columns: List of columns with data types. + :type columns: list[~azure.mgmt.web.v2020_06_01.models.DataTableResponseColumn] + :param rows: Raw row values. + :type rows: list[list[str]] + """ + + _attribute_map = { + 'table_name': {'key': 'tableName', 'type': 'str'}, + 'columns': {'key': 'columns', 'type': '[DataTableResponseColumn]'}, + 'rows': {'key': 'rows', 'type': '[[str]]'}, + } + + def __init__( + self, + **kwargs + ): + super(DataTableResponseObject, self).__init__(**kwargs) + self.table_name = kwargs.get('table_name', None) + self.columns = kwargs.get('columns', None) + self.rows = kwargs.get('rows', None) + + +class DefaultErrorResponse(msrest.serialization.Model): + """App Service error response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: Error model. + :vartype error: ~azure.mgmt.web.v2020_06_01.models.DefaultErrorResponseError + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'DefaultErrorResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponse, self).__init__(**kwargs) + self.error = None + + +class DefaultErrorResponseError(msrest.serialization.Model): + """Error model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + :param details: + :type details: list[~azure.mgmt.web.v2020_06_01.models.DefaultErrorResponseErrorDetailsItem] + :ivar innererror: More information to debug error. + :vartype innererror: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'innererror': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[DefaultErrorResponseErrorDetailsItem]'}, + 'innererror': {'key': 'innererror', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseError, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = kwargs.get('details', None) + self.innererror = None + + +class DefaultErrorResponseErrorDetailsItem(msrest.serialization.Model): + """Detailed errors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseErrorDetailsItem, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + + +class DeletedAppRestoreRequest(ProxyOnlyResource): + """Details about restoring a deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param deleted_site_id: ARM resource ID of the deleted app. Example: + /subscriptions/{subId}/providers/Microsoft.Web/deletedSites/{deletedSiteId}. + :type deleted_site_id: str + :param recover_configuration: If true, deleted site configuration, in addition to content, will + be restored. + :type recover_configuration: bool + :param snapshot_time: Point in time to restore the deleted app from, formatted as a DateTime + string. + If unspecified, default value is the time that the app was deleted. + :type snapshot_time: str + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'str'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedAppRestoreRequest, self).__init__(**kwargs) + self.deleted_site_id = kwargs.get('deleted_site_id', None) + self.recover_configuration = kwargs.get('recover_configuration', None) + self.snapshot_time = kwargs.get('snapshot_time', None) + self.use_dr_secondary = kwargs.get('use_dr_secondary', None) + + +class DeletedSite(ProxyOnlyResource): + """A deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar deleted_site_id: Numeric id for the deleted site. + :vartype deleted_site_id: int + :ivar deleted_timestamp: Time in UTC when the app was deleted. + :vartype deleted_timestamp: str + :ivar subscription: Subscription containing the deleted site. + :vartype subscription: str + :ivar resource_group: ResourceGroup that contained the deleted site. + :vartype resource_group: str + :ivar deleted_site_name: Name of the deleted site. + :vartype deleted_site_name: str + :ivar slot: Slot of the deleted site. + :vartype slot: str + :ivar kind_properties_kind: Kind of site that was deleted. + :vartype kind_properties_kind: str + :ivar geo_region_name: Geo Region of the deleted site. + :vartype geo_region_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'deleted_site_id': {'readonly': True}, + 'deleted_timestamp': {'readonly': True}, + 'subscription': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'deleted_site_name': {'readonly': True}, + 'slot': {'readonly': True}, + 'kind_properties_kind': {'readonly': True}, + 'geo_region_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'int'}, + 'deleted_timestamp': {'key': 'properties.deletedTimestamp', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'deleted_site_name': {'key': 'properties.deletedSiteName', 'type': 'str'}, + 'slot': {'key': 'properties.slot', 'type': 'str'}, + 'kind_properties_kind': {'key': 'properties.kind', 'type': 'str'}, + 'geo_region_name': {'key': 'properties.geoRegionName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedSite, self).__init__(**kwargs) + self.deleted_site_id = None + self.deleted_timestamp = None + self.subscription = None + self.resource_group = None + self.deleted_site_name = None + self.slot = None + self.kind_properties_kind = None + self.geo_region_name = None + + +class DeletedWebAppCollection(msrest.serialization.Model): + """Collection of deleted apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DeletedSite] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeletedSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedWebAppCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Deployment(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param status: Deployment status. + :type status: int + :param message: Details about deployment status. + :type message: str + :param author: Who authored the deployment. + :type author: str + :param deployer: Who performed the deployment. + :type deployer: str + :param author_email: Author email. + :type author_email: str + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param active: True if deployment is currently active, false if completed and null if not + started. + :type active: bool + :param details: Details on deployment. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'int'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'author': {'key': 'properties.author', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'author_email': {'key': 'properties.author_email', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'active': {'key': 'properties.active', 'type': 'bool'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Deployment, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.message = kwargs.get('message', None) + self.author = kwargs.get('author', None) + self.deployer = kwargs.get('deployer', None) + self.author_email = kwargs.get('author_email', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.active = kwargs.get('active', None) + self.details = kwargs.get('details', None) + + +class DeploymentCollection(msrest.serialization.Model): + """Collection of app deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Deployment] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Deployment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DeploymentLocations(msrest.serialization.Model): + """List of available locations (regions or App Service Environments) for +deployment of App Service resources. + + :param locations: Available regions. + :type locations: list[~azure.mgmt.web.v2020_06_01.models.GeoRegion] + :param hosting_environments: Available App Service Environments with full descriptions of the + environments. + :type hosting_environments: list[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironment] + :param hosting_environment_deployment_infos: Available App Service Environments with basic + information. + :type hosting_environment_deployment_infos: + list[~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDeploymentInfo] + """ + + _attribute_map = { + 'locations': {'key': 'locations', 'type': '[GeoRegion]'}, + 'hosting_environments': {'key': 'hostingEnvironments', 'type': '[AppServiceEnvironment]'}, + 'hosting_environment_deployment_infos': {'key': 'hostingEnvironmentDeploymentInfos', 'type': '[HostingEnvironmentDeploymentInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentLocations, self).__init__(**kwargs) + self.locations = kwargs.get('locations', None) + self.hosting_environments = kwargs.get('hosting_environments', None) + self.hosting_environment_deployment_infos = kwargs.get('hosting_environment_deployment_infos', None) + + +class DetectorAbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period detected. + + :param start_time: Start time of the correlated event. + :type start_time: ~datetime.datetime + :param end_time: End time of the correlated event. + :type end_time: ~datetime.datetime + :param message: Message describing the event. + :type message: str + :param source: Represents the name of the Detector. + :type source: str + :param priority: Represents the rank of the Detector. + :type priority: float + :param meta_data: Downtime metadata. + :type meta_data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param type: Represents the type of the Detector. Possible values include: "ServiceIncident", + "AppDeployment", "AppCrash", "RuntimeIssueDetected", "AseDeployment", "UserIssue", + "PlatformIssue", "Other". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.IssueType + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_06_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'message': {'key': 'message', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'float'}, + 'meta_data': {'key': 'metaData', 'type': '[[NameValuePair]]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorAbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.message = kwargs.get('message', None) + self.source = kwargs.get('source', None) + self.priority = kwargs.get('priority', None) + self.meta_data = kwargs.get('meta_data', None) + self.type = kwargs.get('type', None) + self.solutions = kwargs.get('solutions', None) + + +class DetectorDefinition(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar display_name: Display name of the detector. + :vartype display_name: str + :ivar description: Description of the detector. + :vartype description: str + :ivar rank: Detector Rank. + :vartype rank: float + :ivar is_enabled: Flag representing whether detector is enabled or not. + :vartype is_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'display_name': {'readonly': True}, + 'description': {'readonly': True}, + 'rank': {'readonly': True}, + 'is_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'rank': {'key': 'properties.rank', 'type': 'float'}, + 'is_enabled': {'key': 'properties.isEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorDefinition, self).__init__(**kwargs) + self.display_name = None + self.description = None + self.rank = None + self.is_enabled = None + + +class DetectorInfo(msrest.serialization.Model): + """Definition of Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Short description of the detector and its purpose. + :vartype description: str + :ivar category: Support Category. + :vartype category: str + :ivar sub_category: Support Sub Category. + :vartype sub_category: str + :ivar support_topic_id: Support Topic Id. + :vartype support_topic_id: str + """ + + _validation = { + 'description': {'readonly': True}, + 'category': {'readonly': True}, + 'sub_category': {'readonly': True}, + 'support_topic_id': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'sub_category': {'key': 'subCategory', 'type': 'str'}, + 'support_topic_id': {'key': 'supportTopicId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorInfo, self).__init__(**kwargs) + self.description = None + self.category = None + self.sub_category = None + self.support_topic_id = None + + +class DetectorResponse(ProxyOnlyResource): + """Class representing Response from Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param metadata: metadata for the detector. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.DetectorInfo + :param dataset: Data Set. + :type dataset: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticData] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'DetectorInfo'}, + 'dataset': {'key': 'properties.dataset', 'type': '[DiagnosticData]'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorResponse, self).__init__(**kwargs) + self.metadata = kwargs.get('metadata', None) + self.dataset = kwargs.get('dataset', None) + + +class DetectorResponseCollection(msrest.serialization.Model): + """Collection of detector responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DetectorResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorResponseCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticAnalysis(ProxyOnlyResource): + """Class representing a diagnostic analysis done on an application. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param abnormal_time_periods: List of time periods. + :type abnormal_time_periods: list[~azure.mgmt.web.v2020_06_01.models.AbnormalTimePeriod] + :param payload: Data by each detector. + :type payload: list[~azure.mgmt.web.v2020_06_01.models.AnalysisData] + :param non_correlated_detectors: Data by each detector for detectors that did not corelate. + :type non_correlated_detectors: list[~azure.mgmt.web.v2020_06_01.models.DetectorDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[AbnormalTimePeriod]'}, + 'payload': {'key': 'properties.payload', 'type': '[AnalysisData]'}, + 'non_correlated_detectors': {'key': 'properties.nonCorrelatedDetectors', 'type': '[DetectorDefinition]'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticAnalysis, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.abnormal_time_periods = kwargs.get('abnormal_time_periods', None) + self.payload = kwargs.get('payload', None) + self.non_correlated_detectors = kwargs.get('non_correlated_detectors', None) + + +class DiagnosticAnalysisCollection(msrest.serialization.Model): + """Collection of Diagnostic Analyses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AnalysisDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticAnalysisCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticCategory(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Description of the diagnostic category. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticCategory, self).__init__(**kwargs) + self.description = None + + +class DiagnosticCategoryCollection(msrest.serialization.Model): + """Collection of Diagnostic Categories. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DiagnosticCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticCategoryCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticData(msrest.serialization.Model): + """Set of data with rendering instructions. + + :param table: Data in table form. + :type table: ~azure.mgmt.web.v2020_06_01.models.DataTableResponseObject + :param rendering_properties: Properties that describe how the table should be rendered. + :type rendering_properties: ~azure.mgmt.web.v2020_06_01.models.Rendering + """ + + _attribute_map = { + 'table': {'key': 'table', 'type': 'DataTableResponseObject'}, + 'rendering_properties': {'key': 'renderingProperties', 'type': 'Rendering'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticData, self).__init__(**kwargs) + self.table = kwargs.get('table', None) + self.rendering_properties = kwargs.get('rendering_properties', None) + + +class DiagnosticDetectorCollection(msrest.serialization.Model): + """Collection of Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DetectorDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticDetectorCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticDetectorResponse(ProxyOnlyResource): + """Class representing Response from Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param issue_detected: Flag representing Issue was detected. + :type issue_detected: bool + :param detector_definition: Detector's definition. + :type detector_definition: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :param metrics: Metrics provided by the detector. + :type metrics: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSet] + :param abnormal_time_periods: List of Correlated events found by the detector. + :type abnormal_time_periods: + list[~azure.mgmt.web.v2020_06_01.models.DetectorAbnormalTimePeriod] + :param data: Additional Data that detector wants to send. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param response_meta_data: Meta Data. + :type response_meta_data: ~azure.mgmt.web.v2020_06_01.models.ResponseMetaData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'issue_detected': {'key': 'properties.issueDetected', 'type': 'bool'}, + 'detector_definition': {'key': 'properties.detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'properties.metrics', 'type': '[DiagnosticMetricSet]'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[DetectorAbnormalTimePeriod]'}, + 'data': {'key': 'properties.data', 'type': '[[NameValuePair]]'}, + 'response_meta_data': {'key': 'properties.responseMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticDetectorResponse, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.issue_detected = kwargs.get('issue_detected', None) + self.detector_definition = kwargs.get('detector_definition', None) + self.metrics = kwargs.get('metrics', None) + self.abnormal_time_periods = kwargs.get('abnormal_time_periods', None) + self.data = kwargs.get('data', None) + self.response_meta_data = kwargs.get('response_meta_data', None) + + +class DiagnosticMetricSample(msrest.serialization.Model): + """Class representing Diagnostic Metric. + + :param timestamp: Time at which metric is measured. + :type timestamp: ~datetime.datetime + :param role_instance: Role Instance. Null if this counter is not per instance + This is returned and should be whichever instance name we desire to be returned + i.e. CPU and Memory return RDWORKERNAME (LargeDed..._IN_0) + where RDWORKERNAME is Machine name below and RoleInstance name in parenthesis. + :type role_instance: str + :param total: Total value of the metric. If multiple measurements are made this will have sum + of all. + :type total: float + :param maximum: Maximum of the metric sampled during the time period. + :type maximum: float + :param minimum: Minimum of the metric sampled during the time period. + :type minimum: float + :param is_aggregated: Whether the values are aggregates across all workers or not. + :type is_aggregated: bool + """ + + _attribute_map = { + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'role_instance': {'key': 'roleInstance', 'type': 'str'}, + 'total': {'key': 'total', 'type': 'float'}, + 'maximum': {'key': 'maximum', 'type': 'float'}, + 'minimum': {'key': 'minimum', 'type': 'float'}, + 'is_aggregated': {'key': 'isAggregated', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticMetricSample, self).__init__(**kwargs) + self.timestamp = kwargs.get('timestamp', None) + self.role_instance = kwargs.get('role_instance', None) + self.total = kwargs.get('total', None) + self.maximum = kwargs.get('maximum', None) + self.minimum = kwargs.get('minimum', None) + self.is_aggregated = kwargs.get('is_aggregated', None) + + +class DiagnosticMetricSet(msrest.serialization.Model): + """Class representing Diagnostic Metric information. + + :param name: Name of the metric. + :type name: str + :param unit: Metric's unit. + :type unit: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. Supported grains at the moment are PT1M, PT1H, P1D. + :type time_grain: str + :param values: Collection of metric values for the selected period based on the + {Microsoft.Web.Hosting.Administration.DiagnosticMetricSet.TimeGrain}. + :type values: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[DiagnosticMetricSample]'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticMetricSet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.unit = kwargs.get('unit', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.time_grain = kwargs.get('time_grain', None) + self.values = kwargs.get('values', None) + + +class Dimension(msrest.serialization.Model): + """Dimension of a resource metric. For e.g. instance specific HTTP requests for a web app, +where instance name is dimension of the metric HTTP request. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param internal_name: + :type internal_name: str + :param to_be_exported_for_shoebox: + :type to_be_exported_for_shoebox: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + 'to_be_exported_for_shoebox': {'key': 'toBeExportedForShoebox', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(Dimension, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.internal_name = kwargs.get('internal_name', None) + self.to_be_exported_for_shoebox = kwargs.get('to_be_exported_for_shoebox', None) + + +class Domain(Resource): + """Information about a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_06_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_06_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_06_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_06_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.DomainPropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Domain, self).__init__(**kwargs) + self.contact_admin = kwargs.get('contact_admin', None) + self.contact_billing = kwargs.get('contact_billing', None) + self.contact_registrant = kwargs.get('contact_registrant', None) + self.contact_tech = kwargs.get('contact_tech', None) + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = kwargs.get('privacy', None) + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = kwargs.get('auto_renew', True) + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = kwargs.get('consent', None) + self.domain_not_renewable_reasons = None + self.dns_type = kwargs.get('dns_type', None) + self.dns_zone_id = kwargs.get('dns_zone_id', None) + self.target_dns_type = kwargs.get('target_dns_type', None) + self.auth_code = kwargs.get('auth_code', None) + + +class DomainAvailabilityCheckResult(msrest.serialization.Model): + """Domain availability check result. + + :param name: Name of the domain. + :type name: str + :param available: :code:`true` if domain can be purchased using CreateDomain API; + otherwise, :code:`false`. + :type available: bool + :param domain_type: Valid values are Regular domain: Azure will charge the full price of domain + registration, SoftDeleted: Purchasing this domain will simply restore it and this operation + will not cost anything. Possible values include: "Regular", "SoftDeleted". + :type domain_type: str or ~azure.mgmt.web.v2020_06_01.models.DomainType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available': {'key': 'available', 'type': 'bool'}, + 'domain_type': {'key': 'domainType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainAvailabilityCheckResult, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.available = kwargs.get('available', None) + self.domain_type = kwargs.get('domain_type', None) + + +class DomainCollection(msrest.serialization.Model): + """Collection of domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Domain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Domain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DomainControlCenterSsoRequest(msrest.serialization.Model): + """Single sign-on request information for domain management. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar url: URL where the single sign-on request is to be made. + :vartype url: str + :ivar post_parameter_key: Post parameter key. + :vartype post_parameter_key: str + :ivar post_parameter_value: Post parameter value. Client should use 'application/x-www-form- + urlencoded' encoding for this value. + :vartype post_parameter_value: str + """ + + _validation = { + 'url': {'readonly': True}, + 'post_parameter_key': {'readonly': True}, + 'post_parameter_value': {'readonly': True}, + } + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + 'post_parameter_key': {'key': 'postParameterKey', 'type': 'str'}, + 'post_parameter_value': {'key': 'postParameterValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainControlCenterSsoRequest, self).__init__(**kwargs) + self.url = None + self.post_parameter_key = None + self.post_parameter_value = None + + +class DomainOwnershipIdentifier(ProxyOnlyResource): + """Domain ownership Identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param ownership_id: Ownership Id. + :type ownership_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ownership_id': {'key': 'properties.ownershipId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainOwnershipIdentifier, self).__init__(**kwargs) + self.ownership_id = kwargs.get('ownership_id', None) + + +class DomainOwnershipIdentifierCollection(msrest.serialization.Model): + """Collection of domain ownership identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DomainOwnershipIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainOwnershipIdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DomainPatchResource(ProxyOnlyResource): + """ARM resource for a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_06_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_06_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_06_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_06_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.DomainPatchResourcePropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainPatchResource, self).__init__(**kwargs) + self.contact_admin = kwargs.get('contact_admin', None) + self.contact_billing = kwargs.get('contact_billing', None) + self.contact_registrant = kwargs.get('contact_registrant', None) + self.contact_tech = kwargs.get('contact_tech', None) + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = kwargs.get('privacy', None) + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = kwargs.get('auto_renew', True) + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = kwargs.get('consent', None) + self.domain_not_renewable_reasons = None + self.dns_type = kwargs.get('dns_type', None) + self.dns_zone_id = kwargs.get('dns_zone_id', None) + self.target_dns_type = kwargs.get('target_dns_type', None) + self.auth_code = kwargs.get('auth_code', None) + + +class DomainPurchaseConsent(msrest.serialization.Model): + """Domain purchase consent object, representing acceptance of applicable legal agreements. + + :param agreement_keys: List of applicable legal agreement keys. This list can be retrieved + using ListLegalAgreements API under :code:`TopLevelDomain` resource. + :type agreement_keys: list[str] + :param agreed_by: Client IP address. + :type agreed_by: str + :param agreed_at: Timestamp when the agreements were accepted. + :type agreed_at: ~datetime.datetime + """ + + _attribute_map = { + 'agreement_keys': {'key': 'agreementKeys', 'type': '[str]'}, + 'agreed_by': {'key': 'agreedBy', 'type': 'str'}, + 'agreed_at': {'key': 'agreedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainPurchaseConsent, self).__init__(**kwargs) + self.agreement_keys = kwargs.get('agreement_keys', None) + self.agreed_by = kwargs.get('agreed_by', None) + self.agreed_at = kwargs.get('agreed_at', None) + + +class DomainRecommendationSearchParameters(msrest.serialization.Model): + """Domain recommendation search parameters. + + :param keywords: Keywords to be used for generating domain recommendations. + :type keywords: str + :param max_domain_recommendations: Maximum number of recommendations. + :type max_domain_recommendations: int + """ + + _attribute_map = { + 'keywords': {'key': 'keywords', 'type': 'str'}, + 'max_domain_recommendations': {'key': 'maxDomainRecommendations', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainRecommendationSearchParameters, self).__init__(**kwargs) + self.keywords = kwargs.get('keywords', None) + self.max_domain_recommendations = kwargs.get('max_domain_recommendations', None) + + +class EnabledConfig(msrest.serialization.Model): + """Enabled configuration. + + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(EnabledConfig, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + + +class EndpointDependency(msrest.serialization.Model): + """A domain name that a service is reached at, including details of the current connection status. + + :param domain_name: The domain name of the dependency. + :type domain_name: str + :param endpoint_details: The IP Addresses and Ports used when connecting to DomainName. + :type endpoint_details: list[~azure.mgmt.web.v2020_06_01.models.EndpointDetail] + """ + + _attribute_map = { + 'domain_name': {'key': 'domainName', 'type': 'str'}, + 'endpoint_details': {'key': 'endpointDetails', 'type': '[EndpointDetail]'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointDependency, self).__init__(**kwargs) + self.domain_name = kwargs.get('domain_name', None) + self.endpoint_details = kwargs.get('endpoint_details', None) + + +class EndpointDetail(msrest.serialization.Model): + """Current TCP connectivity information from the App Service Environment to a single endpoint. + + :param ip_address: An IP Address that Domain Name currently resolves to. + :type ip_address: str + :param port: The port an endpoint is connected to. + :type port: int + :param latency: The time in milliseconds it takes for a TCP connection to be created from the + App Service Environment to this IpAddress at this Port. + :type latency: float + :param is_accessible: Whether it is possible to create a TCP connection from the App Service + Environment to this IpAddress at this Port. + :type is_accessible: bool + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + 'latency': {'key': 'latency', 'type': 'float'}, + 'is_accessible': {'key': 'isAccessible', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointDetail, self).__init__(**kwargs) + self.ip_address = kwargs.get('ip_address', None) + self.port = kwargs.get('port', None) + self.latency = kwargs.get('latency', None) + self.is_accessible = kwargs.get('is_accessible', None) + + +class ErrorEntity(msrest.serialization.Model): + """Body of the error response returned from the API. + + :param extended_code: Type of error. + :type extended_code: str + :param message_template: Message template. + :type message_template: str + :param parameters: Parameters for the template. + :type parameters: list[str] + :param inner_errors: Inner errors. + :type inner_errors: list[~azure.mgmt.web.v2020_06_01.models.ErrorEntity] + :param code: Basic error code. + :type code: str + :param message: Any details of the error. + :type message: str + """ + + _attribute_map = { + 'extended_code': {'key': 'extendedCode', 'type': 'str'}, + 'message_template': {'key': 'messageTemplate', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[str]'}, + 'inner_errors': {'key': 'innerErrors', 'type': '[ErrorEntity]'}, + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorEntity, self).__init__(**kwargs) + self.extended_code = kwargs.get('extended_code', None) + self.message_template = kwargs.get('message_template', None) + self.parameters = kwargs.get('parameters', None) + self.inner_errors = kwargs.get('inner_errors', None) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + + +class Experiments(msrest.serialization.Model): + """Routing rules in production experiments. + + :param ramp_up_rules: List of ramp-up rules. + :type ramp_up_rules: list[~azure.mgmt.web.v2020_06_01.models.RampUpRule] + """ + + _attribute_map = { + 'ramp_up_rules': {'key': 'rampUpRules', 'type': '[RampUpRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(Experiments, self).__init__(**kwargs) + self.ramp_up_rules = kwargs.get('ramp_up_rules', None) + + +class Facebook(ProxyOnlyResource): + """Facebook. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.AppRegistration + :param graph_api_version: + :type graph_api_version: str + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AppRegistration'}, + 'graph_api_version': {'key': 'properties.graphApiVersion', 'type': 'str'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + **kwargs + ): + super(Facebook, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.graph_api_version = kwargs.get('graph_api_version', None) + self.login = kwargs.get('login', None) + + +class FileSystemApplicationLogsConfig(msrest.serialization.Model): + """Application logs to file system configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + + +class FileSystemHttpLogsConfig(msrest.serialization.Model): + """Http logs to file system configuration. + + :param retention_in_mb: Maximum size in megabytes that http log files can use. + When reached old log files will be removed to make space for new ones. + Value can range between 25 and 100. + :type retention_in_mb: int + :param retention_in_days: Retention in days. + Remove files older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _validation = { + 'retention_in_mb': {'maximum': 100, 'minimum': 25}, + } + + _attribute_map = { + 'retention_in_mb': {'key': 'retentionInMb', 'type': 'int'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemHttpLogsConfig, self).__init__(**kwargs) + self.retention_in_mb = kwargs.get('retention_in_mb', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + self.enabled = kwargs.get('enabled', None) + + +class FileSystemTokenStore(ProxyOnlyResource): + """FileSystemTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param directory: + :type directory: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'directory': {'key': 'properties.directory', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemTokenStore, self).__init__(**kwargs) + self.directory = kwargs.get('directory', None) + + +class ForwardProxy(ProxyOnlyResource): + """ForwardProxy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param convention: Possible values include: "NoProxy", "Standard", "Custom". + :type convention: str or ~azure.mgmt.web.v2020_06_01.models.ForwardProxyConvention + :param custom_host_header_name: + :type custom_host_header_name: str + :param custom_proto_header_name: + :type custom_proto_header_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'custom_host_header_name': {'key': 'properties.customHostHeaderName', 'type': 'str'}, + 'custom_proto_header_name': {'key': 'properties.customProtoHeaderName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ForwardProxy, self).__init__(**kwargs) + self.convention = kwargs.get('convention', None) + self.custom_host_header_name = kwargs.get('custom_host_header_name', None) + self.custom_proto_header_name = kwargs.get('custom_proto_header_name', None) + + +class FunctionEnvelope(ProxyOnlyResource): + """Function information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param function_app_id: Function App ID. + :type function_app_id: str + :param script_root_path_href: Script root path URI. + :type script_root_path_href: str + :param script_href: Script URI. + :type script_href: str + :param config_href: Config URI. + :type config_href: str + :param test_data_href: Test data URI. + :type test_data_href: str + :param secrets_file_href: Secrets file URI. + :type secrets_file_href: str + :param href: Function URI. + :type href: str + :param config: Config information. + :type config: object + :param files: File list. + :type files: dict[str, str] + :param test_data: Test data used when testing via the Azure Portal. + :type test_data: str + :param invoke_url_template: The invocation URL. + :type invoke_url_template: str + :param language: The function language. + :type language: str + :param is_disabled: Gets or sets a value indicating whether the function is disabled. + :type is_disabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'function_app_id': {'key': 'properties.function_app_id', 'type': 'str'}, + 'script_root_path_href': {'key': 'properties.script_root_path_href', 'type': 'str'}, + 'script_href': {'key': 'properties.script_href', 'type': 'str'}, + 'config_href': {'key': 'properties.config_href', 'type': 'str'}, + 'test_data_href': {'key': 'properties.test_data_href', 'type': 'str'}, + 'secrets_file_href': {'key': 'properties.secrets_file_href', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'config': {'key': 'properties.config', 'type': 'object'}, + 'files': {'key': 'properties.files', 'type': '{str}'}, + 'test_data': {'key': 'properties.test_data', 'type': 'str'}, + 'invoke_url_template': {'key': 'properties.invoke_url_template', 'type': 'str'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + 'is_disabled': {'key': 'properties.isDisabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionEnvelope, self).__init__(**kwargs) + self.function_app_id = kwargs.get('function_app_id', None) + self.script_root_path_href = kwargs.get('script_root_path_href', None) + self.script_href = kwargs.get('script_href', None) + self.config_href = kwargs.get('config_href', None) + self.test_data_href = kwargs.get('test_data_href', None) + self.secrets_file_href = kwargs.get('secrets_file_href', None) + self.href = kwargs.get('href', None) + self.config = kwargs.get('config', None) + self.files = kwargs.get('files', None) + self.test_data = kwargs.get('test_data', None) + self.invoke_url_template = kwargs.get('invoke_url_template', None) + self.language = kwargs.get('language', None) + self.is_disabled = kwargs.get('is_disabled', None) + + +class FunctionEnvelopeCollection(msrest.serialization.Model): + """Collection of Kudu function information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FunctionEnvelope]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionEnvelopeCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class FunctionSecrets(msrest.serialization.Model): + """Function secrets. + + :param key: Secret key. + :type key: str + :param trigger_url: Trigger URL. + :type trigger_url: str + """ + + _attribute_map = { + 'key': {'key': 'key', 'type': 'str'}, + 'trigger_url': {'key': 'trigger_url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionSecrets, self).__init__(**kwargs) + self.key = kwargs.get('key', None) + self.trigger_url = kwargs.get('trigger_url', None) + + +class GeoRegion(ProxyOnlyResource): + """Geographical region. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Region description. + :vartype description: str + :ivar display_name: Display name for region. + :vartype display_name: str + :ivar org_domain: Display name for region. + :vartype org_domain: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + 'display_name': {'readonly': True}, + 'org_domain': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'org_domain': {'key': 'properties.orgDomain', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GeoRegion, self).__init__(**kwargs) + self.description = None + self.display_name = None + self.org_domain = None + + +class GeoRegionCollection(msrest.serialization.Model): + """Collection of geographical regions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.GeoRegion] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GeoRegion]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GeoRegionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class GitHub(ProxyOnlyResource): + """GitHub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + **kwargs + ): + super(GitHub, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + + +class GlobalCsmSkuDescription(msrest.serialization.Model): + """A Global SKU Description. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service Tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_06_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + **kwargs + ): + super(GlobalCsmSkuDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.size = kwargs.get('size', None) + self.family = kwargs.get('family', None) + self.capacity = kwargs.get('capacity', None) + self.locations = kwargs.get('locations', None) + self.capabilities = kwargs.get('capabilities', None) + + +class GlobalValidation(ProxyOnlyResource): + """GlobalValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param require_authentication: + :type require_authentication: bool + :param unauthenticated_client_action: Possible values include: "RedirectToLoginPage", + "AllowAnonymous", "Return401", "Return403". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_06_01.models.UnauthenticatedClientActionV2 + :param redirect_to_provider: + :type redirect_to_provider: str + :param excluded_paths: + :type excluded_paths: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'require_authentication': {'key': 'properties.requireAuthentication', 'type': 'bool'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'redirect_to_provider': {'key': 'properties.redirectToProvider', 'type': 'str'}, + 'excluded_paths': {'key': 'properties.excludedPaths', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(GlobalValidation, self).__init__(**kwargs) + self.require_authentication = kwargs.get('require_authentication', None) + self.unauthenticated_client_action = kwargs.get('unauthenticated_client_action', None) + self.redirect_to_provider = kwargs.get('redirect_to_provider', None) + self.excluded_paths = kwargs.get('excluded_paths', None) + + +class Google(ProxyOnlyResource): + """Google. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + :param validation: + :type validation: ~azure.mgmt.web.v2020_06_01.models.AllowedAudiencesValidation + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + 'validation': {'key': 'properties.validation', 'type': 'AllowedAudiencesValidation'}, + } + + def __init__( + self, + **kwargs + ): + super(Google, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + self.validation = kwargs.get('validation', None) + + +class HandlerMapping(msrest.serialization.Model): + """The IIS handler mappings used to define which handler processes HTTP requests with certain extension. +For example, it is used to configure php-cgi.exe process to handle all HTTP requests with *.php extension. + + :param extension: Requests with this extension will be handled using the specified FastCGI + application. + :type extension: str + :param script_processor: The absolute path to the FastCGI application. + :type script_processor: str + :param arguments: Command-line arguments to be passed to the script processor. + :type arguments: str + """ + + _attribute_map = { + 'extension': {'key': 'extension', 'type': 'str'}, + 'script_processor': {'key': 'scriptProcessor', 'type': 'str'}, + 'arguments': {'key': 'arguments', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HandlerMapping, self).__init__(**kwargs) + self.extension = kwargs.get('extension', None) + self.script_processor = kwargs.get('script_processor', None) + self.arguments = kwargs.get('arguments', None) + + +class HostingEnvironmentDeploymentInfo(msrest.serialization.Model): + """Information needed to create resources on an App Service Environment. + + :param name: Name of the App Service Environment. + :type name: str + :param location: Location of the App Service Environment. + :type location: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentDeploymentInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.location = kwargs.get('location', None) + + +class HostingEnvironmentDiagnostics(msrest.serialization.Model): + """Diagnostics for an App Service Environment. + + :param name: Name/identifier of the diagnostics. + :type name: str + :param diagnostics_output: Diagnostics output. + :type diagnostics_output: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'diagnostics_output': {'key': 'diagnosticsOutput', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentDiagnostics, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.diagnostics_output = kwargs.get('diagnostics_output', None) + + +class HostingEnvironmentProfile(msrest.serialization.Model): + """Specification for an App Service Environment to use for this resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID of the App Service Environment. + :type id: str + :ivar name: Name of the App Service Environment. + :vartype name: str + :ivar type: Resource type of the App Service Environment. + :vartype type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentProfile, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = None + self.type = None + + +class HostKeys(msrest.serialization.Model): + """Functions host level keys. + + :param master_key: Secret key. + :type master_key: str + :param function_keys: Host level function keys. + :type function_keys: dict[str, str] + :param system_keys: System keys. + :type system_keys: dict[str, str] + """ + + _attribute_map = { + 'master_key': {'key': 'masterKey', 'type': 'str'}, + 'function_keys': {'key': 'functionKeys', 'type': '{str}'}, + 'system_keys': {'key': 'systemKeys', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(HostKeys, self).__init__(**kwargs) + self.master_key = kwargs.get('master_key', None) + self.function_keys = kwargs.get('function_keys', None) + self.system_keys = kwargs.get('system_keys', None) + + +class HostName(msrest.serialization.Model): + """Details of a hostname derived from a domain. + + :param name: Name of the hostname. + :type name: str + :param site_names: List of apps the hostname is assigned to. This list will have more than one + app only if the hostname is pointing to a Traffic Manager. + :type site_names: list[str] + :param azure_resource_name: Name of the Azure resource the hostname is assigned to. If it is + assigned to a Traffic Manager then it will be the Traffic Manager name otherwise it will be the + app name. + :type azure_resource_name: str + :param azure_resource_type: Type of the Azure resource the hostname is assigned to. Possible + values include: "Website", "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_06_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Type of the DNS record. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_06_01.models.CustomHostNameDnsRecordType + :param host_name_type: Type of the hostname. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_06_01.models.HostNameType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'site_names': {'key': 'siteNames', 'type': '[str]'}, + 'azure_resource_name': {'key': 'azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'hostNameType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostName, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.site_names = kwargs.get('site_names', None) + self.azure_resource_name = kwargs.get('azure_resource_name', None) + self.azure_resource_type = kwargs.get('azure_resource_type', None) + self.custom_host_name_dns_record_type = kwargs.get('custom_host_name_dns_record_type', None) + self.host_name_type = kwargs.get('host_name_type', None) + + +class HostNameBinding(ProxyOnlyResource): + """A hostname binding object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param site_name: App Service app name. + :type site_name: str + :param domain_id: Fully qualified ARM domain resource URI. + :type domain_id: str + :param azure_resource_name: Azure resource name. + :type azure_resource_name: str + :param azure_resource_type: Azure resource type. Possible values include: "Website", + "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_06_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Custom DNS record type. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_06_01.models.CustomHostNameDnsRecordType + :param host_name_type: Hostname type. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_06_01.models.HostNameType + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_06_01.models.SslState + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :ivar virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :vartype virtual_ip: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'virtual_ip': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'domain_id': {'key': 'properties.domainId', 'type': 'str'}, + 'azure_resource_name': {'key': 'properties.azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'properties.azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'properties.customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'properties.hostNameType', 'type': 'str'}, + 'ssl_state': {'key': 'properties.sslState', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'virtual_ip': {'key': 'properties.virtualIP', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameBinding, self).__init__(**kwargs) + self.site_name = kwargs.get('site_name', None) + self.domain_id = kwargs.get('domain_id', None) + self.azure_resource_name = kwargs.get('azure_resource_name', None) + self.azure_resource_type = kwargs.get('azure_resource_type', None) + self.custom_host_name_dns_record_type = kwargs.get('custom_host_name_dns_record_type', None) + self.host_name_type = kwargs.get('host_name_type', None) + self.ssl_state = kwargs.get('ssl_state', None) + self.thumbprint = kwargs.get('thumbprint', None) + self.virtual_ip = None + + +class HostNameBindingCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.HostNameBinding] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HostNameBinding]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameBindingCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class HostNameSslState(msrest.serialization.Model): + """SSL-enabled hostname. + + :param name: Hostname. + :type name: str + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_06_01.models.SslState + :param virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :type virtual_ip: str + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :param to_update: Set to :code:`true` to update existing hostname. + :type to_update: bool + :param host_type: Indicates whether the hostname is a standard or repository hostname. Possible + values include: "Standard", "Repository". + :type host_type: str or ~azure.mgmt.web.v2020_06_01.models.HostType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'ssl_state': {'key': 'sslState', 'type': 'str'}, + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'to_update': {'key': 'toUpdate', 'type': 'bool'}, + 'host_type': {'key': 'hostType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameSslState, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.ssl_state = kwargs.get('ssl_state', None) + self.virtual_ip = kwargs.get('virtual_ip', None) + self.thumbprint = kwargs.get('thumbprint', None) + self.to_update = kwargs.get('to_update', None) + self.host_type = kwargs.get('host_type', None) + + +class HttpLogsConfig(msrest.serialization.Model): + """Http logs configuration. + + :param file_system: Http logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemHttpLogsConfig + :param azure_blob_storage: Http logs to azure blob storage configuration. + :type azure_blob_storage: ~azure.mgmt.web.v2020_06_01.models.AzureBlobStorageHttpLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemHttpLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageHttpLogsConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpLogsConfig, self).__init__(**kwargs) + self.file_system = kwargs.get('file_system', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class HttpSettings(ProxyOnlyResource): + """HttpSettings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param require_https: + :type require_https: bool + :param routes: + :type routes: ~azure.mgmt.web.v2020_06_01.models.HttpSettingsRoutes + :param forward_proxy: + :type forward_proxy: ~azure.mgmt.web.v2020_06_01.models.ForwardProxy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'require_https': {'key': 'properties.requireHttps', 'type': 'bool'}, + 'routes': {'key': 'properties.routes', 'type': 'HttpSettingsRoutes'}, + 'forward_proxy': {'key': 'properties.forwardProxy', 'type': 'ForwardProxy'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpSettings, self).__init__(**kwargs) + self.require_https = kwargs.get('require_https', None) + self.routes = kwargs.get('routes', None) + self.forward_proxy = kwargs.get('forward_proxy', None) + + +class HttpSettingsRoutes(ProxyOnlyResource): + """HttpSettingsRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param api_prefix: + :type api_prefix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'api_prefix': {'key': 'properties.apiPrefix', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpSettingsRoutes, self).__init__(**kwargs) + self.api_prefix = kwargs.get('api_prefix', None) + + +class HybridConnection(ProxyOnlyResource): + """Hybrid Connection contract. This is used to configure a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param service_bus_namespace: The name of the Service Bus namespace. + :type service_bus_namespace: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :param relay_arm_uri: The ARM URI to the Service Bus relay. + :type relay_arm_uri: str + :param hostname: The hostname of the endpoint. + :type hostname: str + :param port: The port of the endpoint. + :type port: int + :param send_key_name: The name of the Service Bus key which has Send permissions. This is used + to authenticate to Service Bus. + :type send_key_name: str + :param send_key_value: The value of the Service Bus key. This is used to authenticate to + Service Bus. In ARM this key will not be returned + normally, use the POST /listKeys API instead. + :type send_key_value: str + :param service_bus_suffix: The suffix for the service bus endpoint. By default this is + .servicebus.windows.net. + :type service_bus_suffix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_bus_namespace': {'key': 'properties.serviceBusNamespace', 'type': 'str'}, + 'relay_name': {'key': 'properties.relayName', 'type': 'str'}, + 'relay_arm_uri': {'key': 'properties.relayArmUri', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + 'service_bus_suffix': {'key': 'properties.serviceBusSuffix', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnection, self).__init__(**kwargs) + self.service_bus_namespace = kwargs.get('service_bus_namespace', None) + self.relay_name = kwargs.get('relay_name', None) + self.relay_arm_uri = kwargs.get('relay_arm_uri', None) + self.hostname = kwargs.get('hostname', None) + self.port = kwargs.get('port', None) + self.send_key_name = kwargs.get('send_key_name', None) + self.send_key_value = kwargs.get('send_key_value', None) + self.service_bus_suffix = kwargs.get('service_bus_suffix', None) + + +class HybridConnectionCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.HybridConnection] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HybridConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class HybridConnectionKey(ProxyOnlyResource): + """Hybrid Connection key contract. This has the send key name and value for a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar send_key_name: The name of the send key. + :vartype send_key_name: str + :ivar send_key_value: The value of the send key. + :vartype send_key_value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'send_key_name': {'readonly': True}, + 'send_key_value': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionKey, self).__init__(**kwargs) + self.send_key_name = None + self.send_key_value = None + + +class HybridConnectionLimits(ProxyOnlyResource): + """Hybrid Connection limits contract. This is used to return the plan limits of Hybrid Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar current: The current number of Hybrid Connections. + :vartype current: int + :ivar maximum: The maximum number of Hybrid Connections allowed. + :vartype maximum: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'current': {'readonly': True}, + 'maximum': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'current': {'key': 'properties.current', 'type': 'int'}, + 'maximum': {'key': 'properties.maximum', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionLimits, self).__init__(**kwargs) + self.current = None + self.maximum = None + + +class Identifier(ProxyOnlyResource): + """A domain specific resource identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param value: String representation of the identity. + :type value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'value': {'key': 'properties.id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Identifier, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class IdentifierCollection(msrest.serialization.Model): + """Collection of identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Identifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Identifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class IdentityProviders(ProxyOnlyResource): + """IdentityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param azure_active_directory: + :type azure_active_directory: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectory + :param facebook: + :type facebook: ~azure.mgmt.web.v2020_06_01.models.Facebook + :param git_hub: + :type git_hub: ~azure.mgmt.web.v2020_06_01.models.GitHub + :param google: + :type google: ~azure.mgmt.web.v2020_06_01.models.Google + :param twitter: + :type twitter: ~azure.mgmt.web.v2020_06_01.models.Twitter + :param custom_open_id_connect_providers: Dictionary of :code:``. + :type custom_open_id_connect_providers: dict[str, + ~azure.mgmt.web.v2020_06_01.models.CustomOpenIdConnectProvider] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'facebook': {'key': 'properties.facebook', 'type': 'Facebook'}, + 'git_hub': {'key': 'properties.gitHub', 'type': 'GitHub'}, + 'google': {'key': 'properties.google', 'type': 'Google'}, + 'twitter': {'key': 'properties.twitter', 'type': 'Twitter'}, + 'custom_open_id_connect_providers': {'key': 'properties.customOpenIdConnectProviders', 'type': '{CustomOpenIdConnectProvider}'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentityProviders, self).__init__(**kwargs) + self.azure_active_directory = kwargs.get('azure_active_directory', None) + self.facebook = kwargs.get('facebook', None) + self.git_hub = kwargs.get('git_hub', None) + self.google = kwargs.get('google', None) + self.twitter = kwargs.get('twitter', None) + self.custom_open_id_connect_providers = kwargs.get('custom_open_id_connect_providers', None) + + +class InboundEnvironmentEndpoint(msrest.serialization.Model): + """The IP Addresses and Ports that require inbound network access to and within the subnet of the App Service Environment. + + :param description: Short text describing the purpose of the network traffic. + :type description: str + :param endpoints: The IP addresses that network traffic will originate from in cidr notation. + :type endpoints: list[str] + :param ports: The ports that network traffic will arrive to the App Service Environment at. + :type ports: list[str] + """ + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[str]'}, + 'ports': {'key': 'ports', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundEnvironmentEndpoint, self).__init__(**kwargs) + self.description = kwargs.get('description', None) + self.endpoints = kwargs.get('endpoints', None) + self.ports = kwargs.get('ports', None) + + +class InboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Inbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.InboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class IpSecurityRestriction(msrest.serialization.Model): + """IP security restriction on an app. + + :param ip_address: IP address the security restriction is valid for. + It can be in form of pure ipv4 address (required SubnetMask property) or + CIDR notation such as ipv4/mask (leading bit match). For CIDR, + SubnetMask property must not be specified. + :type ip_address: str + :param subnet_mask: Subnet mask for the range of IP addresses the restriction is valid for. + :type subnet_mask: str + :param vnet_subnet_resource_id: Virtual network resource id. + :type vnet_subnet_resource_id: str + :param vnet_traffic_tag: (internal) Vnet traffic tag. + :type vnet_traffic_tag: int + :param subnet_traffic_tag: (internal) Subnet traffic tag. + :type subnet_traffic_tag: int + :param action: Allow or Deny access for this IP range. + :type action: str + :param tag: Defines what this IP filter will be used for. This is to support IP filtering on + proxies. Possible values include: "Default", "XffProxy", "ServiceTag". + :type tag: str or ~azure.mgmt.web.v2020_06_01.models.IpFilterTag + :param priority: Priority of IP restriction rule. + :type priority: int + :param name: IP restriction rule name. + :type name: str + :param description: IP restriction rule description. + :type description: str + :param headers: IP restriction rule headers. + X-Forwarded-Host (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + Host#Examples). + The matching logic is .. + + + * If the property is null or empty (default), all hosts(or lack of) are allowed. + * A value is compared using ordinal-ignore-case (excluding port number). + * Subdomain wildcards are permitted but don't match the root domain. For example, + *.contoso.com matches the subdomain foo.contoso.com + but not the root domain contoso.com or multi-level foo.bar.contoso.com + * Unicode host names are allowed but are converted to Punycode for matching. + + X-Forwarded-For (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + For#Examples). + The matching logic is .. + + + * If the property is null or empty (default), any forwarded-for chains (or lack of) are + allowed. + * If any address (excluding port number) in the chain (comma separated) matches the CIDR + defined by the property. + + X-Azure-FDID and X-FD-HealthProbe. + The matching logic is exact match. + :type headers: dict[str, list[str]] + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'subnet_mask': {'key': 'subnetMask', 'type': 'str'}, + 'vnet_subnet_resource_id': {'key': 'vnetSubnetResourceId', 'type': 'str'}, + 'vnet_traffic_tag': {'key': 'vnetTrafficTag', 'type': 'int'}, + 'subnet_traffic_tag': {'key': 'subnetTrafficTag', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '{[str]}'}, + } + + def __init__( + self, + **kwargs + ): + super(IpSecurityRestriction, self).__init__(**kwargs) + self.ip_address = kwargs.get('ip_address', None) + self.subnet_mask = kwargs.get('subnet_mask', None) + self.vnet_subnet_resource_id = kwargs.get('vnet_subnet_resource_id', None) + self.vnet_traffic_tag = kwargs.get('vnet_traffic_tag', None) + self.subnet_traffic_tag = kwargs.get('subnet_traffic_tag', None) + self.action = kwargs.get('action', None) + self.tag = kwargs.get('tag', None) + self.priority = kwargs.get('priority', None) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.headers = kwargs.get('headers', None) + + +class JwtClaimChecks(ProxyOnlyResource): + """JwtClaimChecks. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allowed_groups: + :type allowed_groups: list[str] + :param allowed_client_applications: + :type allowed_client_applications: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_groups': {'key': 'properties.allowedGroups', 'type': '[str]'}, + 'allowed_client_applications': {'key': 'properties.allowedClientApplications', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(JwtClaimChecks, self).__init__(**kwargs) + self.allowed_groups = kwargs.get('allowed_groups', None) + self.allowed_client_applications = kwargs.get('allowed_client_applications', None) + + +class KeyInfo(msrest.serialization.Model): + """Function key info. + + :param name: Key name. + :type name: str + :param value: Key value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(KeyInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + + +class LocalizableString(msrest.serialization.Model): + """Localizable string object containing the name and a localized value. + + :param value: Non-localized name. + :type value: str + :param localized_value: Localized name. + :type localized_value: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LocalizableString, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.localized_value = kwargs.get('localized_value', None) + + +class Login(ProxyOnlyResource): + """Login. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param routes: + :type routes: ~azure.mgmt.web.v2020_06_01.models.LoginRoutes + :param token_store: + :type token_store: ~azure.mgmt.web.v2020_06_01.models.TokenStore + :param preserve_url_fragments_for_logins: + :type preserve_url_fragments_for_logins: bool + :param allowed_external_redirect_urls: + :type allowed_external_redirect_urls: list[str] + :param cookie_expiration: + :type cookie_expiration: ~azure.mgmt.web.v2020_06_01.models.CookieExpiration + :param nonce: + :type nonce: ~azure.mgmt.web.v2020_06_01.models.Nonce + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': 'LoginRoutes'}, + 'token_store': {'key': 'properties.tokenStore', 'type': 'TokenStore'}, + 'preserve_url_fragments_for_logins': {'key': 'properties.preserveUrlFragmentsForLogins', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'cookie_expiration': {'key': 'properties.cookieExpiration', 'type': 'CookieExpiration'}, + 'nonce': {'key': 'properties.nonce', 'type': 'Nonce'}, + } + + def __init__( + self, + **kwargs + ): + super(Login, self).__init__(**kwargs) + self.routes = kwargs.get('routes', None) + self.token_store = kwargs.get('token_store', None) + self.preserve_url_fragments_for_logins = kwargs.get('preserve_url_fragments_for_logins', None) + self.allowed_external_redirect_urls = kwargs.get('allowed_external_redirect_urls', None) + self.cookie_expiration = kwargs.get('cookie_expiration', None) + self.nonce = kwargs.get('nonce', None) + + +class LoginRoutes(ProxyOnlyResource): + """LoginRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param logout_endpoint: + :type logout_endpoint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'logout_endpoint': {'key': 'properties.logoutEndpoint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoginRoutes, self).__init__(**kwargs) + self.logout_endpoint = kwargs.get('logout_endpoint', None) + + +class LoginScopes(ProxyOnlyResource): + """LoginScopes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(LoginScopes, self).__init__(**kwargs) + self.scopes = kwargs.get('scopes', None) + + +class LogSpecification(msrest.serialization.Model): + """Log Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param blob_duration: + :type blob_duration: str + :param log_filter_pattern: + :type log_filter_pattern: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + 'log_filter_pattern': {'key': 'logFilterPattern', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LogSpecification, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.blob_duration = kwargs.get('blob_duration', None) + self.log_filter_pattern = kwargs.get('log_filter_pattern', None) + + +class ManagedServiceIdentity(msrest.serialization.Model): + """Managed service identity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of managed service identity. Possible values include: "SystemAssigned", + "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentityType + :ivar tenant_id: Tenant of managed service identity. + :vartype tenant_id: str + :ivar principal_id: Principal Id of managed service identity. + :vartype principal_id: str + :param user_assigned_identities: The list of user assigned identities associated with the + resource. The user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. + :type user_assigned_identities: dict[str, + ~azure.mgmt.web.v2020_06_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _validation = { + 'tenant_id': {'readonly': True}, + 'principal_id': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedServiceIdentity, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.tenant_id = None + self.principal_id = None + self.user_assigned_identities = kwargs.get('user_assigned_identities', None) + + +class MetricAvailability(msrest.serialization.Model): + """Retention policy of a resource metric. + + :param time_grain: + :type time_grain: str + :param blob_duration: + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MetricAvailability, self).__init__(**kwargs) + self.time_grain = kwargs.get('time_grain', None) + self.blob_duration = kwargs.get('blob_duration', None) + + +class MetricSpecification(msrest.serialization.Model): + """Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param display_description: + :type display_description: str + :param unit: + :type unit: str + :param aggregation_type: + :type aggregation_type: str + :param supports_instance_level_aggregation: + :type supports_instance_level_aggregation: bool + :param enable_regional_mdm_account: + :type enable_regional_mdm_account: bool + :param source_mdm_account: + :type source_mdm_account: str + :param source_mdm_namespace: + :type source_mdm_namespace: str + :param metric_filter_pattern: + :type metric_filter_pattern: str + :param fill_gap_with_zero: + :type fill_gap_with_zero: bool + :param is_internal: + :type is_internal: bool + :param dimensions: + :type dimensions: list[~azure.mgmt.web.v2020_06_01.models.Dimension] + :param category: + :type category: str + :param availabilities: + :type availabilities: list[~azure.mgmt.web.v2020_06_01.models.MetricAvailability] + :param supported_time_grain_types: + :type supported_time_grain_types: list[str] + :param supported_aggregation_types: + :type supported_aggregation_types: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'display_description': {'key': 'displayDescription', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'aggregation_type': {'key': 'aggregationType', 'type': 'str'}, + 'supports_instance_level_aggregation': {'key': 'supportsInstanceLevelAggregation', 'type': 'bool'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'category': {'key': 'category', 'type': 'str'}, + 'availabilities': {'key': 'availabilities', 'type': '[MetricAvailability]'}, + 'supported_time_grain_types': {'key': 'supportedTimeGrainTypes', 'type': '[str]'}, + 'supported_aggregation_types': {'key': 'supportedAggregationTypes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(MetricSpecification, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.display_description = kwargs.get('display_description', None) + self.unit = kwargs.get('unit', None) + self.aggregation_type = kwargs.get('aggregation_type', None) + self.supports_instance_level_aggregation = kwargs.get('supports_instance_level_aggregation', None) + self.enable_regional_mdm_account = kwargs.get('enable_regional_mdm_account', None) + self.source_mdm_account = kwargs.get('source_mdm_account', None) + self.source_mdm_namespace = kwargs.get('source_mdm_namespace', None) + self.metric_filter_pattern = kwargs.get('metric_filter_pattern', None) + self.fill_gap_with_zero = kwargs.get('fill_gap_with_zero', None) + self.is_internal = kwargs.get('is_internal', None) + self.dimensions = kwargs.get('dimensions', None) + self.category = kwargs.get('category', None) + self.availabilities = kwargs.get('availabilities', None) + self.supported_time_grain_types = kwargs.get('supported_time_grain_types', None) + self.supported_aggregation_types = kwargs.get('supported_aggregation_types', None) + + +class MigrateMySqlRequest(ProxyOnlyResource): + """MySQL migration request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param connection_string: Connection string to the remote MySQL database. + :type connection_string: str + :param migration_type: The type of migration operation to be done. Possible values include: + "LocalToRemote", "RemoteToLocal". + :type migration_type: str or ~azure.mgmt.web.v2020_06_01.models.MySqlMigrationType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'migration_type': {'key': 'properties.migrationType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MigrateMySqlRequest, self).__init__(**kwargs) + self.connection_string = kwargs.get('connection_string', None) + self.migration_type = kwargs.get('migration_type', None) + + +class MigrateMySqlStatus(ProxyOnlyResource): + """MySQL migration status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar migration_operation_status: Status of the migration task. Possible values include: + "InProgress", "Failed", "Succeeded", "TimedOut", "Created". + :vartype migration_operation_status: str or ~azure.mgmt.web.v2020_06_01.models.OperationStatus + :ivar operation_id: Operation ID for the migration task. + :vartype operation_id: str + :ivar local_my_sql_enabled: True if the web app has in app MySql enabled. + :vartype local_my_sql_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'migration_operation_status': {'readonly': True}, + 'operation_id': {'readonly': True}, + 'local_my_sql_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'migration_operation_status': {'key': 'properties.migrationOperationStatus', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MigrateMySqlStatus, self).__init__(**kwargs) + self.migration_operation_status = None + self.operation_id = None + self.local_my_sql_enabled = None + + +class MSDeploy(ProxyOnlyResource): + """MSDeploy ARM PUT information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param package_uri: Package URI. + :type package_uri: str + :param connection_string: SQL Connection String. + :type connection_string: str + :param db_type: Database Type. + :type db_type: str + :param set_parameters_xml_file_uri: URI of MSDeploy Parameters file. Must not be set if + SetParameters is used. + :type set_parameters_xml_file_uri: str + :param set_parameters: MSDeploy Parameters. Must not be set if SetParametersXmlFileUri is used. + :type set_parameters: dict[str, str] + :param skip_app_data: Controls whether the MSDeploy operation skips the App_Data directory. + If set to :code:`true`, the existing App_Data directory on the destination + will not be deleted, and any App_Data directory in the source will be ignored. + Setting is :code:`false` by default. + :type skip_app_data: bool + :param app_offline: Sets the AppOffline rule while the MSDeploy operation executes. + Setting is :code:`false` by default. + :type app_offline: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'package_uri': {'key': 'properties.packageUri', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'db_type': {'key': 'properties.dbType', 'type': 'str'}, + 'set_parameters_xml_file_uri': {'key': 'properties.setParametersXmlFileUri', 'type': 'str'}, + 'set_parameters': {'key': 'properties.setParameters', 'type': '{str}'}, + 'skip_app_data': {'key': 'properties.skipAppData', 'type': 'bool'}, + 'app_offline': {'key': 'properties.appOffline', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeploy, self).__init__(**kwargs) + self.package_uri = kwargs.get('package_uri', None) + self.connection_string = kwargs.get('connection_string', None) + self.db_type = kwargs.get('db_type', None) + self.set_parameters_xml_file_uri = kwargs.get('set_parameters_xml_file_uri', None) + self.set_parameters = kwargs.get('set_parameters', None) + self.skip_app_data = kwargs.get('skip_app_data', None) + self.app_offline = kwargs.get('app_offline', None) + + +class MSDeployLog(ProxyOnlyResource): + """MSDeploy log. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar entries: List of log entry messages. + :vartype entries: list[~azure.mgmt.web.v2020_06_01.models.MSDeployLogEntry] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'entries': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'entries': {'key': 'properties.entries', 'type': '[MSDeployLogEntry]'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLog, self).__init__(**kwargs) + self.entries = None + + +class MSDeployLogEntry(msrest.serialization.Model): + """MSDeploy log entry. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time: Timestamp of log entry. + :vartype time: ~datetime.datetime + :ivar type: Log entry type. Possible values include: "Message", "Warning", "Error". + :vartype type: str or ~azure.mgmt.web.v2020_06_01.models.MSDeployLogEntryType + :ivar message: Log entry message. + :vartype message: str + """ + + _validation = { + 'time': {'readonly': True}, + 'type': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'type': {'key': 'type', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLogEntry, self).__init__(**kwargs) + self.time = None + self.type = None + self.message = None + + +class MSDeployStatus(ProxyOnlyResource): + """MSDeploy ARM response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar deployer: Username of deployer. + :vartype deployer: str + :ivar provisioning_state: Provisioning state. Possible values include: "accepted", "running", + "succeeded", "failed", "canceled". + :vartype provisioning_state: str or + ~azure.mgmt.web.v2020_06_01.models.MSDeployProvisioningState + :ivar start_time: Start time of deploy operation. + :vartype start_time: ~datetime.datetime + :ivar end_time: End time of deploy operation. + :vartype end_time: ~datetime.datetime + :ivar complete: Whether the deployment operation has completed. + :vartype complete: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'deployer': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'end_time': {'readonly': True}, + 'complete': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'complete': {'key': 'properties.complete', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployStatus, self).__init__(**kwargs) + self.deployer = None + self.provisioning_state = None + self.start_time = None + self.end_time = None + self.complete = None + + +class NameIdentifier(msrest.serialization.Model): + """Identifies an object. + + :param name: Name of the object. + :type name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameIdentifier, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + + +class NameIdentifierCollection(msrest.serialization.Model): + """Collection of domain name identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.NameIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NameIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameIdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class NameValuePair(msrest.serialization.Model): + """Name value pair. + + :param name: Pair name. + :type name: str + :param value: Pair value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameValuePair, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + + +class NetworkAccessControlEntry(msrest.serialization.Model): + """Network access control entry. + + :param action: Action object. Possible values include: "Permit", "Deny". + :type action: str or ~azure.mgmt.web.v2020_06_01.models.AccessControlEntryAction + :param description: Description of network access control entry. + :type description: str + :param order: Order of precedence. + :type order: int + :param remote_subnet: Remote subnet. + :type remote_subnet: str + """ + + _attribute_map = { + 'action': {'key': 'action', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'int'}, + 'remote_subnet': {'key': 'remoteSubnet', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkAccessControlEntry, self).__init__(**kwargs) + self.action = kwargs.get('action', None) + self.description = kwargs.get('description', None) + self.order = kwargs.get('order', None) + self.remote_subnet = kwargs.get('remote_subnet', None) + + +class NetworkFeatures(ProxyOnlyResource): + """Full view of network features for an app (presently VNET integration and Hybrid Connections). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar virtual_network_name: The Virtual Network name. + :vartype virtual_network_name: str + :ivar virtual_network_connection: The Virtual Network summary view. + :vartype virtual_network_connection: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :ivar hybrid_connections: The Hybrid Connections summary view. + :vartype hybrid_connections: + list[~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity] + :ivar hybrid_connections_v2: The Hybrid Connection V2 (Service Bus) view. + :vartype hybrid_connections_v2: list[~azure.mgmt.web.v2020_06_01.models.HybridConnection] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'virtual_network_name': {'readonly': True}, + 'virtual_network_connection': {'readonly': True}, + 'hybrid_connections': {'readonly': True}, + 'hybrid_connections_v2': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'virtual_network_name': {'key': 'properties.virtualNetworkName', 'type': 'str'}, + 'virtual_network_connection': {'key': 'properties.virtualNetworkConnection', 'type': 'VnetInfo'}, + 'hybrid_connections': {'key': 'properties.hybridConnections', 'type': '[RelayServiceConnectionEntity]'}, + 'hybrid_connections_v2': {'key': 'properties.hybridConnectionsV2', 'type': '[HybridConnection]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkFeatures, self).__init__(**kwargs) + self.virtual_network_name = None + self.virtual_network_connection = None + self.hybrid_connections = None + self.hybrid_connections_v2 = None + + +class NetworkTrace(msrest.serialization.Model): + """Network trace. + + :param path: Local file path for the captured network trace file. + :type path: str + :param status: Current status of the network trace operation, same as Operation.Status + (InProgress/Succeeded/Failed). + :type status: str + :param message: Detailed message of a network trace operation, e.g. error message in case of + failure. + :type message: str + """ + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkTrace, self).__init__(**kwargs) + self.path = kwargs.get('path', None) + self.status = kwargs.get('status', None) + self.message = kwargs.get('message', None) + + +class Nonce(ProxyOnlyResource): + """Nonce. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param validate_nonce: + :type validate_nonce: bool + :param nonce_expiration_interval: + :type nonce_expiration_interval: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'validate_nonce': {'key': 'properties.validateNonce', 'type': 'bool'}, + 'nonce_expiration_interval': {'key': 'properties.nonceExpirationInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Nonce, self).__init__(**kwargs) + self.validate_nonce = kwargs.get('validate_nonce', None) + self.nonce_expiration_interval = kwargs.get('nonce_expiration_interval', None) + + +class OpenIdConnectClientCredential(ProxyOnlyResource): + """OpenIdConnectClientCredential. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar method: Default value: "ClientSecretPost". + :vartype method: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'method': {'constant': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'method': {'key': 'properties.method', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + method = "ClientSecretPost" + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectClientCredential, self).__init__(**kwargs) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + + +class OpenIdConnectConfig(ProxyOnlyResource): + """OpenIdConnectConfig. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param authorization_endpoint: + :type authorization_endpoint: str + :param token_endpoint: + :type token_endpoint: str + :param issuer: + :type issuer: str + :param certification_uri: + :type certification_uri: str + :param well_known_open_id_configuration: + :type well_known_open_id_configuration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'authorization_endpoint': {'key': 'properties.authorizationEndpoint', 'type': 'str'}, + 'token_endpoint': {'key': 'properties.tokenEndpoint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'certification_uri': {'key': 'properties.certificationUri', 'type': 'str'}, + 'well_known_open_id_configuration': {'key': 'properties.wellKnownOpenIdConfiguration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectConfig, self).__init__(**kwargs) + self.authorization_endpoint = kwargs.get('authorization_endpoint', None) + self.token_endpoint = kwargs.get('token_endpoint', None) + self.issuer = kwargs.get('issuer', None) + self.certification_uri = kwargs.get('certification_uri', None) + self.well_known_open_id_configuration = kwargs.get('well_known_open_id_configuration', None) + + +class OpenIdConnectLogin(ProxyOnlyResource): + """OpenIdConnectLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_claim_type: + :type name_claim_type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_claim_type': {'key': 'properties.nameClaimType', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectLogin, self).__init__(**kwargs) + self.name_claim_type = kwargs.get('name_claim_type', None) + self.scopes = kwargs.get('scopes', None) + + +class OpenIdConnectRegistration(ProxyOnlyResource): + """OpenIdConnectRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param client_id: + :type client_id: str + :param client_credential: + :type client_credential: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectClientCredential + :param open_id_connect_configuration: + :type open_id_connect_configuration: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_credential': {'key': 'properties.clientCredential', 'type': 'OpenIdConnectClientCredential'}, + 'open_id_connect_configuration': {'key': 'properties.openIdConnectConfiguration', 'type': 'OpenIdConnectConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectRegistration, self).__init__(**kwargs) + self.client_id = kwargs.get('client_id', None) + self.client_credential = kwargs.get('client_credential', None) + self.open_id_connect_configuration = kwargs.get('open_id_connect_configuration', None) + + +class Operation(msrest.serialization.Model): + """An operation on a resource. + + :param id: Operation ID. + :type id: str + :param name: Operation name. + :type name: str + :param status: The current status of the operation. Possible values include: "InProgress", + "Failed", "Succeeded", "TimedOut", "Created". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.OperationStatus + :param errors: Any errors associate with the operation. + :type errors: list[~azure.mgmt.web.v2020_06_01.models.ErrorEntity] + :param created_time: Time when operation has started. + :type created_time: ~datetime.datetime + :param modified_time: Time when operation has been updated. + :type modified_time: ~datetime.datetime + :param expiration_time: Time when operation will expire. + :type expiration_time: ~datetime.datetime + :param geo_master_operation_id: Applicable only for stamp operation ids. + :type geo_master_operation_id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'errors': {'key': 'errors', 'type': '[ErrorEntity]'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'modified_time': {'key': 'modifiedTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'expirationTime', 'type': 'iso-8601'}, + 'geo_master_operation_id': {'key': 'geoMasterOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = kwargs.get('name', None) + self.status = kwargs.get('status', None) + self.errors = kwargs.get('errors', None) + self.created_time = kwargs.get('created_time', None) + self.modified_time = kwargs.get('modified_time', None) + self.expiration_time = kwargs.get('expiration_time', None) + self.geo_master_operation_id = kwargs.get('geo_master_operation_id', None) + + +class OutboundEnvironmentEndpoint(msrest.serialization.Model): + """Endpoints accessed for a common purpose that the App Service Environment requires outbound network access to. + + :param category: The type of service accessed by the App Service Environment, e.g., Azure + Storage, Azure SQL Database, and Azure Active Directory. + :type category: str + :param endpoints: The endpoints that the App Service Environment reaches the service at. + :type endpoints: list[~azure.mgmt.web.v2020_06_01.models.EndpointDependency] + """ + + _attribute_map = { + 'category': {'key': 'category', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[EndpointDependency]'}, + } + + def __init__( + self, + **kwargs + ): + super(OutboundEnvironmentEndpoint, self).__init__(**kwargs) + self.category = kwargs.get('category', None) + self.endpoints = kwargs.get('endpoints', None) + + +class OutboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Outbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.OutboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OutboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PerfMonCounterCollection(msrest.serialization.Model): + """Collection of performance monitor counters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PerfMonResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PerfMonResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonCounterCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PerfMonResponse(msrest.serialization.Model): + """Performance monitor API response. + + :param code: The response code. + :type code: str + :param message: The message. + :type message: str + :param data: The performance monitor counters. + :type data: ~azure.mgmt.web.v2020_06_01.models.PerfMonSet + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'data': {'key': 'data', 'type': 'PerfMonSet'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonResponse, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + self.data = kwargs.get('data', None) + + +class PerfMonSample(msrest.serialization.Model): + """Performance monitor sample in a set. + + :param time: Point in time for which counter was measured. + :type time: ~datetime.datetime + :param instance_name: Name of the server on which the measurement is made. + :type instance_name: str + :param value: Value of counter at a certain time. + :type value: float + """ + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'instance_name': {'key': 'instanceName', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'float'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonSample, self).__init__(**kwargs) + self.time = kwargs.get('time', None) + self.instance_name = kwargs.get('instance_name', None) + self.value = kwargs.get('value', None) + + +class PerfMonSet(msrest.serialization.Model): + """Metric information. + + :param name: Unique key name of the counter. + :type name: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. + :type time_grain: str + :param values: Collection of workers that are active during this time. + :type values: list[~azure.mgmt.web.v2020_06_01.models.PerfMonSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[PerfMonSample]'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonSet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.time_grain = kwargs.get('time_grain', None) + self.values = kwargs.get('values', None) + + +class PremierAddOn(Resource): + """Premier add-on. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOn, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PremierAddOnOffer(ProxyOnlyResource): + """Premier add-on offer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on offer Product. + :type product: str + :param vendor: Premier add on offer Vendor. + :type vendor: str + :param promo_code_required: :code:`true` if promotion code is required; otherwise, + :code:`false`. + :type promo_code_required: bool + :param quota: Premier add on offer Quota. + :type quota: int + :param web_hosting_plan_restrictions: App Service plans this offer is restricted to. Possible + values include: "None", "Free", "Shared", "Basic", "Standard", "Premium". + :type web_hosting_plan_restrictions: str or + ~azure.mgmt.web.v2020_06_01.models.AppServicePlanRestrictions + :param privacy_policy_url: Privacy policy URL. + :type privacy_policy_url: str + :param legal_terms_url: Legal terms URL. + :type legal_terms_url: str + :param marketplace_publisher: Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'promo_code_required': {'key': 'properties.promoCodeRequired', 'type': 'bool'}, + 'quota': {'key': 'properties.quota', 'type': 'int'}, + 'web_hosting_plan_restrictions': {'key': 'properties.webHostingPlanRestrictions', 'type': 'str'}, + 'privacy_policy_url': {'key': 'properties.privacyPolicyUrl', 'type': 'str'}, + 'legal_terms_url': {'key': 'properties.legalTermsUrl', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnOffer, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.promo_code_required = kwargs.get('promo_code_required', None) + self.quota = kwargs.get('quota', None) + self.web_hosting_plan_restrictions = kwargs.get('web_hosting_plan_restrictions', None) + self.privacy_policy_url = kwargs.get('privacy_policy_url', None) + self.legal_terms_url = kwargs.get('legal_terms_url', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PremierAddOnOfferCollection(msrest.serialization.Model): + """Collection of premier add-on offers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOffer] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PremierAddOnOffer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnOfferCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PremierAddOnPatchResource(ProxyOnlyResource): + """ARM resource for a PremierAddOn. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnPatchResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PrivateAccess(ProxyOnlyResource): + """Description of the parameters of Private Access for a Web Site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: Whether private access is enabled or not. + :type enabled: bool + :param virtual_networks: The Virtual Networks (and subnets) allowed to access the site + privately. + :type virtual_networks: list[~azure.mgmt.web.v2020_06_01.models.PrivateAccessVirtualNetwork] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[PrivateAccessVirtualNetwork]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccess, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.virtual_networks = kwargs.get('virtual_networks', None) + + +class PrivateAccessSubnet(msrest.serialization.Model): + """Description of a Virtual Network subnet that is useable for private site access. + + :param name: The name of the subnet. + :type name: str + :param key: The key (ID) of the subnet. + :type key: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccessSubnet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.key = kwargs.get('key', None) + + +class PrivateAccessVirtualNetwork(msrest.serialization.Model): + """Description of a Virtual Network that is useable for private site access. + + :param name: The name of the Virtual Network. + :type name: str + :param key: The key (ID) of the Virtual Network. + :type key: int + :param resource_id: The ARM uri of the Virtual Network. + :type resource_id: str + :param subnets: A List of subnets that access is allowed to on this Virtual Network. An empty + array (but not null) is interpreted to mean that all subnets are allowed within this Virtual + Network. + :type subnets: list[~azure.mgmt.web.v2020_06_01.models.PrivateAccessSubnet] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'subnets': {'key': 'subnets', 'type': '[PrivateAccessSubnet]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccessVirtualNetwork, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.key = kwargs.get('key', None) + self.resource_id = kwargs.get('resource_id', None) + self.subnets = kwargs.get('subnets', None) + + +class PrivateEndpointConnectionResource(ProxyOnlyResource): + """Private Endpoint Connection ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar provisioning_state: + :vartype provisioning_state: str + :param private_endpoint: PrivateEndpoint of a remote private endpoint connection. + :type private_endpoint: ~azure.mgmt.web.v2020_06_01.models.ArmIdWrapper + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'ArmIdWrapper'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpointConnectionResource, self).__init__(**kwargs) + self.provisioning_state = None + self.private_endpoint = kwargs.get('private_endpoint', None) + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + + +class PrivateLinkConnectionApprovalRequestResource(ProxyOnlyResource): + """Private Endpoint Connection Approval ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkConnectionApprovalRequestResource, self).__init__(**kwargs) + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + + +class PrivateLinkConnectionState(msrest.serialization.Model): + """The state of a private link connection. + + :param status: Status of a private link connection. + :type status: str + :param description: Description of a private link connection. + :type description: str + :param actions_required: ActionsRequired for a private link connection. + :type actions_required: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'actions_required': {'key': 'actionsRequired', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkConnectionState, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.description = kwargs.get('description', None) + self.actions_required = kwargs.get('actions_required', None) + + +class PrivateLinkResource(msrest.serialization.Model): + """A private link resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. + :type id: str + :param name: Required. Name of a private link resource. + :type name: str + :param type: Required. + :type type: str + :param properties: Required. Properties of a private link resource. + :type properties: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkResourceProperties + """ + + _validation = { + 'id': {'required': True}, + 'name': {'required': True}, + 'type': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'PrivateLinkResourceProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResource, self).__init__(**kwargs) + self.id = kwargs['id'] + self.name = kwargs['name'] + self.type = kwargs['type'] + self.properties = kwargs['properties'] + + +class PrivateLinkResourceProperties(msrest.serialization.Model): + """Properties of a private link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: GroupId of a private link resource. + :vartype group_id: str + :ivar required_members: RequiredMembers of a private link resource. + :vartype required_members: list[str] + :ivar required_zone_names: RequiredZoneNames of a private link resource. + :vartype required_zone_names: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + 'required_zone_names': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_members': {'key': 'requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourceProperties, self).__init__(**kwargs) + self.group_id = None + self.required_members = None + self.required_zone_names = None + + +class PrivateLinkResourcesWrapper(msrest.serialization.Model): + """Wrapper for a collection of private link resources. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PrivateLinkResource] + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourcesWrapper, self).__init__(**kwargs) + self.value = kwargs['value'] + + +class ProcessInfo(ProxyOnlyResource): + """Process Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar identifier: ARM Identifier for deployment. + :vartype identifier: int + :param deployment_name: Deployment name. + :type deployment_name: str + :param href: HRef URI. + :type href: str + :param minidump: Minidump URI. + :type minidump: str + :param is_profile_running: Is profile running?. + :type is_profile_running: bool + :param is_iis_profile_running: Is the IIS Profile running?. + :type is_iis_profile_running: bool + :param iis_profile_timeout_in_seconds: IIS Profile timeout (seconds). + :type iis_profile_timeout_in_seconds: float + :param parent: Parent process. + :type parent: str + :param children: Child process list. + :type children: list[str] + :param threads: Thread list. + :type threads: list[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfo] + :param open_file_handles: List of open files. + :type open_file_handles: list[str] + :param modules: List of modules. + :type modules: list[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo] + :param file_name: File name of this process. + :type file_name: str + :param command_line: Command line. + :type command_line: str + :param user_name: User name. + :type user_name: str + :param handle_count: Handle count. + :type handle_count: int + :param module_count: Module count. + :type module_count: int + :param thread_count: Thread count. + :type thread_count: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_cpu_time: Total CPU time. + :type total_cpu_time: str + :param user_cpu_time: User CPU time. + :type user_cpu_time: str + :param privileged_cpu_time: Privileged CPU time. + :type privileged_cpu_time: str + :param working_set: Working set. + :type working_set: long + :param peak_working_set: Peak working set. + :type peak_working_set: long + :param private_memory: Private memory size. + :type private_memory: long + :param virtual_memory: Virtual memory size. + :type virtual_memory: long + :param peak_virtual_memory: Peak virtual memory usage. + :type peak_virtual_memory: long + :param paged_system_memory: Paged system memory. + :type paged_system_memory: long + :param non_paged_system_memory: Non-paged system memory. + :type non_paged_system_memory: long + :param paged_memory: Paged memory. + :type paged_memory: long + :param peak_paged_memory: Peak paged memory. + :type peak_paged_memory: long + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + :param environment_variables: List of environment variables. + :type environment_variables: dict[str, str] + :param is_scm_site: Is this the SCM site?. + :type is_scm_site: bool + :param is_webjob: Is this a Web Job?. + :type is_webjob: bool + :param description: Description of process. + :type description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'deployment_name': {'key': 'properties.deployment_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'minidump': {'key': 'properties.minidump', 'type': 'str'}, + 'is_profile_running': {'key': 'properties.is_profile_running', 'type': 'bool'}, + 'is_iis_profile_running': {'key': 'properties.is_iis_profile_running', 'type': 'bool'}, + 'iis_profile_timeout_in_seconds': {'key': 'properties.iis_profile_timeout_in_seconds', 'type': 'float'}, + 'parent': {'key': 'properties.parent', 'type': 'str'}, + 'children': {'key': 'properties.children', 'type': '[str]'}, + 'threads': {'key': 'properties.threads', 'type': '[ProcessThreadInfo]'}, + 'open_file_handles': {'key': 'properties.open_file_handles', 'type': '[str]'}, + 'modules': {'key': 'properties.modules', 'type': '[ProcessModuleInfo]'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'command_line': {'key': 'properties.command_line', 'type': 'str'}, + 'user_name': {'key': 'properties.user_name', 'type': 'str'}, + 'handle_count': {'key': 'properties.handle_count', 'type': 'int'}, + 'module_count': {'key': 'properties.module_count', 'type': 'int'}, + 'thread_count': {'key': 'properties.thread_count', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_cpu_time': {'key': 'properties.total_cpu_time', 'type': 'str'}, + 'user_cpu_time': {'key': 'properties.user_cpu_time', 'type': 'str'}, + 'privileged_cpu_time': {'key': 'properties.privileged_cpu_time', 'type': 'str'}, + 'working_set': {'key': 'properties.working_set', 'type': 'long'}, + 'peak_working_set': {'key': 'properties.peak_working_set', 'type': 'long'}, + 'private_memory': {'key': 'properties.private_memory', 'type': 'long'}, + 'virtual_memory': {'key': 'properties.virtual_memory', 'type': 'long'}, + 'peak_virtual_memory': {'key': 'properties.peak_virtual_memory', 'type': 'long'}, + 'paged_system_memory': {'key': 'properties.paged_system_memory', 'type': 'long'}, + 'non_paged_system_memory': {'key': 'properties.non_paged_system_memory', 'type': 'long'}, + 'paged_memory': {'key': 'properties.paged_memory', 'type': 'long'}, + 'peak_paged_memory': {'key': 'properties.peak_paged_memory', 'type': 'long'}, + 'time_stamp': {'key': 'properties.time_stamp', 'type': 'iso-8601'}, + 'environment_variables': {'key': 'properties.environment_variables', 'type': '{str}'}, + 'is_scm_site': {'key': 'properties.is_scm_site', 'type': 'bool'}, + 'is_webjob': {'key': 'properties.is_webjob', 'type': 'bool'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessInfo, self).__init__(**kwargs) + self.identifier = None + self.deployment_name = kwargs.get('deployment_name', None) + self.href = kwargs.get('href', None) + self.minidump = kwargs.get('minidump', None) + self.is_profile_running = kwargs.get('is_profile_running', None) + self.is_iis_profile_running = kwargs.get('is_iis_profile_running', None) + self.iis_profile_timeout_in_seconds = kwargs.get('iis_profile_timeout_in_seconds', None) + self.parent = kwargs.get('parent', None) + self.children = kwargs.get('children', None) + self.threads = kwargs.get('threads', None) + self.open_file_handles = kwargs.get('open_file_handles', None) + self.modules = kwargs.get('modules', None) + self.file_name = kwargs.get('file_name', None) + self.command_line = kwargs.get('command_line', None) + self.user_name = kwargs.get('user_name', None) + self.handle_count = kwargs.get('handle_count', None) + self.module_count = kwargs.get('module_count', None) + self.thread_count = kwargs.get('thread_count', None) + self.start_time = kwargs.get('start_time', None) + self.total_cpu_time = kwargs.get('total_cpu_time', None) + self.user_cpu_time = kwargs.get('user_cpu_time', None) + self.privileged_cpu_time = kwargs.get('privileged_cpu_time', None) + self.working_set = kwargs.get('working_set', None) + self.peak_working_set = kwargs.get('peak_working_set', None) + self.private_memory = kwargs.get('private_memory', None) + self.virtual_memory = kwargs.get('virtual_memory', None) + self.peak_virtual_memory = kwargs.get('peak_virtual_memory', None) + self.paged_system_memory = kwargs.get('paged_system_memory', None) + self.non_paged_system_memory = kwargs.get('non_paged_system_memory', None) + self.paged_memory = kwargs.get('paged_memory', None) + self.peak_paged_memory = kwargs.get('peak_paged_memory', None) + self.time_stamp = kwargs.get('time_stamp', None) + self.environment_variables = kwargs.get('environment_variables', None) + self.is_scm_site = kwargs.get('is_scm_site', None) + self.is_webjob = kwargs.get('is_webjob', None) + self.description = kwargs.get('description', None) + + +class ProcessInfoCollection(msrest.serialization.Model): + """Collection of Kudu process information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ProcessModuleInfo(ProxyOnlyResource): + """Process Module Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param base_address: Base address. Used as module identifier in ARM resource URI. + :type base_address: str + :param file_name: File name. + :type file_name: str + :param href: HRef URI. + :type href: str + :param file_path: File path. + :type file_path: str + :param module_memory_size: Module memory size. + :type module_memory_size: int + :param file_version: File version. + :type file_version: str + :param file_description: File description. + :type file_description: str + :param product: Product name. + :type product: str + :param product_version: Product version. + :type product_version: str + :param is_debug: Is debug?. + :type is_debug: bool + :param language: Module language (locale). + :type language: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'base_address': {'key': 'properties.base_address', 'type': 'str'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'file_path': {'key': 'properties.file_path', 'type': 'str'}, + 'module_memory_size': {'key': 'properties.module_memory_size', 'type': 'int'}, + 'file_version': {'key': 'properties.file_version', 'type': 'str'}, + 'file_description': {'key': 'properties.file_description', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'product_version': {'key': 'properties.product_version', 'type': 'str'}, + 'is_debug': {'key': 'properties.is_debug', 'type': 'bool'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessModuleInfo, self).__init__(**kwargs) + self.base_address = kwargs.get('base_address', None) + self.file_name = kwargs.get('file_name', None) + self.href = kwargs.get('href', None) + self.file_path = kwargs.get('file_path', None) + self.module_memory_size = kwargs.get('module_memory_size', None) + self.file_version = kwargs.get('file_version', None) + self.file_description = kwargs.get('file_description', None) + self.product = kwargs.get('product', None) + self.product_version = kwargs.get('product_version', None) + self.is_debug = kwargs.get('is_debug', None) + self.language = kwargs.get('language', None) + + +class ProcessModuleInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessModuleInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessModuleInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ProcessThreadInfo(ProxyOnlyResource): + """Process Thread Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar identifier: Site extension ID. + :vartype identifier: int + :param href: HRef URI. + :type href: str + :param process: Process URI. + :type process: str + :param start_address: Start address. + :type start_address: str + :param current_priority: Current thread priority. + :type current_priority: int + :param priority_level: Thread priority level. + :type priority_level: str + :param base_priority: Base priority. + :type base_priority: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_processor_time: Total processor time. + :type total_processor_time: str + :param user_processor_time: User processor time. + :type user_processor_time: str + :param state: Thread state. + :type state: str + :param wait_reason: Wait reason. + :type wait_reason: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'process': {'key': 'properties.process', 'type': 'str'}, + 'start_address': {'key': 'properties.start_address', 'type': 'str'}, + 'current_priority': {'key': 'properties.current_priority', 'type': 'int'}, + 'priority_level': {'key': 'properties.priority_level', 'type': 'str'}, + 'base_priority': {'key': 'properties.base_priority', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_processor_time': {'key': 'properties.total_processor_time', 'type': 'str'}, + 'user_processor_time': {'key': 'properties.user_processor_time', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'wait_reason': {'key': 'properties.wait_reason', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessThreadInfo, self).__init__(**kwargs) + self.identifier = None + self.href = kwargs.get('href', None) + self.process = kwargs.get('process', None) + self.start_address = kwargs.get('start_address', None) + self.current_priority = kwargs.get('current_priority', None) + self.priority_level = kwargs.get('priority_level', None) + self.base_priority = kwargs.get('base_priority', None) + self.start_time = kwargs.get('start_time', None) + self.total_processor_time = kwargs.get('total_processor_time', None) + self.user_processor_time = kwargs.get('user_processor_time', None) + self.state = kwargs.get('state', None) + self.wait_reason = kwargs.get('wait_reason', None) + + +class ProcessThreadInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessThreadInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessThreadInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PublicCertificate(ProxyOnlyResource): + """Public certificate object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param blob: Public Certificate byte array. + :type blob: bytearray + :param public_certificate_location: Public Certificate Location. Possible values include: + "CurrentUserMy", "LocalMachineMy", "Unknown". + :type public_certificate_location: str or + ~azure.mgmt.web.v2020_06_01.models.PublicCertificateLocation + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'thumbprint': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'blob': {'key': 'properties.blob', 'type': 'bytearray'}, + 'public_certificate_location': {'key': 'properties.publicCertificateLocation', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicCertificate, self).__init__(**kwargs) + self.blob = kwargs.get('blob', None) + self.public_certificate_location = kwargs.get('public_certificate_location', None) + self.thumbprint = None + + +class PublicCertificateCollection(msrest.serialization.Model): + """Collection of public certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PublicCertificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicCertificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicCertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PushSettings(ProxyOnlyResource): + """Push settings for the App. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param is_push_enabled: Gets or sets a flag indicating whether the Push endpoint is enabled. + :type is_push_enabled: bool + :param tag_whitelist_json: Gets or sets a JSON string containing a list of tags that are + whitelisted for use by the push registration endpoint. + :type tag_whitelist_json: str + :param tags_requiring_auth: Gets or sets a JSON string containing a list of tags that require + user authentication to be used in the push registration endpoint. + Tags can consist of alphanumeric characters and the following: + '_', '@', '#', '.', ':', '-'. + Validation should be performed at the PushRequestHandler. + :type tags_requiring_auth: str + :param dynamic_tags_json: Gets or sets a JSON string containing a list of dynamic tags that + will be evaluated from user claims in the push registration endpoint. + :type dynamic_tags_json: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_push_enabled': {'key': 'properties.isPushEnabled', 'type': 'bool'}, + 'tag_whitelist_json': {'key': 'properties.tagWhitelistJson', 'type': 'str'}, + 'tags_requiring_auth': {'key': 'properties.tagsRequiringAuth', 'type': 'str'}, + 'dynamic_tags_json': {'key': 'properties.dynamicTagsJson', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PushSettings, self).__init__(**kwargs) + self.is_push_enabled = kwargs.get('is_push_enabled', None) + self.tag_whitelist_json = kwargs.get('tag_whitelist_json', None) + self.tags_requiring_auth = kwargs.get('tags_requiring_auth', None) + self.dynamic_tags_json = kwargs.get('dynamic_tags_json', None) + + +class RampUpRule(msrest.serialization.Model): + """Routing rules for ramp up testing. This rule allows to redirect static traffic % to a slot or to gradually change routing % based on performance. + + :param action_host_name: Hostname of a slot to which the traffic will be redirected if decided + to. E.g. myapp-stage.azurewebsites.net. + :type action_host_name: str + :param reroute_percentage: Percentage of the traffic which will be redirected to + :code:`ActionHostName`. + :type reroute_percentage: float + :param change_step: In auto ramp up scenario this is the step to add/remove from + :code:`ReroutePercentage` until it reaches + \n:code:`MinReroutePercentage` or + :code:`MaxReroutePercentage`. Site metrics are checked every N minutes specified + in :code:`ChangeIntervalInMinutes`.\nCustom decision algorithm + can be provided in TiPCallback site extension which URL can be specified in + :code:`ChangeDecisionCallbackUrl`. + :type change_step: float + :param change_interval_in_minutes: Specifies interval in minutes to reevaluate + ReroutePercentage. + :type change_interval_in_minutes: int + :param min_reroute_percentage: Specifies lower boundary above which ReroutePercentage will + stay. + :type min_reroute_percentage: float + :param max_reroute_percentage: Specifies upper boundary below which ReroutePercentage will + stay. + :type max_reroute_percentage: float + :param change_decision_callback_url: Custom decision algorithm can be provided in TiPCallback + site extension which URL can be specified. See TiPCallback site extension for the scaffold and + contracts. + https://www.siteextensions.net/packages/TiPCallback/. + :type change_decision_callback_url: str + :param name: Name of the routing rule. The recommended name would be to point to the slot which + will receive the traffic in the experiment. + :type name: str + """ + + _attribute_map = { + 'action_host_name': {'key': 'actionHostName', 'type': 'str'}, + 'reroute_percentage': {'key': 'reroutePercentage', 'type': 'float'}, + 'change_step': {'key': 'changeStep', 'type': 'float'}, + 'change_interval_in_minutes': {'key': 'changeIntervalInMinutes', 'type': 'int'}, + 'min_reroute_percentage': {'key': 'minReroutePercentage', 'type': 'float'}, + 'max_reroute_percentage': {'key': 'maxReroutePercentage', 'type': 'float'}, + 'change_decision_callback_url': {'key': 'changeDecisionCallbackUrl', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RampUpRule, self).__init__(**kwargs) + self.action_host_name = kwargs.get('action_host_name', None) + self.reroute_percentage = kwargs.get('reroute_percentage', None) + self.change_step = kwargs.get('change_step', None) + self.change_interval_in_minutes = kwargs.get('change_interval_in_minutes', None) + self.min_reroute_percentage = kwargs.get('min_reroute_percentage', None) + self.max_reroute_percentage = kwargs.get('max_reroute_percentage', None) + self.change_decision_callback_url = kwargs.get('change_decision_callback_url', None) + self.name = kwargs.get('name', None) + + +class Recommendation(ProxyOnlyResource): + """Represents a recommendation result generated by the recommendation engine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param creation_time: Timestamp when this instance was created. + :type creation_time: ~datetime.datetime + :param recommendation_id: A GUID value that each recommendation object is associated with. + :type recommendation_id: str + :param resource_id: Full ARM resource ID string that this recommendation object is associated + with. + :type resource_id: str + :param resource_scope: Name of a resource type this recommendation applies, e.g. Subscription, + ServerFarm, Site. Possible values include: "ServerFarm", "Subscription", "WebSite". + :type resource_scope: str or ~azure.mgmt.web.v2020_06_01.models.ResourceScopeType + :param rule_name: Unique name of the rule. + :type rule_name: str + :param display_name: UI friendly name of the rule (may not be unique). + :type display_name: str + :param message: Recommendation text. + :type message: str + :param level: Level indicating how critical this recommendation can impact. Possible values + include: "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.NotificationLevel + :param channels: List of channels that this recommendation can apply. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_06_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation belongs to. + :vartype category_tags: list[str] + :param action_name: Name of action recommended by this object. + :type action_name: str + :param enabled: True if this recommendation is still valid (i.e. "actionable"). False if it is + invalid. + :type enabled: int + :param states: The list of states of this recommendation. If it's null then it should be + considered "Active". + :type states: list[str] + :param start_time: The beginning time in UTC of a range that the recommendation refers to. + :type start_time: ~datetime.datetime + :param end_time: The end time in UTC of a range that the recommendation refers to. + :type end_time: ~datetime.datetime + :param next_notification_time: When to notify this recommendation next in UTC. Null means that + this will never be notified anymore. + :type next_notification_time: ~datetime.datetime + :param notification_expiration_time: Date and time in UTC when this notification expires. + :type notification_expiration_time: ~datetime.datetime + :param notified_time: Last timestamp in UTC this instance was actually notified. Null means + that this recommendation hasn't been notified yet. + :type notified_time: ~datetime.datetime + :param score: A metric value measured by the rule. + :type score: float + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'creation_time': {'key': 'properties.creationTime', 'type': 'iso-8601'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'resource_id': {'key': 'properties.resourceId', 'type': 'str'}, + 'resource_scope': {'key': 'properties.resourceScope', 'type': 'str'}, + 'rule_name': {'key': 'properties.ruleName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'int'}, + 'states': {'key': 'properties.states', 'type': '[str]'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'next_notification_time': {'key': 'properties.nextNotificationTime', 'type': 'iso-8601'}, + 'notification_expiration_time': {'key': 'properties.notificationExpirationTime', 'type': 'iso-8601'}, + 'notified_time': {'key': 'properties.notifiedTime', 'type': 'iso-8601'}, + 'score': {'key': 'properties.score', 'type': 'float'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Recommendation, self).__init__(**kwargs) + self.creation_time = kwargs.get('creation_time', None) + self.recommendation_id = kwargs.get('recommendation_id', None) + self.resource_id = kwargs.get('resource_id', None) + self.resource_scope = kwargs.get('resource_scope', None) + self.rule_name = kwargs.get('rule_name', None) + self.display_name = kwargs.get('display_name', None) + self.message = kwargs.get('message', None) + self.level = kwargs.get('level', None) + self.channels = kwargs.get('channels', None) + self.category_tags = None + self.action_name = kwargs.get('action_name', None) + self.enabled = kwargs.get('enabled', None) + self.states = kwargs.get('states', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.next_notification_time = kwargs.get('next_notification_time', None) + self.notification_expiration_time = kwargs.get('notification_expiration_time', None) + self.notified_time = kwargs.get('notified_time', None) + self.score = kwargs.get('score', None) + self.is_dynamic = kwargs.get('is_dynamic', None) + self.extension_name = kwargs.get('extension_name', None) + self.blade_name = kwargs.get('blade_name', None) + self.forward_link = kwargs.get('forward_link', None) + + +class RecommendationCollection(msrest.serialization.Model): + """Collection of recommendations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Recommendation] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Recommendation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RecommendationCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class RecommendationRule(ProxyOnlyResource): + """Represents a recommendation rule that the recommendation engine can perform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param recommendation_name: Unique name of the rule. + :type recommendation_name: str + :param display_name: UI friendly name of the rule. + :type display_name: str + :param message: Localized name of the rule (Good for UI). + :type message: str + :param recommendation_id: Recommendation ID of an associated recommendation object tied to the + rule, if exists. + If such an object doesn't exist, it is set to null. + :type recommendation_id: str + :param description: Localized detailed description of the rule. + :type description: str + :param action_name: Name of action that is recommended by this rule in string. + :type action_name: str + :param level: Level of impact indicating how critical this rule is. Possible values include: + "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.NotificationLevel + :param channels: List of available channels that this rule applies. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_06_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation rule belongs to. + :vartype category_tags: list[str] + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. Applicable to dynamic rule only. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. Applicable to dynamic rule only. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. Applicable + to dynamic rule only. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'recommendation_name': {'key': 'properties.recommendationName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RecommendationRule, self).__init__(**kwargs) + self.recommendation_name = kwargs.get('recommendation_name', None) + self.display_name = kwargs.get('display_name', None) + self.message = kwargs.get('message', None) + self.recommendation_id = kwargs.get('recommendation_id', None) + self.description = kwargs.get('description', None) + self.action_name = kwargs.get('action_name', None) + self.level = kwargs.get('level', None) + self.channels = kwargs.get('channels', None) + self.category_tags = None + self.is_dynamic = kwargs.get('is_dynamic', None) + self.extension_name = kwargs.get('extension_name', None) + self.blade_name = kwargs.get('blade_name', None) + self.forward_link = kwargs.get('forward_link', None) + + +class ReissueCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate reissue request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_size: Certificate Key Size. + :type key_size: int + :param delay_existing_revoke_in_hours: Delay in hours to revoke existing certificate after the + new certificate is issued. + :type delay_existing_revoke_in_hours: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'delay_existing_revoke_in_hours': {'key': 'properties.delayExistingRevokeInHours', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ReissueCertificateOrderRequest, self).__init__(**kwargs) + self.key_size = kwargs.get('key_size', None) + self.delay_existing_revoke_in_hours = kwargs.get('delay_existing_revoke_in_hours', None) + self.csr = kwargs.get('csr', None) + self.is_private_key_external = kwargs.get('is_private_key_external', None) + + +class RelayServiceConnectionEntity(ProxyOnlyResource): + """Hybrid Connection for an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param entity_name: + :type entity_name: str + :param entity_connection_string: + :type entity_connection_string: str + :param resource_type: + :type resource_type: str + :param resource_connection_string: + :type resource_connection_string: str + :param hostname: + :type hostname: str + :param port: + :type port: int + :param biztalk_uri: + :type biztalk_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'entity_name': {'key': 'properties.entityName', 'type': 'str'}, + 'entity_connection_string': {'key': 'properties.entityConnectionString', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'resource_connection_string': {'key': 'properties.resourceConnectionString', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'biztalk_uri': {'key': 'properties.biztalkUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RelayServiceConnectionEntity, self).__init__(**kwargs) + self.entity_name = kwargs.get('entity_name', None) + self.entity_connection_string = kwargs.get('entity_connection_string', None) + self.resource_type = kwargs.get('resource_type', None) + self.resource_connection_string = kwargs.get('resource_connection_string', None) + self.hostname = kwargs.get('hostname', None) + self.port = kwargs.get('port', None) + self.biztalk_uri = kwargs.get('biztalk_uri', None) + + +class Rendering(msrest.serialization.Model): + """Instructions for rendering the data. + + :param type: Rendering Type. Possible values include: "NoGraph", "Table", "TimeSeries", + "TimeSeriesPerInstance". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.RenderingType + :param title: Title of data. + :type title: str + :param description: Description of the data that will help it be interpreted. + :type description: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Rendering, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.title = kwargs.get('title', None) + self.description = kwargs.get('description', None) + + +class RenewCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate renew request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_size: Certificate Key Size. + :type key_size: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(RenewCertificateOrderRequest, self).__init__(**kwargs) + self.key_size = kwargs.get('key_size', None) + self.csr = kwargs.get('csr', None) + self.is_private_key_external = kwargs.get('is_private_key_external', None) + + +class RequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on total requests. + + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RequestsBasedTrigger, self).__init__(**kwargs) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class ResourceCollection(msrest.serialization.Model): + """Collection of resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[str] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[str]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceHealthMetadata(ProxyOnlyResource): + """Used for getting ResourceHealthCheck settings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param category: The category that the resource matches in the RHC Policy File. + :type category: str + :param signal_availability: Is there a health signal for the resource. + :type signal_availability: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'category': {'key': 'properties.category', 'type': 'str'}, + 'signal_availability': {'key': 'properties.signalAvailability', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceHealthMetadata, self).__init__(**kwargs) + self.category = kwargs.get('category', None) + self.signal_availability = kwargs.get('signal_availability', None) + + +class ResourceHealthMetadataCollection(msrest.serialization.Model): + """Collection of resource health metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceHealthMetadata]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceHealthMetadataCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceMetricAvailability(msrest.serialization.Model): + """Metrics availability and retention. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time_grain: Time grain . + :vartype time_grain: str + :ivar retention: Retention period for the current time grain. + :vartype retention: str + """ + + _validation = { + 'time_grain': {'readonly': True}, + 'retention': {'readonly': True}, + } + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricAvailability, self).__init__(**kwargs) + self.time_grain = None + self.retention = None + + +class ResourceMetricDefinition(ProxyOnlyResource): + """Metadata for the metrics. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar unit: Unit of the metric. + :vartype unit: str + :ivar primary_aggregation_type: Primary aggregation type. + :vartype primary_aggregation_type: str + :ivar metric_availabilities: List of time grains supported for the metric together with + retention period. + :vartype metric_availabilities: + list[~azure.mgmt.web.v2020_06_01.models.ResourceMetricAvailability] + :ivar resource_uri: Resource URI. + :vartype resource_uri: str + :ivar properties: Resource metric definition properties. + :vartype properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'unit': {'readonly': True}, + 'primary_aggregation_type': {'readonly': True}, + 'metric_availabilities': {'readonly': True}, + 'resource_uri': {'readonly': True}, + 'properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'primary_aggregation_type': {'key': 'properties.primaryAggregationType', 'type': 'str'}, + 'metric_availabilities': {'key': 'properties.metricAvailabilities', 'type': '[ResourceMetricAvailability]'}, + 'resource_uri': {'key': 'properties.resourceUri', 'type': 'str'}, + 'properties': {'key': 'properties.properties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricDefinition, self).__init__(**kwargs) + self.unit = None + self.primary_aggregation_type = None + self.metric_availabilities = None + self.resource_uri = None + self.properties = None + + +class ResourceMetricDefinitionCollection(msrest.serialization.Model): + """Collection of metric definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceMetricDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricDefinitionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceNameAvailability(msrest.serialization.Model): + """Information regarding availability of a resource name. + + :param name_available: :code:`true` indicates name is valid and available. + :code:`false` indicates the name is invalid, unavailable, or both. + :type name_available: bool + :param reason: :code:`Invalid` indicates the name provided does not match Azure + App Service naming requirements. :code:`AlreadyExists` indicates that the name is + already in use and is therefore unavailable. Possible values include: "Invalid", + "AlreadyExists". + :type reason: str or ~azure.mgmt.web.v2020_06_01.models.InAvailabilityReasonType + :param message: If reason == invalid, provide the user with the reason why the given name is + invalid, and provide the resource naming requirements so that the user can select a valid name. + If reason == AlreadyExists, explain that resource name is already in use, and direct them to + select a different name. + :type message: str + """ + + _attribute_map = { + 'name_available': {'key': 'nameAvailable', 'type': 'bool'}, + 'reason': {'key': 'reason', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNameAvailability, self).__init__(**kwargs) + self.name_available = kwargs.get('name_available', None) + self.reason = kwargs.get('reason', None) + self.message = kwargs.get('message', None) + + +class ResourceNameAvailabilityRequest(msrest.serialization.Model): + """Resource name availability request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: "Site", + "Slot", "HostingEnvironment", "PublishingUser", "Microsoft.Web/sites", + "Microsoft.Web/sites/slots", "Microsoft.Web/hostingEnvironments", + "Microsoft.Web/publishingUsers". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_fqdn': {'key': 'isFqdn', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNameAvailabilityRequest, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs['type'] + self.is_fqdn = kwargs.get('is_fqdn', None) + + +class ResponseMetaData(msrest.serialization.Model): + """ResponseMetaData. + + :param data_source: Source of the Data. + :type data_source: ~azure.mgmt.web.v2020_06_01.models.DataSource + """ + + _attribute_map = { + 'data_source': {'key': 'dataSource', 'type': 'DataSource'}, + } + + def __init__( + self, + **kwargs + ): + super(ResponseMetaData, self).__init__(**kwargs) + self.data_source = kwargs.get('data_source', None) + + +class RestoreRequest(ProxyOnlyResource): + """Description of a restore request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param blob_name: Name of a blob which contains the backup. + :type blob_name: str + :param overwrite: :code:`true` if the restore operation can overwrite target app; + otherwise, :code:`false`. :code:`true` is needed if trying to restore + over an existing app. + :type overwrite: bool + :param site_name: Name of an app. + :type site_name: str + :param databases: Collection of databases which should be restored. This list has to match the + list of databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + :param ignore_conflicting_host_names: Changes a logic when restoring an app with custom + domains. :code:`true` to remove custom domains automatically. If + :code:`false`, custom domains are added to + the app's object when it is being restored, but that might fail due to conflicts during the + operation. + :type ignore_conflicting_host_names: bool + :param ignore_databases: Ignore the databases and only restore the site content. + :type ignore_databases: bool + :param app_service_plan: Specify app service plan that will own restored site. + :type app_service_plan: str + :param operation_type: Operation type. Possible values include: "Default", "Clone", + "Relocation", "Snapshot", "CloudFS". Default value: "Default". + :type operation_type: str or ~azure.mgmt.web.v2020_06_01.models.BackupRestoreOperationType + :param adjust_connection_strings: :code:`true` if SiteConfig.ConnectionStrings + should be set in new app; otherwise, :code:`false`. + :type adjust_connection_strings: bool + :param hosting_environment: App Service Environment name, if needed (only when restoring an app + to an App Service Environment). + :type hosting_environment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'ignore_databases': {'key': 'properties.ignoreDatabases', 'type': 'bool'}, + 'app_service_plan': {'key': 'properties.appServicePlan', 'type': 'str'}, + 'operation_type': {'key': 'properties.operationType', 'type': 'str'}, + 'adjust_connection_strings': {'key': 'properties.adjustConnectionStrings', 'type': 'bool'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RestoreRequest, self).__init__(**kwargs) + self.storage_account_url = kwargs.get('storage_account_url', None) + self.blob_name = kwargs.get('blob_name', None) + self.overwrite = kwargs.get('overwrite', None) + self.site_name = kwargs.get('site_name', None) + self.databases = kwargs.get('databases', None) + self.ignore_conflicting_host_names = kwargs.get('ignore_conflicting_host_names', False) + self.ignore_databases = kwargs.get('ignore_databases', False) + self.app_service_plan = kwargs.get('app_service_plan', None) + self.operation_type = kwargs.get('operation_type', "Default") + self.adjust_connection_strings = kwargs.get('adjust_connection_strings', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + + +class ServiceSpecification(msrest.serialization.Model): + """Resource metrics service provided by Microsoft.Insights resource provider. + + :param metric_specifications: + :type metric_specifications: list[~azure.mgmt.web.v2020_06_01.models.MetricSpecification] + :param log_specifications: + :type log_specifications: list[~azure.mgmt.web.v2020_06_01.models.LogSpecification] + """ + + _attribute_map = { + 'metric_specifications': {'key': 'metricSpecifications', 'type': '[MetricSpecification]'}, + 'log_specifications': {'key': 'logSpecifications', 'type': '[LogSpecification]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = kwargs.get('metric_specifications', None) + self.log_specifications = kwargs.get('log_specifications', None) + + +class Site(Resource): + """A web app, a mobile app backend, or an API app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_06_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_06_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_06_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_06_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_06_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_06_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_06_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Site, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = kwargs.get('enabled', None) + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = kwargs.get('host_name_ssl_states', None) + self.server_farm_id = kwargs.get('server_farm_id', None) + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.last_modified_time_utc = None + self.site_config = kwargs.get('site_config', None) + self.traffic_manager_host_names = None + self.scm_site_also_stopped = kwargs.get('scm_site_also_stopped', False) + self.target_swap_slot = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.client_affinity_enabled = kwargs.get('client_affinity_enabled', None) + self.client_cert_enabled = kwargs.get('client_cert_enabled', None) + self.client_cert_mode = kwargs.get('client_cert_mode', None) + self.client_cert_exclusion_paths = kwargs.get('client_cert_exclusion_paths', None) + self.host_names_disabled = kwargs.get('host_names_disabled', None) + self.custom_domain_verification_id = kwargs.get('custom_domain_verification_id', None) + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = kwargs.get('container_size', None) + self.daily_memory_time_quota = kwargs.get('daily_memory_time_quota', None) + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = kwargs.get('cloning_info', None) + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = kwargs.get('https_only', None) + self.redundancy_mode = kwargs.get('redundancy_mode', None) + self.in_progress_operation_id = None + + +class SiteAuthSettings(ProxyOnlyResource): + """Configuration settings for the Azure App Service Authentication / Authorization feature. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: :code:`true` if the Authentication / Authorization feature is + enabled for the current app; otherwise, :code:`false`. + :type enabled: bool + :param runtime_version: The RuntimeVersion of the Authentication / Authorization feature in use + for the current app. + The setting in this value can control the behavior of certain features in the Authentication / + Authorization module. + :type runtime_version: str + :param unauthenticated_client_action: The action to take when an unauthenticated client + attempts to access the app. Possible values include: "RedirectToLoginPage", "AllowAnonymous". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_06_01.models.UnauthenticatedClientAction + :param token_store_enabled: :code:`true` to durably store platform-specific + security tokens that are obtained during login flows; otherwise, :code:`false`. + The default is :code:`false`. + :type token_store_enabled: bool + :param allowed_external_redirect_urls: External URLs that can be redirected to as part of + logging in or logging out of the app. Note that the query string part of the URL is ignored. + This is an advanced setting typically only needed by Windows Store application backends. + Note that URLs within the current domain are always implicitly allowed. + :type allowed_external_redirect_urls: list[str] + :param default_provider: The default authentication provider to use when multiple providers are + configured. + This setting is only needed if multiple providers are configured and the unauthenticated + client + action is set to "RedirectToLoginPage". Possible values include: "AzureActiveDirectory", + "Facebook", "Google", "MicrosoftAccount", "Twitter", "Github". + :type default_provider: str or ~azure.mgmt.web.v2020_06_01.models.BuiltInAuthenticationProvider + :param token_refresh_extension_hours: The number of hours after session token expiration that a + session token can be used to + call the token refresh API. The default is 72 hours. + :type token_refresh_extension_hours: float + :param client_id: The Client ID of this relying party application, known as the client_id. + This setting is required for enabling OpenID Connection authentication with Azure Active + Directory or + other 3rd party OpenID Connect providers. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_id: str + :param client_secret: The Client Secret of this relying party application (in Azure Active + Directory, this is also referred to as the Key). + This setting is optional. If no client secret is configured, the OpenID Connect implicit auth + flow is used to authenticate end users. + Otherwise, the OpenID Connect Authorization Code Flow is used to authenticate end users. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_secret: str + :param client_secret_setting_name: The app setting name that contains the client secret of the + relying party application. + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: An alternative to the client secret, that is the + thumbprint of a certificate used for signing purposes. This property acts as + a replacement for the Client Secret. It is also optional. + :type client_secret_certificate_thumbprint: str + :param issuer: The OpenID Connect Issuer URI that represents the entity which issues access + tokens for this application. + When using Azure Active Directory, this value is the URI of the directory tenant, e.g. + https://sts.windows.net/{tenant-guid}/. + This URI is a case-sensitive identifier for the token issuer. + More information on OpenID Connect Discovery: http://openid.net/specs/openid-connect- + discovery-1_0.html. + :type issuer: str + :param validate_issuer: Gets a value indicating whether the issuer should be a valid HTTPS url + and be validated as such. + :type validate_issuer: bool + :param allowed_audiences: Allowed audience values to consider when validating JWTs issued by + Azure Active Directory. Note that the :code:`ClientID` value is always considered + an + allowed audience, regardless of this setting. + :type allowed_audiences: list[str] + :param additional_login_params: Login parameters to send to the OpenID Connect authorization + endpoint when + a user logs in. Each parameter must be in the form "key=value". + :type additional_login_params: list[str] + :param aad_claims_authorization: Gets a JSON string containing the Azure AD Acl settings. + :type aad_claims_authorization: str + :param google_client_id: The OpenID Connect Client ID for the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_id: str + :param google_client_secret: The client secret associated with the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_secret: str + :param google_client_secret_setting_name: The app setting name that contains the client secret + associated with + the Google web application. + :type google_client_secret_setting_name: str + :param google_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Google + Sign-In authentication. + This setting is optional. If not specified, "openid", "profile", and "email" are used as + default scopes. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_o_auth_scopes: list[str] + :param facebook_app_id: The App ID of the Facebook app used for login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_id: str + :param facebook_app_secret: The App Secret of the Facebook app used for Facebook Login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_secret: str + :param facebook_app_secret_setting_name: The app setting name that contains the app secret used + for Facebook Login. + :type facebook_app_secret_setting_name: str + :param facebook_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Facebook + Login authentication. + This setting is optional. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_o_auth_scopes: list[str] + :param git_hub_client_id: The Client Id of the GitHub app used for login. + This setting is required for enabling Github login. + :type git_hub_client_id: str + :param git_hub_client_secret: The Client Secret of the GitHub app used for Github Login. + This setting is required for enabling Github login. + :type git_hub_client_secret: str + :param git_hub_client_secret_setting_name: The app setting name that contains the client secret + of the Github + app used for GitHub Login. + :type git_hub_client_secret_setting_name: str + :param git_hub_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of GitHub + Login authentication. + This setting is optional. + :type git_hub_o_auth_scopes: list[str] + :param twitter_consumer_key: The OAuth 1.0a consumer key of the Twitter application used for + sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_key: str + :param twitter_consumer_secret: The OAuth 1.0a consumer secret of the Twitter application used + for sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_secret: str + :param twitter_consumer_secret_setting_name: The app setting name that contains the OAuth 1.0a + consumer secret of the Twitter + application used for sign-in. + :type twitter_consumer_secret_setting_name: str + :param microsoft_account_client_id: The OAuth 2.0 client ID that was created for the app used + for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_id: str + :param microsoft_account_client_secret: The OAuth 2.0 client secret that was created for the + app used for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_secret: str + :param microsoft_account_client_secret_setting_name: The app setting name containing the OAuth + 2.0 client secret that was created for the + app used for authentication. + :type microsoft_account_client_secret_setting_name: str + :param microsoft_account_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of + Microsoft Account authentication. + This setting is optional. If not specified, "wl.basic" is used as the default scope. + Microsoft Account Scopes and permissions documentation: https://msdn.microsoft.com/en- + us/library/dn631845.aspx. + :type microsoft_account_o_auth_scopes: list[str] + :param is_auth_from_file: "true" if the auth config settings should be read from a file, + "false" otherwise. + :type is_auth_from_file: str + :param auth_file_path: The path of the config file containing auth settings. + If the path is relative, base will the site's root directory. + :type auth_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'token_store_enabled': {'key': 'properties.tokenStoreEnabled', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'default_provider': {'key': 'properties.defaultProvider', 'type': 'str'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret': {'key': 'properties.clientSecret', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'validate_issuer': {'key': 'properties.validateIssuer', 'type': 'bool'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + 'additional_login_params': {'key': 'properties.additionalLoginParams', 'type': '[str]'}, + 'aad_claims_authorization': {'key': 'properties.aadClaimsAuthorization', 'type': 'str'}, + 'google_client_id': {'key': 'properties.googleClientId', 'type': 'str'}, + 'google_client_secret': {'key': 'properties.googleClientSecret', 'type': 'str'}, + 'google_client_secret_setting_name': {'key': 'properties.googleClientSecretSettingName', 'type': 'str'}, + 'google_o_auth_scopes': {'key': 'properties.googleOAuthScopes', 'type': '[str]'}, + 'facebook_app_id': {'key': 'properties.facebookAppId', 'type': 'str'}, + 'facebook_app_secret': {'key': 'properties.facebookAppSecret', 'type': 'str'}, + 'facebook_app_secret_setting_name': {'key': 'properties.facebookAppSecretSettingName', 'type': 'str'}, + 'facebook_o_auth_scopes': {'key': 'properties.facebookOAuthScopes', 'type': '[str]'}, + 'git_hub_client_id': {'key': 'properties.gitHubClientId', 'type': 'str'}, + 'git_hub_client_secret': {'key': 'properties.gitHubClientSecret', 'type': 'str'}, + 'git_hub_client_secret_setting_name': {'key': 'properties.gitHubClientSecretSettingName', 'type': 'str'}, + 'git_hub_o_auth_scopes': {'key': 'properties.gitHubOAuthScopes', 'type': '[str]'}, + 'twitter_consumer_key': {'key': 'properties.twitterConsumerKey', 'type': 'str'}, + 'twitter_consumer_secret': {'key': 'properties.twitterConsumerSecret', 'type': 'str'}, + 'twitter_consumer_secret_setting_name': {'key': 'properties.twitterConsumerSecretSettingName', 'type': 'str'}, + 'microsoft_account_client_id': {'key': 'properties.microsoftAccountClientId', 'type': 'str'}, + 'microsoft_account_client_secret': {'key': 'properties.microsoftAccountClientSecret', 'type': 'str'}, + 'microsoft_account_client_secret_setting_name': {'key': 'properties.microsoftAccountClientSecretSettingName', 'type': 'str'}, + 'microsoft_account_o_auth_scopes': {'key': 'properties.microsoftAccountOAuthScopes', 'type': '[str]'}, + 'is_auth_from_file': {'key': 'properties.isAuthFromFile', 'type': 'str'}, + 'auth_file_path': {'key': 'properties.authFilePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteAuthSettings, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.unauthenticated_client_action = kwargs.get('unauthenticated_client_action', None) + self.token_store_enabled = kwargs.get('token_store_enabled', None) + self.allowed_external_redirect_urls = kwargs.get('allowed_external_redirect_urls', None) + self.default_provider = kwargs.get('default_provider', None) + self.token_refresh_extension_hours = kwargs.get('token_refresh_extension_hours', None) + self.client_id = kwargs.get('client_id', None) + self.client_secret = kwargs.get('client_secret', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + self.client_secret_certificate_thumbprint = kwargs.get('client_secret_certificate_thumbprint', None) + self.issuer = kwargs.get('issuer', None) + self.validate_issuer = kwargs.get('validate_issuer', None) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + self.additional_login_params = kwargs.get('additional_login_params', None) + self.aad_claims_authorization = kwargs.get('aad_claims_authorization', None) + self.google_client_id = kwargs.get('google_client_id', None) + self.google_client_secret = kwargs.get('google_client_secret', None) + self.google_client_secret_setting_name = kwargs.get('google_client_secret_setting_name', None) + self.google_o_auth_scopes = kwargs.get('google_o_auth_scopes', None) + self.facebook_app_id = kwargs.get('facebook_app_id', None) + self.facebook_app_secret = kwargs.get('facebook_app_secret', None) + self.facebook_app_secret_setting_name = kwargs.get('facebook_app_secret_setting_name', None) + self.facebook_o_auth_scopes = kwargs.get('facebook_o_auth_scopes', None) + self.git_hub_client_id = kwargs.get('git_hub_client_id', None) + self.git_hub_client_secret = kwargs.get('git_hub_client_secret', None) + self.git_hub_client_secret_setting_name = kwargs.get('git_hub_client_secret_setting_name', None) + self.git_hub_o_auth_scopes = kwargs.get('git_hub_o_auth_scopes', None) + self.twitter_consumer_key = kwargs.get('twitter_consumer_key', None) + self.twitter_consumer_secret = kwargs.get('twitter_consumer_secret', None) + self.twitter_consumer_secret_setting_name = kwargs.get('twitter_consumer_secret_setting_name', None) + self.microsoft_account_client_id = kwargs.get('microsoft_account_client_id', None) + self.microsoft_account_client_secret = kwargs.get('microsoft_account_client_secret', None) + self.microsoft_account_client_secret_setting_name = kwargs.get('microsoft_account_client_secret_setting_name', None) + self.microsoft_account_o_auth_scopes = kwargs.get('microsoft_account_o_auth_scopes', None) + self.is_auth_from_file = kwargs.get('is_auth_from_file', None) + self.auth_file_path = kwargs.get('auth_file_path', None) + + +class SiteAuthSettingsV2(ProxyOnlyResource): + """SiteAuthSettingsV2. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param platform: + :type platform: ~azure.mgmt.web.v2020_06_01.models.AuthPlatform + :param global_validation: + :type global_validation: ~azure.mgmt.web.v2020_06_01.models.GlobalValidation + :param identity_providers: + :type identity_providers: ~azure.mgmt.web.v2020_06_01.models.IdentityProviders + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.Login + :param http_settings: + :type http_settings: ~azure.mgmt.web.v2020_06_01.models.HttpSettings + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'platform': {'key': 'properties.platform', 'type': 'AuthPlatform'}, + 'global_validation': {'key': 'properties.globalValidation', 'type': 'GlobalValidation'}, + 'identity_providers': {'key': 'properties.identityProviders', 'type': 'IdentityProviders'}, + 'login': {'key': 'properties.login', 'type': 'Login'}, + 'http_settings': {'key': 'properties.httpSettings', 'type': 'HttpSettings'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteAuthSettingsV2, self).__init__(**kwargs) + self.platform = kwargs.get('platform', None) + self.global_validation = kwargs.get('global_validation', None) + self.identity_providers = kwargs.get('identity_providers', None) + self.login = kwargs.get('login', None) + self.http_settings = kwargs.get('http_settings', None) + + +class SiteCloneability(msrest.serialization.Model): + """Represents whether or not an app is cloneable. + + :param result: Name of app. Possible values include: "Cloneable", "PartiallyCloneable", + "NotCloneable". + :type result: str or ~azure.mgmt.web.v2020_06_01.models.CloneAbilityResult + :param blocking_features: List of features enabled on app that prevent cloning. + :type blocking_features: list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + :param unsupported_features: List of features enabled on app that are non-blocking but cannot + be cloned. The app can still be cloned + but the features in this list will not be set up on cloned app. + :type unsupported_features: list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + :param blocking_characteristics: List of blocking application characteristics. + :type blocking_characteristics: + list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + """ + + _attribute_map = { + 'result': {'key': 'result', 'type': 'str'}, + 'blocking_features': {'key': 'blockingFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'unsupported_features': {'key': 'unsupportedFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'blocking_characteristics': {'key': 'blockingCharacteristics', 'type': '[SiteCloneabilityCriterion]'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteCloneability, self).__init__(**kwargs) + self.result = kwargs.get('result', None) + self.blocking_features = kwargs.get('blocking_features', None) + self.unsupported_features = kwargs.get('unsupported_features', None) + self.blocking_characteristics = kwargs.get('blocking_characteristics', None) + + +class SiteCloneabilityCriterion(msrest.serialization.Model): + """An app cloneability criterion. + + :param name: Name of criterion. + :type name: str + :param description: Description of criterion. + :type description: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteCloneabilityCriterion, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + + +class SiteConfig(msrest.serialization.Model): + """Configuration of an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_06_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_06_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_06_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_06_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_06_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_06_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_06_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_06_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_06_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_06_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_06_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_06_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_06_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_06_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'number_of_workers': {'key': 'numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'phpVersion', 'type': 'str'}, + 'python_version': {'key': 'pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'javaVersion', 'type': 'str'}, + 'java_container': {'key': 'javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'experiments', 'type': 'Experiments'}, + 'limits': {'key': 'limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'cors', 'type': 'CorsSettings'}, + 'push': {'key': 'push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfig, self).__init__(**kwargs) + self.number_of_workers = kwargs.get('number_of_workers', None) + self.default_documents = kwargs.get('default_documents', None) + self.net_framework_version = kwargs.get('net_framework_version', "v4.6") + self.php_version = kwargs.get('php_version', None) + self.python_version = kwargs.get('python_version', None) + self.node_version = kwargs.get('node_version', None) + self.power_shell_version = kwargs.get('power_shell_version', None) + self.linux_fx_version = kwargs.get('linux_fx_version', None) + self.windows_fx_version = kwargs.get('windows_fx_version', None) + self.request_tracing_enabled = kwargs.get('request_tracing_enabled', None) + self.request_tracing_expiration_time = kwargs.get('request_tracing_expiration_time', None) + self.remote_debugging_enabled = kwargs.get('remote_debugging_enabled', None) + self.remote_debugging_version = kwargs.get('remote_debugging_version', None) + self.http_logging_enabled = kwargs.get('http_logging_enabled', None) + self.logs_directory_size_limit = kwargs.get('logs_directory_size_limit', None) + self.detailed_error_logging_enabled = kwargs.get('detailed_error_logging_enabled', None) + self.publishing_username = kwargs.get('publishing_username', None) + self.app_settings = kwargs.get('app_settings', None) + self.connection_strings = kwargs.get('connection_strings', None) + self.machine_key = None + self.handler_mappings = kwargs.get('handler_mappings', None) + self.document_root = kwargs.get('document_root', None) + self.scm_type = kwargs.get('scm_type', None) + self.use32_bit_worker_process = kwargs.get('use32_bit_worker_process', None) + self.web_sockets_enabled = kwargs.get('web_sockets_enabled', None) + self.always_on = kwargs.get('always_on', None) + self.java_version = kwargs.get('java_version', None) + self.java_container = kwargs.get('java_container', None) + self.java_container_version = kwargs.get('java_container_version', None) + self.app_command_line = kwargs.get('app_command_line', None) + self.managed_pipeline_mode = kwargs.get('managed_pipeline_mode', None) + self.virtual_applications = kwargs.get('virtual_applications', None) + self.load_balancing = kwargs.get('load_balancing', None) + self.experiments = kwargs.get('experiments', None) + self.limits = kwargs.get('limits', None) + self.auto_heal_enabled = kwargs.get('auto_heal_enabled', None) + self.auto_heal_rules = kwargs.get('auto_heal_rules', None) + self.tracing_options = kwargs.get('tracing_options', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_route_all_enabled = kwargs.get('vnet_route_all_enabled', None) + self.vnet_private_ports_count = kwargs.get('vnet_private_ports_count', None) + self.cors = kwargs.get('cors', None) + self.push = kwargs.get('push', None) + self.api_definition = kwargs.get('api_definition', None) + self.api_management_config = kwargs.get('api_management_config', None) + self.auto_swap_slot_name = kwargs.get('auto_swap_slot_name', None) + self.local_my_sql_enabled = kwargs.get('local_my_sql_enabled', False) + self.managed_service_identity_id = kwargs.get('managed_service_identity_id', None) + self.x_managed_service_identity_id = kwargs.get('x_managed_service_identity_id', None) + self.ip_security_restrictions = kwargs.get('ip_security_restrictions', None) + self.scm_ip_security_restrictions = kwargs.get('scm_ip_security_restrictions', None) + self.scm_ip_security_restrictions_use_main = kwargs.get('scm_ip_security_restrictions_use_main', None) + self.http20_enabled = kwargs.get('http20_enabled', True) + self.min_tls_version = kwargs.get('min_tls_version', None) + self.scm_min_tls_version = kwargs.get('scm_min_tls_version', None) + self.ftps_state = kwargs.get('ftps_state', None) + self.pre_warmed_instance_count = kwargs.get('pre_warmed_instance_count', None) + self.health_check_path = kwargs.get('health_check_path', None) + + +class SiteConfigResource(ProxyOnlyResource): + """Web app configuration ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_06_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_06_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_06_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_06_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_06_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_06_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_06_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_06_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_06_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_06_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_06_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_06_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_06_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_06_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'number_of_workers': {'key': 'properties.numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'properties.defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'properties.netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'properties.phpVersion', 'type': 'str'}, + 'python_version': {'key': 'properties.pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'properties.nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'properties.powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'properties.linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'properties.windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'properties.requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'properties.requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'properties.remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'properties.remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'properties.httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'properties.logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'properties.detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'properties.publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'properties.appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'properties.connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'properties.machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'properties.handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'properties.documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'properties.scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'properties.use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'properties.webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'properties.alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'properties.javaVersion', 'type': 'str'}, + 'java_container': {'key': 'properties.javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'properties.javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'properties.appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'properties.managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'properties.virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'properties.loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'properties.experiments', 'type': 'Experiments'}, + 'limits': {'key': 'properties.limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'properties.autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'properties.autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'properties.tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'properties.vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'properties.vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'properties.cors', 'type': 'CorsSettings'}, + 'push': {'key': 'properties.push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'properties.apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'properties.apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'properties.autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'properties.managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'properties.xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'properties.ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'properties.scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'properties.scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'properties.http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'properties.minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'properties.scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'properties.ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'properties.preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'properties.healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigResource, self).__init__(**kwargs) + self.number_of_workers = kwargs.get('number_of_workers', None) + self.default_documents = kwargs.get('default_documents', None) + self.net_framework_version = kwargs.get('net_framework_version', "v4.6") + self.php_version = kwargs.get('php_version', None) + self.python_version = kwargs.get('python_version', None) + self.node_version = kwargs.get('node_version', None) + self.power_shell_version = kwargs.get('power_shell_version', None) + self.linux_fx_version = kwargs.get('linux_fx_version', None) + self.windows_fx_version = kwargs.get('windows_fx_version', None) + self.request_tracing_enabled = kwargs.get('request_tracing_enabled', None) + self.request_tracing_expiration_time = kwargs.get('request_tracing_expiration_time', None) + self.remote_debugging_enabled = kwargs.get('remote_debugging_enabled', None) + self.remote_debugging_version = kwargs.get('remote_debugging_version', None) + self.http_logging_enabled = kwargs.get('http_logging_enabled', None) + self.logs_directory_size_limit = kwargs.get('logs_directory_size_limit', None) + self.detailed_error_logging_enabled = kwargs.get('detailed_error_logging_enabled', None) + self.publishing_username = kwargs.get('publishing_username', None) + self.app_settings = kwargs.get('app_settings', None) + self.connection_strings = kwargs.get('connection_strings', None) + self.machine_key = None + self.handler_mappings = kwargs.get('handler_mappings', None) + self.document_root = kwargs.get('document_root', None) + self.scm_type = kwargs.get('scm_type', None) + self.use32_bit_worker_process = kwargs.get('use32_bit_worker_process', None) + self.web_sockets_enabled = kwargs.get('web_sockets_enabled', None) + self.always_on = kwargs.get('always_on', None) + self.java_version = kwargs.get('java_version', None) + self.java_container = kwargs.get('java_container', None) + self.java_container_version = kwargs.get('java_container_version', None) + self.app_command_line = kwargs.get('app_command_line', None) + self.managed_pipeline_mode = kwargs.get('managed_pipeline_mode', None) + self.virtual_applications = kwargs.get('virtual_applications', None) + self.load_balancing = kwargs.get('load_balancing', None) + self.experiments = kwargs.get('experiments', None) + self.limits = kwargs.get('limits', None) + self.auto_heal_enabled = kwargs.get('auto_heal_enabled', None) + self.auto_heal_rules = kwargs.get('auto_heal_rules', None) + self.tracing_options = kwargs.get('tracing_options', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_route_all_enabled = kwargs.get('vnet_route_all_enabled', None) + self.vnet_private_ports_count = kwargs.get('vnet_private_ports_count', None) + self.cors = kwargs.get('cors', None) + self.push = kwargs.get('push', None) + self.api_definition = kwargs.get('api_definition', None) + self.api_management_config = kwargs.get('api_management_config', None) + self.auto_swap_slot_name = kwargs.get('auto_swap_slot_name', None) + self.local_my_sql_enabled = kwargs.get('local_my_sql_enabled', False) + self.managed_service_identity_id = kwargs.get('managed_service_identity_id', None) + self.x_managed_service_identity_id = kwargs.get('x_managed_service_identity_id', None) + self.ip_security_restrictions = kwargs.get('ip_security_restrictions', None) + self.scm_ip_security_restrictions = kwargs.get('scm_ip_security_restrictions', None) + self.scm_ip_security_restrictions_use_main = kwargs.get('scm_ip_security_restrictions_use_main', None) + self.http20_enabled = kwargs.get('http20_enabled', True) + self.min_tls_version = kwargs.get('min_tls_version', None) + self.scm_min_tls_version = kwargs.get('scm_min_tls_version', None) + self.ftps_state = kwargs.get('ftps_state', None) + self.pre_warmed_instance_count = kwargs.get('pre_warmed_instance_count', None) + self.health_check_path = kwargs.get('health_check_path', None) + + +class SiteConfigResourceCollection(msrest.serialization.Model): + """Collection of site configurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteConfigResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigResourceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteConfigurationSnapshotInfo(ProxyOnlyResource): + """A snapshot of a web app configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar time: The time the snapshot was taken. + :vartype time: ~datetime.datetime + :ivar snapshot_id: The id of the snapshot. + :vartype snapshot_id: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'time': {'readonly': True}, + 'snapshot_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'time': {'key': 'properties.time', 'type': 'iso-8601'}, + 'snapshot_id': {'key': 'properties.snapshotId', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigurationSnapshotInfo, self).__init__(**kwargs) + self.time = None + self.snapshot_id = None + + +class SiteConfigurationSnapshotInfoCollection(msrest.serialization.Model): + """Collection of metadata for the app configuration snapshots that can be restored. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigurationSnapshotInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigurationSnapshotInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteExtensionInfo(ProxyOnlyResource): + """Site Extension Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param extension_id: Site extension ID. + :type extension_id: str + :param title: + :type title: str + :param extension_type: Site extension type. Possible values include: "Gallery", "WebRoot". + :type extension_type: str or ~azure.mgmt.web.v2020_06_01.models.SiteExtensionType + :param summary: Summary description. + :type summary: str + :param description: Detailed description. + :type description: str + :param version: Version information. + :type version: str + :param extension_url: Extension URL. + :type extension_url: str + :param project_url: Project URL. + :type project_url: str + :param icon_url: Icon URL. + :type icon_url: str + :param license_url: License URL. + :type license_url: str + :param feed_url: Feed URL. + :type feed_url: str + :param authors: List of authors. + :type authors: list[str] + :param installer_command_line_params: Installer command line parameters. + :type installer_command_line_params: str + :param published_date_time: Published timestamp. + :type published_date_time: ~datetime.datetime + :param download_count: Count of downloads. + :type download_count: int + :param local_is_latest_version: :code:`true` if the local version is the latest + version; :code:`false` otherwise. + :type local_is_latest_version: bool + :param local_path: Local path. + :type local_path: str + :param installed_date_time: Installed timestamp. + :type installed_date_time: ~datetime.datetime + :param provisioning_state: Provisioning state. + :type provisioning_state: str + :param comment: Site Extension comment. + :type comment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'extension_id': {'key': 'properties.extension_id', 'type': 'str'}, + 'title': {'key': 'properties.title', 'type': 'str'}, + 'extension_type': {'key': 'properties.extension_type', 'type': 'str'}, + 'summary': {'key': 'properties.summary', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'extension_url': {'key': 'properties.extension_url', 'type': 'str'}, + 'project_url': {'key': 'properties.project_url', 'type': 'str'}, + 'icon_url': {'key': 'properties.icon_url', 'type': 'str'}, + 'license_url': {'key': 'properties.license_url', 'type': 'str'}, + 'feed_url': {'key': 'properties.feed_url', 'type': 'str'}, + 'authors': {'key': 'properties.authors', 'type': '[str]'}, + 'installer_command_line_params': {'key': 'properties.installer_command_line_params', 'type': 'str'}, + 'published_date_time': {'key': 'properties.published_date_time', 'type': 'iso-8601'}, + 'download_count': {'key': 'properties.download_count', 'type': 'int'}, + 'local_is_latest_version': {'key': 'properties.local_is_latest_version', 'type': 'bool'}, + 'local_path': {'key': 'properties.local_path', 'type': 'str'}, + 'installed_date_time': {'key': 'properties.installed_date_time', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'comment': {'key': 'properties.comment', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteExtensionInfo, self).__init__(**kwargs) + self.extension_id = kwargs.get('extension_id', None) + self.title = kwargs.get('title', None) + self.extension_type = kwargs.get('extension_type', None) + self.summary = kwargs.get('summary', None) + self.description = kwargs.get('description', None) + self.version = kwargs.get('version', None) + self.extension_url = kwargs.get('extension_url', None) + self.project_url = kwargs.get('project_url', None) + self.icon_url = kwargs.get('icon_url', None) + self.license_url = kwargs.get('license_url', None) + self.feed_url = kwargs.get('feed_url', None) + self.authors = kwargs.get('authors', None) + self.installer_command_line_params = kwargs.get('installer_command_line_params', None) + self.published_date_time = kwargs.get('published_date_time', None) + self.download_count = kwargs.get('download_count', None) + self.local_is_latest_version = kwargs.get('local_is_latest_version', None) + self.local_path = kwargs.get('local_path', None) + self.installed_date_time = kwargs.get('installed_date_time', None) + self.provisioning_state = kwargs.get('provisioning_state', None) + self.comment = kwargs.get('comment', None) + + +class SiteExtensionInfoCollection(msrest.serialization.Model): + """Collection of Kudu site extension information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteExtensionInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteExtensionInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteLimits(msrest.serialization.Model): + """Metric limits set on an app. + + :param max_percentage_cpu: Maximum allowed CPU usage percentage. + :type max_percentage_cpu: float + :param max_memory_in_mb: Maximum allowed memory usage in MB. + :type max_memory_in_mb: long + :param max_disk_size_in_mb: Maximum allowed disk size usage in MB. + :type max_disk_size_in_mb: long + """ + + _attribute_map = { + 'max_percentage_cpu': {'key': 'maxPercentageCpu', 'type': 'float'}, + 'max_memory_in_mb': {'key': 'maxMemoryInMb', 'type': 'long'}, + 'max_disk_size_in_mb': {'key': 'maxDiskSizeInMb', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteLimits, self).__init__(**kwargs) + self.max_percentage_cpu = kwargs.get('max_percentage_cpu', None) + self.max_memory_in_mb = kwargs.get('max_memory_in_mb', None) + self.max_disk_size_in_mb = kwargs.get('max_disk_size_in_mb', None) + + +class SiteLogsConfig(ProxyOnlyResource): + """Configuration of App Service site logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param application_logs: Application logs configuration. + :type application_logs: ~azure.mgmt.web.v2020_06_01.models.ApplicationLogsConfig + :param http_logs: HTTP logs configuration. + :type http_logs: ~azure.mgmt.web.v2020_06_01.models.HttpLogsConfig + :param failed_requests_tracing: Failed requests tracing configuration. + :type failed_requests_tracing: ~azure.mgmt.web.v2020_06_01.models.EnabledConfig + :param detailed_error_messages: Detailed error messages configuration. + :type detailed_error_messages: ~azure.mgmt.web.v2020_06_01.models.EnabledConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'application_logs': {'key': 'properties.applicationLogs', 'type': 'ApplicationLogsConfig'}, + 'http_logs': {'key': 'properties.httpLogs', 'type': 'HttpLogsConfig'}, + 'failed_requests_tracing': {'key': 'properties.failedRequestsTracing', 'type': 'EnabledConfig'}, + 'detailed_error_messages': {'key': 'properties.detailedErrorMessages', 'type': 'EnabledConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteLogsConfig, self).__init__(**kwargs) + self.application_logs = kwargs.get('application_logs', None) + self.http_logs = kwargs.get('http_logs', None) + self.failed_requests_tracing = kwargs.get('failed_requests_tracing', None) + self.detailed_error_messages = kwargs.get('detailed_error_messages', None) + + +class SiteMachineKey(msrest.serialization.Model): + """MachineKey of an app. + + :param validation: MachineKey validation. + :type validation: str + :param validation_key: Validation key. + :type validation_key: str + :param decryption: Algorithm used for decryption. + :type decryption: str + :param decryption_key: Decryption key. + :type decryption_key: str + """ + + _attribute_map = { + 'validation': {'key': 'validation', 'type': 'str'}, + 'validation_key': {'key': 'validationKey', 'type': 'str'}, + 'decryption': {'key': 'decryption', 'type': 'str'}, + 'decryption_key': {'key': 'decryptionKey', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteMachineKey, self).__init__(**kwargs) + self.validation = kwargs.get('validation', None) + self.validation_key = kwargs.get('validation_key', None) + self.decryption = kwargs.get('decryption', None) + self.decryption_key = kwargs.get('decryption_key', None) + + +class SitePatchResource(ProxyOnlyResource): + """ARM resource for a site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_06_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_06_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_06_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_06_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_06_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_06_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_06_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SitePatchResource, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = kwargs.get('enabled', None) + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = kwargs.get('host_name_ssl_states', None) + self.server_farm_id = kwargs.get('server_farm_id', None) + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.last_modified_time_utc = None + self.site_config = kwargs.get('site_config', None) + self.traffic_manager_host_names = None + self.scm_site_also_stopped = kwargs.get('scm_site_also_stopped', False) + self.target_swap_slot = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.client_affinity_enabled = kwargs.get('client_affinity_enabled', None) + self.client_cert_enabled = kwargs.get('client_cert_enabled', None) + self.client_cert_mode = kwargs.get('client_cert_mode', None) + self.client_cert_exclusion_paths = kwargs.get('client_cert_exclusion_paths', None) + self.host_names_disabled = kwargs.get('host_names_disabled', None) + self.custom_domain_verification_id = kwargs.get('custom_domain_verification_id', None) + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = kwargs.get('container_size', None) + self.daily_memory_time_quota = kwargs.get('daily_memory_time_quota', None) + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = kwargs.get('cloning_info', None) + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = kwargs.get('https_only', None) + self.redundancy_mode = kwargs.get('redundancy_mode', None) + self.in_progress_operation_id = None + + +class SitePhpErrorLogFlag(ProxyOnlyResource): + """Used for getting PHP error logging flag. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param local_log_errors: Local log_errors setting. + :type local_log_errors: str + :param master_log_errors: Master log_errors setting. + :type master_log_errors: str + :param local_log_errors_max_length: Local log_errors_max_len setting. + :type local_log_errors_max_length: str + :param master_log_errors_max_length: Master log_errors_max_len setting. + :type master_log_errors_max_length: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'local_log_errors': {'key': 'properties.localLogErrors', 'type': 'str'}, + 'master_log_errors': {'key': 'properties.masterLogErrors', 'type': 'str'}, + 'local_log_errors_max_length': {'key': 'properties.localLogErrorsMaxLength', 'type': 'str'}, + 'master_log_errors_max_length': {'key': 'properties.masterLogErrorsMaxLength', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SitePhpErrorLogFlag, self).__init__(**kwargs) + self.local_log_errors = kwargs.get('local_log_errors', None) + self.master_log_errors = kwargs.get('master_log_errors', None) + self.local_log_errors_max_length = kwargs.get('local_log_errors_max_length', None) + self.master_log_errors_max_length = kwargs.get('master_log_errors_max_length', None) + + +class SiteSeal(msrest.serialization.Model): + """Site seal. + + All required parameters must be populated in order to send to Azure. + + :param html: Required. HTML snippet. + :type html: str + """ + + _validation = { + 'html': {'required': True}, + } + + _attribute_map = { + 'html': {'key': 'html', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSeal, self).__init__(**kwargs) + self.html = kwargs['html'] + + +class SiteSealRequest(msrest.serialization.Model): + """Site seal request. + + :param light_theme: If :code:`true` use the light color theme for site seal; + otherwise, use the default color theme. + :type light_theme: bool + :param locale: Locale of site seal. + :type locale: str + """ + + _attribute_map = { + 'light_theme': {'key': 'lightTheme', 'type': 'bool'}, + 'locale': {'key': 'locale', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSealRequest, self).__init__(**kwargs) + self.light_theme = kwargs.get('light_theme', None) + self.locale = kwargs.get('locale', None) + + +class SiteSourceControl(ProxyOnlyResource): + """Source control configuration for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repo_url: Repository or source control URL. + :type repo_url: str + :param branch: Name of branch to use for deployment. + :type branch: str + :param is_manual_integration: :code:`true` to limit to manual integration; + :code:`false` to enable continuous integration (which configures webhooks into + online repos like GitHub). + :type is_manual_integration: bool + :param is_git_hub_action: :code:`true` if this is deployed via GitHub action. + :type is_git_hub_action: bool + :param deployment_rollback_enabled: :code:`true` to enable deployment rollback; + otherwise, :code:`false`. + :type deployment_rollback_enabled: bool + :param is_mercurial: :code:`true` for a Mercurial repository; + :code:`false` for a Git repository. + :type is_mercurial: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repo_url': {'key': 'properties.repoUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'is_manual_integration': {'key': 'properties.isManualIntegration', 'type': 'bool'}, + 'is_git_hub_action': {'key': 'properties.isGitHubAction', 'type': 'bool'}, + 'deployment_rollback_enabled': {'key': 'properties.deploymentRollbackEnabled', 'type': 'bool'}, + 'is_mercurial': {'key': 'properties.isMercurial', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSourceControl, self).__init__(**kwargs) + self.repo_url = kwargs.get('repo_url', None) + self.branch = kwargs.get('branch', None) + self.is_manual_integration = kwargs.get('is_manual_integration', None) + self.is_git_hub_action = kwargs.get('is_git_hub_action', None) + self.deployment_rollback_enabled = kwargs.get('deployment_rollback_enabled', None) + self.is_mercurial = kwargs.get('is_mercurial', None) + + +class SkuCapacity(msrest.serialization.Model): + """Description of the App Service plan scale options. + + :param minimum: Minimum number of workers for this App Service plan SKU. + :type minimum: int + :param maximum: Maximum number of workers for this App Service plan SKU. + :type maximum: int + :param default: Default number of workers for this App Service plan SKU. + :type default: int + :param scale_type: Available scale configurations for an App Service plan. + :type scale_type: str + """ + + _attribute_map = { + 'minimum': {'key': 'minimum', 'type': 'int'}, + 'maximum': {'key': 'maximum', 'type': 'int'}, + 'default': {'key': 'default', 'type': 'int'}, + 'scale_type': {'key': 'scaleType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuCapacity, self).__init__(**kwargs) + self.minimum = kwargs.get('minimum', None) + self.maximum = kwargs.get('maximum', None) + self.default = kwargs.get('default', None) + self.scale_type = kwargs.get('scale_type', None) + + +class SkuDescription(msrest.serialization.Model): + """Description of a SKU for a scalable resource. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Current number of instances assigned to the resource. + :type capacity: int + :param sku_capacity: Min, max, and default scale values of the SKU. + :type sku_capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_06_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + 'sku_capacity': {'key': 'skuCapacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.size = kwargs.get('size', None) + self.family = kwargs.get('family', None) + self.capacity = kwargs.get('capacity', None) + self.sku_capacity = kwargs.get('sku_capacity', None) + self.locations = kwargs.get('locations', None) + self.capabilities = kwargs.get('capabilities', None) + + +class SkuInfo(msrest.serialization.Model): + """SKU discovery information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param sku: Name and tier of the SKU. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfo, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.sku = kwargs.get('sku', None) + self.capacity = kwargs.get('capacity', None) + + +class SkuInfoCollection(msrest.serialization.Model): + """Collection of SKU information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SkuInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SkuInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SkuInfos(msrest.serialization.Model): + """Collection of SKU information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param skus: List of SKUs the subscription is able to use. + :type skus: list[~azure.mgmt.web.v2020_06_01.models.GlobalCsmSkuDescription] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'skus': {'key': 'skus', 'type': '[GlobalCsmSkuDescription]'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfos, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.skus = kwargs.get('skus', None) + + +class SlotConfigNamesResource(ProxyOnlyResource): + """Slot Config names azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param connection_string_names: List of connection string names. + :type connection_string_names: list[str] + :param app_setting_names: List of application settings names. + :type app_setting_names: list[str] + :param azure_storage_config_names: List of external Azure storage account identifiers. + :type azure_storage_config_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'connection_string_names': {'key': 'properties.connectionStringNames', 'type': '[str]'}, + 'app_setting_names': {'key': 'properties.appSettingNames', 'type': '[str]'}, + 'azure_storage_config_names': {'key': 'properties.azureStorageConfigNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotConfigNamesResource, self).__init__(**kwargs) + self.connection_string_names = kwargs.get('connection_string_names', None) + self.app_setting_names = kwargs.get('app_setting_names', None) + self.azure_storage_config_names = kwargs.get('azure_storage_config_names', None) + + +class SlotDifference(ProxyOnlyResource): + """A setting difference between two deployment slots of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar level: Level of the difference: Information, Warning or Error. + :vartype level: str + :ivar setting_type: The type of the setting: General, AppSetting or ConnectionString. + :vartype setting_type: str + :ivar diff_rule: Rule that describes how to process the setting difference during a slot swap. + :vartype diff_rule: str + :ivar setting_name: Name of the setting. + :vartype setting_name: str + :ivar value_in_current_slot: Value of the setting in the current slot. + :vartype value_in_current_slot: str + :ivar value_in_target_slot: Value of the setting in the target slot. + :vartype value_in_target_slot: str + :ivar description: Description of the setting difference. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'level': {'readonly': True}, + 'setting_type': {'readonly': True}, + 'diff_rule': {'readonly': True}, + 'setting_name': {'readonly': True}, + 'value_in_current_slot': {'readonly': True}, + 'value_in_target_slot': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'setting_type': {'key': 'properties.settingType', 'type': 'str'}, + 'diff_rule': {'key': 'properties.diffRule', 'type': 'str'}, + 'setting_name': {'key': 'properties.settingName', 'type': 'str'}, + 'value_in_current_slot': {'key': 'properties.valueInCurrentSlot', 'type': 'str'}, + 'value_in_target_slot': {'key': 'properties.valueInTargetSlot', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotDifference, self).__init__(**kwargs) + self.level = None + self.setting_type = None + self.diff_rule = None + self.setting_name = None + self.value_in_current_slot = None + self.value_in_target_slot = None + self.description = None + + +class SlotDifferenceCollection(msrest.serialization.Model): + """Collection of slot differences. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SlotDifference] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SlotDifference]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotDifferenceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SlotSwapStatus(msrest.serialization.Model): + """The status of the last successful slot swap operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar timestamp_utc: The time the last successful slot swap completed. + :vartype timestamp_utc: ~datetime.datetime + :ivar source_slot_name: The source slot of the last swap operation. + :vartype source_slot_name: str + :ivar destination_slot_name: The destination slot of the last swap operation. + :vartype destination_slot_name: str + """ + + _validation = { + 'timestamp_utc': {'readonly': True}, + 'source_slot_name': {'readonly': True}, + 'destination_slot_name': {'readonly': True}, + } + + _attribute_map = { + 'timestamp_utc': {'key': 'timestampUtc', 'type': 'iso-8601'}, + 'source_slot_name': {'key': 'sourceSlotName', 'type': 'str'}, + 'destination_slot_name': {'key': 'destinationSlotName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotSwapStatus, self).__init__(**kwargs) + self.timestamp_utc = None + self.source_slot_name = None + self.destination_slot_name = None + + +class SlowRequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on request execution time. + + :param time_taken: Time taken. + :type time_taken: str + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'time_taken': {'key': 'timeTaken', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlowRequestsBasedTrigger, self).__init__(**kwargs) + self.time_taken = kwargs.get('time_taken', None) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class Snapshot(ProxyOnlyResource): + """A snapshot of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar time: The time the snapshot was taken. + :vartype time: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'time': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'time': {'key': 'properties.time', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Snapshot, self).__init__(**kwargs) + self.time = None + + +class SnapshotCollection(msrest.serialization.Model): + """Collection of snapshots which can be used to revert an app to a previous time. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Snapshot] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Snapshot]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SnapshotRecoverySource(msrest.serialization.Model): + """Specifies the web app that snapshot contents will be retrieved from. + + :param location: Geographical location of the source web app, e.g. SouthEastAsia, + SouthCentralUS. + :type location: str + :param id: ARM resource ID of the source app. + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type id: str + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotRecoverySource, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.id = kwargs.get('id', None) + + +class SnapshotRestoreRequest(ProxyOnlyResource): + """Details about app recovery operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param snapshot_time: Point in time in which the app restore should be done, formatted as a + DateTime string. + :type snapshot_time: str + :param recovery_source: Optional. Specifies the web app that snapshot contents will be + retrieved from. + If empty, the targeted web app will be used as the source. + :type recovery_source: ~azure.mgmt.web.v2020_06_01.models.SnapshotRecoverySource + :param overwrite: If :code:`true` the restore operation can overwrite source app; + otherwise, :code:`false`. + :type overwrite: bool + :param recover_configuration: If true, site configuration, in addition to content, will be + reverted. + :type recover_configuration: bool + :param ignore_conflicting_host_names: If true, custom hostname conflicts will be ignored when + recovering to a target web app. + This setting is only necessary when RecoverConfiguration is enabled. + :type ignore_conflicting_host_names: bool + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'recovery_source': {'key': 'properties.recoverySource', 'type': 'SnapshotRecoverySource'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotRestoreRequest, self).__init__(**kwargs) + self.snapshot_time = kwargs.get('snapshot_time', None) + self.recovery_source = kwargs.get('recovery_source', None) + self.overwrite = kwargs.get('overwrite', None) + self.recover_configuration = kwargs.get('recover_configuration', None) + self.ignore_conflicting_host_names = kwargs.get('ignore_conflicting_host_names', None) + self.use_dr_secondary = kwargs.get('use_dr_secondary', None) + + +class Solution(msrest.serialization.Model): + """Class Representing Solution for problems detected. + + :param id: Solution Id. + :type id: float + :param display_name: Display Name of the solution. + :type display_name: str + :param order: Order of the solution. + :type order: float + :param description: Description of the solution. + :type description: str + :param type: Type of Solution. Possible values include: "QuickSolution", "DeepInvestigation", + "BestPractices". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.SolutionType + :param data: Solution Data. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param metadata: Solution Metadata. + :type metadata: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'float'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'float'}, + 'description': {'key': 'description', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'metadata': {'key': 'metadata', 'type': '[[NameValuePair]]'}, + } + + def __init__( + self, + **kwargs + ): + super(Solution, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.display_name = kwargs.get('display_name', None) + self.order = kwargs.get('order', None) + self.description = kwargs.get('description', None) + self.type = kwargs.get('type', None) + self.data = kwargs.get('data', None) + self.metadata = kwargs.get('metadata', None) + + +class SourceControl(ProxyOnlyResource): + """The source control OAuth token. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param token: OAuth access token. + :type token: str + :param token_secret: OAuth access token secret. + :type token_secret: str + :param refresh_token: OAuth refresh token. + :type refresh_token: str + :param expiration_time: OAuth token expiration. + :type expiration_time: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'token': {'key': 'properties.token', 'type': 'str'}, + 'token_secret': {'key': 'properties.tokenSecret', 'type': 'str'}, + 'refresh_token': {'key': 'properties.refreshToken', 'type': 'str'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(SourceControl, self).__init__(**kwargs) + self.token = kwargs.get('token', None) + self.token_secret = kwargs.get('token_secret', None) + self.refresh_token = kwargs.get('refresh_token', None) + self.expiration_time = kwargs.get('expiration_time', None) + + +class SourceControlCollection(msrest.serialization.Model): + """Collection of source controls. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SourceControl] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SourceControl]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SourceControlCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StackMajorVersion(msrest.serialization.Model): + """Application stack major version. + + :param display_version: Application stack major version (display only). + :type display_version: str + :param runtime_version: Application stack major version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default major version; otherwise, + :code:`false`. + :type is_default: bool + :param minor_versions: Minor versions associated with the major version. + :type minor_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMinorVersion] + :param application_insights: :code:`true` if this supports Application Insights; + otherwise, :code:`false`. + :type application_insights: bool + :param is_preview: :code:`true` if this stack is in Preview, otherwise + :code:`false`. + :type is_preview: bool + :param is_deprecated: :code:`true` if this stack has been deprecated, otherwise + :code:`false`. + :type is_deprecated: bool + :param is_hidden: :code:`true` if this stack should be hidden for new customers on + portal, otherwise :code:`false`. + :type is_hidden: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'minor_versions': {'key': 'minorVersions', 'type': '[StackMinorVersion]'}, + 'application_insights': {'key': 'applicationInsights', 'type': 'bool'}, + 'is_preview': {'key': 'isPreview', 'type': 'bool'}, + 'is_deprecated': {'key': 'isDeprecated', 'type': 'bool'}, + 'is_hidden': {'key': 'isHidden', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StackMajorVersion, self).__init__(**kwargs) + self.display_version = kwargs.get('display_version', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.is_default = kwargs.get('is_default', None) + self.minor_versions = kwargs.get('minor_versions', None) + self.application_insights = kwargs.get('application_insights', None) + self.is_preview = kwargs.get('is_preview', None) + self.is_deprecated = kwargs.get('is_deprecated', None) + self.is_hidden = kwargs.get('is_hidden', None) + + +class StackMinorVersion(msrest.serialization.Model): + """Application stack minor version. + + :param display_version: Application stack minor version (display only). + :type display_version: str + :param runtime_version: Application stack minor version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default minor version; otherwise, + :code:`false`. + :type is_default: bool + :param is_remote_debugging_enabled: :code:`true` if this supports Remote + Debugging, otherwise :code:`false`. + :type is_remote_debugging_enabled: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'is_remote_debugging_enabled': {'key': 'isRemoteDebuggingEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StackMinorVersion, self).__init__(**kwargs) + self.display_version = kwargs.get('display_version', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.is_default = kwargs.get('is_default', None) + self.is_remote_debugging_enabled = kwargs.get('is_remote_debugging_enabled', None) + + +class StampCapacity(msrest.serialization.Model): + """Stamp capacity information. + + :param name: Name of the stamp. + :type name: str + :param available_capacity: Available capacity (# of machines, bytes of storage etc...). + :type available_capacity: long + :param total_capacity: Total capacity (# of machines, bytes of storage etc...). + :type total_capacity: long + :param unit: Name of the unit. + :type unit: str + :param compute_mode: Shared/dedicated workers. Possible values include: "Shared", "Dedicated", + "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: Size of the machines. Possible values include: "Small", "Medium", "Large", + "D1", "D2", "D3", "NestedSmall", "Default". + :type worker_size: str or ~azure.mgmt.web.v2020_06_01.models.WorkerSizeOptions + :param worker_size_id: Size ID of machines: + 0 - Small + 1 - Medium + 2 - Large. + :type worker_size_id: int + :param exclude_from_capacity_allocation: If :code:`true`, it includes basic apps. + Basic apps are not used for capacity allocation. + :type exclude_from_capacity_allocation: bool + :param is_applicable_for_all_compute_modes: :code:`true` if capacity is applicable + for all apps; otherwise, :code:`false`. + :type is_applicable_for_all_compute_modes: bool + :param site_mode: Shared or Dedicated. + :type site_mode: str + :param is_linux: Is this a linux stamp capacity. + :type is_linux: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available_capacity': {'key': 'availableCapacity', 'type': 'long'}, + 'total_capacity': {'key': 'totalCapacity', 'type': 'long'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'exclude_from_capacity_allocation': {'key': 'excludeFromCapacityAllocation', 'type': 'bool'}, + 'is_applicable_for_all_compute_modes': {'key': 'isApplicableForAllComputeModes', 'type': 'bool'}, + 'site_mode': {'key': 'siteMode', 'type': 'str'}, + 'is_linux': {'key': 'isLinux', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StampCapacity, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.available_capacity = kwargs.get('available_capacity', None) + self.total_capacity = kwargs.get('total_capacity', None) + self.unit = kwargs.get('unit', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.exclude_from_capacity_allocation = kwargs.get('exclude_from_capacity_allocation', None) + self.is_applicable_for_all_compute_modes = kwargs.get('is_applicable_for_all_compute_modes', None) + self.site_mode = kwargs.get('site_mode', None) + self.is_linux = kwargs.get('is_linux', None) + + +class StampCapacityCollection(msrest.serialization.Model): + """Collection of stamp capacities. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StampCapacity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StampCapacityCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteARMResource(Resource): + """Static Site ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteARMResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.default_hostname = None + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.custom_domains = None + self.repository_token = kwargs.get('repository_token', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteBuildARMResource(ProxyOnlyResource): + """Static Site Build ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar build_id: An identifier for the static site build. + :vartype build_id: str + :ivar source_branch: The source branch. + :vartype source_branch: str + :ivar pull_request_title: The title of a pull request that a static site build is related to. + :vartype pull_request_title: str + :ivar hostname: The hostname for a static site build. + :vartype hostname: str + :ivar created_time_utc: When this build was created. + :vartype created_time_utc: ~datetime.datetime + :ivar last_updated_on: When this build was updated. + :vartype last_updated_on: ~datetime.datetime + :ivar status: The status of the static site build. Possible values include: + "WaitingForDeployment", "Uploading", "Deploying", "Ready", "Failed", "Deleting", "Detached". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.BuildStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'build_id': {'readonly': True}, + 'source_branch': {'readonly': True}, + 'pull_request_title': {'readonly': True}, + 'hostname': {'readonly': True}, + 'created_time_utc': {'readonly': True}, + 'last_updated_on': {'readonly': True}, + 'status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'build_id': {'key': 'properties.buildId', 'type': 'str'}, + 'source_branch': {'key': 'properties.sourceBranch', 'type': 'str'}, + 'pull_request_title': {'key': 'properties.pullRequestTitle', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'created_time_utc': {'key': 'properties.createdTimeUtc', 'type': 'iso-8601'}, + 'last_updated_on': {'key': 'properties.lastUpdatedOn', 'type': 'iso-8601'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildARMResource, self).__init__(**kwargs) + self.build_id = None + self.source_branch = None + self.pull_request_title = None + self.hostname = None + self.created_time_utc = None + self.last_updated_on = None + self.status = None + + +class StaticSiteBuildCollection(msrest.serialization.Model): + """Collection of static site builds. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteBuildARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteBuildProperties(msrest.serialization.Model): + """Build properties for the static site. + + :param app_location: The path to the app code within the repository. + :type app_location: str + :param api_location: The path to the api code within the repository. + :type api_location: str + :param app_artifact_location: The path of the app artifacts after building. + :type app_artifact_location: str + """ + + _attribute_map = { + 'app_location': {'key': 'appLocation', 'type': 'str'}, + 'api_location': {'key': 'apiLocation', 'type': 'str'}, + 'app_artifact_location': {'key': 'appArtifactLocation', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildProperties, self).__init__(**kwargs) + self.app_location = kwargs.get('app_location', None) + self.api_location = kwargs.get('api_location', None) + self.app_artifact_location = kwargs.get('app_artifact_location', None) + + +class StaticSiteCollection(msrest.serialization.Model): + """Collection of static sites. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteCustomDomainOverviewARMResource(ProxyOnlyResource): + """Static Site Custom Domain Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar domain_name: The domain name for the static site custom domain. + :vartype domain_name: str + :ivar created_on: The date and time on which the custom domain was created for the static site. + :vartype created_on: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'domain_name': {'readonly': True}, + 'created_on': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'properties.domainName', 'type': 'str'}, + 'created_on': {'key': 'properties.createdOn', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCustomDomainOverviewARMResource, self).__init__(**kwargs) + self.domain_name = None + self.created_on = None + + +class StaticSiteCustomDomainOverviewCollection(msrest.serialization.Model): + """Collection of static site custom domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteCustomDomainOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCustomDomainOverviewCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteFunctionOverviewARMResource(ProxyOnlyResource): + """Static Site Function Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar function_name: The name for the function. + :vartype function_name: str + :ivar trigger_type: The trigger type of the function. Possible values include: "HttpTrigger", + "Unknown". + :vartype trigger_type: str or ~azure.mgmt.web.v2020_06_01.models.TriggerTypes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'function_name': {'readonly': True}, + 'trigger_type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'function_name': {'key': 'properties.functionName', 'type': 'str'}, + 'trigger_type': {'key': 'properties.triggerType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteFunctionOverviewARMResource, self).__init__(**kwargs) + self.function_name = None + self.trigger_type = None + + +class StaticSiteFunctionOverviewCollection(msrest.serialization.Model): + """Collection of static site functions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteFunctionOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteFunctionOverviewCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSitePatchResource(ProxyOnlyResource): + """ARM resource for a static site when patching. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitePatchResource, self).__init__(**kwargs) + self.default_hostname = None + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.custom_domains = None + self.repository_token = kwargs.get('repository_token', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteResetPropertiesARMResource(ProxyOnlyResource): + """Static Site Reset Properties ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repository_token: The token which proves admin privileges to the repository. + :type repository_token: str + :param should_update_repository: Determines whether the repository should be updated with the + new properties. + :type should_update_repository: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'should_update_repository': {'key': 'properties.shouldUpdateRepository', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteResetPropertiesARMResource, self).__init__(**kwargs) + self.repository_token = kwargs.get('repository_token', None) + self.should_update_repository = kwargs.get('should_update_repository', None) + + +class StaticSitesWorkflowPreview(ProxyOnlyResource): + """Preview for the Static Site Workflow to be generated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar path: The path for the workflow file to be generated. + :vartype path: str + :ivar contents: The contents for the workflow file to be generated. + :vartype contents: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'path': {'readonly': True}, + 'contents': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'contents': {'key': 'properties.contents', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitesWorkflowPreview, self).__init__(**kwargs) + self.path = None + self.contents = None + + +class StaticSitesWorkflowPreviewRequest(ProxyOnlyResource): + """Request entity for previewing the Static Site workflow. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitesWorkflowPreviewRequest, self).__init__(**kwargs) + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteUserARMResource(ProxyOnlyResource): + """Static Site User ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar provider: The identity provider for the static site user. + :vartype provider: str + :ivar user_id: The user id for the static site user. + :vartype user_id: str + :ivar display_name: The display name for the static site user. + :vartype display_name: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provider': {'readonly': True}, + 'user_id': {'readonly': True}, + 'display_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_id': {'key': 'properties.userId', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserARMResource, self).__init__(**kwargs) + self.provider = None + self.user_id = None + self.display_name = None + self.roles = kwargs.get('roles', None) + + +class StaticSiteUserCollection(msrest.serialization.Model): + """Collection of static site custom users. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteUserARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteUserInvitationRequestResource(ProxyOnlyResource): + """Static sites user roles invitation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param domain: The domain name for the static site custom domain. + :type domain: str + :param provider: The identity provider for the static site user. + :type provider: str + :param user_details: The user id for the static site user. + :type user_details: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + :param num_hours_to_expiration: The number of hours the sas token stays valid. + :type num_hours_to_expiration: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'domain': {'key': 'properties.domain', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_details': {'key': 'properties.userDetails', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + 'num_hours_to_expiration': {'key': 'properties.numHoursToExpiration', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserInvitationRequestResource, self).__init__(**kwargs) + self.domain = kwargs.get('domain', None) + self.provider = kwargs.get('provider', None) + self.user_details = kwargs.get('user_details', None) + self.roles = kwargs.get('roles', None) + self.num_hours_to_expiration = kwargs.get('num_hours_to_expiration', None) + + +class StaticSiteUserInvitationResponseResource(ProxyOnlyResource): + """Static sites user roles invitation link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar expires_on: The expiration time of the invitation. + :vartype expires_on: ~datetime.datetime + :ivar invitation_url: The url for the invitation link. + :vartype invitation_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'expires_on': {'readonly': True}, + 'invitation_url': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'invitation_url': {'key': 'properties.invitationUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserInvitationResponseResource, self).__init__(**kwargs) + self.expires_on = None + self.invitation_url = None + + +class StatusCodesBasedTrigger(msrest.serialization.Model): + """Trigger based on status code. + + :param status: HTTP status code. + :type status: int + :param sub_status: Request Sub Status. + :type sub_status: int + :param win32_status: Win32 error code. + :type win32_status: int + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'int'}, + 'sub_status': {'key': 'subStatus', 'type': 'int'}, + 'win32_status': {'key': 'win32Status', 'type': 'int'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StatusCodesBasedTrigger, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.sub_status = kwargs.get('sub_status', None) + self.win32_status = kwargs.get('win32_status', None) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class StorageMigrationOptions(ProxyOnlyResource): + """Options for app content migration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param azurefiles_connection_string: AzureFiles connection string. + :type azurefiles_connection_string: str + :param azurefiles_share: AzureFiles share. + :type azurefiles_share: str + :param switch_site_after_migration: :code:`true`if the app should be switched + over; otherwise, :code:`false`. + :type switch_site_after_migration: bool + :param block_write_access_to_site: :code:`true` if the app should be read only + during copy operation; otherwise, :code:`false`. + :type block_write_access_to_site: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'azurefiles_connection_string': {'key': 'properties.azurefilesConnectionString', 'type': 'str'}, + 'azurefiles_share': {'key': 'properties.azurefilesShare', 'type': 'str'}, + 'switch_site_after_migration': {'key': 'properties.switchSiteAfterMigration', 'type': 'bool'}, + 'block_write_access_to_site': {'key': 'properties.blockWriteAccessToSite', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StorageMigrationOptions, self).__init__(**kwargs) + self.azurefiles_connection_string = kwargs.get('azurefiles_connection_string', None) + self.azurefiles_share = kwargs.get('azurefiles_share', None) + self.switch_site_after_migration = kwargs.get('switch_site_after_migration', False) + self.block_write_access_to_site = kwargs.get('block_write_access_to_site', False) + + +class StorageMigrationResponse(ProxyOnlyResource): + """Response for a migration of app content request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar operation_id: When server starts the migration process, it will return an operation ID + identifying that particular migration operation. + :vartype operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StorageMigrationResponse, self).__init__(**kwargs) + self.operation_id = None + + +class StringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Settings. + :type properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(StringDictionary, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class SwiftVirtualNetwork(ProxyOnlyResource): + """Swift Virtual Network Contract. This is used to enable the new Swift way of doing virtual network integration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param subnet_resource_id: The Virtual Network subnet's resource ID. This is the subnet that + this Web App will join. This subnet must have a delegation to Microsoft.Web/serverFarms defined + first. + :type subnet_resource_id: str + :param swift_supported: A flag that specifies if the scale unit this Web App is on supports + Swift integration. + :type swift_supported: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet_resource_id': {'key': 'properties.subnetResourceId', 'type': 'str'}, + 'swift_supported': {'key': 'properties.swiftSupported', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SwiftVirtualNetwork, self).__init__(**kwargs) + self.subnet_resource_id = kwargs.get('subnet_resource_id', None) + self.swift_supported = kwargs.get('swift_supported', None) + + +class TldLegalAgreement(msrest.serialization.Model): + """Legal agreement for a top level domain. + + All required parameters must be populated in order to send to Azure. + + :param agreement_key: Required. Unique identifier for the agreement. + :type agreement_key: str + :param title: Required. Agreement title. + :type title: str + :param content: Required. Agreement details. + :type content: str + :param url: URL where a copy of the agreement details is hosted. + :type url: str + """ + + _validation = { + 'agreement_key': {'required': True}, + 'title': {'required': True}, + 'content': {'required': True}, + } + + _attribute_map = { + 'agreement_key': {'key': 'agreementKey', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'content': {'key': 'content', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TldLegalAgreement, self).__init__(**kwargs) + self.agreement_key = kwargs['agreement_key'] + self.title = kwargs['title'] + self.content = kwargs['content'] + self.url = kwargs.get('url', None) + + +class TldLegalAgreementCollection(msrest.serialization.Model): + """Collection of top-level domain legal agreements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TldLegalAgreement] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TldLegalAgreement]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TldLegalAgreementCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TokenStore(ProxyOnlyResource): + """TokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param token_refresh_extension_hours: + :type token_refresh_extension_hours: float + :param file_system: + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemTokenStore + :param azure_blob_storage: + :type azure_blob_storage: ~azure.mgmt.web.v2020_06_01.models.BlobStorageTokenStore + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'file_system': {'key': 'properties.fileSystem', 'type': 'FileSystemTokenStore'}, + 'azure_blob_storage': {'key': 'properties.azureBlobStorage', 'type': 'BlobStorageTokenStore'}, + } + + def __init__( + self, + **kwargs + ): + super(TokenStore, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.token_refresh_extension_hours = kwargs.get('token_refresh_extension_hours', None) + self.file_system = kwargs.get('file_system', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class TopLevelDomain(ProxyOnlyResource): + """A top level domain object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param privacy: If :code:`true`, then the top level domain supports domain + privacy; otherwise, :code:`false`. + :type privacy: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomain, self).__init__(**kwargs) + self.privacy = kwargs.get('privacy', None) + + +class TopLevelDomainAgreementOption(msrest.serialization.Model): + """Options for retrieving the list of top level domain legal agreements. + + :param include_privacy: If :code:`true`, then the list of agreements will include + agreements for domain privacy as well; otherwise, :code:`false`. + :type include_privacy: bool + :param for_transfer: If :code:`true`, then the list of agreements will include + agreements for domain transfer as well; otherwise, :code:`false`. + :type for_transfer: bool + """ + + _attribute_map = { + 'include_privacy': {'key': 'includePrivacy', 'type': 'bool'}, + 'for_transfer': {'key': 'forTransfer', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomainAgreementOption, self).__init__(**kwargs) + self.include_privacy = kwargs.get('include_privacy', None) + self.for_transfer = kwargs.get('for_transfer', None) + + +class TopLevelDomainCollection(msrest.serialization.Model): + """Collection of Top-level domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TopLevelDomain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TopLevelDomain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomainCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TriggeredJobHistory(ProxyOnlyResource): + """Triggered Web Job History. List of Triggered Web Job Run Information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param runs: List of triggered web job runs. + :type runs: list[~azure.mgmt.web.v2020_06_01.models.TriggeredJobRun] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'runs': {'key': 'properties.runs', 'type': '[TriggeredJobRun]'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobHistory, self).__init__(**kwargs) + self.runs = kwargs.get('runs', None) + + +class TriggeredJobHistoryCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredJobHistory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobHistoryCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TriggeredJobRun(ProxyOnlyResource): + """Triggered Web Job Run Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param web_job_id: Job ID. + :type web_job_id: str + :param web_job_name: Job name. + :type web_job_name: str + :param status: Job status. Possible values include: "Success", "Failed", "Error". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobStatus + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param duration: Job duration. + :type duration: str + :param output_url: Output URL. + :type output_url: str + :param error_url: Error URL. + :type error_url: str + :param url: Job URL. + :type url: str + :param job_name: Job name. + :type job_name: str + :param trigger: Job trigger. + :type trigger: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'web_job_id': {'key': 'properties.web_job_id', 'type': 'str'}, + 'web_job_name': {'key': 'properties.web_job_name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'duration': {'key': 'properties.duration', 'type': 'str'}, + 'output_url': {'key': 'properties.output_url', 'type': 'str'}, + 'error_url': {'key': 'properties.error_url', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'job_name': {'key': 'properties.job_name', 'type': 'str'}, + 'trigger': {'key': 'properties.trigger', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobRun, self).__init__(**kwargs) + self.web_job_id = kwargs.get('web_job_id', None) + self.web_job_name = kwargs.get('web_job_name', None) + self.status = kwargs.get('status', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.duration = kwargs.get('duration', None) + self.output_url = kwargs.get('output_url', None) + self.error_url = kwargs.get('error_url', None) + self.url = kwargs.get('url', None) + self.job_name = kwargs.get('job_name', None) + self.trigger = kwargs.get('trigger', None) + + +class TriggeredWebJob(ProxyOnlyResource): + """Triggered Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param latest_run: Latest job run information. + :type latest_run: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobRun + :param history_url: History URL. + :type history_url: str + :param scheduler_logs_url: Scheduler Logs URL. + :type scheduler_logs_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'latest_run': {'key': 'properties.latest_run', 'type': 'TriggeredJobRun'}, + 'history_url': {'key': 'properties.history_url', 'type': 'str'}, + 'scheduler_logs_url': {'key': 'properties.scheduler_logs_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredWebJob, self).__init__(**kwargs) + self.latest_run = kwargs.get('latest_run', None) + self.history_url = kwargs.get('history_url', None) + self.scheduler_logs_url = kwargs.get('scheduler_logs_url', None) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class TriggeredWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredWebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Twitter(ProxyOnlyResource): + """Twitter. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.TwitterRegistration + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'TwitterRegistration'}, + } + + def __init__( + self, + **kwargs + ): + super(Twitter, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + + +class TwitterRegistration(ProxyOnlyResource): + """TwitterRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param consumer_key: + :type consumer_key: str + :param consumer_secret_setting_name: + :type consumer_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'consumer_key': {'key': 'properties.consumerKey', 'type': 'str'}, + 'consumer_secret_setting_name': {'key': 'properties.consumerSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TwitterRegistration, self).__init__(**kwargs) + self.consumer_key = kwargs.get('consumer_key', None) + self.consumer_secret_setting_name = kwargs.get('consumer_secret_setting_name', None) + + +class Usage(ProxyOnlyResource): + """Usage of the quota resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar display_name: Friendly name shown in the UI. + :vartype display_name: str + :ivar resource_name: Name of the quota resource. + :vartype resource_name: str + :ivar unit: Units of measurement for the quota resource. + :vartype unit: str + :ivar current_value: The current value of the resource counter. + :vartype current_value: long + :ivar limit: The resource limit. + :vartype limit: long + :ivar next_reset_time: Next reset time for the resource counter. + :vartype next_reset_time: ~datetime.datetime + :ivar compute_mode: Compute mode used for this usage. Possible values include: "Shared", + "Dedicated", "Dynamic". + :vartype compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :ivar site_mode: Site mode used for this usage. + :vartype site_mode: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'display_name': {'readonly': True}, + 'resource_name': {'readonly': True}, + 'unit': {'readonly': True}, + 'current_value': {'readonly': True}, + 'limit': {'readonly': True}, + 'next_reset_time': {'readonly': True}, + 'compute_mode': {'readonly': True}, + 'site_mode': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'resource_name': {'key': 'properties.resourceName', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'current_value': {'key': 'properties.currentValue', 'type': 'long'}, + 'limit': {'key': 'properties.limit', 'type': 'long'}, + 'next_reset_time': {'key': 'properties.nextResetTime', 'type': 'iso-8601'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'site_mode': {'key': 'properties.siteMode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Usage, self).__init__(**kwargs) + self.display_name = None + self.resource_name = None + self.unit = None + self.current_value = None + self.limit = None + self.next_reset_time = None + self.compute_mode = None + self.site_mode = None + + +class UsageCollection(msrest.serialization.Model): + """Collection of usages. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Usage] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UsageCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class User(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param publishing_user_name: Username used for publishing. + :type publishing_user_name: str + :param publishing_password: Password used for publishing. + :type publishing_password: str + :param publishing_password_hash: Password hash used for publishing. + :type publishing_password_hash: str + :param publishing_password_hash_salt: Password hash salt used for publishing. + :type publishing_password_hash_salt: str + :param scm_uri: Url of SCM site. + :type scm_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'publishing_user_name': {'key': 'properties.publishingUserName', 'type': 'str'}, + 'publishing_password': {'key': 'properties.publishingPassword', 'type': 'str'}, + 'publishing_password_hash': {'key': 'properties.publishingPasswordHash', 'type': 'str'}, + 'publishing_password_hash_salt': {'key': 'properties.publishingPasswordHashSalt', 'type': 'str'}, + 'scm_uri': {'key': 'properties.scmUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(User, self).__init__(**kwargs) + self.publishing_user_name = kwargs.get('publishing_user_name', None) + self.publishing_password = kwargs.get('publishing_password', None) + self.publishing_password_hash = kwargs.get('publishing_password_hash', None) + self.publishing_password_hash_salt = kwargs.get('publishing_password_hash_salt', None) + self.scm_uri = kwargs.get('scm_uri', None) + + +class ValidateRequest(msrest.serialization.Model): + """Resource validation request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: + "ServerFarm", "Site". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ValidateResourceTypes + :param location: Required. Expected location of the resource. + :type location: str + :param server_farm_id: ARM resource ID of an App Service plan that would host the app. + :type server_farm_id: str + :param sku_name: Name of the target SKU for the App Service plan. + :type sku_name: str + :param need_linux_workers: :code:`true` if App Service plan is for Linux workers; + otherwise, :code:`false`. + :type need_linux_workers: bool + :param is_spot: :code:`true` if App Service plan is for Spot instances; otherwise, + :code:`false`. + :type is_spot: bool + :param capacity: Target capacity of the App Service plan (number of VMs). + :type capacity: int + :param hosting_environment: Name of App Service Environment where app or App Service plan + should be created. + :type hosting_environment: str + :param is_xenon: :code:`true` if App Service plan is running as a windows + container. + :type is_xenon: bool + :param container_registry_base_url: Base URL of the container registry. + :type container_registry_base_url: str + :param container_registry_username: Username for to access the container registry. + :type container_registry_username: str + :param container_registry_password: Password for to access the container registry. + :type container_registry_password: str + :param container_image_repository: Repository name (image name). + :type container_image_repository: str + :param container_image_tag: Image tag. + :type container_image_tag: str + :param container_image_platform: Platform (windows or linux). + :type container_image_platform: str + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + 'location': {'required': True}, + 'capacity': {'minimum': 1}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'sku_name': {'key': 'properties.skuName', 'type': 'str'}, + 'need_linux_workers': {'key': 'properties.needLinuxWorkers', 'type': 'bool'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'capacity': {'key': 'properties.capacity', 'type': 'int'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'container_registry_base_url': {'key': 'properties.containerRegistryBaseUrl', 'type': 'str'}, + 'container_registry_username': {'key': 'properties.containerRegistryUsername', 'type': 'str'}, + 'container_registry_password': {'key': 'properties.containerRegistryPassword', 'type': 'str'}, + 'container_image_repository': {'key': 'properties.containerImageRepository', 'type': 'str'}, + 'container_image_tag': {'key': 'properties.containerImageTag', 'type': 'str'}, + 'container_image_platform': {'key': 'properties.containerImagePlatform', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateRequest, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs['type'] + self.location = kwargs['location'] + self.server_farm_id = kwargs.get('server_farm_id', None) + self.sku_name = kwargs.get('sku_name', None) + self.need_linux_workers = kwargs.get('need_linux_workers', None) + self.is_spot = kwargs.get('is_spot', None) + self.capacity = kwargs.get('capacity', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + self.is_xenon = kwargs.get('is_xenon', None) + self.container_registry_base_url = kwargs.get('container_registry_base_url', None) + self.container_registry_username = kwargs.get('container_registry_username', None) + self.container_registry_password = kwargs.get('container_registry_password', None) + self.container_image_repository = kwargs.get('container_image_repository', None) + self.container_image_tag = kwargs.get('container_image_tag', None) + self.container_image_platform = kwargs.get('container_image_platform', None) + + +class ValidateResponse(msrest.serialization.Model): + """Describes the result of resource validation. + + :param status: Result of validation. + :type status: str + :param error: Error details for the case when validation fails. + :type error: ~azure.mgmt.web.v2020_06_01.models.ValidateResponseError + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ValidateResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateResponse, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.error = kwargs.get('error', None) + + +class ValidateResponseError(msrest.serialization.Model): + """Error details for when validation fails. + + :param code: Validation error code. + :type code: str + :param message: Validation error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateResponseError, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + + +class VirtualApplication(msrest.serialization.Model): + """Virtual application in an app. + + :param virtual_path: Virtual path. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + :param preload_enabled: :code:`true` if preloading is enabled; otherwise, + :code:`false`. + :type preload_enabled: bool + :param virtual_directories: Virtual directories for virtual application. + :type virtual_directories: list[~azure.mgmt.web.v2020_06_01.models.VirtualDirectory] + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + 'preload_enabled': {'key': 'preloadEnabled', 'type': 'bool'}, + 'virtual_directories': {'key': 'virtualDirectories', 'type': '[VirtualDirectory]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplication, self).__init__(**kwargs) + self.virtual_path = kwargs.get('virtual_path', None) + self.physical_path = kwargs.get('physical_path', None) + self.preload_enabled = kwargs.get('preload_enabled', None) + self.virtual_directories = kwargs.get('virtual_directories', None) + + +class VirtualDirectory(msrest.serialization.Model): + """Directory for virtual application. + + :param virtual_path: Path to virtual application. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualDirectory, self).__init__(**kwargs) + self.virtual_path = kwargs.get('virtual_path', None) + self.physical_path = kwargs.get('physical_path', None) + + +class VirtualIPMapping(msrest.serialization.Model): + """Virtual IP mapping. + + :param virtual_ip: Virtual IP address. + :type virtual_ip: str + :param internal_http_port: Internal HTTP port. + :type internal_http_port: int + :param internal_https_port: Internal HTTPS port. + :type internal_https_port: int + :param in_use: Is virtual IP mapping in use. + :type in_use: bool + :param service_name: name of the service that virtual IP is assigned to. + :type service_name: str + """ + + _attribute_map = { + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'internal_http_port': {'key': 'internalHttpPort', 'type': 'int'}, + 'internal_https_port': {'key': 'internalHttpsPort', 'type': 'int'}, + 'in_use': {'key': 'inUse', 'type': 'bool'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualIPMapping, self).__init__(**kwargs) + self.virtual_ip = kwargs.get('virtual_ip', None) + self.internal_http_port = kwargs.get('internal_http_port', None) + self.internal_https_port = kwargs.get('internal_https_port', None) + self.in_use = kwargs.get('in_use', None) + self.service_name = kwargs.get('service_name', None) + + +class VirtualNetworkProfile(msrest.serialization.Model): + """Specification for using a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource id of the Virtual Network. + :type id: str + :ivar name: Name of the Virtual Network (read-only). + :vartype name: str + :ivar type: Resource type of the Virtual Network (read-only). + :vartype type: str + :param subnet: Subnet within the Virtual Network. + :type subnet: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'subnet', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkProfile, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = None + self.type = None + self.subnet = kwargs.get('subnet', None) + + +class VnetGateway(ProxyOnlyResource): + """The Virtual Network gateway contract. This is used to give the Virtual Network gateway access to the VPN package. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_name: The Virtual Network name. + :type vnet_name: str + :param vpn_package_uri: The URI where the VPN package can be downloaded. + :type vpn_package_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vpn_package_uri': {'key': 'properties.vpnPackageUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetGateway, self).__init__(**kwargs) + self.vnet_name = kwargs.get('vnet_name', None) + self.vpn_package_uri = kwargs.get('vpn_package_uri', None) + + +class VnetInfo(ProxyOnlyResource): + """Virtual Network information contract. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_resource_id: The Virtual Network's resource ID. + :type vnet_resource_id: str + :ivar cert_thumbprint: The client certificate thumbprint. + :vartype cert_thumbprint: str + :param cert_blob: A certificate file (.cer) blob containing the public key of the private key + used to authenticate a + Point-To-Site VPN connection. + :type cert_blob: str + :ivar routes: The routes that this Virtual Network connection uses. + :vartype routes: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] + :ivar resync_required: :code:`true` if a resync is required; otherwise, + :code:`false`. + :vartype resync_required: bool + :param dns_servers: DNS servers to be used by this Virtual Network. This should be a comma- + separated list of IP addresses. + :type dns_servers: str + :param is_swift: Flag that is used to denote if this is VNET injection. + :type is_swift: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'cert_thumbprint': {'readonly': True}, + 'routes': {'readonly': True}, + 'resync_required': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_resource_id': {'key': 'properties.vnetResourceId', 'type': 'str'}, + 'cert_thumbprint': {'key': 'properties.certThumbprint', 'type': 'str'}, + 'cert_blob': {'key': 'properties.certBlob', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VnetRoute]'}, + 'resync_required': {'key': 'properties.resyncRequired', 'type': 'bool'}, + 'dns_servers': {'key': 'properties.dnsServers', 'type': 'str'}, + 'is_swift': {'key': 'properties.isSwift', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetInfo, self).__init__(**kwargs) + self.vnet_resource_id = kwargs.get('vnet_resource_id', None) + self.cert_thumbprint = None + self.cert_blob = kwargs.get('cert_blob', None) + self.routes = None + self.resync_required = None + self.dns_servers = kwargs.get('dns_servers', None) + self.is_swift = kwargs.get('is_swift', None) + + +class VnetParameters(ProxyOnlyResource): + """The required set of inputs to validate a VNET. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_resource_group: The Resource Group of the VNET to be validated. + :type vnet_resource_group: str + :param vnet_name: The name of the VNET to be validated. + :type vnet_name: str + :param vnet_subnet_name: The subnet name to be validated. + :type vnet_subnet_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_resource_group': {'key': 'properties.vnetResourceGroup', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetParameters, self).__init__(**kwargs) + self.vnet_resource_group = kwargs.get('vnet_resource_group', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + + +class VnetRoute(ProxyOnlyResource): + """Virtual Network route contract used to pass routing information for a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_address: The starting address for this route. This may also include a CIDR + notation, in which case the end address must not be specified. + :type start_address: str + :param end_address: The ending address for this route. If the start address is specified in + CIDR notation, this must be omitted. + :type end_address: str + :param route_type: The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + Possible values include: "DEFAULT", "INHERITED", "STATIC". + :type route_type: str or ~azure.mgmt.web.v2020_06_01.models.RouteType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_address': {'key': 'properties.startAddress', 'type': 'str'}, + 'end_address': {'key': 'properties.endAddress', 'type': 'str'}, + 'route_type': {'key': 'properties.routeType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetRoute, self).__init__(**kwargs) + self.start_address = kwargs.get('start_address', None) + self.end_address = kwargs.get('end_address', None) + self.route_type = kwargs.get('route_type', None) + + +class VnetValidationFailureDetails(ProxyOnlyResource): + """A class that describes the reason for a validation failure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param failed: A flag describing whether or not validation failed. + :type failed: bool + :param failed_tests: A list of tests that failed in the validation. + :type failed_tests: list[~azure.mgmt.web.v2020_06_01.models.VnetValidationTestFailure] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'failed': {'key': 'properties.failed', 'type': 'bool'}, + 'failed_tests': {'key': 'properties.failedTests', 'type': '[VnetValidationTestFailure]'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetValidationFailureDetails, self).__init__(**kwargs) + self.failed = kwargs.get('failed', None) + self.failed_tests = kwargs.get('failed_tests', None) + + +class VnetValidationTestFailure(ProxyOnlyResource): + """A class that describes a test that failed during NSG and UDR validation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param test_name: The name of the test that failed. + :type test_name: str + :param details: The details of what caused the failure, e.g. the blocking rule name, etc. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'test_name': {'key': 'properties.testName', 'type': 'str'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetValidationTestFailure, self).__init__(**kwargs) + self.test_name = kwargs.get('test_name', None) + self.details = kwargs.get('details', None) + + +class WebAppCollection(msrest.serialization.Model): + """Collection of App Service apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Site] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Site]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebAppCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebAppInstanceStatusCollection(msrest.serialization.Model): + """Collection of app instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebSiteInstanceStatus]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebAppInstanceStatusCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebJob(ProxyOnlyResource): + """Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(WebJob, self).__init__(**kwargs) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class WebJobCollection(msrest.serialization.Model): + """Collection of Kudu web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebSiteInstanceStatus(ProxyOnlyResource): + """WebSiteInstanceStatus. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param state: Possible values include: "READY", "STOPPED", "UNKNOWN". + :type state: str or ~azure.mgmt.web.v2020_06_01.models.SiteRuntimeState + :param status_url: Link to the GetStatusApi in Kudu. + :type status_url: str + :param detector_url: Link to the Diagnose and Solve Portal. + :type detector_url: str + :param console_url: Link to the console to web app instance. + :type console_url: str + :param health_check_url: Link to the console to web app instance. + :type health_check_url: str + :param containers: Dictionary of :code:``. + :type containers: dict[str, ~azure.mgmt.web.v2020_06_01.models.ContainerInfo] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'status_url': {'key': 'properties.statusUrl', 'type': 'str'}, + 'detector_url': {'key': 'properties.detectorUrl', 'type': 'str'}, + 'console_url': {'key': 'properties.consoleUrl', 'type': 'str'}, + 'health_check_url': {'key': 'properties.healthCheckUrl', 'type': 'str'}, + 'containers': {'key': 'properties.containers', 'type': '{ContainerInfo}'}, + } + + def __init__( + self, + **kwargs + ): + super(WebSiteInstanceStatus, self).__init__(**kwargs) + self.state = kwargs.get('state', None) + self.status_url = kwargs.get('status_url', None) + self.detector_url = kwargs.get('detector_url', None) + self.console_url = kwargs.get('console_url', None) + self.health_check_url = kwargs.get('health_check_url', None) + self.containers = kwargs.get('containers', None) + + +class WorkerPool(msrest.serialization.Model): + """Worker pool of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_count': {'key': 'workerCount', 'type': 'int'}, + 'instance_names': {'key': 'instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPool, self).__init__(**kwargs) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_count = kwargs.get('worker_count', None) + self.instance_names = None + + +class WorkerPoolCollection(msrest.serialization.Model): + """Collection of worker pools. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WorkerPoolResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPoolCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WorkerPoolResource(ProxyOnlyResource): + """Worker pool of an App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_size_id': {'key': 'properties.workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'worker_size': {'key': 'properties.workerSize', 'type': 'str'}, + 'worker_count': {'key': 'properties.workerCount', 'type': 'int'}, + 'instance_names': {'key': 'properties.instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPoolResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_count = kwargs.get('worker_count', None) + self.instance_names = None diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models_py3.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models_py3.py new file mode 100644 index 000000000000..f4b8a591914f --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_models_py3.py @@ -0,0 +1,18799 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import datetime +from typing import Dict, List, Optional, Union + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + +from ._web_site_management_client_enums import * + + +class AbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period identified in diagnosis. + + :param start_time: Start time of the downtime. + :type start_time: ~datetime.datetime + :param end_time: End time of the downtime. + :type end_time: ~datetime.datetime + :param events: List of Possible Cause of downtime. + :type events: list[~azure.mgmt.web.v2020_06_01.models.DetectorAbnormalTimePeriod] + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_06_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'events': {'key': 'events', 'type': '[DetectorAbnormalTimePeriod]'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + *, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + events: Optional[List["DetectorAbnormalTimePeriod"]] = None, + solutions: Optional[List["Solution"]] = None, + **kwargs + ): + super(AbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = start_time + self.end_time = end_time + self.events = events + self.solutions = solutions + + +class Address(msrest.serialization.Model): + """Address information for domain registration. + + All required parameters must be populated in order to send to Azure. + + :param address1: Required. First line of an Address. + :type address1: str + :param address2: The second line of the Address. Optional. + :type address2: str + :param city: Required. The city for the address. + :type city: str + :param country: Required. The country for the address. + :type country: str + :param postal_code: Required. The postal code for the address. + :type postal_code: str + :param state: Required. The state or province for the address. + :type state: str + """ + + _validation = { + 'address1': {'required': True}, + 'city': {'required': True}, + 'country': {'required': True}, + 'postal_code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'address1': {'key': 'address1', 'type': 'str'}, + 'address2': {'key': 'address2', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + 'country': {'key': 'country', 'type': 'str'}, + 'postal_code': {'key': 'postalCode', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + address1: str, + city: str, + country: str, + postal_code: str, + state: str, + address2: Optional[str] = None, + **kwargs + ): + super(Address, self).__init__(**kwargs) + self.address1 = address1 + self.address2 = address2 + self.city = city + self.country = country + self.postal_code = postal_code + self.state = state + + +class ProxyOnlyResource(msrest.serialization.Model): + """Azure proxy only resource. This resource is not tracked by Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(ProxyOnlyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kind + self.type = None + + +class AddressResponse(ProxyOnlyResource): + """Describes main public IP address and any extra virtual IPs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param service_ip_address: Main public virtual IP. + :type service_ip_address: str + :param internal_ip_address: Virtual Network internal IP address of the App Service Environment + if it is in internal load-balancing mode. + :type internal_ip_address: str + :param outbound_ip_addresses: IP addresses appearing on outbound connections. + :type outbound_ip_addresses: list[str] + :param vip_mappings: Additional virtual IPs. + :type vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_ip_address': {'key': 'properties.serviceIpAddress', 'type': 'str'}, + 'internal_ip_address': {'key': 'properties.internalIpAddress', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': '[str]'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + service_ip_address: Optional[str] = None, + internal_ip_address: Optional[str] = None, + outbound_ip_addresses: Optional[List[str]] = None, + vip_mappings: Optional[List["VirtualIPMapping"]] = None, + **kwargs + ): + super(AddressResponse, self).__init__(kind=kind, **kwargs) + self.service_ip_address = service_ip_address + self.internal_ip_address = internal_ip_address + self.outbound_ip_addresses = outbound_ip_addresses + self.vip_mappings = vip_mappings + + +class AllowedAudiencesValidation(ProxyOnlyResource): + """AllowedAudiencesValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allowed_audiences: Optional[List[str]] = None, + **kwargs + ): + super(AllowedAudiencesValidation, self).__init__(kind=kind, **kwargs) + self.allowed_audiences = allowed_audiences + + +class AnalysisData(msrest.serialization.Model): + """Class Representing Detector Evidence used for analysis. + + :param source: Name of the Detector. + :type source: str + :param detector_definition: Detector Definition. + :type detector_definition: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :param metrics: Source Metrics. + :type metrics: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSet] + :param data: Additional Source Data. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param detector_meta_data: Detector Meta Data. + :type detector_meta_data: ~azure.mgmt.web.v2020_06_01.models.ResponseMetaData + """ + + _attribute_map = { + 'source': {'key': 'source', 'type': 'str'}, + 'detector_definition': {'key': 'detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'metrics', 'type': '[DiagnosticMetricSet]'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'detector_meta_data': {'key': 'detectorMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + *, + source: Optional[str] = None, + detector_definition: Optional["DetectorDefinition"] = None, + metrics: Optional[List["DiagnosticMetricSet"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + detector_meta_data: Optional["ResponseMetaData"] = None, + **kwargs + ): + super(AnalysisData, self).__init__(**kwargs) + self.source = source + self.detector_definition = detector_definition + self.metrics = metrics + self.data = data + self.detector_meta_data = detector_meta_data + + +class AnalysisDefinition(ProxyOnlyResource): + """Definition of Analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Description of the Analysis. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(AnalysisDefinition, self).__init__(kind=kind, **kwargs) + self.description = None + + +class ApiDefinitionInfo(msrest.serialization.Model): + """Information about the formal API definition for the app. + + :param url: The URL of the API definition. + :type url: str + """ + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + *, + url: Optional[str] = None, + **kwargs + ): + super(ApiDefinitionInfo, self).__init__(**kwargs) + self.url = url + + +class ApiManagementConfig(msrest.serialization.Model): + """Azure API management (APIM) configuration linked to the app. + + :param id: APIM-Api Identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(ApiManagementConfig, self).__init__(**kwargs) + self.id = id + + +class ApplicationLogsConfig(msrest.serialization.Model): + """Application logs configuration. + + :param file_system: Application logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemApplicationLogsConfig + :param azure_table_storage: Application logs to azure table storage configuration. + :type azure_table_storage: + ~azure.mgmt.web.v2020_06_01.models.AzureTableStorageApplicationLogsConfig + :param azure_blob_storage: Application logs to blob storage configuration. + :type azure_blob_storage: + ~azure.mgmt.web.v2020_06_01.models.AzureBlobStorageApplicationLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemApplicationLogsConfig'}, + 'azure_table_storage': {'key': 'azureTableStorage', 'type': 'AzureTableStorageApplicationLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageApplicationLogsConfig'}, + } + + def __init__( + self, + *, + file_system: Optional["FileSystemApplicationLogsConfig"] = None, + azure_table_storage: Optional["AzureTableStorageApplicationLogsConfig"] = None, + azure_blob_storage: Optional["AzureBlobStorageApplicationLogsConfig"] = None, + **kwargs + ): + super(ApplicationLogsConfig, self).__init__(**kwargs) + self.file_system = file_system + self.azure_table_storage = azure_table_storage + self.azure_blob_storage = azure_blob_storage + + +class ApplicationStack(msrest.serialization.Model): + """Application stack. + + :param name: Application stack name. + :type name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStack] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'str'}, + 'dependency': {'key': 'dependency', 'type': 'str'}, + 'major_versions': {'key': 'majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional[str] = None, + dependency: Optional[str] = None, + major_versions: Optional[List["StackMajorVersion"]] = None, + frameworks: Optional[List["ApplicationStack"]] = None, + **kwargs + ): + super(ApplicationStack, self).__init__(**kwargs) + self.name = name + self.display = display + self.dependency = dependency + self.major_versions = major_versions + self.frameworks = frameworks + + +class ApplicationStackCollection(msrest.serialization.Model): + """Collection of Application Stacks. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStackResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationStackResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ApplicationStackResource"], + **kwargs + ): + super(ApplicationStackCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ApplicationStackResource(ProxyOnlyResource): + """ARM resource for a ApplicationStack. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_properties_name: Application stack name. + :type name_properties_name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_06_01.models.ApplicationStack] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'display': {'key': 'properties.display', 'type': 'str'}, + 'dependency': {'key': 'properties.dependency', 'type': 'str'}, + 'major_versions': {'key': 'properties.majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'properties.frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_properties_name: Optional[str] = None, + display: Optional[str] = None, + dependency: Optional[str] = None, + major_versions: Optional[List["StackMajorVersion"]] = None, + frameworks: Optional[List["ApplicationStack"]] = None, + **kwargs + ): + super(ApplicationStackResource, self).__init__(kind=kind, **kwargs) + self.name_properties_name = name_properties_name + self.display = display + self.dependency = dependency + self.major_versions = major_versions + self.frameworks = frameworks + + +class AppRegistration(ProxyOnlyResource): + """AppRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param app_id: + :type app_id: str + :param app_secret_setting_name: + :type app_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'app_id': {'key': 'properties.appId', 'type': 'str'}, + 'app_secret_setting_name': {'key': 'properties.appSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + app_id: Optional[str] = None, + app_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(AppRegistration, self).__init__(kind=kind, **kwargs) + self.app_id = app_id + self.app_secret_setting_name = app_secret_setting_name + + +class AppServiceCertificate(msrest.serialization.Model): + """Key Vault container for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'key_vault_id': {'key': 'keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificate, self).__init__(**kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceCertificateCollection(msrest.serialization.Model): + """Collection of certificate order certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceCertificateResource"], + **kwargs + ): + super(AppServiceCertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Resource(msrest.serialization.Model): + """Azure resource. This resource is tracked in Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kind + self.location = location + self.type = None + self.tags = tags + + +class AppServiceCertificateOrder(Resource): + """SSL certificate purchase order. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + certificates: Optional[Dict[str, "AppServiceCertificate"]] = None, + distinguished_name: Optional[str] = None, + validity_in_years: Optional[int] = 1, + key_size: Optional[int] = 2048, + product_type: Optional[Union[str, "CertificateProductType"]] = None, + auto_renew: Optional[bool] = True, + csr: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateOrder, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.certificates = certificates + self.distinguished_name = distinguished_name + self.domain_verification_token = None + self.validity_in_years = validity_in_years + self.key_size = key_size + self.product_type = product_type + self.auto_renew = auto_renew + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = csr + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificateOrderCollection(msrest.serialization.Model): + """Collection of certificate orders. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateOrder]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceCertificateOrder"], + **kwargs + ): + super(AppServiceCertificateOrderCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServiceCertificateOrderPatchResource(ProxyOnlyResource): + """ARM resource for a certificate order that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_06_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + certificates: Optional[Dict[str, "AppServiceCertificate"]] = None, + distinguished_name: Optional[str] = None, + validity_in_years: Optional[int] = 1, + key_size: Optional[int] = 2048, + product_type: Optional[Union[str, "CertificateProductType"]] = None, + auto_renew: Optional[bool] = True, + csr: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateOrderPatchResource, self).__init__(kind=kind, **kwargs) + self.certificates = certificates + self.distinguished_name = distinguished_name + self.domain_verification_token = None + self.validity_in_years = validity_in_years + self.key_size = key_size + self.product_type = product_type + self.auto_renew = auto_renew + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = csr + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificatePatchResource(ProxyOnlyResource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificatePatchResource, self).__init__(kind=kind, **kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceCertificateResource(Resource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceEnvironment(msrest.serialization.Model): + """Description of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Name of the App Service Environment. + :type name: str + :param location: Required. Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Required. Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Required. Description of worker pools with worker size IDs, VM sizes, and + number of workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'name': {'required': True}, + 'location': {'required': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'virtual_network': {'required': True}, + 'worker_pools': {'required': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + location: str, + virtual_network: "VirtualNetworkProfile", + worker_pools: List["WorkerPool"], + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironment, self).__init__(**kwargs) + self.name = name + self.location = location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppServiceEnvironmentCollection(msrest.serialization.Model): + """Collection of App Service Environments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceEnvironmentResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceEnvironmentResource"], + **kwargs + ): + super(AppServiceEnvironmentCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServiceEnvironmentPatchResource(ProxyOnlyResource): + """ARM resource for a app service environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location: Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_properties_name: Optional[str] = None, + location: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + virtual_network: Optional["VirtualNetworkProfile"] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + worker_pools: Optional[List["WorkerPool"]] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironmentPatchResource, self).__init__(kind=kind, **kwargs) + self.name_properties_name = name_properties_name + self.location = location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppServiceEnvironmentResource(Resource): + """App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location_properties_location: Location of the App Service Environment, e.g. "West US". + :type location_properties_location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_06_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_06_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_06_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_06_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location_properties_location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + name_properties_name: Optional[str] = None, + location_properties_location: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + virtual_network: Optional["VirtualNetworkProfile"] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + worker_pools: Optional[List["WorkerPool"]] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironmentResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.name_properties_name = name_properties_name + self.location_properties_location = location_properties_location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppServicePlan(Resource): + """App Service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: If Linux app service plan :code:`true`, + :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["SkuDescription"] = None, + worker_tier_name: Optional[str] = None, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + per_site_scaling: Optional[bool] = False, + maximum_elastic_worker_count: Optional[int] = None, + is_spot: Optional[bool] = None, + spot_expiration_time: Optional[datetime.datetime] = None, + free_offer_expiration_time: Optional[datetime.datetime] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + target_worker_count: Optional[int] = None, + target_worker_size_id: Optional[int] = None, + **kwargs + ): + super(AppServicePlan, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.worker_tier_name = worker_tier_name + self.status = None + self.subscription = None + self.hosting_environment_profile = hosting_environment_profile + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = per_site_scaling + self.maximum_elastic_worker_count = maximum_elastic_worker_count + self.number_of_sites = None + self.is_spot = is_spot + self.spot_expiration_time = spot_expiration_time + self.free_offer_expiration_time = free_offer_expiration_time + self.resource_group = None + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.target_worker_count = target_worker_count + self.target_worker_size_id = target_worker_size_id + self.provisioning_state = None + + +class AppServicePlanCollection(msrest.serialization.Model): + """Collection of App Service plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AppServicePlan] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServicePlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServicePlan"], + **kwargs + ): + super(AppServicePlanCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServicePlanPatchResource(ProxyOnlyResource): + """ARM resource for a app service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: This needs to set to :code:`true` when creating a Linux App + Service Plan, along with :code:`kind` set to :code:`Linux`. It should + be :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + worker_tier_name: Optional[str] = None, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + per_site_scaling: Optional[bool] = False, + maximum_elastic_worker_count: Optional[int] = None, + is_spot: Optional[bool] = None, + spot_expiration_time: Optional[datetime.datetime] = None, + free_offer_expiration_time: Optional[datetime.datetime] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + target_worker_count: Optional[int] = None, + target_worker_size_id: Optional[int] = None, + **kwargs + ): + super(AppServicePlanPatchResource, self).__init__(kind=kind, **kwargs) + self.worker_tier_name = worker_tier_name + self.status = None + self.subscription = None + self.hosting_environment_profile = hosting_environment_profile + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = per_site_scaling + self.maximum_elastic_worker_count = maximum_elastic_worker_count + self.number_of_sites = None + self.is_spot = is_spot + self.spot_expiration_time = spot_expiration_time + self.free_offer_expiration_time = free_offer_expiration_time + self.resource_group = None + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.target_worker_count = target_worker_count + self.target_worker_size_id = target_worker_size_id + self.provisioning_state = None + + +class ArmIdWrapper(msrest.serialization.Model): + """A wrapper for an ARM resource id. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ArmIdWrapper, self).__init__(**kwargs) + self.id = None + + +class AuthPlatform(ProxyOnlyResource): + """AuthPlatform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param runtime_version: + :type runtime_version: str + :param config_file_path: + :type config_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'config_file_path': {'key': 'properties.configFilePath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + runtime_version: Optional[str] = None, + config_file_path: Optional[str] = None, + **kwargs + ): + super(AuthPlatform, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.runtime_version = runtime_version + self.config_file_path = config_file_path + + +class AutoHealActions(msrest.serialization.Model): + """Actions which to take by the auto-heal module when a rule is triggered. + + :param action_type: Predefined action to be taken. Possible values include: "Recycle", + "LogEvent", "CustomAction". + :type action_type: str or ~azure.mgmt.web.v2020_06_01.models.AutoHealActionType + :param custom_action: Custom action to be taken. + :type custom_action: ~azure.mgmt.web.v2020_06_01.models.AutoHealCustomAction + :param min_process_execution_time: Minimum time the process must execute + before taking the action. + :type min_process_execution_time: str + """ + + _attribute_map = { + 'action_type': {'key': 'actionType', 'type': 'str'}, + 'custom_action': {'key': 'customAction', 'type': 'AutoHealCustomAction'}, + 'min_process_execution_time': {'key': 'minProcessExecutionTime', 'type': 'str'}, + } + + def __init__( + self, + *, + action_type: Optional[Union[str, "AutoHealActionType"]] = None, + custom_action: Optional["AutoHealCustomAction"] = None, + min_process_execution_time: Optional[str] = None, + **kwargs + ): + super(AutoHealActions, self).__init__(**kwargs) + self.action_type = action_type + self.custom_action = custom_action + self.min_process_execution_time = min_process_execution_time + + +class AutoHealCustomAction(msrest.serialization.Model): + """Custom action to be executed +when an auto heal rule is triggered. + + :param exe: Executable to be run. + :type exe: str + :param parameters: Parameters for the executable. + :type parameters: str + """ + + _attribute_map = { + 'exe': {'key': 'exe', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': 'str'}, + } + + def __init__( + self, + *, + exe: Optional[str] = None, + parameters: Optional[str] = None, + **kwargs + ): + super(AutoHealCustomAction, self).__init__(**kwargs) + self.exe = exe + self.parameters = parameters + + +class AutoHealRules(msrest.serialization.Model): + """Rules that can be defined for auto-heal. + + :param triggers: Conditions that describe when to execute the auto-heal actions. + :type triggers: ~azure.mgmt.web.v2020_06_01.models.AutoHealTriggers + :param actions: Actions to be executed when a rule is triggered. + :type actions: ~azure.mgmt.web.v2020_06_01.models.AutoHealActions + """ + + _attribute_map = { + 'triggers': {'key': 'triggers', 'type': 'AutoHealTriggers'}, + 'actions': {'key': 'actions', 'type': 'AutoHealActions'}, + } + + def __init__( + self, + *, + triggers: Optional["AutoHealTriggers"] = None, + actions: Optional["AutoHealActions"] = None, + **kwargs + ): + super(AutoHealRules, self).__init__(**kwargs) + self.triggers = triggers + self.actions = actions + + +class AutoHealTriggers(msrest.serialization.Model): + """Triggers for auto-heal. + + :param requests: A rule based on total requests. + :type requests: ~azure.mgmt.web.v2020_06_01.models.RequestsBasedTrigger + :param private_bytes_in_kb: A rule based on private bytes. + :type private_bytes_in_kb: int + :param status_codes: A rule based on status codes. + :type status_codes: list[~azure.mgmt.web.v2020_06_01.models.StatusCodesBasedTrigger] + :param slow_requests: A rule based on request execution time. + :type slow_requests: ~azure.mgmt.web.v2020_06_01.models.SlowRequestsBasedTrigger + """ + + _attribute_map = { + 'requests': {'key': 'requests', 'type': 'RequestsBasedTrigger'}, + 'private_bytes_in_kb': {'key': 'privateBytesInKB', 'type': 'int'}, + 'status_codes': {'key': 'statusCodes', 'type': '[StatusCodesBasedTrigger]'}, + 'slow_requests': {'key': 'slowRequests', 'type': 'SlowRequestsBasedTrigger'}, + } + + def __init__( + self, + *, + requests: Optional["RequestsBasedTrigger"] = None, + private_bytes_in_kb: Optional[int] = None, + status_codes: Optional[List["StatusCodesBasedTrigger"]] = None, + slow_requests: Optional["SlowRequestsBasedTrigger"] = None, + **kwargs + ): + super(AutoHealTriggers, self).__init__(**kwargs) + self.requests = requests + self.private_bytes_in_kb = private_bytes_in_kb + self.status_codes = status_codes + self.slow_requests = slow_requests + + +class AzureActiveDirectory(ProxyOnlyResource): + """AzureActiveDirectory. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryLogin + :param validation: + :type validation: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectoryValidation + :param is_auto_provisioned: + :type is_auto_provisioned: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AzureActiveDirectoryRegistration'}, + 'login': {'key': 'properties.login', 'type': 'AzureActiveDirectoryLogin'}, + 'validation': {'key': 'properties.validation', 'type': 'AzureActiveDirectoryValidation'}, + 'is_auto_provisioned': {'key': 'properties.isAutoProvisioned', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["AzureActiveDirectoryRegistration"] = None, + login: Optional["AzureActiveDirectoryLogin"] = None, + validation: Optional["AzureActiveDirectoryValidation"] = None, + is_auto_provisioned: Optional[bool] = None, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + self.validation = validation + self.is_auto_provisioned = is_auto_provisioned + + +class AzureActiveDirectoryLogin(ProxyOnlyResource): + """AzureActiveDirectoryLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param disable_www_authenticate: + :type disable_www_authenticate: bool + :param login_parameters: + :type login_parameters: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'disable_www_authenticate': {'key': 'properties.disableWWWAuthenticate', 'type': 'bool'}, + 'login_parameters': {'key': 'properties.loginParameters', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + disable_www_authenticate: Optional[bool] = None, + login_parameters: Optional[List[str]] = None, + **kwargs + ): + super(AzureActiveDirectoryLogin, self).__init__(kind=kind, **kwargs) + self.disable_www_authenticate = disable_www_authenticate + self.login_parameters = login_parameters + + +class AzureActiveDirectoryRegistration(ProxyOnlyResource): + """AzureActiveDirectoryRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param open_id_issuer: + :type open_id_issuer: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: + :type client_secret_certificate_thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'open_id_issuer': {'key': 'properties.openIdIssuer', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + open_id_issuer: Optional[str] = None, + client_id: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + client_secret_certificate_thumbprint: Optional[str] = None, + **kwargs + ): + super(AzureActiveDirectoryRegistration, self).__init__(kind=kind, **kwargs) + self.open_id_issuer = open_id_issuer + self.client_id = client_id + self.client_secret_setting_name = client_secret_setting_name + self.client_secret_certificate_thumbprint = client_secret_certificate_thumbprint + + +class AzureActiveDirectoryValidation(ProxyOnlyResource): + """AzureActiveDirectoryValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param jwt_claim_checks: + :type jwt_claim_checks: ~azure.mgmt.web.v2020_06_01.models.JwtClaimChecks + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'jwt_claim_checks': {'key': 'properties.jwtClaimChecks', 'type': 'JwtClaimChecks'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + jwt_claim_checks: Optional["JwtClaimChecks"] = None, + allowed_audiences: Optional[List[str]] = None, + **kwargs + ): + super(AzureActiveDirectoryValidation, self).__init__(kind=kind, **kwargs) + self.jwt_claim_checks = jwt_claim_checks + self.allowed_audiences = allowed_audiences + + +class AzureBlobStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs azure blob storage configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + } + + def __init__( + self, + *, + level: Optional[Union[str, "LogLevel"]] = None, + sas_url: Optional[str] = None, + retention_in_days: Optional[int] = None, + **kwargs + ): + super(AzureBlobStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + self.sas_url = sas_url + self.retention_in_days = retention_in_days + + +class AzureBlobStorageHttpLogsConfig(msrest.serialization.Model): + """Http logs to azure blob storage configuration. + + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + retention_in_days: Optional[int] = None, + enabled: Optional[bool] = None, + **kwargs + ): + super(AzureBlobStorageHttpLogsConfig, self).__init__(**kwargs) + self.sas_url = sas_url + self.retention_in_days = retention_in_days + self.enabled = enabled + + +class AzureStorageInfoValue(msrest.serialization.Model): + """Azure Files or Blob Storage access information value for dictionary storage. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of storage. Possible values include: "AzureFiles", "AzureBlob". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.AzureStorageType + :param account_name: Name of the storage account. + :type account_name: str + :param share_name: Name of the file share (container name, for Blob storage). + :type share_name: str + :param access_key: Access key for the storage account. + :type access_key: str + :param mount_path: Path to mount the storage within the site's runtime environment. + :type mount_path: str + :ivar state: State of the storage account. Possible values include: "Ok", "InvalidCredentials", + "InvalidShare". + :vartype state: str or ~azure.mgmt.web.v2020_06_01.models.AzureStorageState + """ + + _validation = { + 'state': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'account_name': {'key': 'accountName', 'type': 'str'}, + 'share_name': {'key': 'shareName', 'type': 'str'}, + 'access_key': {'key': 'accessKey', 'type': 'str'}, + 'mount_path': {'key': 'mountPath', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "AzureStorageType"]] = None, + account_name: Optional[str] = None, + share_name: Optional[str] = None, + access_key: Optional[str] = None, + mount_path: Optional[str] = None, + **kwargs + ): + super(AzureStorageInfoValue, self).__init__(**kwargs) + self.type = type + self.account_name = account_name + self.share_name = share_name + self.access_key = access_key + self.mount_path = mount_path + self.state = None + + +class AzureStoragePropertyDictionaryResource(ProxyOnlyResource): + """AzureStorageInfo dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Azure storage accounts. + :type properties: dict[str, ~azure.mgmt.web.v2020_06_01.models.AzureStorageInfoValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{AzureStorageInfoValue}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, "AzureStorageInfoValue"]] = None, + **kwargs + ): + super(AzureStoragePropertyDictionaryResource, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class AzureTableStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs to Azure table storage configuration. + + All required parameters must be populated in order to send to Azure. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + :param sas_url: Required. SAS URL to an Azure table with add/query/delete permissions. + :type sas_url: str + """ + + _validation = { + 'sas_url': {'required': True}, + } + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + sas_url: str, + level: Optional[Union[str, "LogLevel"]] = None, + **kwargs + ): + super(AzureTableStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + self.sas_url = sas_url + + +class BackupItem(ProxyOnlyResource): + """Backup description. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar backup_id: Id of the backup. + :vartype backup_id: int + :ivar storage_account_url: SAS URL for the storage account container which contains this + backup. + :vartype storage_account_url: str + :ivar blob_name: Name of the blob which contains data for this backup. + :vartype blob_name: str + :ivar name_properties_name: Name of this backup. + :vartype name_properties_name: str + :ivar status: Backup status. Possible values include: "InProgress", "Failed", "Succeeded", + "TimedOut", "Created", "Skipped", "PartiallySucceeded", "DeleteInProgress", "DeleteFailed", + "Deleted". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.BackupItemStatus + :ivar size_in_bytes: Size of the backup in bytes. + :vartype size_in_bytes: long + :ivar created: Timestamp of the backup creation. + :vartype created: ~datetime.datetime + :ivar log: Details regarding this backup. Might contain an error message. + :vartype log: str + :ivar databases: List of databases included in the backup. + :vartype databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + :ivar scheduled: True if this backup has been created due to a schedule being triggered. + :vartype scheduled: bool + :ivar last_restore_time_stamp: Timestamp of a last restore operation which used this backup. + :vartype last_restore_time_stamp: ~datetime.datetime + :ivar finished_time_stamp: Timestamp when this backup finished. + :vartype finished_time_stamp: ~datetime.datetime + :ivar correlation_id: Unique correlation identifier. Please use this along with the timestamp + while communicating with Azure support. + :vartype correlation_id: str + :ivar website_size_in_bytes: Size of the original web app which has been backed up. + :vartype website_size_in_bytes: long + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'backup_id': {'readonly': True}, + 'storage_account_url': {'readonly': True}, + 'blob_name': {'readonly': True}, + 'name_properties_name': {'readonly': True}, + 'status': {'readonly': True}, + 'size_in_bytes': {'readonly': True}, + 'created': {'readonly': True}, + 'log': {'readonly': True}, + 'databases': {'readonly': True}, + 'scheduled': {'readonly': True}, + 'last_restore_time_stamp': {'readonly': True}, + 'finished_time_stamp': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'website_size_in_bytes': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backup_id': {'key': 'properties.id', 'type': 'int'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'size_in_bytes': {'key': 'properties.sizeInBytes', 'type': 'long'}, + 'created': {'key': 'properties.created', 'type': 'iso-8601'}, + 'log': {'key': 'properties.log', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'scheduled': {'key': 'properties.scheduled', 'type': 'bool'}, + 'last_restore_time_stamp': {'key': 'properties.lastRestoreTimeStamp', 'type': 'iso-8601'}, + 'finished_time_stamp': {'key': 'properties.finishedTimeStamp', 'type': 'iso-8601'}, + 'correlation_id': {'key': 'properties.correlationId', 'type': 'str'}, + 'website_size_in_bytes': {'key': 'properties.websiteSizeInBytes', 'type': 'long'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(BackupItem, self).__init__(kind=kind, **kwargs) + self.backup_id = None + self.storage_account_url = None + self.blob_name = None + self.name_properties_name = None + self.status = None + self.size_in_bytes = None + self.created = None + self.log = None + self.databases = None + self.scheduled = None + self.last_restore_time_stamp = None + self.finished_time_stamp = None + self.correlation_id = None + self.website_size_in_bytes = None + + +class BackupItemCollection(msrest.serialization.Model): + """Collection of backup items. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.BackupItem] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackupItem]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["BackupItem"], + **kwargs + ): + super(BackupItemCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class BackupRequest(ProxyOnlyResource): + """Description of a backup which will be performed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param backup_name: Name of the backup. + :type backup_name: str + :param enabled: True if the backup schedule is enabled (must be included in that case), false + if the backup schedule should be disabled. + :type enabled: bool + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param backup_schedule: Schedule for the backup if it is executed periodically. + :type backup_schedule: ~azure.mgmt.web.v2020_06_01.models.BackupSchedule + :param databases: Databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'backup_name': {'key': 'properties.backupName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'backup_schedule': {'key': 'properties.backupSchedule', 'type': 'BackupSchedule'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + backup_name: Optional[str] = None, + enabled: Optional[bool] = None, + storage_account_url: Optional[str] = None, + backup_schedule: Optional["BackupSchedule"] = None, + databases: Optional[List["DatabaseBackupSetting"]] = None, + **kwargs + ): + super(BackupRequest, self).__init__(kind=kind, **kwargs) + self.backup_name = backup_name + self.enabled = enabled + self.storage_account_url = storage_account_url + self.backup_schedule = backup_schedule + self.databases = databases + + +class BackupSchedule(msrest.serialization.Model): + """Description of a backup schedule. Describes how often should be the backup performed and what should be the retention policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param frequency_interval: Required. How often the backup should be executed (e.g. for weekly + backup, this should be set to 7 and FrequencyUnit should be set to Day). + :type frequency_interval: int + :param frequency_unit: Required. The unit of time for how often the backup should be executed + (e.g. for weekly backup, this should be set to Day and FrequencyInterval should be set to 7). + Possible values include: "Day", "Hour". Default value: "Day". + :type frequency_unit: str or ~azure.mgmt.web.v2020_06_01.models.FrequencyUnit + :param keep_at_least_one_backup: Required. True if the retention policy should always keep at + least one backup in the storage account, regardless how old it is; false otherwise. + :type keep_at_least_one_backup: bool + :param retention_period_in_days: Required. After how many days backups should be deleted. + :type retention_period_in_days: int + :param start_time: When the schedule should start working. + :type start_time: ~datetime.datetime + :ivar last_execution_time: Last time when this schedule was triggered. + :vartype last_execution_time: ~datetime.datetime + """ + + _validation = { + 'frequency_interval': {'required': True}, + 'frequency_unit': {'required': True}, + 'keep_at_least_one_backup': {'required': True}, + 'retention_period_in_days': {'required': True}, + 'last_execution_time': {'readonly': True}, + } + + _attribute_map = { + 'frequency_interval': {'key': 'frequencyInterval', 'type': 'int'}, + 'frequency_unit': {'key': 'frequencyUnit', 'type': 'str'}, + 'keep_at_least_one_backup': {'key': 'keepAtLeastOneBackup', 'type': 'bool'}, + 'retention_period_in_days': {'key': 'retentionPeriodInDays', 'type': 'int'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'last_execution_time': {'key': 'lastExecutionTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + frequency_interval: int = 7, + frequency_unit: Union[str, "FrequencyUnit"] = "Day", + keep_at_least_one_backup: bool = True, + retention_period_in_days: int = 30, + start_time: Optional[datetime.datetime] = None, + **kwargs + ): + super(BackupSchedule, self).__init__(**kwargs) + self.frequency_interval = frequency_interval + self.frequency_unit = frequency_unit + self.keep_at_least_one_backup = keep_at_least_one_backup + self.retention_period_in_days = retention_period_in_days + self.start_time = start_time + self.last_execution_time = None + + +class BillingMeter(ProxyOnlyResource): + """App Service billing entity that contains information about meter which the Azure billing system utilizes to charge users for services. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param meter_id: Meter GUID onboarded in Commerce. + :type meter_id: str + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param short_name: Short Name from App Service Azure pricing Page. + :type short_name: str + :param friendly_name: Friendly name of the meter. + :type friendly_name: str + :param resource_type: App Service ResourceType meter used for. + :type resource_type: str + :param os_type: App Service OS type meter used for. + :type os_type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'meter_id': {'key': 'properties.meterId', 'type': 'str'}, + 'billing_location': {'key': 'properties.billingLocation', 'type': 'str'}, + 'short_name': {'key': 'properties.shortName', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'os_type': {'key': 'properties.osType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + meter_id: Optional[str] = None, + billing_location: Optional[str] = None, + short_name: Optional[str] = None, + friendly_name: Optional[str] = None, + resource_type: Optional[str] = None, + os_type: Optional[str] = None, + **kwargs + ): + super(BillingMeter, self).__init__(kind=kind, **kwargs) + self.meter_id = meter_id + self.billing_location = billing_location + self.short_name = short_name + self.friendly_name = friendly_name + self.resource_type = resource_type + self.os_type = os_type + + +class BillingMeterCollection(msrest.serialization.Model): + """Collection of Billing Meters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.BillingMeter] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BillingMeter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["BillingMeter"], + **kwargs + ): + super(BillingMeterCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class BlobStorageTokenStore(ProxyOnlyResource): + """BlobStorageTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sas_url_setting_name: + :type sas_url_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sas_url_setting_name': {'key': 'properties.sasUrlSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sas_url_setting_name: Optional[str] = None, + **kwargs + ): + super(BlobStorageTokenStore, self).__init__(kind=kind, **kwargs) + self.sas_url_setting_name = sas_url_setting_name + + +class Capability(msrest.serialization.Model): + """Describes the capabilities/features allowed for a specific SKU. + + :param name: Name of the SKU capability. + :type name: str + :param value: Value of the SKU capability. + :type value: str + :param reason: Reason of the SKU capability. + :type reason: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + 'reason': {'key': 'reason', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + reason: Optional[str] = None, + **kwargs + ): + super(Capability, self).__init__(**kwargs) + self.name = name + self.value = value + self.reason = reason + + +class Certificate(Resource): + """SSL certificate for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + host_names: Optional[List[str]] = None, + pfx_blob: Optional[bytearray] = None, + password: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + server_farm_id: Optional[str] = None, + canonical_name: Optional[str] = None, + **kwargs + ): + super(Certificate, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = host_names + self.pfx_blob = pfx_blob + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = password + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.key_vault_secret_status = None + self.server_farm_id = server_farm_id + self.canonical_name = canonical_name + + +class CertificateCollection(msrest.serialization.Model): + """Collection of certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Certificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Certificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Certificate"], + **kwargs + ): + super(CertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CertificateDetails(msrest.serialization.Model): + """SSL certificate details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar version: Certificate Version. + :vartype version: int + :ivar serial_number: Certificate Serial Number. + :vartype serial_number: str + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + :ivar subject: Certificate Subject. + :vartype subject: str + :ivar not_before: Date Certificate is valid from. + :vartype not_before: ~datetime.datetime + :ivar not_after: Date Certificate is valid to. + :vartype not_after: ~datetime.datetime + :ivar signature_algorithm: Certificate Signature algorithm. + :vartype signature_algorithm: str + :ivar issuer: Certificate Issuer. + :vartype issuer: str + :ivar raw_data: Raw certificate data. + :vartype raw_data: str + """ + + _validation = { + 'version': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'subject': {'readonly': True}, + 'not_before': {'readonly': True}, + 'not_after': {'readonly': True}, + 'signature_algorithm': {'readonly': True}, + 'issuer': {'readonly': True}, + 'raw_data': {'readonly': True}, + } + + _attribute_map = { + 'version': {'key': 'version', 'type': 'int'}, + 'serial_number': {'key': 'serialNumber', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'subject': {'key': 'subject', 'type': 'str'}, + 'not_before': {'key': 'notBefore', 'type': 'iso-8601'}, + 'not_after': {'key': 'notAfter', 'type': 'iso-8601'}, + 'signature_algorithm': {'key': 'signatureAlgorithm', 'type': 'str'}, + 'issuer': {'key': 'issuer', 'type': 'str'}, + 'raw_data': {'key': 'rawData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateDetails, self).__init__(**kwargs) + self.version = None + self.serial_number = None + self.thumbprint = None + self.subject = None + self.not_before = None + self.not_after = None + self.signature_algorithm = None + self.issuer = None + self.raw_data = None + + +class CertificateEmail(ProxyOnlyResource): + """SSL certificate email. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param email_id: Email id. + :type email_id: str + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'email_id': {'key': 'properties.emailId', 'type': 'str'}, + 'time_stamp': {'key': 'properties.timeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + email_id: Optional[str] = None, + time_stamp: Optional[datetime.datetime] = None, + **kwargs + ): + super(CertificateEmail, self).__init__(kind=kind, **kwargs) + self.email_id = email_id + self.time_stamp = time_stamp + + +class CertificateOrderAction(ProxyOnlyResource): + """Certificate order action. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar action_type: Action type. Possible values include: "CertificateIssued", + "CertificateOrderCanceled", "CertificateOrderCreated", "CertificateRevoked", + "DomainValidationComplete", "FraudDetected", "OrgNameChange", "OrgValidationComplete", + "SanDrop", "FraudCleared", "CertificateExpired", "CertificateExpirationWarning", + "FraudDocumentationRequired", "Unknown". + :vartype action_type: str or ~azure.mgmt.web.v2020_06_01.models.CertificateOrderActionType + :ivar created_at: Time at which the certificate action was performed. + :vartype created_at: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'action_type': {'readonly': True}, + 'created_at': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'action_type': {'key': 'properties.actionType', 'type': 'str'}, + 'created_at': {'key': 'properties.createdAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(CertificateOrderAction, self).__init__(kind=kind, **kwargs) + self.action_type = None + self.created_at = None + + +class CertificatePatchResource(ProxyOnlyResource): + """ARM resource for a certificate. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_06_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + host_names: Optional[List[str]] = None, + pfx_blob: Optional[bytearray] = None, + password: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + server_farm_id: Optional[str] = None, + canonical_name: Optional[str] = None, + **kwargs + ): + super(CertificatePatchResource, self).__init__(kind=kind, **kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = host_names + self.pfx_blob = pfx_blob + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = password + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.key_vault_secret_status = None + self.server_farm_id = server_farm_id + self.canonical_name = canonical_name + + +class ClientRegistration(ProxyOnlyResource): + """ClientRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + client_id: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(ClientRegistration, self).__init__(kind=kind, **kwargs) + self.client_id = client_id + self.client_secret_setting_name = client_secret_setting_name + + +class CloningInfo(msrest.serialization.Model): + """Information needed for cloning operation. + + All required parameters must be populated in order to send to Azure. + + :param correlation_id: Correlation ID of cloning operation. This ID ties multiple cloning + operations + together to use the same snapshot. + :type correlation_id: str + :param overwrite: :code:`true` to overwrite destination app; otherwise, + :code:`false`. + :type overwrite: bool + :param clone_custom_host_names: :code:`true` to clone custom hostnames from source + app; otherwise, :code:`false`. + :type clone_custom_host_names: bool + :param clone_source_control: :code:`true` to clone source control from source app; + otherwise, :code:`false`. + :type clone_source_control: bool + :param source_web_app_id: Required. ARM resource ID of the source app. App resource ID is of + the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type source_web_app_id: str + :param source_web_app_location: Location of source app ex: West US or North Europe. + :type source_web_app_location: str + :param hosting_environment: App Service Environment. + :type hosting_environment: str + :param app_settings_overrides: Application setting overrides for cloned app. If specified, + these settings override the settings cloned + from source app. Otherwise, application settings from source app are retained. + :type app_settings_overrides: dict[str, str] + :param configure_load_balancing: :code:`true` to configure load balancing for + source and destination app. + :type configure_load_balancing: bool + :param traffic_manager_profile_id: ARM resource ID of the Traffic Manager profile to use, if it + exists. Traffic Manager resource ID is of the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/trafficManagerProfiles/{profileName}. + :type traffic_manager_profile_id: str + :param traffic_manager_profile_name: Name of Traffic Manager profile to create. This is only + needed if Traffic Manager profile does not already exist. + :type traffic_manager_profile_name: str + """ + + _validation = { + 'source_web_app_id': {'required': True}, + } + + _attribute_map = { + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'overwrite': {'key': 'overwrite', 'type': 'bool'}, + 'clone_custom_host_names': {'key': 'cloneCustomHostNames', 'type': 'bool'}, + 'clone_source_control': {'key': 'cloneSourceControl', 'type': 'bool'}, + 'source_web_app_id': {'key': 'sourceWebAppId', 'type': 'str'}, + 'source_web_app_location': {'key': 'sourceWebAppLocation', 'type': 'str'}, + 'hosting_environment': {'key': 'hostingEnvironment', 'type': 'str'}, + 'app_settings_overrides': {'key': 'appSettingsOverrides', 'type': '{str}'}, + 'configure_load_balancing': {'key': 'configureLoadBalancing', 'type': 'bool'}, + 'traffic_manager_profile_id': {'key': 'trafficManagerProfileId', 'type': 'str'}, + 'traffic_manager_profile_name': {'key': 'trafficManagerProfileName', 'type': 'str'}, + } + + def __init__( + self, + *, + source_web_app_id: str, + correlation_id: Optional[str] = None, + overwrite: Optional[bool] = None, + clone_custom_host_names: Optional[bool] = None, + clone_source_control: Optional[bool] = None, + source_web_app_location: Optional[str] = None, + hosting_environment: Optional[str] = None, + app_settings_overrides: Optional[Dict[str, str]] = None, + configure_load_balancing: Optional[bool] = None, + traffic_manager_profile_id: Optional[str] = None, + traffic_manager_profile_name: Optional[str] = None, + **kwargs + ): + super(CloningInfo, self).__init__(**kwargs) + self.correlation_id = correlation_id + self.overwrite = overwrite + self.clone_custom_host_names = clone_custom_host_names + self.clone_source_control = clone_source_control + self.source_web_app_id = source_web_app_id + self.source_web_app_location = source_web_app_location + self.hosting_environment = hosting_environment + self.app_settings_overrides = app_settings_overrides + self.configure_load_balancing = configure_load_balancing + self.traffic_manager_profile_id = traffic_manager_profile_id + self.traffic_manager_profile_name = traffic_manager_profile_name + + +class Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties(msrest.serialization.Model): + """Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Principal Id of user assigned identity. + :vartype principal_id: str + :ivar client_id: Client Id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionStringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Connection strings. + :type properties: dict[str, ~azure.mgmt.web.v2020_06_01.models.ConnStringValueTypePair] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{ConnStringValueTypePair}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, "ConnStringValueTypePair"]] = None, + **kwargs + ): + super(ConnectionStringDictionary, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class ConnStringInfo(msrest.serialization.Model): + """Database connection string information. + + :param name: Name of connection string. + :type name: str + :param connection_string: Connection string value. + :type connection_string: str + :param type: Type of database. Possible values include: "MySql", "SQLServer", "SQLAzure", + "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", "RedisCache", + "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ConnectionStringType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + connection_string: Optional[str] = None, + type: Optional[Union[str, "ConnectionStringType"]] = None, + **kwargs + ): + super(ConnStringInfo, self).__init__(**kwargs) + self.name = name + self.connection_string = connection_string + self.type = type + + +class ConnStringValueTypePair(msrest.serialization.Model): + """Database connection string value to type pair. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Value of pair. + :type value: str + :param type: Required. Type of database. Possible values include: "MySql", "SQLServer", + "SQLAzure", "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", + "RedisCache", "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ConnectionStringType + """ + + _validation = { + 'value': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + value: str, + type: Union[str, "ConnectionStringType"], + **kwargs + ): + super(ConnStringValueTypePair, self).__init__(**kwargs) + self.value = value + self.type = type + + +class Contact(msrest.serialization.Model): + """Contact information for domain registration. If 'Domain Privacy' option is not selected then the contact information is made publicly available through the Whois +directories as per ICANN requirements. + + All required parameters must be populated in order to send to Azure. + + :param address_mailing: Mailing address. + :type address_mailing: ~azure.mgmt.web.v2020_06_01.models.Address + :param email: Required. Email address. + :type email: str + :param fax: Fax number. + :type fax: str + :param job_title: Job title. + :type job_title: str + :param name_first: Required. First name. + :type name_first: str + :param name_last: Required. Last name. + :type name_last: str + :param name_middle: Middle name. + :type name_middle: str + :param organization: Organization contact belongs to. + :type organization: str + :param phone: Required. Phone number. + :type phone: str + """ + + _validation = { + 'email': {'required': True}, + 'name_first': {'required': True}, + 'name_last': {'required': True}, + 'phone': {'required': True}, + } + + _attribute_map = { + 'address_mailing': {'key': 'addressMailing', 'type': 'Address'}, + 'email': {'key': 'email', 'type': 'str'}, + 'fax': {'key': 'fax', 'type': 'str'}, + 'job_title': {'key': 'jobTitle', 'type': 'str'}, + 'name_first': {'key': 'nameFirst', 'type': 'str'}, + 'name_last': {'key': 'nameLast', 'type': 'str'}, + 'name_middle': {'key': 'nameMiddle', 'type': 'str'}, + 'organization': {'key': 'organization', 'type': 'str'}, + 'phone': {'key': 'phone', 'type': 'str'}, + } + + def __init__( + self, + *, + email: str, + name_first: str, + name_last: str, + phone: str, + address_mailing: Optional["Address"] = None, + fax: Optional[str] = None, + job_title: Optional[str] = None, + name_middle: Optional[str] = None, + organization: Optional[str] = None, + **kwargs + ): + super(Contact, self).__init__(**kwargs) + self.address_mailing = address_mailing + self.email = email + self.fax = fax + self.job_title = job_title + self.name_first = name_first + self.name_last = name_last + self.name_middle = name_middle + self.organization = organization + self.phone = phone + + +class ContainerCpuStatistics(msrest.serialization.Model): + """ContainerCpuStatistics. + + :param cpu_usage: + :type cpu_usage: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuUsage + :param system_cpu_usage: + :type system_cpu_usage: long + :param online_cpu_count: + :type online_cpu_count: int + :param throttling_data: + :type throttling_data: ~azure.mgmt.web.v2020_06_01.models.ContainerThrottlingData + """ + + _attribute_map = { + 'cpu_usage': {'key': 'cpuUsage', 'type': 'ContainerCpuUsage'}, + 'system_cpu_usage': {'key': 'systemCpuUsage', 'type': 'long'}, + 'online_cpu_count': {'key': 'onlineCpuCount', 'type': 'int'}, + 'throttling_data': {'key': 'throttlingData', 'type': 'ContainerThrottlingData'}, + } + + def __init__( + self, + *, + cpu_usage: Optional["ContainerCpuUsage"] = None, + system_cpu_usage: Optional[int] = None, + online_cpu_count: Optional[int] = None, + throttling_data: Optional["ContainerThrottlingData"] = None, + **kwargs + ): + super(ContainerCpuStatistics, self).__init__(**kwargs) + self.cpu_usage = cpu_usage + self.system_cpu_usage = system_cpu_usage + self.online_cpu_count = online_cpu_count + self.throttling_data = throttling_data + + +class ContainerCpuUsage(msrest.serialization.Model): + """ContainerCpuUsage. + + :param total_usage: + :type total_usage: long + :param per_cpu_usage: + :type per_cpu_usage: list[long] + :param kernel_mode_usage: + :type kernel_mode_usage: long + :param user_mode_usage: + :type user_mode_usage: long + """ + + _attribute_map = { + 'total_usage': {'key': 'totalUsage', 'type': 'long'}, + 'per_cpu_usage': {'key': 'perCpuUsage', 'type': '[long]'}, + 'kernel_mode_usage': {'key': 'kernelModeUsage', 'type': 'long'}, + 'user_mode_usage': {'key': 'userModeUsage', 'type': 'long'}, + } + + def __init__( + self, + *, + total_usage: Optional[int] = None, + per_cpu_usage: Optional[List[int]] = None, + kernel_mode_usage: Optional[int] = None, + user_mode_usage: Optional[int] = None, + **kwargs + ): + super(ContainerCpuUsage, self).__init__(**kwargs) + self.total_usage = total_usage + self.per_cpu_usage = per_cpu_usage + self.kernel_mode_usage = kernel_mode_usage + self.user_mode_usage = user_mode_usage + + +class ContainerInfo(msrest.serialization.Model): + """ContainerInfo. + + :param current_time_stamp: + :type current_time_stamp: ~datetime.datetime + :param previous_time_stamp: + :type previous_time_stamp: ~datetime.datetime + :param current_cpu_stats: + :type current_cpu_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuStatistics + :param previous_cpu_stats: + :type previous_cpu_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerCpuStatistics + :param memory_stats: + :type memory_stats: ~azure.mgmt.web.v2020_06_01.models.ContainerMemoryStatistics + :param name: + :type name: str + :param id: + :type id: str + :param eth0: + :type eth0: ~azure.mgmt.web.v2020_06_01.models.ContainerNetworkInterfaceStatistics + """ + + _attribute_map = { + 'current_time_stamp': {'key': 'currentTimeStamp', 'type': 'iso-8601'}, + 'previous_time_stamp': {'key': 'previousTimeStamp', 'type': 'iso-8601'}, + 'current_cpu_stats': {'key': 'currentCpuStats', 'type': 'ContainerCpuStatistics'}, + 'previous_cpu_stats': {'key': 'previousCpuStats', 'type': 'ContainerCpuStatistics'}, + 'memory_stats': {'key': 'memoryStats', 'type': 'ContainerMemoryStatistics'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'eth0': {'key': 'eth0', 'type': 'ContainerNetworkInterfaceStatistics'}, + } + + def __init__( + self, + *, + current_time_stamp: Optional[datetime.datetime] = None, + previous_time_stamp: Optional[datetime.datetime] = None, + current_cpu_stats: Optional["ContainerCpuStatistics"] = None, + previous_cpu_stats: Optional["ContainerCpuStatistics"] = None, + memory_stats: Optional["ContainerMemoryStatistics"] = None, + name: Optional[str] = None, + id: Optional[str] = None, + eth0: Optional["ContainerNetworkInterfaceStatistics"] = None, + **kwargs + ): + super(ContainerInfo, self).__init__(**kwargs) + self.current_time_stamp = current_time_stamp + self.previous_time_stamp = previous_time_stamp + self.current_cpu_stats = current_cpu_stats + self.previous_cpu_stats = previous_cpu_stats + self.memory_stats = memory_stats + self.name = name + self.id = id + self.eth0 = eth0 + + +class ContainerMemoryStatistics(msrest.serialization.Model): + """ContainerMemoryStatistics. + + :param usage: + :type usage: long + :param max_usage: + :type max_usage: long + :param limit: + :type limit: long + """ + + _attribute_map = { + 'usage': {'key': 'usage', 'type': 'long'}, + 'max_usage': {'key': 'maxUsage', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + } + + def __init__( + self, + *, + usage: Optional[int] = None, + max_usage: Optional[int] = None, + limit: Optional[int] = None, + **kwargs + ): + super(ContainerMemoryStatistics, self).__init__(**kwargs) + self.usage = usage + self.max_usage = max_usage + self.limit = limit + + +class ContainerNetworkInterfaceStatistics(msrest.serialization.Model): + """ContainerNetworkInterfaceStatistics. + + :param rx_bytes: + :type rx_bytes: long + :param rx_packets: + :type rx_packets: long + :param rx_errors: + :type rx_errors: long + :param rx_dropped: + :type rx_dropped: long + :param tx_bytes: + :type tx_bytes: long + :param tx_packets: + :type tx_packets: long + :param tx_errors: + :type tx_errors: long + :param tx_dropped: + :type tx_dropped: long + """ + + _attribute_map = { + 'rx_bytes': {'key': 'rxBytes', 'type': 'long'}, + 'rx_packets': {'key': 'rxPackets', 'type': 'long'}, + 'rx_errors': {'key': 'rxErrors', 'type': 'long'}, + 'rx_dropped': {'key': 'rxDropped', 'type': 'long'}, + 'tx_bytes': {'key': 'txBytes', 'type': 'long'}, + 'tx_packets': {'key': 'txPackets', 'type': 'long'}, + 'tx_errors': {'key': 'txErrors', 'type': 'long'}, + 'tx_dropped': {'key': 'txDropped', 'type': 'long'}, + } + + def __init__( + self, + *, + rx_bytes: Optional[int] = None, + rx_packets: Optional[int] = None, + rx_errors: Optional[int] = None, + rx_dropped: Optional[int] = None, + tx_bytes: Optional[int] = None, + tx_packets: Optional[int] = None, + tx_errors: Optional[int] = None, + tx_dropped: Optional[int] = None, + **kwargs + ): + super(ContainerNetworkInterfaceStatistics, self).__init__(**kwargs) + self.rx_bytes = rx_bytes + self.rx_packets = rx_packets + self.rx_errors = rx_errors + self.rx_dropped = rx_dropped + self.tx_bytes = tx_bytes + self.tx_packets = tx_packets + self.tx_errors = tx_errors + self.tx_dropped = tx_dropped + + +class ContainerThrottlingData(msrest.serialization.Model): + """ContainerThrottlingData. + + :param periods: + :type periods: int + :param throttled_periods: + :type throttled_periods: int + :param throttled_time: + :type throttled_time: int + """ + + _attribute_map = { + 'periods': {'key': 'periods', 'type': 'int'}, + 'throttled_periods': {'key': 'throttledPeriods', 'type': 'int'}, + 'throttled_time': {'key': 'throttledTime', 'type': 'int'}, + } + + def __init__( + self, + *, + periods: Optional[int] = None, + throttled_periods: Optional[int] = None, + throttled_time: Optional[int] = None, + **kwargs + ): + super(ContainerThrottlingData, self).__init__(**kwargs) + self.periods = periods + self.throttled_periods = throttled_periods + self.throttled_time = throttled_time + + +class ContinuousWebJob(ProxyOnlyResource): + """Continuous Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param status: Job status. Possible values include: "Initializing", "Starting", "Running", + "PendingRestart", "Stopped". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobStatus + :param detailed_status: Detailed status. + :type detailed_status: str + :param log_url: Log URL. + :type log_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'detailed_status': {'key': 'properties.detailed_status', 'type': 'str'}, + 'log_url': {'key': 'properties.log_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + status: Optional[Union[str, "ContinuousWebJobStatus"]] = None, + detailed_status: Optional[str] = None, + log_url: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(ContinuousWebJob, self).__init__(kind=kind, **kwargs) + self.status = status + self.detailed_status = detailed_status + self.log_url = log_url + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class ContinuousWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ContinuousWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ContinuousWebJob"], + **kwargs + ): + super(ContinuousWebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CookieExpiration(ProxyOnlyResource): + """CookieExpiration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param convention: Possible values include: "FixedTime", "IdentityProviderDerived". + :type convention: str or ~azure.mgmt.web.v2020_06_01.models.CookieExpirationConvention + :param time_to_expiration: + :type time_to_expiration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'time_to_expiration': {'key': 'properties.timeToExpiration', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + convention: Optional[Union[str, "CookieExpirationConvention"]] = None, + time_to_expiration: Optional[str] = None, + **kwargs + ): + super(CookieExpiration, self).__init__(kind=kind, **kwargs) + self.convention = convention + self.time_to_expiration = time_to_expiration + + +class CorsSettings(msrest.serialization.Model): + """Cross-Origin Resource Sharing (CORS) settings for the app. + + :param allowed_origins: Gets or sets the list of origins that should be allowed to make cross- + origin + calls (for example: http://example.com:12345). Use "*" to allow all. + :type allowed_origins: list[str] + :param support_credentials: Gets or sets whether CORS requests with credentials are allowed. + See + https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#Requests_with_credentials + for more details. + :type support_credentials: bool + """ + + _attribute_map = { + 'allowed_origins': {'key': 'allowedOrigins', 'type': '[str]'}, + 'support_credentials': {'key': 'supportCredentials', 'type': 'bool'}, + } + + def __init__( + self, + *, + allowed_origins: Optional[List[str]] = None, + support_credentials: Optional[bool] = None, + **kwargs + ): + super(CorsSettings, self).__init__(**kwargs) + self.allowed_origins = allowed_origins + self.support_credentials = support_credentials + + +class CsmCopySlotEntity(msrest.serialization.Model): + """Copy deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during copy operation. + :type target_slot: str + :param site_config: Required. The site object which will be merged with the source slot site + to produce new destination slot site object. + :code:`null` to just copy source slot content. Otherwise a + :code:`Site` + object with properties to override source slot site. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + """ + + _validation = { + 'target_slot': {'required': True}, + 'site_config': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'site_config': {'key': 'siteConfig', 'type': 'SiteConfig'}, + } + + def __init__( + self, + *, + target_slot: str, + site_config: "SiteConfig", + **kwargs + ): + super(CsmCopySlotEntity, self).__init__(**kwargs) + self.target_slot = target_slot + self.site_config = site_config + + +class CsmMoveResourceEnvelope(msrest.serialization.Model): + """Object with a list of the resources that need to be moved and the resource group they should be moved to. + + :param target_resource_group: + :type target_resource_group: str + :param resources: + :type resources: list[str] + """ + + _validation = { + 'target_resource_group': {'max_length': 90, 'min_length': 1, 'pattern': r' ^[-\w\._\(\)]+[^\.]$'}, + } + + _attribute_map = { + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'resources': {'key': 'resources', 'type': '[str]'}, + } + + def __init__( + self, + *, + target_resource_group: Optional[str] = None, + resources: Optional[List[str]] = None, + **kwargs + ): + super(CsmMoveResourceEnvelope, self).__init__(**kwargs) + self.target_resource_group = target_resource_group + self.resources = resources + + +class CsmOperationCollection(msrest.serialization.Model): + """Collection of Azure resource manager operation metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.CsmOperationDescription] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmOperationDescription]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["CsmOperationDescription"], + **kwargs + ): + super(CsmOperationCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CsmOperationDescription(msrest.serialization.Model): + """Description of an operation available for Microsoft.Web resource provider. + + :param name: + :type name: str + :param display: Meta data about operation used for display in portal. + :type display: ~azure.mgmt.web.v2020_06_01.models.CsmOperationDisplay + :param origin: + :type origin: str + :param properties: Properties available for a Microsoft.Web resource provider operation. + :type properties: ~azure.mgmt.web.v2020_06_01.models.CsmOperationDescriptionProperties + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'CsmOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'CsmOperationDescriptionProperties'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional["CsmOperationDisplay"] = None, + origin: Optional[str] = None, + properties: Optional["CsmOperationDescriptionProperties"] = None, + **kwargs + ): + super(CsmOperationDescription, self).__init__(**kwargs) + self.name = name + self.display = display + self.origin = origin + self.properties = properties + + +class CsmOperationDescriptionProperties(msrest.serialization.Model): + """Properties available for a Microsoft.Web resource provider operation. + + :param service_specification: Resource metrics service provided by Microsoft.Insights resource + provider. + :type service_specification: ~azure.mgmt.web.v2020_06_01.models.ServiceSpecification + """ + + _attribute_map = { + 'service_specification': {'key': 'serviceSpecification', 'type': 'ServiceSpecification'}, + } + + def __init__( + self, + *, + service_specification: Optional["ServiceSpecification"] = None, + **kwargs + ): + super(CsmOperationDescriptionProperties, self).__init__(**kwargs) + self.service_specification = service_specification + + +class CsmOperationDisplay(msrest.serialization.Model): + """Meta data about operation used for display in portal. + + :param provider: + :type provider: str + :param resource: + :type resource: str + :param operation: + :type operation: str + :param description: + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(CsmOperationDisplay, self).__init__(**kwargs) + self.provider = provider + self.resource = resource + self.operation = operation + self.description = description + + +class CsmPublishingCredentialsPoliciesCollection(ProxyOnlyResource): + """Publishing Credentials Policies collection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param ftp: Whether FTP is allowed. + :type ftp: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :param scm: Whether Scm Basic Auth is allowed. + :type scm: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ftp': {'key': 'properties.ftp', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + 'scm': {'key': 'properties.scm', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + ftp: Optional["CsmPublishingCredentialsPoliciesEntity"] = None, + scm: Optional["CsmPublishingCredentialsPoliciesEntity"] = None, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesCollection, self).__init__(kind=kind, **kwargs) + self.ftp = ftp + self.scm = scm + + +class CsmPublishingCredentialsPoliciesEntity(ProxyOnlyResource): + """Publishing Credentials Policies parameters. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allow: :code:`true` to allow access to a publishing method; otherwise, + :code:`false`. + :type allow: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allow': {'key': 'properties.allow', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allow: Optional[bool] = None, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesEntity, self).__init__(kind=kind, **kwargs) + self.allow = allow + + +class CsmPublishingProfileOptions(msrest.serialization.Model): + """Publishing options for requested profile. + + :param format: Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp. Possible values include: "FileZilla3", "WebDeploy", "Ftp". + :type format: str or ~azure.mgmt.web.v2020_06_01.models.PublishingProfileFormat + :param include_disaster_recovery_endpoints: Include the DisasterRecover endpoint if true. + :type include_disaster_recovery_endpoints: bool + """ + + _attribute_map = { + 'format': {'key': 'format', 'type': 'str'}, + 'include_disaster_recovery_endpoints': {'key': 'includeDisasterRecoveryEndpoints', 'type': 'bool'}, + } + + def __init__( + self, + *, + format: Optional[Union[str, "PublishingProfileFormat"]] = None, + include_disaster_recovery_endpoints: Optional[bool] = None, + **kwargs + ): + super(CsmPublishingProfileOptions, self).__init__(**kwargs) + self.format = format + self.include_disaster_recovery_endpoints = include_disaster_recovery_endpoints + + +class CsmSlotEntity(msrest.serialization.Model): + """Deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during swap operation. + :type target_slot: str + :param preserve_vnet: Required. :code:`true` to preserve Virtual Network to the + slot during swap; otherwise, :code:`false`. + :type preserve_vnet: bool + """ + + _validation = { + 'target_slot': {'required': True}, + 'preserve_vnet': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'preserve_vnet': {'key': 'preserveVnet', 'type': 'bool'}, + } + + def __init__( + self, + *, + target_slot: str, + preserve_vnet: bool, + **kwargs + ): + super(CsmSlotEntity, self).__init__(**kwargs) + self.target_slot = target_slot + self.preserve_vnet = preserve_vnet + + +class CsmUsageQuota(msrest.serialization.Model): + """Usage of the quota resource. + + :param unit: Units of measurement for the quota resource. + :type unit: str + :param next_reset_time: Next reset time for the resource counter. + :type next_reset_time: ~datetime.datetime + :param current_value: The current value of the resource counter. + :type current_value: long + :param limit: The resource limit. + :type limit: long + :param name: Quota name. + :type name: ~azure.mgmt.web.v2020_06_01.models.LocalizableString + """ + + _attribute_map = { + 'unit': {'key': 'unit', 'type': 'str'}, + 'next_reset_time': {'key': 'nextResetTime', 'type': 'iso-8601'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'LocalizableString'}, + } + + def __init__( + self, + *, + unit: Optional[str] = None, + next_reset_time: Optional[datetime.datetime] = None, + current_value: Optional[int] = None, + limit: Optional[int] = None, + name: Optional["LocalizableString"] = None, + **kwargs + ): + super(CsmUsageQuota, self).__init__(**kwargs) + self.unit = unit + self.next_reset_time = next_reset_time + self.current_value = current_value + self.limit = limit + self.name = name + + +class CsmUsageQuotaCollection(msrest.serialization.Model): + """Collection of CSM usage quotas. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuota] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmUsageQuota]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["CsmUsageQuota"], + **kwargs + ): + super(CsmUsageQuotaCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CustomHostnameAnalysisResult(ProxyOnlyResource): + """Custom domain analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar is_hostname_already_verified: :code:`true` if hostname is already verified; + otherwise, :code:`false`. + :vartype is_hostname_already_verified: bool + :ivar custom_domain_verification_test: DNS verification test result. Possible values include: + "Passed", "Failed", "Skipped". + :vartype custom_domain_verification_test: str or + ~azure.mgmt.web.v2020_06_01.models.DnsVerificationTestResult + :ivar custom_domain_verification_failure_info: Raw failure information if DNS verification + fails. + :vartype custom_domain_verification_failure_info: + ~azure.mgmt.web.v2020_06_01.models.ErrorEntity + :ivar has_conflict_on_scale_unit: :code:`true` if there is a conflict on a scale + unit; otherwise, :code:`false`. + :vartype has_conflict_on_scale_unit: bool + :ivar has_conflict_across_subscription: :code:`true` if there is a conflict across + subscriptions; otherwise, :code:`false`. + :vartype has_conflict_across_subscription: bool + :ivar conflicting_app_resource_id: Name of the conflicting app on scale unit if it's within the + same subscription. + :vartype conflicting_app_resource_id: str + :param c_name_records: CName records controller can see for this hostname. + :type c_name_records: list[str] + :param txt_records: TXT records controller can see for this hostname. + :type txt_records: list[str] + :param a_records: A records controller can see for this hostname. + :type a_records: list[str] + :param alternate_c_name_records: Alternate CName records controller can see for this hostname. + :type alternate_c_name_records: list[str] + :param alternate_txt_records: Alternate TXT records controller can see for this hostname. + :type alternate_txt_records: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'is_hostname_already_verified': {'readonly': True}, + 'custom_domain_verification_test': {'readonly': True}, + 'custom_domain_verification_failure_info': {'readonly': True}, + 'has_conflict_on_scale_unit': {'readonly': True}, + 'has_conflict_across_subscription': {'readonly': True}, + 'conflicting_app_resource_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_hostname_already_verified': {'key': 'properties.isHostnameAlreadyVerified', 'type': 'bool'}, + 'custom_domain_verification_test': {'key': 'properties.customDomainVerificationTest', 'type': 'str'}, + 'custom_domain_verification_failure_info': {'key': 'properties.customDomainVerificationFailureInfo', 'type': 'ErrorEntity'}, + 'has_conflict_on_scale_unit': {'key': 'properties.hasConflictOnScaleUnit', 'type': 'bool'}, + 'has_conflict_across_subscription': {'key': 'properties.hasConflictAcrossSubscription', 'type': 'bool'}, + 'conflicting_app_resource_id': {'key': 'properties.conflictingAppResourceId', 'type': 'str'}, + 'c_name_records': {'key': 'properties.cNameRecords', 'type': '[str]'}, + 'txt_records': {'key': 'properties.txtRecords', 'type': '[str]'}, + 'a_records': {'key': 'properties.aRecords', 'type': '[str]'}, + 'alternate_c_name_records': {'key': 'properties.alternateCNameRecords', 'type': '[str]'}, + 'alternate_txt_records': {'key': 'properties.alternateTxtRecords', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + c_name_records: Optional[List[str]] = None, + txt_records: Optional[List[str]] = None, + a_records: Optional[List[str]] = None, + alternate_c_name_records: Optional[List[str]] = None, + alternate_txt_records: Optional[List[str]] = None, + **kwargs + ): + super(CustomHostnameAnalysisResult, self).__init__(kind=kind, **kwargs) + self.is_hostname_already_verified = None + self.custom_domain_verification_test = None + self.custom_domain_verification_failure_info = None + self.has_conflict_on_scale_unit = None + self.has_conflict_across_subscription = None + self.conflicting_app_resource_id = None + self.c_name_records = c_name_records + self.txt_records = txt_records + self.a_records = a_records + self.alternate_c_name_records = alternate_c_name_records + self.alternate_txt_records = alternate_txt_records + + +class CustomOpenIdConnectProvider(ProxyOnlyResource): + """CustomOpenIdConnectProvider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectLogin + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'OpenIdConnectRegistration'}, + 'login': {'key': 'properties.login', 'type': 'OpenIdConnectLogin'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["OpenIdConnectRegistration"] = None, + login: Optional["OpenIdConnectLogin"] = None, + **kwargs + ): + super(CustomOpenIdConnectProvider, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + + +class DatabaseBackupSetting(msrest.serialization.Model): + """Database backup settings. + + All required parameters must be populated in order to send to Azure. + + :param database_type: Required. Database type (e.g. SqlAzure / MySql). Possible values include: + "SqlAzure", "MySql", "LocalMySql", "PostgreSql". + :type database_type: str or ~azure.mgmt.web.v2020_06_01.models.DatabaseType + :param name: + :type name: str + :param connection_string_name: Contains a connection string name that is linked to the + SiteConfig.ConnectionStrings. + This is used during restore with overwrite connection strings options. + :type connection_string_name: str + :param connection_string: Contains a connection string to a database which is being backed up + or restored. If the restore should happen to a new database, the database name inside is the + new one. + :type connection_string: str + """ + + _validation = { + 'database_type': {'required': True}, + } + + _attribute_map = { + 'database_type': {'key': 'databaseType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string_name': {'key': 'connectionStringName', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + } + + def __init__( + self, + *, + database_type: Union[str, "DatabaseType"], + name: Optional[str] = None, + connection_string_name: Optional[str] = None, + connection_string: Optional[str] = None, + **kwargs + ): + super(DatabaseBackupSetting, self).__init__(**kwargs) + self.database_type = database_type + self.name = name + self.connection_string_name = connection_string_name + self.connection_string = connection_string + + +class DataSource(msrest.serialization.Model): + """Class representing data source used by the detectors. + + :param instructions: Instructions if any for the data source. + :type instructions: list[str] + :param data_source_uri: Datasource Uri Links. + :type data_source_uri: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + """ + + _attribute_map = { + 'instructions': {'key': 'instructions', 'type': '[str]'}, + 'data_source_uri': {'key': 'dataSourceUri', 'type': '[NameValuePair]'}, + } + + def __init__( + self, + *, + instructions: Optional[List[str]] = None, + data_source_uri: Optional[List["NameValuePair"]] = None, + **kwargs + ): + super(DataSource, self).__init__(**kwargs) + self.instructions = instructions + self.data_source_uri = data_source_uri + + +class DataTableResponseColumn(msrest.serialization.Model): + """Column definition. + + :param column_name: Name of the column. + :type column_name: str + :param data_type: Data type which looks like 'String' or 'Int32'. + :type data_type: str + :param column_type: Column Type. + :type column_type: str + """ + + _attribute_map = { + 'column_name': {'key': 'columnName', 'type': 'str'}, + 'data_type': {'key': 'dataType', 'type': 'str'}, + 'column_type': {'key': 'columnType', 'type': 'str'}, + } + + def __init__( + self, + *, + column_name: Optional[str] = None, + data_type: Optional[str] = None, + column_type: Optional[str] = None, + **kwargs + ): + super(DataTableResponseColumn, self).__init__(**kwargs) + self.column_name = column_name + self.data_type = data_type + self.column_type = column_type + + +class DataTableResponseObject(msrest.serialization.Model): + """Data Table which defines columns and raw row values. + + :param table_name: Name of the table. + :type table_name: str + :param columns: List of columns with data types. + :type columns: list[~azure.mgmt.web.v2020_06_01.models.DataTableResponseColumn] + :param rows: Raw row values. + :type rows: list[list[str]] + """ + + _attribute_map = { + 'table_name': {'key': 'tableName', 'type': 'str'}, + 'columns': {'key': 'columns', 'type': '[DataTableResponseColumn]'}, + 'rows': {'key': 'rows', 'type': '[[str]]'}, + } + + def __init__( + self, + *, + table_name: Optional[str] = None, + columns: Optional[List["DataTableResponseColumn"]] = None, + rows: Optional[List[List[str]]] = None, + **kwargs + ): + super(DataTableResponseObject, self).__init__(**kwargs) + self.table_name = table_name + self.columns = columns + self.rows = rows + + +class DefaultErrorResponse(msrest.serialization.Model): + """App Service error response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: Error model. + :vartype error: ~azure.mgmt.web.v2020_06_01.models.DefaultErrorResponseError + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'DefaultErrorResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponse, self).__init__(**kwargs) + self.error = None + + +class DefaultErrorResponseError(msrest.serialization.Model): + """Error model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + :param details: + :type details: list[~azure.mgmt.web.v2020_06_01.models.DefaultErrorResponseErrorDetailsItem] + :ivar innererror: More information to debug error. + :vartype innererror: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'innererror': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[DefaultErrorResponseErrorDetailsItem]'}, + 'innererror': {'key': 'innererror', 'type': 'str'}, + } + + def __init__( + self, + *, + details: Optional[List["DefaultErrorResponseErrorDetailsItem"]] = None, + **kwargs + ): + super(DefaultErrorResponseError, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = details + self.innererror = None + + +class DefaultErrorResponseErrorDetailsItem(msrest.serialization.Model): + """Detailed errors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseErrorDetailsItem, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + + +class DeletedAppRestoreRequest(ProxyOnlyResource): + """Details about restoring a deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param deleted_site_id: ARM resource ID of the deleted app. Example: + /subscriptions/{subId}/providers/Microsoft.Web/deletedSites/{deletedSiteId}. + :type deleted_site_id: str + :param recover_configuration: If true, deleted site configuration, in addition to content, will + be restored. + :type recover_configuration: bool + :param snapshot_time: Point in time to restore the deleted app from, formatted as a DateTime + string. + If unspecified, default value is the time that the app was deleted. + :type snapshot_time: str + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'str'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + deleted_site_id: Optional[str] = None, + recover_configuration: Optional[bool] = None, + snapshot_time: Optional[str] = None, + use_dr_secondary: Optional[bool] = None, + **kwargs + ): + super(DeletedAppRestoreRequest, self).__init__(kind=kind, **kwargs) + self.deleted_site_id = deleted_site_id + self.recover_configuration = recover_configuration + self.snapshot_time = snapshot_time + self.use_dr_secondary = use_dr_secondary + + +class DeletedSite(ProxyOnlyResource): + """A deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar deleted_site_id: Numeric id for the deleted site. + :vartype deleted_site_id: int + :ivar deleted_timestamp: Time in UTC when the app was deleted. + :vartype deleted_timestamp: str + :ivar subscription: Subscription containing the deleted site. + :vartype subscription: str + :ivar resource_group: ResourceGroup that contained the deleted site. + :vartype resource_group: str + :ivar deleted_site_name: Name of the deleted site. + :vartype deleted_site_name: str + :ivar slot: Slot of the deleted site. + :vartype slot: str + :ivar kind_properties_kind: Kind of site that was deleted. + :vartype kind_properties_kind: str + :ivar geo_region_name: Geo Region of the deleted site. + :vartype geo_region_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'deleted_site_id': {'readonly': True}, + 'deleted_timestamp': {'readonly': True}, + 'subscription': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'deleted_site_name': {'readonly': True}, + 'slot': {'readonly': True}, + 'kind_properties_kind': {'readonly': True}, + 'geo_region_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'int'}, + 'deleted_timestamp': {'key': 'properties.deletedTimestamp', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'deleted_site_name': {'key': 'properties.deletedSiteName', 'type': 'str'}, + 'slot': {'key': 'properties.slot', 'type': 'str'}, + 'kind_properties_kind': {'key': 'properties.kind', 'type': 'str'}, + 'geo_region_name': {'key': 'properties.geoRegionName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DeletedSite, self).__init__(kind=kind, **kwargs) + self.deleted_site_id = None + self.deleted_timestamp = None + self.subscription = None + self.resource_group = None + self.deleted_site_name = None + self.slot = None + self.kind_properties_kind = None + self.geo_region_name = None + + +class DeletedWebAppCollection(msrest.serialization.Model): + """Collection of deleted apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DeletedSite] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeletedSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DeletedSite"], + **kwargs + ): + super(DeletedWebAppCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Deployment(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param status: Deployment status. + :type status: int + :param message: Details about deployment status. + :type message: str + :param author: Who authored the deployment. + :type author: str + :param deployer: Who performed the deployment. + :type deployer: str + :param author_email: Author email. + :type author_email: str + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param active: True if deployment is currently active, false if completed and null if not + started. + :type active: bool + :param details: Details on deployment. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'int'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'author': {'key': 'properties.author', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'author_email': {'key': 'properties.author_email', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'active': {'key': 'properties.active', 'type': 'bool'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + status: Optional[int] = None, + message: Optional[str] = None, + author: Optional[str] = None, + deployer: Optional[str] = None, + author_email: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + active: Optional[bool] = None, + details: Optional[str] = None, + **kwargs + ): + super(Deployment, self).__init__(kind=kind, **kwargs) + self.status = status + self.message = message + self.author = author + self.deployer = deployer + self.author_email = author_email + self.start_time = start_time + self.end_time = end_time + self.active = active + self.details = details + + +class DeploymentCollection(msrest.serialization.Model): + """Collection of app deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Deployment] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Deployment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Deployment"], + **kwargs + ): + super(DeploymentCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DeploymentLocations(msrest.serialization.Model): + """List of available locations (regions or App Service Environments) for +deployment of App Service resources. + + :param locations: Available regions. + :type locations: list[~azure.mgmt.web.v2020_06_01.models.GeoRegion] + :param hosting_environments: Available App Service Environments with full descriptions of the + environments. + :type hosting_environments: list[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironment] + :param hosting_environment_deployment_infos: Available App Service Environments with basic + information. + :type hosting_environment_deployment_infos: + list[~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDeploymentInfo] + """ + + _attribute_map = { + 'locations': {'key': 'locations', 'type': '[GeoRegion]'}, + 'hosting_environments': {'key': 'hostingEnvironments', 'type': '[AppServiceEnvironment]'}, + 'hosting_environment_deployment_infos': {'key': 'hostingEnvironmentDeploymentInfos', 'type': '[HostingEnvironmentDeploymentInfo]'}, + } + + def __init__( + self, + *, + locations: Optional[List["GeoRegion"]] = None, + hosting_environments: Optional[List["AppServiceEnvironment"]] = None, + hosting_environment_deployment_infos: Optional[List["HostingEnvironmentDeploymentInfo"]] = None, + **kwargs + ): + super(DeploymentLocations, self).__init__(**kwargs) + self.locations = locations + self.hosting_environments = hosting_environments + self.hosting_environment_deployment_infos = hosting_environment_deployment_infos + + +class DetectorAbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period detected. + + :param start_time: Start time of the correlated event. + :type start_time: ~datetime.datetime + :param end_time: End time of the correlated event. + :type end_time: ~datetime.datetime + :param message: Message describing the event. + :type message: str + :param source: Represents the name of the Detector. + :type source: str + :param priority: Represents the rank of the Detector. + :type priority: float + :param meta_data: Downtime metadata. + :type meta_data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param type: Represents the type of the Detector. Possible values include: "ServiceIncident", + "AppDeployment", "AppCrash", "RuntimeIssueDetected", "AseDeployment", "UserIssue", + "PlatformIssue", "Other". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.IssueType + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_06_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'message': {'key': 'message', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'float'}, + 'meta_data': {'key': 'metaData', 'type': '[[NameValuePair]]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + *, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + message: Optional[str] = None, + source: Optional[str] = None, + priority: Optional[float] = None, + meta_data: Optional[List[List["NameValuePair"]]] = None, + type: Optional[Union[str, "IssueType"]] = None, + solutions: Optional[List["Solution"]] = None, + **kwargs + ): + super(DetectorAbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = start_time + self.end_time = end_time + self.message = message + self.source = source + self.priority = priority + self.meta_data = meta_data + self.type = type + self.solutions = solutions + + +class DetectorDefinition(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar display_name: Display name of the detector. + :vartype display_name: str + :ivar description: Description of the detector. + :vartype description: str + :ivar rank: Detector Rank. + :vartype rank: float + :ivar is_enabled: Flag representing whether detector is enabled or not. + :vartype is_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'display_name': {'readonly': True}, + 'description': {'readonly': True}, + 'rank': {'readonly': True}, + 'is_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'rank': {'key': 'properties.rank', 'type': 'float'}, + 'is_enabled': {'key': 'properties.isEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DetectorDefinition, self).__init__(kind=kind, **kwargs) + self.display_name = None + self.description = None + self.rank = None + self.is_enabled = None + + +class DetectorInfo(msrest.serialization.Model): + """Definition of Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Short description of the detector and its purpose. + :vartype description: str + :ivar category: Support Category. + :vartype category: str + :ivar sub_category: Support Sub Category. + :vartype sub_category: str + :ivar support_topic_id: Support Topic Id. + :vartype support_topic_id: str + """ + + _validation = { + 'description': {'readonly': True}, + 'category': {'readonly': True}, + 'sub_category': {'readonly': True}, + 'support_topic_id': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'sub_category': {'key': 'subCategory', 'type': 'str'}, + 'support_topic_id': {'key': 'supportTopicId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorInfo, self).__init__(**kwargs) + self.description = None + self.category = None + self.sub_category = None + self.support_topic_id = None + + +class DetectorResponse(ProxyOnlyResource): + """Class representing Response from Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param metadata: metadata for the detector. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.DetectorInfo + :param dataset: Data Set. + :type dataset: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticData] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'DetectorInfo'}, + 'dataset': {'key': 'properties.dataset', 'type': '[DiagnosticData]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + metadata: Optional["DetectorInfo"] = None, + dataset: Optional[List["DiagnosticData"]] = None, + **kwargs + ): + super(DetectorResponse, self).__init__(kind=kind, **kwargs) + self.metadata = metadata + self.dataset = dataset + + +class DetectorResponseCollection(msrest.serialization.Model): + """Collection of detector responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DetectorResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DetectorResponse"], + **kwargs + ): + super(DetectorResponseCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticAnalysis(ProxyOnlyResource): + """Class representing a diagnostic analysis done on an application. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param abnormal_time_periods: List of time periods. + :type abnormal_time_periods: list[~azure.mgmt.web.v2020_06_01.models.AbnormalTimePeriod] + :param payload: Data by each detector. + :type payload: list[~azure.mgmt.web.v2020_06_01.models.AnalysisData] + :param non_correlated_detectors: Data by each detector for detectors that did not corelate. + :type non_correlated_detectors: list[~azure.mgmt.web.v2020_06_01.models.DetectorDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[AbnormalTimePeriod]'}, + 'payload': {'key': 'properties.payload', 'type': '[AnalysisData]'}, + 'non_correlated_detectors': {'key': 'properties.nonCorrelatedDetectors', 'type': '[DetectorDefinition]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + abnormal_time_periods: Optional[List["AbnormalTimePeriod"]] = None, + payload: Optional[List["AnalysisData"]] = None, + non_correlated_detectors: Optional[List["DetectorDefinition"]] = None, + **kwargs + ): + super(DiagnosticAnalysis, self).__init__(kind=kind, **kwargs) + self.start_time = start_time + self.end_time = end_time + self.abnormal_time_periods = abnormal_time_periods + self.payload = payload + self.non_correlated_detectors = non_correlated_detectors + + +class DiagnosticAnalysisCollection(msrest.serialization.Model): + """Collection of Diagnostic Analyses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AnalysisDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AnalysisDefinition"], + **kwargs + ): + super(DiagnosticAnalysisCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticCategory(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Description of the diagnostic category. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DiagnosticCategory, self).__init__(kind=kind, **kwargs) + self.description = None + + +class DiagnosticCategoryCollection(msrest.serialization.Model): + """Collection of Diagnostic Categories. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DiagnosticCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DiagnosticCategory"], + **kwargs + ): + super(DiagnosticCategoryCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticData(msrest.serialization.Model): + """Set of data with rendering instructions. + + :param table: Data in table form. + :type table: ~azure.mgmt.web.v2020_06_01.models.DataTableResponseObject + :param rendering_properties: Properties that describe how the table should be rendered. + :type rendering_properties: ~azure.mgmt.web.v2020_06_01.models.Rendering + """ + + _attribute_map = { + 'table': {'key': 'table', 'type': 'DataTableResponseObject'}, + 'rendering_properties': {'key': 'renderingProperties', 'type': 'Rendering'}, + } + + def __init__( + self, + *, + table: Optional["DataTableResponseObject"] = None, + rendering_properties: Optional["Rendering"] = None, + **kwargs + ): + super(DiagnosticData, self).__init__(**kwargs) + self.table = table + self.rendering_properties = rendering_properties + + +class DiagnosticDetectorCollection(msrest.serialization.Model): + """Collection of Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DetectorDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DetectorDefinition"], + **kwargs + ): + super(DiagnosticDetectorCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticDetectorResponse(ProxyOnlyResource): + """Class representing Response from Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param issue_detected: Flag representing Issue was detected. + :type issue_detected: bool + :param detector_definition: Detector's definition. + :type detector_definition: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :param metrics: Metrics provided by the detector. + :type metrics: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSet] + :param abnormal_time_periods: List of Correlated events found by the detector. + :type abnormal_time_periods: + list[~azure.mgmt.web.v2020_06_01.models.DetectorAbnormalTimePeriod] + :param data: Additional Data that detector wants to send. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param response_meta_data: Meta Data. + :type response_meta_data: ~azure.mgmt.web.v2020_06_01.models.ResponseMetaData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'issue_detected': {'key': 'properties.issueDetected', 'type': 'bool'}, + 'detector_definition': {'key': 'properties.detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'properties.metrics', 'type': '[DiagnosticMetricSet]'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[DetectorAbnormalTimePeriod]'}, + 'data': {'key': 'properties.data', 'type': '[[NameValuePair]]'}, + 'response_meta_data': {'key': 'properties.responseMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + issue_detected: Optional[bool] = None, + detector_definition: Optional["DetectorDefinition"] = None, + metrics: Optional[List["DiagnosticMetricSet"]] = None, + abnormal_time_periods: Optional[List["DetectorAbnormalTimePeriod"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + response_meta_data: Optional["ResponseMetaData"] = None, + **kwargs + ): + super(DiagnosticDetectorResponse, self).__init__(kind=kind, **kwargs) + self.start_time = start_time + self.end_time = end_time + self.issue_detected = issue_detected + self.detector_definition = detector_definition + self.metrics = metrics + self.abnormal_time_periods = abnormal_time_periods + self.data = data + self.response_meta_data = response_meta_data + + +class DiagnosticMetricSample(msrest.serialization.Model): + """Class representing Diagnostic Metric. + + :param timestamp: Time at which metric is measured. + :type timestamp: ~datetime.datetime + :param role_instance: Role Instance. Null if this counter is not per instance + This is returned and should be whichever instance name we desire to be returned + i.e. CPU and Memory return RDWORKERNAME (LargeDed..._IN_0) + where RDWORKERNAME is Machine name below and RoleInstance name in parenthesis. + :type role_instance: str + :param total: Total value of the metric. If multiple measurements are made this will have sum + of all. + :type total: float + :param maximum: Maximum of the metric sampled during the time period. + :type maximum: float + :param minimum: Minimum of the metric sampled during the time period. + :type minimum: float + :param is_aggregated: Whether the values are aggregates across all workers or not. + :type is_aggregated: bool + """ + + _attribute_map = { + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'role_instance': {'key': 'roleInstance', 'type': 'str'}, + 'total': {'key': 'total', 'type': 'float'}, + 'maximum': {'key': 'maximum', 'type': 'float'}, + 'minimum': {'key': 'minimum', 'type': 'float'}, + 'is_aggregated': {'key': 'isAggregated', 'type': 'bool'}, + } + + def __init__( + self, + *, + timestamp: Optional[datetime.datetime] = None, + role_instance: Optional[str] = None, + total: Optional[float] = None, + maximum: Optional[float] = None, + minimum: Optional[float] = None, + is_aggregated: Optional[bool] = None, + **kwargs + ): + super(DiagnosticMetricSample, self).__init__(**kwargs) + self.timestamp = timestamp + self.role_instance = role_instance + self.total = total + self.maximum = maximum + self.minimum = minimum + self.is_aggregated = is_aggregated + + +class DiagnosticMetricSet(msrest.serialization.Model): + """Class representing Diagnostic Metric information. + + :param name: Name of the metric. + :type name: str + :param unit: Metric's unit. + :type unit: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. Supported grains at the moment are PT1M, PT1H, P1D. + :type time_grain: str + :param values: Collection of metric values for the selected period based on the + {Microsoft.Web.Hosting.Administration.DiagnosticMetricSet.TimeGrain}. + :type values: list[~azure.mgmt.web.v2020_06_01.models.DiagnosticMetricSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[DiagnosticMetricSample]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + unit: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + values: Optional[List["DiagnosticMetricSample"]] = None, + **kwargs + ): + super(DiagnosticMetricSet, self).__init__(**kwargs) + self.name = name + self.unit = unit + self.start_time = start_time + self.end_time = end_time + self.time_grain = time_grain + self.values = values + + +class Dimension(msrest.serialization.Model): + """Dimension of a resource metric. For e.g. instance specific HTTP requests for a web app, +where instance name is dimension of the metric HTTP request. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param internal_name: + :type internal_name: str + :param to_be_exported_for_shoebox: + :type to_be_exported_for_shoebox: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + 'to_be_exported_for_shoebox': {'key': 'toBeExportedForShoebox', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + internal_name: Optional[str] = None, + to_be_exported_for_shoebox: Optional[bool] = None, + **kwargs + ): + super(Dimension, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.internal_name = internal_name + self.to_be_exported_for_shoebox = to_be_exported_for_shoebox + + +class Domain(Resource): + """Information about a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_06_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_06_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_06_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_06_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.DomainPropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + contact_admin: Optional["Contact"] = None, + contact_billing: Optional["Contact"] = None, + contact_registrant: Optional["Contact"] = None, + contact_tech: Optional["Contact"] = None, + privacy: Optional[bool] = None, + auto_renew: Optional[bool] = True, + consent: Optional["DomainPurchaseConsent"] = None, + dns_type: Optional[Union[str, "DnsType"]] = None, + dns_zone_id: Optional[str] = None, + target_dns_type: Optional[Union[str, "DnsType"]] = None, + auth_code: Optional[str] = None, + **kwargs + ): + super(Domain, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.contact_admin = contact_admin + self.contact_billing = contact_billing + self.contact_registrant = contact_registrant + self.contact_tech = contact_tech + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = privacy + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = auto_renew + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = consent + self.domain_not_renewable_reasons = None + self.dns_type = dns_type + self.dns_zone_id = dns_zone_id + self.target_dns_type = target_dns_type + self.auth_code = auth_code + + +class DomainAvailabilityCheckResult(msrest.serialization.Model): + """Domain availability check result. + + :param name: Name of the domain. + :type name: str + :param available: :code:`true` if domain can be purchased using CreateDomain API; + otherwise, :code:`false`. + :type available: bool + :param domain_type: Valid values are Regular domain: Azure will charge the full price of domain + registration, SoftDeleted: Purchasing this domain will simply restore it and this operation + will not cost anything. Possible values include: "Regular", "SoftDeleted". + :type domain_type: str or ~azure.mgmt.web.v2020_06_01.models.DomainType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available': {'key': 'available', 'type': 'bool'}, + 'domain_type': {'key': 'domainType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + available: Optional[bool] = None, + domain_type: Optional[Union[str, "DomainType"]] = None, + **kwargs + ): + super(DomainAvailabilityCheckResult, self).__init__(**kwargs) + self.name = name + self.available = available + self.domain_type = domain_type + + +class DomainCollection(msrest.serialization.Model): + """Collection of domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Domain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Domain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Domain"], + **kwargs + ): + super(DomainCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DomainControlCenterSsoRequest(msrest.serialization.Model): + """Single sign-on request information for domain management. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar url: URL where the single sign-on request is to be made. + :vartype url: str + :ivar post_parameter_key: Post parameter key. + :vartype post_parameter_key: str + :ivar post_parameter_value: Post parameter value. Client should use 'application/x-www-form- + urlencoded' encoding for this value. + :vartype post_parameter_value: str + """ + + _validation = { + 'url': {'readonly': True}, + 'post_parameter_key': {'readonly': True}, + 'post_parameter_value': {'readonly': True}, + } + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + 'post_parameter_key': {'key': 'postParameterKey', 'type': 'str'}, + 'post_parameter_value': {'key': 'postParameterValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainControlCenterSsoRequest, self).__init__(**kwargs) + self.url = None + self.post_parameter_key = None + self.post_parameter_value = None + + +class DomainOwnershipIdentifier(ProxyOnlyResource): + """Domain ownership Identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param ownership_id: Ownership Id. + :type ownership_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'ownership_id': {'key': 'properties.ownershipId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + ownership_id: Optional[str] = None, + **kwargs + ): + super(DomainOwnershipIdentifier, self).__init__(kind=kind, **kwargs) + self.ownership_id = ownership_id + + +class DomainOwnershipIdentifierCollection(msrest.serialization.Model): + """Collection of domain ownership identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DomainOwnershipIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DomainOwnershipIdentifier"], + **kwargs + ): + super(DomainOwnershipIdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DomainPatchResource(ProxyOnlyResource): + """ARM resource for a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_06_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_06_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_06_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_06_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_06_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_06_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_06_01.models.DomainPatchResourcePropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_06_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + contact_admin: Optional["Contact"] = None, + contact_billing: Optional["Contact"] = None, + contact_registrant: Optional["Contact"] = None, + contact_tech: Optional["Contact"] = None, + privacy: Optional[bool] = None, + auto_renew: Optional[bool] = True, + consent: Optional["DomainPurchaseConsent"] = None, + dns_type: Optional[Union[str, "DnsType"]] = None, + dns_zone_id: Optional[str] = None, + target_dns_type: Optional[Union[str, "DnsType"]] = None, + auth_code: Optional[str] = None, + **kwargs + ): + super(DomainPatchResource, self).__init__(kind=kind, **kwargs) + self.contact_admin = contact_admin + self.contact_billing = contact_billing + self.contact_registrant = contact_registrant + self.contact_tech = contact_tech + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = privacy + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = auto_renew + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = consent + self.domain_not_renewable_reasons = None + self.dns_type = dns_type + self.dns_zone_id = dns_zone_id + self.target_dns_type = target_dns_type + self.auth_code = auth_code + + +class DomainPurchaseConsent(msrest.serialization.Model): + """Domain purchase consent object, representing acceptance of applicable legal agreements. + + :param agreement_keys: List of applicable legal agreement keys. This list can be retrieved + using ListLegalAgreements API under :code:`TopLevelDomain` resource. + :type agreement_keys: list[str] + :param agreed_by: Client IP address. + :type agreed_by: str + :param agreed_at: Timestamp when the agreements were accepted. + :type agreed_at: ~datetime.datetime + """ + + _attribute_map = { + 'agreement_keys': {'key': 'agreementKeys', 'type': '[str]'}, + 'agreed_by': {'key': 'agreedBy', 'type': 'str'}, + 'agreed_at': {'key': 'agreedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + agreement_keys: Optional[List[str]] = None, + agreed_by: Optional[str] = None, + agreed_at: Optional[datetime.datetime] = None, + **kwargs + ): + super(DomainPurchaseConsent, self).__init__(**kwargs) + self.agreement_keys = agreement_keys + self.agreed_by = agreed_by + self.agreed_at = agreed_at + + +class DomainRecommendationSearchParameters(msrest.serialization.Model): + """Domain recommendation search parameters. + + :param keywords: Keywords to be used for generating domain recommendations. + :type keywords: str + :param max_domain_recommendations: Maximum number of recommendations. + :type max_domain_recommendations: int + """ + + _attribute_map = { + 'keywords': {'key': 'keywords', 'type': 'str'}, + 'max_domain_recommendations': {'key': 'maxDomainRecommendations', 'type': 'int'}, + } + + def __init__( + self, + *, + keywords: Optional[str] = None, + max_domain_recommendations: Optional[int] = None, + **kwargs + ): + super(DomainRecommendationSearchParameters, self).__init__(**kwargs) + self.keywords = keywords + self.max_domain_recommendations = max_domain_recommendations + + +class EnabledConfig(msrest.serialization.Model): + """Enabled configuration. + + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + enabled: Optional[bool] = None, + **kwargs + ): + super(EnabledConfig, self).__init__(**kwargs) + self.enabled = enabled + + +class EndpointDependency(msrest.serialization.Model): + """A domain name that a service is reached at, including details of the current connection status. + + :param domain_name: The domain name of the dependency. + :type domain_name: str + :param endpoint_details: The IP Addresses and Ports used when connecting to DomainName. + :type endpoint_details: list[~azure.mgmt.web.v2020_06_01.models.EndpointDetail] + """ + + _attribute_map = { + 'domain_name': {'key': 'domainName', 'type': 'str'}, + 'endpoint_details': {'key': 'endpointDetails', 'type': '[EndpointDetail]'}, + } + + def __init__( + self, + *, + domain_name: Optional[str] = None, + endpoint_details: Optional[List["EndpointDetail"]] = None, + **kwargs + ): + super(EndpointDependency, self).__init__(**kwargs) + self.domain_name = domain_name + self.endpoint_details = endpoint_details + + +class EndpointDetail(msrest.serialization.Model): + """Current TCP connectivity information from the App Service Environment to a single endpoint. + + :param ip_address: An IP Address that Domain Name currently resolves to. + :type ip_address: str + :param port: The port an endpoint is connected to. + :type port: int + :param latency: The time in milliseconds it takes for a TCP connection to be created from the + App Service Environment to this IpAddress at this Port. + :type latency: float + :param is_accessible: Whether it is possible to create a TCP connection from the App Service + Environment to this IpAddress at this Port. + :type is_accessible: bool + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + 'latency': {'key': 'latency', 'type': 'float'}, + 'is_accessible': {'key': 'isAccessible', 'type': 'bool'}, + } + + def __init__( + self, + *, + ip_address: Optional[str] = None, + port: Optional[int] = None, + latency: Optional[float] = None, + is_accessible: Optional[bool] = None, + **kwargs + ): + super(EndpointDetail, self).__init__(**kwargs) + self.ip_address = ip_address + self.port = port + self.latency = latency + self.is_accessible = is_accessible + + +class ErrorEntity(msrest.serialization.Model): + """Body of the error response returned from the API. + + :param extended_code: Type of error. + :type extended_code: str + :param message_template: Message template. + :type message_template: str + :param parameters: Parameters for the template. + :type parameters: list[str] + :param inner_errors: Inner errors. + :type inner_errors: list[~azure.mgmt.web.v2020_06_01.models.ErrorEntity] + :param code: Basic error code. + :type code: str + :param message: Any details of the error. + :type message: str + """ + + _attribute_map = { + 'extended_code': {'key': 'extendedCode', 'type': 'str'}, + 'message_template': {'key': 'messageTemplate', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[str]'}, + 'inner_errors': {'key': 'innerErrors', 'type': '[ErrorEntity]'}, + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + extended_code: Optional[str] = None, + message_template: Optional[str] = None, + parameters: Optional[List[str]] = None, + inner_errors: Optional[List["ErrorEntity"]] = None, + code: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ErrorEntity, self).__init__(**kwargs) + self.extended_code = extended_code + self.message_template = message_template + self.parameters = parameters + self.inner_errors = inner_errors + self.code = code + self.message = message + + +class Experiments(msrest.serialization.Model): + """Routing rules in production experiments. + + :param ramp_up_rules: List of ramp-up rules. + :type ramp_up_rules: list[~azure.mgmt.web.v2020_06_01.models.RampUpRule] + """ + + _attribute_map = { + 'ramp_up_rules': {'key': 'rampUpRules', 'type': '[RampUpRule]'}, + } + + def __init__( + self, + *, + ramp_up_rules: Optional[List["RampUpRule"]] = None, + **kwargs + ): + super(Experiments, self).__init__(**kwargs) + self.ramp_up_rules = ramp_up_rules + + +class Facebook(ProxyOnlyResource): + """Facebook. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.AppRegistration + :param graph_api_version: + :type graph_api_version: str + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AppRegistration'}, + 'graph_api_version': {'key': 'properties.graphApiVersion', 'type': 'str'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["AppRegistration"] = None, + graph_api_version: Optional[str] = None, + login: Optional["LoginScopes"] = None, + **kwargs + ): + super(Facebook, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.graph_api_version = graph_api_version + self.login = login + + +class FileSystemApplicationLogsConfig(msrest.serialization.Model): + """Application logs to file system configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.LogLevel + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + } + + def __init__( + self, + *, + level: Optional[Union[str, "LogLevel"]] = None, + **kwargs + ): + super(FileSystemApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + + +class FileSystemHttpLogsConfig(msrest.serialization.Model): + """Http logs to file system configuration. + + :param retention_in_mb: Maximum size in megabytes that http log files can use. + When reached old log files will be removed to make space for new ones. + Value can range between 25 and 100. + :type retention_in_mb: int + :param retention_in_days: Retention in days. + Remove files older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _validation = { + 'retention_in_mb': {'maximum': 100, 'minimum': 25}, + } + + _attribute_map = { + 'retention_in_mb': {'key': 'retentionInMb', 'type': 'int'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + retention_in_mb: Optional[int] = None, + retention_in_days: Optional[int] = None, + enabled: Optional[bool] = None, + **kwargs + ): + super(FileSystemHttpLogsConfig, self).__init__(**kwargs) + self.retention_in_mb = retention_in_mb + self.retention_in_days = retention_in_days + self.enabled = enabled + + +class FileSystemTokenStore(ProxyOnlyResource): + """FileSystemTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param directory: + :type directory: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'directory': {'key': 'properties.directory', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + directory: Optional[str] = None, + **kwargs + ): + super(FileSystemTokenStore, self).__init__(kind=kind, **kwargs) + self.directory = directory + + +class ForwardProxy(ProxyOnlyResource): + """ForwardProxy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param convention: Possible values include: "NoProxy", "Standard", "Custom". + :type convention: str or ~azure.mgmt.web.v2020_06_01.models.ForwardProxyConvention + :param custom_host_header_name: + :type custom_host_header_name: str + :param custom_proto_header_name: + :type custom_proto_header_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'custom_host_header_name': {'key': 'properties.customHostHeaderName', 'type': 'str'}, + 'custom_proto_header_name': {'key': 'properties.customProtoHeaderName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + convention: Optional[Union[str, "ForwardProxyConvention"]] = None, + custom_host_header_name: Optional[str] = None, + custom_proto_header_name: Optional[str] = None, + **kwargs + ): + super(ForwardProxy, self).__init__(kind=kind, **kwargs) + self.convention = convention + self.custom_host_header_name = custom_host_header_name + self.custom_proto_header_name = custom_proto_header_name + + +class FunctionEnvelope(ProxyOnlyResource): + """Function information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param function_app_id: Function App ID. + :type function_app_id: str + :param script_root_path_href: Script root path URI. + :type script_root_path_href: str + :param script_href: Script URI. + :type script_href: str + :param config_href: Config URI. + :type config_href: str + :param test_data_href: Test data URI. + :type test_data_href: str + :param secrets_file_href: Secrets file URI. + :type secrets_file_href: str + :param href: Function URI. + :type href: str + :param config: Config information. + :type config: object + :param files: File list. + :type files: dict[str, str] + :param test_data: Test data used when testing via the Azure Portal. + :type test_data: str + :param invoke_url_template: The invocation URL. + :type invoke_url_template: str + :param language: The function language. + :type language: str + :param is_disabled: Gets or sets a value indicating whether the function is disabled. + :type is_disabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'function_app_id': {'key': 'properties.function_app_id', 'type': 'str'}, + 'script_root_path_href': {'key': 'properties.script_root_path_href', 'type': 'str'}, + 'script_href': {'key': 'properties.script_href', 'type': 'str'}, + 'config_href': {'key': 'properties.config_href', 'type': 'str'}, + 'test_data_href': {'key': 'properties.test_data_href', 'type': 'str'}, + 'secrets_file_href': {'key': 'properties.secrets_file_href', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'config': {'key': 'properties.config', 'type': 'object'}, + 'files': {'key': 'properties.files', 'type': '{str}'}, + 'test_data': {'key': 'properties.test_data', 'type': 'str'}, + 'invoke_url_template': {'key': 'properties.invoke_url_template', 'type': 'str'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + 'is_disabled': {'key': 'properties.isDisabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + function_app_id: Optional[str] = None, + script_root_path_href: Optional[str] = None, + script_href: Optional[str] = None, + config_href: Optional[str] = None, + test_data_href: Optional[str] = None, + secrets_file_href: Optional[str] = None, + href: Optional[str] = None, + config: Optional[object] = None, + files: Optional[Dict[str, str]] = None, + test_data: Optional[str] = None, + invoke_url_template: Optional[str] = None, + language: Optional[str] = None, + is_disabled: Optional[bool] = None, + **kwargs + ): + super(FunctionEnvelope, self).__init__(kind=kind, **kwargs) + self.function_app_id = function_app_id + self.script_root_path_href = script_root_path_href + self.script_href = script_href + self.config_href = config_href + self.test_data_href = test_data_href + self.secrets_file_href = secrets_file_href + self.href = href + self.config = config + self.files = files + self.test_data = test_data + self.invoke_url_template = invoke_url_template + self.language = language + self.is_disabled = is_disabled + + +class FunctionEnvelopeCollection(msrest.serialization.Model): + """Collection of Kudu function information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FunctionEnvelope]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["FunctionEnvelope"], + **kwargs + ): + super(FunctionEnvelopeCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class FunctionSecrets(msrest.serialization.Model): + """Function secrets. + + :param key: Secret key. + :type key: str + :param trigger_url: Trigger URL. + :type trigger_url: str + """ + + _attribute_map = { + 'key': {'key': 'key', 'type': 'str'}, + 'trigger_url': {'key': 'trigger_url', 'type': 'str'}, + } + + def __init__( + self, + *, + key: Optional[str] = None, + trigger_url: Optional[str] = None, + **kwargs + ): + super(FunctionSecrets, self).__init__(**kwargs) + self.key = key + self.trigger_url = trigger_url + + +class GeoRegion(ProxyOnlyResource): + """Geographical region. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar description: Region description. + :vartype description: str + :ivar display_name: Display name for region. + :vartype display_name: str + :ivar org_domain: Display name for region. + :vartype org_domain: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'description': {'readonly': True}, + 'display_name': {'readonly': True}, + 'org_domain': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'org_domain': {'key': 'properties.orgDomain', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(GeoRegion, self).__init__(kind=kind, **kwargs) + self.description = None + self.display_name = None + self.org_domain = None + + +class GeoRegionCollection(msrest.serialization.Model): + """Collection of geographical regions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.GeoRegion] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GeoRegion]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["GeoRegion"], + **kwargs + ): + super(GeoRegionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class GitHub(ProxyOnlyResource): + """GitHub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["ClientRegistration"] = None, + login: Optional["LoginScopes"] = None, + **kwargs + ): + super(GitHub, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + + +class GlobalCsmSkuDescription(msrest.serialization.Model): + """A Global SKU Description. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service Tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_06_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[str] = None, + size: Optional[str] = None, + family: Optional[str] = None, + capacity: Optional["SkuCapacity"] = None, + locations: Optional[List[str]] = None, + capabilities: Optional[List["Capability"]] = None, + **kwargs + ): + super(GlobalCsmSkuDescription, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.size = size + self.family = family + self.capacity = capacity + self.locations = locations + self.capabilities = capabilities + + +class GlobalValidation(ProxyOnlyResource): + """GlobalValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param require_authentication: + :type require_authentication: bool + :param unauthenticated_client_action: Possible values include: "RedirectToLoginPage", + "AllowAnonymous", "Return401", "Return403". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_06_01.models.UnauthenticatedClientActionV2 + :param redirect_to_provider: + :type redirect_to_provider: str + :param excluded_paths: + :type excluded_paths: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'require_authentication': {'key': 'properties.requireAuthentication', 'type': 'bool'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'redirect_to_provider': {'key': 'properties.redirectToProvider', 'type': 'str'}, + 'excluded_paths': {'key': 'properties.excludedPaths', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + require_authentication: Optional[bool] = None, + unauthenticated_client_action: Optional[Union[str, "UnauthenticatedClientActionV2"]] = None, + redirect_to_provider: Optional[str] = None, + excluded_paths: Optional[List[str]] = None, + **kwargs + ): + super(GlobalValidation, self).__init__(kind=kind, **kwargs) + self.require_authentication = require_authentication + self.unauthenticated_client_action = unauthenticated_client_action + self.redirect_to_provider = redirect_to_provider + self.excluded_paths = excluded_paths + + +class Google(ProxyOnlyResource): + """Google. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.LoginScopes + :param validation: + :type validation: ~azure.mgmt.web.v2020_06_01.models.AllowedAudiencesValidation + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + 'validation': {'key': 'properties.validation', 'type': 'AllowedAudiencesValidation'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["ClientRegistration"] = None, + login: Optional["LoginScopes"] = None, + validation: Optional["AllowedAudiencesValidation"] = None, + **kwargs + ): + super(Google, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + self.validation = validation + + +class HandlerMapping(msrest.serialization.Model): + """The IIS handler mappings used to define which handler processes HTTP requests with certain extension. +For example, it is used to configure php-cgi.exe process to handle all HTTP requests with *.php extension. + + :param extension: Requests with this extension will be handled using the specified FastCGI + application. + :type extension: str + :param script_processor: The absolute path to the FastCGI application. + :type script_processor: str + :param arguments: Command-line arguments to be passed to the script processor. + :type arguments: str + """ + + _attribute_map = { + 'extension': {'key': 'extension', 'type': 'str'}, + 'script_processor': {'key': 'scriptProcessor', 'type': 'str'}, + 'arguments': {'key': 'arguments', 'type': 'str'}, + } + + def __init__( + self, + *, + extension: Optional[str] = None, + script_processor: Optional[str] = None, + arguments: Optional[str] = None, + **kwargs + ): + super(HandlerMapping, self).__init__(**kwargs) + self.extension = extension + self.script_processor = script_processor + self.arguments = arguments + + +class HostingEnvironmentDeploymentInfo(msrest.serialization.Model): + """Information needed to create resources on an App Service Environment. + + :param name: Name of the App Service Environment. + :type name: str + :param location: Location of the App Service Environment. + :type location: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + location: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentDeploymentInfo, self).__init__(**kwargs) + self.name = name + self.location = location + + +class HostingEnvironmentDiagnostics(msrest.serialization.Model): + """Diagnostics for an App Service Environment. + + :param name: Name/identifier of the diagnostics. + :type name: str + :param diagnostics_output: Diagnostics output. + :type diagnostics_output: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'diagnostics_output': {'key': 'diagnosticsOutput', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + diagnostics_output: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentDiagnostics, self).__init__(**kwargs) + self.name = name + self.diagnostics_output = diagnostics_output + + +class HostingEnvironmentProfile(msrest.serialization.Model): + """Specification for an App Service Environment to use for this resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID of the App Service Environment. + :type id: str + :ivar name: Name of the App Service Environment. + :vartype name: str + :ivar type: Resource type of the App Service Environment. + :vartype type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentProfile, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + + +class HostKeys(msrest.serialization.Model): + """Functions host level keys. + + :param master_key: Secret key. + :type master_key: str + :param function_keys: Host level function keys. + :type function_keys: dict[str, str] + :param system_keys: System keys. + :type system_keys: dict[str, str] + """ + + _attribute_map = { + 'master_key': {'key': 'masterKey', 'type': 'str'}, + 'function_keys': {'key': 'functionKeys', 'type': '{str}'}, + 'system_keys': {'key': 'systemKeys', 'type': '{str}'}, + } + + def __init__( + self, + *, + master_key: Optional[str] = None, + function_keys: Optional[Dict[str, str]] = None, + system_keys: Optional[Dict[str, str]] = None, + **kwargs + ): + super(HostKeys, self).__init__(**kwargs) + self.master_key = master_key + self.function_keys = function_keys + self.system_keys = system_keys + + +class HostName(msrest.serialization.Model): + """Details of a hostname derived from a domain. + + :param name: Name of the hostname. + :type name: str + :param site_names: List of apps the hostname is assigned to. This list will have more than one + app only if the hostname is pointing to a Traffic Manager. + :type site_names: list[str] + :param azure_resource_name: Name of the Azure resource the hostname is assigned to. If it is + assigned to a Traffic Manager then it will be the Traffic Manager name otherwise it will be the + app name. + :type azure_resource_name: str + :param azure_resource_type: Type of the Azure resource the hostname is assigned to. Possible + values include: "Website", "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_06_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Type of the DNS record. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_06_01.models.CustomHostNameDnsRecordType + :param host_name_type: Type of the hostname. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_06_01.models.HostNameType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'site_names': {'key': 'siteNames', 'type': '[str]'}, + 'azure_resource_name': {'key': 'azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'hostNameType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + site_names: Optional[List[str]] = None, + azure_resource_name: Optional[str] = None, + azure_resource_type: Optional[Union[str, "AzureResourceType"]] = None, + custom_host_name_dns_record_type: Optional[Union[str, "CustomHostNameDnsRecordType"]] = None, + host_name_type: Optional[Union[str, "HostNameType"]] = None, + **kwargs + ): + super(HostName, self).__init__(**kwargs) + self.name = name + self.site_names = site_names + self.azure_resource_name = azure_resource_name + self.azure_resource_type = azure_resource_type + self.custom_host_name_dns_record_type = custom_host_name_dns_record_type + self.host_name_type = host_name_type + + +class HostNameBinding(ProxyOnlyResource): + """A hostname binding object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param site_name: App Service app name. + :type site_name: str + :param domain_id: Fully qualified ARM domain resource URI. + :type domain_id: str + :param azure_resource_name: Azure resource name. + :type azure_resource_name: str + :param azure_resource_type: Azure resource type. Possible values include: "Website", + "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_06_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Custom DNS record type. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_06_01.models.CustomHostNameDnsRecordType + :param host_name_type: Hostname type. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_06_01.models.HostNameType + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_06_01.models.SslState + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :ivar virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :vartype virtual_ip: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'virtual_ip': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'domain_id': {'key': 'properties.domainId', 'type': 'str'}, + 'azure_resource_name': {'key': 'properties.azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'properties.azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'properties.customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'properties.hostNameType', 'type': 'str'}, + 'ssl_state': {'key': 'properties.sslState', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'virtual_ip': {'key': 'properties.virtualIP', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + site_name: Optional[str] = None, + domain_id: Optional[str] = None, + azure_resource_name: Optional[str] = None, + azure_resource_type: Optional[Union[str, "AzureResourceType"]] = None, + custom_host_name_dns_record_type: Optional[Union[str, "CustomHostNameDnsRecordType"]] = None, + host_name_type: Optional[Union[str, "HostNameType"]] = None, + ssl_state: Optional[Union[str, "SslState"]] = None, + thumbprint: Optional[str] = None, + **kwargs + ): + super(HostNameBinding, self).__init__(kind=kind, **kwargs) + self.site_name = site_name + self.domain_id = domain_id + self.azure_resource_name = azure_resource_name + self.azure_resource_type = azure_resource_type + self.custom_host_name_dns_record_type = custom_host_name_dns_record_type + self.host_name_type = host_name_type + self.ssl_state = ssl_state + self.thumbprint = thumbprint + self.virtual_ip = None + + +class HostNameBindingCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.HostNameBinding] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HostNameBinding]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["HostNameBinding"], + **kwargs + ): + super(HostNameBindingCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class HostNameSslState(msrest.serialization.Model): + """SSL-enabled hostname. + + :param name: Hostname. + :type name: str + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_06_01.models.SslState + :param virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :type virtual_ip: str + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :param to_update: Set to :code:`true` to update existing hostname. + :type to_update: bool + :param host_type: Indicates whether the hostname is a standard or repository hostname. Possible + values include: "Standard", "Repository". + :type host_type: str or ~azure.mgmt.web.v2020_06_01.models.HostType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'ssl_state': {'key': 'sslState', 'type': 'str'}, + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'to_update': {'key': 'toUpdate', 'type': 'bool'}, + 'host_type': {'key': 'hostType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + ssl_state: Optional[Union[str, "SslState"]] = None, + virtual_ip: Optional[str] = None, + thumbprint: Optional[str] = None, + to_update: Optional[bool] = None, + host_type: Optional[Union[str, "HostType"]] = None, + **kwargs + ): + super(HostNameSslState, self).__init__(**kwargs) + self.name = name + self.ssl_state = ssl_state + self.virtual_ip = virtual_ip + self.thumbprint = thumbprint + self.to_update = to_update + self.host_type = host_type + + +class HttpLogsConfig(msrest.serialization.Model): + """Http logs configuration. + + :param file_system: Http logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemHttpLogsConfig + :param azure_blob_storage: Http logs to azure blob storage configuration. + :type azure_blob_storage: ~azure.mgmt.web.v2020_06_01.models.AzureBlobStorageHttpLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemHttpLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageHttpLogsConfig'}, + } + + def __init__( + self, + *, + file_system: Optional["FileSystemHttpLogsConfig"] = None, + azure_blob_storage: Optional["AzureBlobStorageHttpLogsConfig"] = None, + **kwargs + ): + super(HttpLogsConfig, self).__init__(**kwargs) + self.file_system = file_system + self.azure_blob_storage = azure_blob_storage + + +class HttpSettings(ProxyOnlyResource): + """HttpSettings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param require_https: + :type require_https: bool + :param routes: + :type routes: ~azure.mgmt.web.v2020_06_01.models.HttpSettingsRoutes + :param forward_proxy: + :type forward_proxy: ~azure.mgmt.web.v2020_06_01.models.ForwardProxy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'require_https': {'key': 'properties.requireHttps', 'type': 'bool'}, + 'routes': {'key': 'properties.routes', 'type': 'HttpSettingsRoutes'}, + 'forward_proxy': {'key': 'properties.forwardProxy', 'type': 'ForwardProxy'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + require_https: Optional[bool] = None, + routes: Optional["HttpSettingsRoutes"] = None, + forward_proxy: Optional["ForwardProxy"] = None, + **kwargs + ): + super(HttpSettings, self).__init__(kind=kind, **kwargs) + self.require_https = require_https + self.routes = routes + self.forward_proxy = forward_proxy + + +class HttpSettingsRoutes(ProxyOnlyResource): + """HttpSettingsRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param api_prefix: + :type api_prefix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'api_prefix': {'key': 'properties.apiPrefix', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + api_prefix: Optional[str] = None, + **kwargs + ): + super(HttpSettingsRoutes, self).__init__(kind=kind, **kwargs) + self.api_prefix = api_prefix + + +class HybridConnection(ProxyOnlyResource): + """Hybrid Connection contract. This is used to configure a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param service_bus_namespace: The name of the Service Bus namespace. + :type service_bus_namespace: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :param relay_arm_uri: The ARM URI to the Service Bus relay. + :type relay_arm_uri: str + :param hostname: The hostname of the endpoint. + :type hostname: str + :param port: The port of the endpoint. + :type port: int + :param send_key_name: The name of the Service Bus key which has Send permissions. This is used + to authenticate to Service Bus. + :type send_key_name: str + :param send_key_value: The value of the Service Bus key. This is used to authenticate to + Service Bus. In ARM this key will not be returned + normally, use the POST /listKeys API instead. + :type send_key_value: str + :param service_bus_suffix: The suffix for the service bus endpoint. By default this is + .servicebus.windows.net. + :type service_bus_suffix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'service_bus_namespace': {'key': 'properties.serviceBusNamespace', 'type': 'str'}, + 'relay_name': {'key': 'properties.relayName', 'type': 'str'}, + 'relay_arm_uri': {'key': 'properties.relayArmUri', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + 'service_bus_suffix': {'key': 'properties.serviceBusSuffix', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + service_bus_namespace: Optional[str] = None, + relay_name: Optional[str] = None, + relay_arm_uri: Optional[str] = None, + hostname: Optional[str] = None, + port: Optional[int] = None, + send_key_name: Optional[str] = None, + send_key_value: Optional[str] = None, + service_bus_suffix: Optional[str] = None, + **kwargs + ): + super(HybridConnection, self).__init__(kind=kind, **kwargs) + self.service_bus_namespace = service_bus_namespace + self.relay_name = relay_name + self.relay_arm_uri = relay_arm_uri + self.hostname = hostname + self.port = port + self.send_key_name = send_key_name + self.send_key_value = send_key_value + self.service_bus_suffix = service_bus_suffix + + +class HybridConnectionCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.HybridConnection] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HybridConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["HybridConnection"], + **kwargs + ): + super(HybridConnectionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class HybridConnectionKey(ProxyOnlyResource): + """Hybrid Connection key contract. This has the send key name and value for a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar send_key_name: The name of the send key. + :vartype send_key_name: str + :ivar send_key_value: The value of the send key. + :vartype send_key_value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'send_key_name': {'readonly': True}, + 'send_key_value': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(HybridConnectionKey, self).__init__(kind=kind, **kwargs) + self.send_key_name = None + self.send_key_value = None + + +class HybridConnectionLimits(ProxyOnlyResource): + """Hybrid Connection limits contract. This is used to return the plan limits of Hybrid Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar current: The current number of Hybrid Connections. + :vartype current: int + :ivar maximum: The maximum number of Hybrid Connections allowed. + :vartype maximum: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'current': {'readonly': True}, + 'maximum': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'current': {'key': 'properties.current', 'type': 'int'}, + 'maximum': {'key': 'properties.maximum', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(HybridConnectionLimits, self).__init__(kind=kind, **kwargs) + self.current = None + self.maximum = None + + +class Identifier(ProxyOnlyResource): + """A domain specific resource identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param value: String representation of the identity. + :type value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'value': {'key': 'properties.id', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(Identifier, self).__init__(kind=kind, **kwargs) + self.value = value + + +class IdentifierCollection(msrest.serialization.Model): + """Collection of identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Identifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Identifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Identifier"], + **kwargs + ): + super(IdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class IdentityProviders(ProxyOnlyResource): + """IdentityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param azure_active_directory: + :type azure_active_directory: ~azure.mgmt.web.v2020_06_01.models.AzureActiveDirectory + :param facebook: + :type facebook: ~azure.mgmt.web.v2020_06_01.models.Facebook + :param git_hub: + :type git_hub: ~azure.mgmt.web.v2020_06_01.models.GitHub + :param google: + :type google: ~azure.mgmt.web.v2020_06_01.models.Google + :param twitter: + :type twitter: ~azure.mgmt.web.v2020_06_01.models.Twitter + :param custom_open_id_connect_providers: Dictionary of :code:``. + :type custom_open_id_connect_providers: dict[str, + ~azure.mgmt.web.v2020_06_01.models.CustomOpenIdConnectProvider] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'facebook': {'key': 'properties.facebook', 'type': 'Facebook'}, + 'git_hub': {'key': 'properties.gitHub', 'type': 'GitHub'}, + 'google': {'key': 'properties.google', 'type': 'Google'}, + 'twitter': {'key': 'properties.twitter', 'type': 'Twitter'}, + 'custom_open_id_connect_providers': {'key': 'properties.customOpenIdConnectProviders', 'type': '{CustomOpenIdConnectProvider}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + azure_active_directory: Optional["AzureActiveDirectory"] = None, + facebook: Optional["Facebook"] = None, + git_hub: Optional["GitHub"] = None, + google: Optional["Google"] = None, + twitter: Optional["Twitter"] = None, + custom_open_id_connect_providers: Optional[Dict[str, "CustomOpenIdConnectProvider"]] = None, + **kwargs + ): + super(IdentityProviders, self).__init__(kind=kind, **kwargs) + self.azure_active_directory = azure_active_directory + self.facebook = facebook + self.git_hub = git_hub + self.google = google + self.twitter = twitter + self.custom_open_id_connect_providers = custom_open_id_connect_providers + + +class InboundEnvironmentEndpoint(msrest.serialization.Model): + """The IP Addresses and Ports that require inbound network access to and within the subnet of the App Service Environment. + + :param description: Short text describing the purpose of the network traffic. + :type description: str + :param endpoints: The IP addresses that network traffic will originate from in cidr notation. + :type endpoints: list[str] + :param ports: The ports that network traffic will arrive to the App Service Environment at. + :type ports: list[str] + """ + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[str]'}, + 'ports': {'key': 'ports', 'type': '[str]'}, + } + + def __init__( + self, + *, + description: Optional[str] = None, + endpoints: Optional[List[str]] = None, + ports: Optional[List[str]] = None, + **kwargs + ): + super(InboundEnvironmentEndpoint, self).__init__(**kwargs) + self.description = description + self.endpoints = endpoints + self.ports = ports + + +class InboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Inbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.InboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["InboundEnvironmentEndpoint"], + **kwargs + ): + super(InboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class IpSecurityRestriction(msrest.serialization.Model): + """IP security restriction on an app. + + :param ip_address: IP address the security restriction is valid for. + It can be in form of pure ipv4 address (required SubnetMask property) or + CIDR notation such as ipv4/mask (leading bit match). For CIDR, + SubnetMask property must not be specified. + :type ip_address: str + :param subnet_mask: Subnet mask for the range of IP addresses the restriction is valid for. + :type subnet_mask: str + :param vnet_subnet_resource_id: Virtual network resource id. + :type vnet_subnet_resource_id: str + :param vnet_traffic_tag: (internal) Vnet traffic tag. + :type vnet_traffic_tag: int + :param subnet_traffic_tag: (internal) Subnet traffic tag. + :type subnet_traffic_tag: int + :param action: Allow or Deny access for this IP range. + :type action: str + :param tag: Defines what this IP filter will be used for. This is to support IP filtering on + proxies. Possible values include: "Default", "XffProxy", "ServiceTag". + :type tag: str or ~azure.mgmt.web.v2020_06_01.models.IpFilterTag + :param priority: Priority of IP restriction rule. + :type priority: int + :param name: IP restriction rule name. + :type name: str + :param description: IP restriction rule description. + :type description: str + :param headers: IP restriction rule headers. + X-Forwarded-Host (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + Host#Examples). + The matching logic is .. + + + * If the property is null or empty (default), all hosts(or lack of) are allowed. + * A value is compared using ordinal-ignore-case (excluding port number). + * Subdomain wildcards are permitted but don't match the root domain. For example, + *.contoso.com matches the subdomain foo.contoso.com + but not the root domain contoso.com or multi-level foo.bar.contoso.com + * Unicode host names are allowed but are converted to Punycode for matching. + + X-Forwarded-For (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + For#Examples). + The matching logic is .. + + + * If the property is null or empty (default), any forwarded-for chains (or lack of) are + allowed. + * If any address (excluding port number) in the chain (comma separated) matches the CIDR + defined by the property. + + X-Azure-FDID and X-FD-HealthProbe. + The matching logic is exact match. + :type headers: dict[str, list[str]] + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'subnet_mask': {'key': 'subnetMask', 'type': 'str'}, + 'vnet_subnet_resource_id': {'key': 'vnetSubnetResourceId', 'type': 'str'}, + 'vnet_traffic_tag': {'key': 'vnetTrafficTag', 'type': 'int'}, + 'subnet_traffic_tag': {'key': 'subnetTrafficTag', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '{[str]}'}, + } + + def __init__( + self, + *, + ip_address: Optional[str] = None, + subnet_mask: Optional[str] = None, + vnet_subnet_resource_id: Optional[str] = None, + vnet_traffic_tag: Optional[int] = None, + subnet_traffic_tag: Optional[int] = None, + action: Optional[str] = None, + tag: Optional[Union[str, "IpFilterTag"]] = None, + priority: Optional[int] = None, + name: Optional[str] = None, + description: Optional[str] = None, + headers: Optional[Dict[str, List[str]]] = None, + **kwargs + ): + super(IpSecurityRestriction, self).__init__(**kwargs) + self.ip_address = ip_address + self.subnet_mask = subnet_mask + self.vnet_subnet_resource_id = vnet_subnet_resource_id + self.vnet_traffic_tag = vnet_traffic_tag + self.subnet_traffic_tag = subnet_traffic_tag + self.action = action + self.tag = tag + self.priority = priority + self.name = name + self.description = description + self.headers = headers + + +class JwtClaimChecks(ProxyOnlyResource): + """JwtClaimChecks. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param allowed_groups: + :type allowed_groups: list[str] + :param allowed_client_applications: + :type allowed_client_applications: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_groups': {'key': 'properties.allowedGroups', 'type': '[str]'}, + 'allowed_client_applications': {'key': 'properties.allowedClientApplications', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allowed_groups: Optional[List[str]] = None, + allowed_client_applications: Optional[List[str]] = None, + **kwargs + ): + super(JwtClaimChecks, self).__init__(kind=kind, **kwargs) + self.allowed_groups = allowed_groups + self.allowed_client_applications = allowed_client_applications + + +class KeyInfo(msrest.serialization.Model): + """Function key info. + + :param name: Key name. + :type name: str + :param value: Key value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(KeyInfo, self).__init__(**kwargs) + self.name = name + self.value = value + + +class LocalizableString(msrest.serialization.Model): + """Localizable string object containing the name and a localized value. + + :param value: Non-localized name. + :type value: str + :param localized_value: Localized name. + :type localized_value: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[str] = None, + localized_value: Optional[str] = None, + **kwargs + ): + super(LocalizableString, self).__init__(**kwargs) + self.value = value + self.localized_value = localized_value + + +class Login(ProxyOnlyResource): + """Login. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param routes: + :type routes: ~azure.mgmt.web.v2020_06_01.models.LoginRoutes + :param token_store: + :type token_store: ~azure.mgmt.web.v2020_06_01.models.TokenStore + :param preserve_url_fragments_for_logins: + :type preserve_url_fragments_for_logins: bool + :param allowed_external_redirect_urls: + :type allowed_external_redirect_urls: list[str] + :param cookie_expiration: + :type cookie_expiration: ~azure.mgmt.web.v2020_06_01.models.CookieExpiration + :param nonce: + :type nonce: ~azure.mgmt.web.v2020_06_01.models.Nonce + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': 'LoginRoutes'}, + 'token_store': {'key': 'properties.tokenStore', 'type': 'TokenStore'}, + 'preserve_url_fragments_for_logins': {'key': 'properties.preserveUrlFragmentsForLogins', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'cookie_expiration': {'key': 'properties.cookieExpiration', 'type': 'CookieExpiration'}, + 'nonce': {'key': 'properties.nonce', 'type': 'Nonce'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + routes: Optional["LoginRoutes"] = None, + token_store: Optional["TokenStore"] = None, + preserve_url_fragments_for_logins: Optional[bool] = None, + allowed_external_redirect_urls: Optional[List[str]] = None, + cookie_expiration: Optional["CookieExpiration"] = None, + nonce: Optional["Nonce"] = None, + **kwargs + ): + super(Login, self).__init__(kind=kind, **kwargs) + self.routes = routes + self.token_store = token_store + self.preserve_url_fragments_for_logins = preserve_url_fragments_for_logins + self.allowed_external_redirect_urls = allowed_external_redirect_urls + self.cookie_expiration = cookie_expiration + self.nonce = nonce + + +class LoginRoutes(ProxyOnlyResource): + """LoginRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param logout_endpoint: + :type logout_endpoint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'logout_endpoint': {'key': 'properties.logoutEndpoint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + logout_endpoint: Optional[str] = None, + **kwargs + ): + super(LoginRoutes, self).__init__(kind=kind, **kwargs) + self.logout_endpoint = logout_endpoint + + +class LoginScopes(ProxyOnlyResource): + """LoginScopes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + scopes: Optional[List[str]] = None, + **kwargs + ): + super(LoginScopes, self).__init__(kind=kind, **kwargs) + self.scopes = scopes + + +class LogSpecification(msrest.serialization.Model): + """Log Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param blob_duration: + :type blob_duration: str + :param log_filter_pattern: + :type log_filter_pattern: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + 'log_filter_pattern': {'key': 'logFilterPattern', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + blob_duration: Optional[str] = None, + log_filter_pattern: Optional[str] = None, + **kwargs + ): + super(LogSpecification, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.blob_duration = blob_duration + self.log_filter_pattern = log_filter_pattern + + +class ManagedServiceIdentity(msrest.serialization.Model): + """Managed service identity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of managed service identity. Possible values include: "SystemAssigned", + "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentityType + :ivar tenant_id: Tenant of managed service identity. + :vartype tenant_id: str + :ivar principal_id: Principal Id of managed service identity. + :vartype principal_id: str + :param user_assigned_identities: The list of user assigned identities associated with the + resource. The user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. + :type user_assigned_identities: dict[str, + ~azure.mgmt.web.v2020_06_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _validation = { + 'tenant_id': {'readonly': True}, + 'principal_id': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ManagedServiceIdentityType"]] = None, + user_assigned_identities: Optional[Dict[str, "Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties"]] = None, + **kwargs + ): + super(ManagedServiceIdentity, self).__init__(**kwargs) + self.type = type + self.tenant_id = None + self.principal_id = None + self.user_assigned_identities = user_assigned_identities + + +class MetricAvailability(msrest.serialization.Model): + """Retention policy of a resource metric. + + :param time_grain: + :type time_grain: str + :param blob_duration: + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + *, + time_grain: Optional[str] = None, + blob_duration: Optional[str] = None, + **kwargs + ): + super(MetricAvailability, self).__init__(**kwargs) + self.time_grain = time_grain + self.blob_duration = blob_duration + + +class MetricSpecification(msrest.serialization.Model): + """Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param display_description: + :type display_description: str + :param unit: + :type unit: str + :param aggregation_type: + :type aggregation_type: str + :param supports_instance_level_aggregation: + :type supports_instance_level_aggregation: bool + :param enable_regional_mdm_account: + :type enable_regional_mdm_account: bool + :param source_mdm_account: + :type source_mdm_account: str + :param source_mdm_namespace: + :type source_mdm_namespace: str + :param metric_filter_pattern: + :type metric_filter_pattern: str + :param fill_gap_with_zero: + :type fill_gap_with_zero: bool + :param is_internal: + :type is_internal: bool + :param dimensions: + :type dimensions: list[~azure.mgmt.web.v2020_06_01.models.Dimension] + :param category: + :type category: str + :param availabilities: + :type availabilities: list[~azure.mgmt.web.v2020_06_01.models.MetricAvailability] + :param supported_time_grain_types: + :type supported_time_grain_types: list[str] + :param supported_aggregation_types: + :type supported_aggregation_types: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'display_description': {'key': 'displayDescription', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'aggregation_type': {'key': 'aggregationType', 'type': 'str'}, + 'supports_instance_level_aggregation': {'key': 'supportsInstanceLevelAggregation', 'type': 'bool'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'category': {'key': 'category', 'type': 'str'}, + 'availabilities': {'key': 'availabilities', 'type': '[MetricAvailability]'}, + 'supported_time_grain_types': {'key': 'supportedTimeGrainTypes', 'type': '[str]'}, + 'supported_aggregation_types': {'key': 'supportedAggregationTypes', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + display_description: Optional[str] = None, + unit: Optional[str] = None, + aggregation_type: Optional[str] = None, + supports_instance_level_aggregation: Optional[bool] = None, + enable_regional_mdm_account: Optional[bool] = None, + source_mdm_account: Optional[str] = None, + source_mdm_namespace: Optional[str] = None, + metric_filter_pattern: Optional[str] = None, + fill_gap_with_zero: Optional[bool] = None, + is_internal: Optional[bool] = None, + dimensions: Optional[List["Dimension"]] = None, + category: Optional[str] = None, + availabilities: Optional[List["MetricAvailability"]] = None, + supported_time_grain_types: Optional[List[str]] = None, + supported_aggregation_types: Optional[List[str]] = None, + **kwargs + ): + super(MetricSpecification, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.display_description = display_description + self.unit = unit + self.aggregation_type = aggregation_type + self.supports_instance_level_aggregation = supports_instance_level_aggregation + self.enable_regional_mdm_account = enable_regional_mdm_account + self.source_mdm_account = source_mdm_account + self.source_mdm_namespace = source_mdm_namespace + self.metric_filter_pattern = metric_filter_pattern + self.fill_gap_with_zero = fill_gap_with_zero + self.is_internal = is_internal + self.dimensions = dimensions + self.category = category + self.availabilities = availabilities + self.supported_time_grain_types = supported_time_grain_types + self.supported_aggregation_types = supported_aggregation_types + + +class MigrateMySqlRequest(ProxyOnlyResource): + """MySQL migration request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param connection_string: Connection string to the remote MySQL database. + :type connection_string: str + :param migration_type: The type of migration operation to be done. Possible values include: + "LocalToRemote", "RemoteToLocal". + :type migration_type: str or ~azure.mgmt.web.v2020_06_01.models.MySqlMigrationType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'migration_type': {'key': 'properties.migrationType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + connection_string: Optional[str] = None, + migration_type: Optional[Union[str, "MySqlMigrationType"]] = None, + **kwargs + ): + super(MigrateMySqlRequest, self).__init__(kind=kind, **kwargs) + self.connection_string = connection_string + self.migration_type = migration_type + + +class MigrateMySqlStatus(ProxyOnlyResource): + """MySQL migration status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar migration_operation_status: Status of the migration task. Possible values include: + "InProgress", "Failed", "Succeeded", "TimedOut", "Created". + :vartype migration_operation_status: str or ~azure.mgmt.web.v2020_06_01.models.OperationStatus + :ivar operation_id: Operation ID for the migration task. + :vartype operation_id: str + :ivar local_my_sql_enabled: True if the web app has in app MySql enabled. + :vartype local_my_sql_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'migration_operation_status': {'readonly': True}, + 'operation_id': {'readonly': True}, + 'local_my_sql_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'migration_operation_status': {'key': 'properties.migrationOperationStatus', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MigrateMySqlStatus, self).__init__(kind=kind, **kwargs) + self.migration_operation_status = None + self.operation_id = None + self.local_my_sql_enabled = None + + +class MSDeploy(ProxyOnlyResource): + """MSDeploy ARM PUT information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param package_uri: Package URI. + :type package_uri: str + :param connection_string: SQL Connection String. + :type connection_string: str + :param db_type: Database Type. + :type db_type: str + :param set_parameters_xml_file_uri: URI of MSDeploy Parameters file. Must not be set if + SetParameters is used. + :type set_parameters_xml_file_uri: str + :param set_parameters: MSDeploy Parameters. Must not be set if SetParametersXmlFileUri is used. + :type set_parameters: dict[str, str] + :param skip_app_data: Controls whether the MSDeploy operation skips the App_Data directory. + If set to :code:`true`, the existing App_Data directory on the destination + will not be deleted, and any App_Data directory in the source will be ignored. + Setting is :code:`false` by default. + :type skip_app_data: bool + :param app_offline: Sets the AppOffline rule while the MSDeploy operation executes. + Setting is :code:`false` by default. + :type app_offline: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'package_uri': {'key': 'properties.packageUri', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'db_type': {'key': 'properties.dbType', 'type': 'str'}, + 'set_parameters_xml_file_uri': {'key': 'properties.setParametersXmlFileUri', 'type': 'str'}, + 'set_parameters': {'key': 'properties.setParameters', 'type': '{str}'}, + 'skip_app_data': {'key': 'properties.skipAppData', 'type': 'bool'}, + 'app_offline': {'key': 'properties.appOffline', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + package_uri: Optional[str] = None, + connection_string: Optional[str] = None, + db_type: Optional[str] = None, + set_parameters_xml_file_uri: Optional[str] = None, + set_parameters: Optional[Dict[str, str]] = None, + skip_app_data: Optional[bool] = None, + app_offline: Optional[bool] = None, + **kwargs + ): + super(MSDeploy, self).__init__(kind=kind, **kwargs) + self.package_uri = package_uri + self.connection_string = connection_string + self.db_type = db_type + self.set_parameters_xml_file_uri = set_parameters_xml_file_uri + self.set_parameters = set_parameters + self.skip_app_data = skip_app_data + self.app_offline = app_offline + + +class MSDeployLog(ProxyOnlyResource): + """MSDeploy log. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar entries: List of log entry messages. + :vartype entries: list[~azure.mgmt.web.v2020_06_01.models.MSDeployLogEntry] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'entries': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'entries': {'key': 'properties.entries', 'type': '[MSDeployLogEntry]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MSDeployLog, self).__init__(kind=kind, **kwargs) + self.entries = None + + +class MSDeployLogEntry(msrest.serialization.Model): + """MSDeploy log entry. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time: Timestamp of log entry. + :vartype time: ~datetime.datetime + :ivar type: Log entry type. Possible values include: "Message", "Warning", "Error". + :vartype type: str or ~azure.mgmt.web.v2020_06_01.models.MSDeployLogEntryType + :ivar message: Log entry message. + :vartype message: str + """ + + _validation = { + 'time': {'readonly': True}, + 'type': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'type': {'key': 'type', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLogEntry, self).__init__(**kwargs) + self.time = None + self.type = None + self.message = None + + +class MSDeployStatus(ProxyOnlyResource): + """MSDeploy ARM response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar deployer: Username of deployer. + :vartype deployer: str + :ivar provisioning_state: Provisioning state. Possible values include: "accepted", "running", + "succeeded", "failed", "canceled". + :vartype provisioning_state: str or + ~azure.mgmt.web.v2020_06_01.models.MSDeployProvisioningState + :ivar start_time: Start time of deploy operation. + :vartype start_time: ~datetime.datetime + :ivar end_time: End time of deploy operation. + :vartype end_time: ~datetime.datetime + :ivar complete: Whether the deployment operation has completed. + :vartype complete: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'deployer': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'end_time': {'readonly': True}, + 'complete': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'complete': {'key': 'properties.complete', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MSDeployStatus, self).__init__(kind=kind, **kwargs) + self.deployer = None + self.provisioning_state = None + self.start_time = None + self.end_time = None + self.complete = None + + +class NameIdentifier(msrest.serialization.Model): + """Identifies an object. + + :param name: Name of the object. + :type name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + **kwargs + ): + super(NameIdentifier, self).__init__(**kwargs) + self.name = name + + +class NameIdentifierCollection(msrest.serialization.Model): + """Collection of domain name identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.NameIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NameIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["NameIdentifier"], + **kwargs + ): + super(NameIdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NameValuePair(msrest.serialization.Model): + """Name value pair. + + :param name: Pair name. + :type name: str + :param value: Pair value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(NameValuePair, self).__init__(**kwargs) + self.name = name + self.value = value + + +class NetworkAccessControlEntry(msrest.serialization.Model): + """Network access control entry. + + :param action: Action object. Possible values include: "Permit", "Deny". + :type action: str or ~azure.mgmt.web.v2020_06_01.models.AccessControlEntryAction + :param description: Description of network access control entry. + :type description: str + :param order: Order of precedence. + :type order: int + :param remote_subnet: Remote subnet. + :type remote_subnet: str + """ + + _attribute_map = { + 'action': {'key': 'action', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'int'}, + 'remote_subnet': {'key': 'remoteSubnet', 'type': 'str'}, + } + + def __init__( + self, + *, + action: Optional[Union[str, "AccessControlEntryAction"]] = None, + description: Optional[str] = None, + order: Optional[int] = None, + remote_subnet: Optional[str] = None, + **kwargs + ): + super(NetworkAccessControlEntry, self).__init__(**kwargs) + self.action = action + self.description = description + self.order = order + self.remote_subnet = remote_subnet + + +class NetworkFeatures(ProxyOnlyResource): + """Full view of network features for an app (presently VNET integration and Hybrid Connections). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar virtual_network_name: The Virtual Network name. + :vartype virtual_network_name: str + :ivar virtual_network_connection: The Virtual Network summary view. + :vartype virtual_network_connection: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :ivar hybrid_connections: The Hybrid Connections summary view. + :vartype hybrid_connections: + list[~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity] + :ivar hybrid_connections_v2: The Hybrid Connection V2 (Service Bus) view. + :vartype hybrid_connections_v2: list[~azure.mgmt.web.v2020_06_01.models.HybridConnection] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'virtual_network_name': {'readonly': True}, + 'virtual_network_connection': {'readonly': True}, + 'hybrid_connections': {'readonly': True}, + 'hybrid_connections_v2': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'virtual_network_name': {'key': 'properties.virtualNetworkName', 'type': 'str'}, + 'virtual_network_connection': {'key': 'properties.virtualNetworkConnection', 'type': 'VnetInfo'}, + 'hybrid_connections': {'key': 'properties.hybridConnections', 'type': '[RelayServiceConnectionEntity]'}, + 'hybrid_connections_v2': {'key': 'properties.hybridConnectionsV2', 'type': '[HybridConnection]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(NetworkFeatures, self).__init__(kind=kind, **kwargs) + self.virtual_network_name = None + self.virtual_network_connection = None + self.hybrid_connections = None + self.hybrid_connections_v2 = None + + +class NetworkTrace(msrest.serialization.Model): + """Network trace. + + :param path: Local file path for the captured network trace file. + :type path: str + :param status: Current status of the network trace operation, same as Operation.Status + (InProgress/Succeeded/Failed). + :type status: str + :param message: Detailed message of a network trace operation, e.g. error message in case of + failure. + :type message: str + """ + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + path: Optional[str] = None, + status: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(NetworkTrace, self).__init__(**kwargs) + self.path = path + self.status = status + self.message = message + + +class Nonce(ProxyOnlyResource): + """Nonce. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param validate_nonce: + :type validate_nonce: bool + :param nonce_expiration_interval: + :type nonce_expiration_interval: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'validate_nonce': {'key': 'properties.validateNonce', 'type': 'bool'}, + 'nonce_expiration_interval': {'key': 'properties.nonceExpirationInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + validate_nonce: Optional[bool] = None, + nonce_expiration_interval: Optional[str] = None, + **kwargs + ): + super(Nonce, self).__init__(kind=kind, **kwargs) + self.validate_nonce = validate_nonce + self.nonce_expiration_interval = nonce_expiration_interval + + +class OpenIdConnectClientCredential(ProxyOnlyResource): + """OpenIdConnectClientCredential. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar method: Default value: "ClientSecretPost". + :vartype method: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'method': {'constant': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'method': {'key': 'properties.method', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + method = "ClientSecretPost" + + def __init__( + self, + *, + kind: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(OpenIdConnectClientCredential, self).__init__(kind=kind, **kwargs) + self.client_secret_setting_name = client_secret_setting_name + + +class OpenIdConnectConfig(ProxyOnlyResource): + """OpenIdConnectConfig. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param authorization_endpoint: + :type authorization_endpoint: str + :param token_endpoint: + :type token_endpoint: str + :param issuer: + :type issuer: str + :param certification_uri: + :type certification_uri: str + :param well_known_open_id_configuration: + :type well_known_open_id_configuration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'authorization_endpoint': {'key': 'properties.authorizationEndpoint', 'type': 'str'}, + 'token_endpoint': {'key': 'properties.tokenEndpoint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'certification_uri': {'key': 'properties.certificationUri', 'type': 'str'}, + 'well_known_open_id_configuration': {'key': 'properties.wellKnownOpenIdConfiguration', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + authorization_endpoint: Optional[str] = None, + token_endpoint: Optional[str] = None, + issuer: Optional[str] = None, + certification_uri: Optional[str] = None, + well_known_open_id_configuration: Optional[str] = None, + **kwargs + ): + super(OpenIdConnectConfig, self).__init__(kind=kind, **kwargs) + self.authorization_endpoint = authorization_endpoint + self.token_endpoint = token_endpoint + self.issuer = issuer + self.certification_uri = certification_uri + self.well_known_open_id_configuration = well_known_open_id_configuration + + +class OpenIdConnectLogin(ProxyOnlyResource): + """OpenIdConnectLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param name_claim_type: + :type name_claim_type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name_claim_type': {'key': 'properties.nameClaimType', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_claim_type: Optional[str] = None, + scopes: Optional[List[str]] = None, + **kwargs + ): + super(OpenIdConnectLogin, self).__init__(kind=kind, **kwargs) + self.name_claim_type = name_claim_type + self.scopes = scopes + + +class OpenIdConnectRegistration(ProxyOnlyResource): + """OpenIdConnectRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param client_id: + :type client_id: str + :param client_credential: + :type client_credential: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectClientCredential + :param open_id_connect_configuration: + :type open_id_connect_configuration: ~azure.mgmt.web.v2020_06_01.models.OpenIdConnectConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_credential': {'key': 'properties.clientCredential', 'type': 'OpenIdConnectClientCredential'}, + 'open_id_connect_configuration': {'key': 'properties.openIdConnectConfiguration', 'type': 'OpenIdConnectConfig'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + client_id: Optional[str] = None, + client_credential: Optional["OpenIdConnectClientCredential"] = None, + open_id_connect_configuration: Optional["OpenIdConnectConfig"] = None, + **kwargs + ): + super(OpenIdConnectRegistration, self).__init__(kind=kind, **kwargs) + self.client_id = client_id + self.client_credential = client_credential + self.open_id_connect_configuration = open_id_connect_configuration + + +class Operation(msrest.serialization.Model): + """An operation on a resource. + + :param id: Operation ID. + :type id: str + :param name: Operation name. + :type name: str + :param status: The current status of the operation. Possible values include: "InProgress", + "Failed", "Succeeded", "TimedOut", "Created". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.OperationStatus + :param errors: Any errors associate with the operation. + :type errors: list[~azure.mgmt.web.v2020_06_01.models.ErrorEntity] + :param created_time: Time when operation has started. + :type created_time: ~datetime.datetime + :param modified_time: Time when operation has been updated. + :type modified_time: ~datetime.datetime + :param expiration_time: Time when operation will expire. + :type expiration_time: ~datetime.datetime + :param geo_master_operation_id: Applicable only for stamp operation ids. + :type geo_master_operation_id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'errors': {'key': 'errors', 'type': '[ErrorEntity]'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'modified_time': {'key': 'modifiedTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'expirationTime', 'type': 'iso-8601'}, + 'geo_master_operation_id': {'key': 'geoMasterOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + status: Optional[Union[str, "OperationStatus"]] = None, + errors: Optional[List["ErrorEntity"]] = None, + created_time: Optional[datetime.datetime] = None, + modified_time: Optional[datetime.datetime] = None, + expiration_time: Optional[datetime.datetime] = None, + geo_master_operation_id: Optional[str] = None, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.id = id + self.name = name + self.status = status + self.errors = errors + self.created_time = created_time + self.modified_time = modified_time + self.expiration_time = expiration_time + self.geo_master_operation_id = geo_master_operation_id + + +class OutboundEnvironmentEndpoint(msrest.serialization.Model): + """Endpoints accessed for a common purpose that the App Service Environment requires outbound network access to. + + :param category: The type of service accessed by the App Service Environment, e.g., Azure + Storage, Azure SQL Database, and Azure Active Directory. + :type category: str + :param endpoints: The endpoints that the App Service Environment reaches the service at. + :type endpoints: list[~azure.mgmt.web.v2020_06_01.models.EndpointDependency] + """ + + _attribute_map = { + 'category': {'key': 'category', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[EndpointDependency]'}, + } + + def __init__( + self, + *, + category: Optional[str] = None, + endpoints: Optional[List["EndpointDependency"]] = None, + **kwargs + ): + super(OutboundEnvironmentEndpoint, self).__init__(**kwargs) + self.category = category + self.endpoints = endpoints + + +class OutboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Outbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.OutboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["OutboundEnvironmentEndpoint"], + **kwargs + ): + super(OutboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PerfMonCounterCollection(msrest.serialization.Model): + """Collection of performance monitor counters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PerfMonResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PerfMonResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PerfMonResponse"], + **kwargs + ): + super(PerfMonCounterCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PerfMonResponse(msrest.serialization.Model): + """Performance monitor API response. + + :param code: The response code. + :type code: str + :param message: The message. + :type message: str + :param data: The performance monitor counters. + :type data: ~azure.mgmt.web.v2020_06_01.models.PerfMonSet + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'data': {'key': 'data', 'type': 'PerfMonSet'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + data: Optional["PerfMonSet"] = None, + **kwargs + ): + super(PerfMonResponse, self).__init__(**kwargs) + self.code = code + self.message = message + self.data = data + + +class PerfMonSample(msrest.serialization.Model): + """Performance monitor sample in a set. + + :param time: Point in time for which counter was measured. + :type time: ~datetime.datetime + :param instance_name: Name of the server on which the measurement is made. + :type instance_name: str + :param value: Value of counter at a certain time. + :type value: float + """ + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'instance_name': {'key': 'instanceName', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'float'}, + } + + def __init__( + self, + *, + time: Optional[datetime.datetime] = None, + instance_name: Optional[str] = None, + value: Optional[float] = None, + **kwargs + ): + super(PerfMonSample, self).__init__(**kwargs) + self.time = time + self.instance_name = instance_name + self.value = value + + +class PerfMonSet(msrest.serialization.Model): + """Metric information. + + :param name: Unique key name of the counter. + :type name: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. + :type time_grain: str + :param values: Collection of workers that are active during this time. + :type values: list[~azure.mgmt.web.v2020_06_01.models.PerfMonSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[PerfMonSample]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + values: Optional[List["PerfMonSample"]] = None, + **kwargs + ): + super(PerfMonSet, self).__init__(**kwargs) + self.name = name + self.start_time = start_time + self.end_time = end_time + self.time_grain = time_grain + self.values = values + + +class PremierAddOn(Resource): + """Premier add-on. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOn, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PremierAddOnOffer(ProxyOnlyResource): + """Premier add-on offer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on offer Product. + :type product: str + :param vendor: Premier add on offer Vendor. + :type vendor: str + :param promo_code_required: :code:`true` if promotion code is required; otherwise, + :code:`false`. + :type promo_code_required: bool + :param quota: Premier add on offer Quota. + :type quota: int + :param web_hosting_plan_restrictions: App Service plans this offer is restricted to. Possible + values include: "None", "Free", "Shared", "Basic", "Standard", "Premium". + :type web_hosting_plan_restrictions: str or + ~azure.mgmt.web.v2020_06_01.models.AppServicePlanRestrictions + :param privacy_policy_url: Privacy policy URL. + :type privacy_policy_url: str + :param legal_terms_url: Legal terms URL. + :type legal_terms_url: str + :param marketplace_publisher: Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'promo_code_required': {'key': 'properties.promoCodeRequired', 'type': 'bool'}, + 'quota': {'key': 'properties.quota', 'type': 'int'}, + 'web_hosting_plan_restrictions': {'key': 'properties.webHostingPlanRestrictions', 'type': 'str'}, + 'privacy_policy_url': {'key': 'properties.privacyPolicyUrl', 'type': 'str'}, + 'legal_terms_url': {'key': 'properties.legalTermsUrl', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + promo_code_required: Optional[bool] = None, + quota: Optional[int] = None, + web_hosting_plan_restrictions: Optional[Union[str, "AppServicePlanRestrictions"]] = None, + privacy_policy_url: Optional[str] = None, + legal_terms_url: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOnOffer, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.promo_code_required = promo_code_required + self.quota = quota + self.web_hosting_plan_restrictions = web_hosting_plan_restrictions + self.privacy_policy_url = privacy_policy_url + self.legal_terms_url = legal_terms_url + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PremierAddOnOfferCollection(msrest.serialization.Model): + """Collection of premier add-on offers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOffer] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PremierAddOnOffer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PremierAddOnOffer"], + **kwargs + ): + super(PremierAddOnOfferCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PremierAddOnPatchResource(ProxyOnlyResource): + """ARM resource for a PremierAddOn. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOnPatchResource, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PrivateAccess(ProxyOnlyResource): + """Description of the parameters of Private Access for a Web Site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: Whether private access is enabled or not. + :type enabled: bool + :param virtual_networks: The Virtual Networks (and subnets) allowed to access the site + privately. + :type virtual_networks: list[~azure.mgmt.web.v2020_06_01.models.PrivateAccessVirtualNetwork] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[PrivateAccessVirtualNetwork]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + virtual_networks: Optional[List["PrivateAccessVirtualNetwork"]] = None, + **kwargs + ): + super(PrivateAccess, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.virtual_networks = virtual_networks + + +class PrivateAccessSubnet(msrest.serialization.Model): + """Description of a Virtual Network subnet that is useable for private site access. + + :param name: The name of the subnet. + :type name: str + :param key: The key (ID) of the subnet. + :type key: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + key: Optional[int] = None, + **kwargs + ): + super(PrivateAccessSubnet, self).__init__(**kwargs) + self.name = name + self.key = key + + +class PrivateAccessVirtualNetwork(msrest.serialization.Model): + """Description of a Virtual Network that is useable for private site access. + + :param name: The name of the Virtual Network. + :type name: str + :param key: The key (ID) of the Virtual Network. + :type key: int + :param resource_id: The ARM uri of the Virtual Network. + :type resource_id: str + :param subnets: A List of subnets that access is allowed to on this Virtual Network. An empty + array (but not null) is interpreted to mean that all subnets are allowed within this Virtual + Network. + :type subnets: list[~azure.mgmt.web.v2020_06_01.models.PrivateAccessSubnet] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'subnets': {'key': 'subnets', 'type': '[PrivateAccessSubnet]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + key: Optional[int] = None, + resource_id: Optional[str] = None, + subnets: Optional[List["PrivateAccessSubnet"]] = None, + **kwargs + ): + super(PrivateAccessVirtualNetwork, self).__init__(**kwargs) + self.name = name + self.key = key + self.resource_id = resource_id + self.subnets = subnets + + +class PrivateEndpointConnectionResource(ProxyOnlyResource): + """Private Endpoint Connection ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar provisioning_state: + :vartype provisioning_state: str + :param private_endpoint: PrivateEndpoint of a remote private endpoint connection. + :type private_endpoint: ~azure.mgmt.web.v2020_06_01.models.ArmIdWrapper + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'ArmIdWrapper'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + private_endpoint: Optional["ArmIdWrapper"] = None, + private_link_service_connection_state: Optional["PrivateLinkConnectionState"] = None, + **kwargs + ): + super(PrivateEndpointConnectionResource, self).__init__(kind=kind, **kwargs) + self.provisioning_state = None + self.private_endpoint = private_endpoint + self.private_link_service_connection_state = private_link_service_connection_state + + +class PrivateLinkConnectionApprovalRequestResource(ProxyOnlyResource): + """Private Endpoint Connection Approval ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + private_link_service_connection_state: Optional["PrivateLinkConnectionState"] = None, + **kwargs + ): + super(PrivateLinkConnectionApprovalRequestResource, self).__init__(kind=kind, **kwargs) + self.private_link_service_connection_state = private_link_service_connection_state + + +class PrivateLinkConnectionState(msrest.serialization.Model): + """The state of a private link connection. + + :param status: Status of a private link connection. + :type status: str + :param description: Description of a private link connection. + :type description: str + :param actions_required: ActionsRequired for a private link connection. + :type actions_required: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'actions_required': {'key': 'actionsRequired', 'type': 'str'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + description: Optional[str] = None, + actions_required: Optional[str] = None, + **kwargs + ): + super(PrivateLinkConnectionState, self).__init__(**kwargs) + self.status = status + self.description = description + self.actions_required = actions_required + + +class PrivateLinkResource(msrest.serialization.Model): + """A private link resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. + :type id: str + :param name: Required. Name of a private link resource. + :type name: str + :param type: Required. + :type type: str + :param properties: Required. Properties of a private link resource. + :type properties: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkResourceProperties + """ + + _validation = { + 'id': {'required': True}, + 'name': {'required': True}, + 'type': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'PrivateLinkResourceProperties'}, + } + + def __init__( + self, + *, + id: str, + name: str, + type: str, + properties: "PrivateLinkResourceProperties", + **kwargs + ): + super(PrivateLinkResource, self).__init__(**kwargs) + self.id = id + self.name = name + self.type = type + self.properties = properties + + +class PrivateLinkResourceProperties(msrest.serialization.Model): + """Properties of a private link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: GroupId of a private link resource. + :vartype group_id: str + :ivar required_members: RequiredMembers of a private link resource. + :vartype required_members: list[str] + :ivar required_zone_names: RequiredZoneNames of a private link resource. + :vartype required_zone_names: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + 'required_zone_names': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_members': {'key': 'requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourceProperties, self).__init__(**kwargs) + self.group_id = None + self.required_members = None + self.required_zone_names = None + + +class PrivateLinkResourcesWrapper(msrest.serialization.Model): + """Wrapper for a collection of private link resources. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PrivateLinkResource] + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkResource]'}, + } + + def __init__( + self, + *, + value: List["PrivateLinkResource"], + **kwargs + ): + super(PrivateLinkResourcesWrapper, self).__init__(**kwargs) + self.value = value + + +class ProcessInfo(ProxyOnlyResource): + """Process Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar identifier: ARM Identifier for deployment. + :vartype identifier: int + :param deployment_name: Deployment name. + :type deployment_name: str + :param href: HRef URI. + :type href: str + :param minidump: Minidump URI. + :type minidump: str + :param is_profile_running: Is profile running?. + :type is_profile_running: bool + :param is_iis_profile_running: Is the IIS Profile running?. + :type is_iis_profile_running: bool + :param iis_profile_timeout_in_seconds: IIS Profile timeout (seconds). + :type iis_profile_timeout_in_seconds: float + :param parent: Parent process. + :type parent: str + :param children: Child process list. + :type children: list[str] + :param threads: Thread list. + :type threads: list[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfo] + :param open_file_handles: List of open files. + :type open_file_handles: list[str] + :param modules: List of modules. + :type modules: list[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo] + :param file_name: File name of this process. + :type file_name: str + :param command_line: Command line. + :type command_line: str + :param user_name: User name. + :type user_name: str + :param handle_count: Handle count. + :type handle_count: int + :param module_count: Module count. + :type module_count: int + :param thread_count: Thread count. + :type thread_count: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_cpu_time: Total CPU time. + :type total_cpu_time: str + :param user_cpu_time: User CPU time. + :type user_cpu_time: str + :param privileged_cpu_time: Privileged CPU time. + :type privileged_cpu_time: str + :param working_set: Working set. + :type working_set: long + :param peak_working_set: Peak working set. + :type peak_working_set: long + :param private_memory: Private memory size. + :type private_memory: long + :param virtual_memory: Virtual memory size. + :type virtual_memory: long + :param peak_virtual_memory: Peak virtual memory usage. + :type peak_virtual_memory: long + :param paged_system_memory: Paged system memory. + :type paged_system_memory: long + :param non_paged_system_memory: Non-paged system memory. + :type non_paged_system_memory: long + :param paged_memory: Paged memory. + :type paged_memory: long + :param peak_paged_memory: Peak paged memory. + :type peak_paged_memory: long + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + :param environment_variables: List of environment variables. + :type environment_variables: dict[str, str] + :param is_scm_site: Is this the SCM site?. + :type is_scm_site: bool + :param is_webjob: Is this a Web Job?. + :type is_webjob: bool + :param description: Description of process. + :type description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'deployment_name': {'key': 'properties.deployment_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'minidump': {'key': 'properties.minidump', 'type': 'str'}, + 'is_profile_running': {'key': 'properties.is_profile_running', 'type': 'bool'}, + 'is_iis_profile_running': {'key': 'properties.is_iis_profile_running', 'type': 'bool'}, + 'iis_profile_timeout_in_seconds': {'key': 'properties.iis_profile_timeout_in_seconds', 'type': 'float'}, + 'parent': {'key': 'properties.parent', 'type': 'str'}, + 'children': {'key': 'properties.children', 'type': '[str]'}, + 'threads': {'key': 'properties.threads', 'type': '[ProcessThreadInfo]'}, + 'open_file_handles': {'key': 'properties.open_file_handles', 'type': '[str]'}, + 'modules': {'key': 'properties.modules', 'type': '[ProcessModuleInfo]'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'command_line': {'key': 'properties.command_line', 'type': 'str'}, + 'user_name': {'key': 'properties.user_name', 'type': 'str'}, + 'handle_count': {'key': 'properties.handle_count', 'type': 'int'}, + 'module_count': {'key': 'properties.module_count', 'type': 'int'}, + 'thread_count': {'key': 'properties.thread_count', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_cpu_time': {'key': 'properties.total_cpu_time', 'type': 'str'}, + 'user_cpu_time': {'key': 'properties.user_cpu_time', 'type': 'str'}, + 'privileged_cpu_time': {'key': 'properties.privileged_cpu_time', 'type': 'str'}, + 'working_set': {'key': 'properties.working_set', 'type': 'long'}, + 'peak_working_set': {'key': 'properties.peak_working_set', 'type': 'long'}, + 'private_memory': {'key': 'properties.private_memory', 'type': 'long'}, + 'virtual_memory': {'key': 'properties.virtual_memory', 'type': 'long'}, + 'peak_virtual_memory': {'key': 'properties.peak_virtual_memory', 'type': 'long'}, + 'paged_system_memory': {'key': 'properties.paged_system_memory', 'type': 'long'}, + 'non_paged_system_memory': {'key': 'properties.non_paged_system_memory', 'type': 'long'}, + 'paged_memory': {'key': 'properties.paged_memory', 'type': 'long'}, + 'peak_paged_memory': {'key': 'properties.peak_paged_memory', 'type': 'long'}, + 'time_stamp': {'key': 'properties.time_stamp', 'type': 'iso-8601'}, + 'environment_variables': {'key': 'properties.environment_variables', 'type': '{str}'}, + 'is_scm_site': {'key': 'properties.is_scm_site', 'type': 'bool'}, + 'is_webjob': {'key': 'properties.is_webjob', 'type': 'bool'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + deployment_name: Optional[str] = None, + href: Optional[str] = None, + minidump: Optional[str] = None, + is_profile_running: Optional[bool] = None, + is_iis_profile_running: Optional[bool] = None, + iis_profile_timeout_in_seconds: Optional[float] = None, + parent: Optional[str] = None, + children: Optional[List[str]] = None, + threads: Optional[List["ProcessThreadInfo"]] = None, + open_file_handles: Optional[List[str]] = None, + modules: Optional[List["ProcessModuleInfo"]] = None, + file_name: Optional[str] = None, + command_line: Optional[str] = None, + user_name: Optional[str] = None, + handle_count: Optional[int] = None, + module_count: Optional[int] = None, + thread_count: Optional[int] = None, + start_time: Optional[datetime.datetime] = None, + total_cpu_time: Optional[str] = None, + user_cpu_time: Optional[str] = None, + privileged_cpu_time: Optional[str] = None, + working_set: Optional[int] = None, + peak_working_set: Optional[int] = None, + private_memory: Optional[int] = None, + virtual_memory: Optional[int] = None, + peak_virtual_memory: Optional[int] = None, + paged_system_memory: Optional[int] = None, + non_paged_system_memory: Optional[int] = None, + paged_memory: Optional[int] = None, + peak_paged_memory: Optional[int] = None, + time_stamp: Optional[datetime.datetime] = None, + environment_variables: Optional[Dict[str, str]] = None, + is_scm_site: Optional[bool] = None, + is_webjob: Optional[bool] = None, + description: Optional[str] = None, + **kwargs + ): + super(ProcessInfo, self).__init__(kind=kind, **kwargs) + self.identifier = None + self.deployment_name = deployment_name + self.href = href + self.minidump = minidump + self.is_profile_running = is_profile_running + self.is_iis_profile_running = is_iis_profile_running + self.iis_profile_timeout_in_seconds = iis_profile_timeout_in_seconds + self.parent = parent + self.children = children + self.threads = threads + self.open_file_handles = open_file_handles + self.modules = modules + self.file_name = file_name + self.command_line = command_line + self.user_name = user_name + self.handle_count = handle_count + self.module_count = module_count + self.thread_count = thread_count + self.start_time = start_time + self.total_cpu_time = total_cpu_time + self.user_cpu_time = user_cpu_time + self.privileged_cpu_time = privileged_cpu_time + self.working_set = working_set + self.peak_working_set = peak_working_set + self.private_memory = private_memory + self.virtual_memory = virtual_memory + self.peak_virtual_memory = peak_virtual_memory + self.paged_system_memory = paged_system_memory + self.non_paged_system_memory = non_paged_system_memory + self.paged_memory = paged_memory + self.peak_paged_memory = peak_paged_memory + self.time_stamp = time_stamp + self.environment_variables = environment_variables + self.is_scm_site = is_scm_site + self.is_webjob = is_webjob + self.description = description + + +class ProcessInfoCollection(msrest.serialization.Model): + """Collection of Kudu process information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessInfo"], + **kwargs + ): + super(ProcessInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ProcessModuleInfo(ProxyOnlyResource): + """Process Module Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param base_address: Base address. Used as module identifier in ARM resource URI. + :type base_address: str + :param file_name: File name. + :type file_name: str + :param href: HRef URI. + :type href: str + :param file_path: File path. + :type file_path: str + :param module_memory_size: Module memory size. + :type module_memory_size: int + :param file_version: File version. + :type file_version: str + :param file_description: File description. + :type file_description: str + :param product: Product name. + :type product: str + :param product_version: Product version. + :type product_version: str + :param is_debug: Is debug?. + :type is_debug: bool + :param language: Module language (locale). + :type language: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'base_address': {'key': 'properties.base_address', 'type': 'str'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'file_path': {'key': 'properties.file_path', 'type': 'str'}, + 'module_memory_size': {'key': 'properties.module_memory_size', 'type': 'int'}, + 'file_version': {'key': 'properties.file_version', 'type': 'str'}, + 'file_description': {'key': 'properties.file_description', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'product_version': {'key': 'properties.product_version', 'type': 'str'}, + 'is_debug': {'key': 'properties.is_debug', 'type': 'bool'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + base_address: Optional[str] = None, + file_name: Optional[str] = None, + href: Optional[str] = None, + file_path: Optional[str] = None, + module_memory_size: Optional[int] = None, + file_version: Optional[str] = None, + file_description: Optional[str] = None, + product: Optional[str] = None, + product_version: Optional[str] = None, + is_debug: Optional[bool] = None, + language: Optional[str] = None, + **kwargs + ): + super(ProcessModuleInfo, self).__init__(kind=kind, **kwargs) + self.base_address = base_address + self.file_name = file_name + self.href = href + self.file_path = file_path + self.module_memory_size = module_memory_size + self.file_version = file_version + self.file_description = file_description + self.product = product + self.product_version = product_version + self.is_debug = is_debug + self.language = language + + +class ProcessModuleInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessModuleInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessModuleInfo"], + **kwargs + ): + super(ProcessModuleInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ProcessThreadInfo(ProxyOnlyResource): + """Process Thread Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar identifier: Site extension ID. + :vartype identifier: int + :param href: HRef URI. + :type href: str + :param process: Process URI. + :type process: str + :param start_address: Start address. + :type start_address: str + :param current_priority: Current thread priority. + :type current_priority: int + :param priority_level: Thread priority level. + :type priority_level: str + :param base_priority: Base priority. + :type base_priority: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_processor_time: Total processor time. + :type total_processor_time: str + :param user_processor_time: User processor time. + :type user_processor_time: str + :param state: Thread state. + :type state: str + :param wait_reason: Wait reason. + :type wait_reason: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'process': {'key': 'properties.process', 'type': 'str'}, + 'start_address': {'key': 'properties.start_address', 'type': 'str'}, + 'current_priority': {'key': 'properties.current_priority', 'type': 'int'}, + 'priority_level': {'key': 'properties.priority_level', 'type': 'str'}, + 'base_priority': {'key': 'properties.base_priority', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_processor_time': {'key': 'properties.total_processor_time', 'type': 'str'}, + 'user_processor_time': {'key': 'properties.user_processor_time', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'wait_reason': {'key': 'properties.wait_reason', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + href: Optional[str] = None, + process: Optional[str] = None, + start_address: Optional[str] = None, + current_priority: Optional[int] = None, + priority_level: Optional[str] = None, + base_priority: Optional[int] = None, + start_time: Optional[datetime.datetime] = None, + total_processor_time: Optional[str] = None, + user_processor_time: Optional[str] = None, + state: Optional[str] = None, + wait_reason: Optional[str] = None, + **kwargs + ): + super(ProcessThreadInfo, self).__init__(kind=kind, **kwargs) + self.identifier = None + self.href = href + self.process = process + self.start_address = start_address + self.current_priority = current_priority + self.priority_level = priority_level + self.base_priority = base_priority + self.start_time = start_time + self.total_processor_time = total_processor_time + self.user_processor_time = user_processor_time + self.state = state + self.wait_reason = wait_reason + + +class ProcessThreadInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessThreadInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessThreadInfo"], + **kwargs + ): + super(ProcessThreadInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PublicCertificate(ProxyOnlyResource): + """Public certificate object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param blob: Public Certificate byte array. + :type blob: bytearray + :param public_certificate_location: Public Certificate Location. Possible values include: + "CurrentUserMy", "LocalMachineMy", "Unknown". + :type public_certificate_location: str or + ~azure.mgmt.web.v2020_06_01.models.PublicCertificateLocation + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'thumbprint': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'blob': {'key': 'properties.blob', 'type': 'bytearray'}, + 'public_certificate_location': {'key': 'properties.publicCertificateLocation', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + blob: Optional[bytearray] = None, + public_certificate_location: Optional[Union[str, "PublicCertificateLocation"]] = None, + **kwargs + ): + super(PublicCertificate, self).__init__(kind=kind, **kwargs) + self.blob = blob + self.public_certificate_location = public_certificate_location + self.thumbprint = None + + +class PublicCertificateCollection(msrest.serialization.Model): + """Collection of public certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.PublicCertificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicCertificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PublicCertificate"], + **kwargs + ): + super(PublicCertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PushSettings(ProxyOnlyResource): + """Push settings for the App. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param is_push_enabled: Gets or sets a flag indicating whether the Push endpoint is enabled. + :type is_push_enabled: bool + :param tag_whitelist_json: Gets or sets a JSON string containing a list of tags that are + whitelisted for use by the push registration endpoint. + :type tag_whitelist_json: str + :param tags_requiring_auth: Gets or sets a JSON string containing a list of tags that require + user authentication to be used in the push registration endpoint. + Tags can consist of alphanumeric characters and the following: + '_', '@', '#', '.', ':', '-'. + Validation should be performed at the PushRequestHandler. + :type tags_requiring_auth: str + :param dynamic_tags_json: Gets or sets a JSON string containing a list of dynamic tags that + will be evaluated from user claims in the push registration endpoint. + :type dynamic_tags_json: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_push_enabled': {'key': 'properties.isPushEnabled', 'type': 'bool'}, + 'tag_whitelist_json': {'key': 'properties.tagWhitelistJson', 'type': 'str'}, + 'tags_requiring_auth': {'key': 'properties.tagsRequiringAuth', 'type': 'str'}, + 'dynamic_tags_json': {'key': 'properties.dynamicTagsJson', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + is_push_enabled: Optional[bool] = None, + tag_whitelist_json: Optional[str] = None, + tags_requiring_auth: Optional[str] = None, + dynamic_tags_json: Optional[str] = None, + **kwargs + ): + super(PushSettings, self).__init__(kind=kind, **kwargs) + self.is_push_enabled = is_push_enabled + self.tag_whitelist_json = tag_whitelist_json + self.tags_requiring_auth = tags_requiring_auth + self.dynamic_tags_json = dynamic_tags_json + + +class RampUpRule(msrest.serialization.Model): + """Routing rules for ramp up testing. This rule allows to redirect static traffic % to a slot or to gradually change routing % based on performance. + + :param action_host_name: Hostname of a slot to which the traffic will be redirected if decided + to. E.g. myapp-stage.azurewebsites.net. + :type action_host_name: str + :param reroute_percentage: Percentage of the traffic which will be redirected to + :code:`ActionHostName`. + :type reroute_percentage: float + :param change_step: In auto ramp up scenario this is the step to add/remove from + :code:`ReroutePercentage` until it reaches + \n:code:`MinReroutePercentage` or + :code:`MaxReroutePercentage`. Site metrics are checked every N minutes specified + in :code:`ChangeIntervalInMinutes`.\nCustom decision algorithm + can be provided in TiPCallback site extension which URL can be specified in + :code:`ChangeDecisionCallbackUrl`. + :type change_step: float + :param change_interval_in_minutes: Specifies interval in minutes to reevaluate + ReroutePercentage. + :type change_interval_in_minutes: int + :param min_reroute_percentage: Specifies lower boundary above which ReroutePercentage will + stay. + :type min_reroute_percentage: float + :param max_reroute_percentage: Specifies upper boundary below which ReroutePercentage will + stay. + :type max_reroute_percentage: float + :param change_decision_callback_url: Custom decision algorithm can be provided in TiPCallback + site extension which URL can be specified. See TiPCallback site extension for the scaffold and + contracts. + https://www.siteextensions.net/packages/TiPCallback/. + :type change_decision_callback_url: str + :param name: Name of the routing rule. The recommended name would be to point to the slot which + will receive the traffic in the experiment. + :type name: str + """ + + _attribute_map = { + 'action_host_name': {'key': 'actionHostName', 'type': 'str'}, + 'reroute_percentage': {'key': 'reroutePercentage', 'type': 'float'}, + 'change_step': {'key': 'changeStep', 'type': 'float'}, + 'change_interval_in_minutes': {'key': 'changeIntervalInMinutes', 'type': 'int'}, + 'min_reroute_percentage': {'key': 'minReroutePercentage', 'type': 'float'}, + 'max_reroute_percentage': {'key': 'maxReroutePercentage', 'type': 'float'}, + 'change_decision_callback_url': {'key': 'changeDecisionCallbackUrl', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + action_host_name: Optional[str] = None, + reroute_percentage: Optional[float] = None, + change_step: Optional[float] = None, + change_interval_in_minutes: Optional[int] = None, + min_reroute_percentage: Optional[float] = None, + max_reroute_percentage: Optional[float] = None, + change_decision_callback_url: Optional[str] = None, + name: Optional[str] = None, + **kwargs + ): + super(RampUpRule, self).__init__(**kwargs) + self.action_host_name = action_host_name + self.reroute_percentage = reroute_percentage + self.change_step = change_step + self.change_interval_in_minutes = change_interval_in_minutes + self.min_reroute_percentage = min_reroute_percentage + self.max_reroute_percentage = max_reroute_percentage + self.change_decision_callback_url = change_decision_callback_url + self.name = name + + +class Recommendation(ProxyOnlyResource): + """Represents a recommendation result generated by the recommendation engine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param creation_time: Timestamp when this instance was created. + :type creation_time: ~datetime.datetime + :param recommendation_id: A GUID value that each recommendation object is associated with. + :type recommendation_id: str + :param resource_id: Full ARM resource ID string that this recommendation object is associated + with. + :type resource_id: str + :param resource_scope: Name of a resource type this recommendation applies, e.g. Subscription, + ServerFarm, Site. Possible values include: "ServerFarm", "Subscription", "WebSite". + :type resource_scope: str or ~azure.mgmt.web.v2020_06_01.models.ResourceScopeType + :param rule_name: Unique name of the rule. + :type rule_name: str + :param display_name: UI friendly name of the rule (may not be unique). + :type display_name: str + :param message: Recommendation text. + :type message: str + :param level: Level indicating how critical this recommendation can impact. Possible values + include: "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.NotificationLevel + :param channels: List of channels that this recommendation can apply. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_06_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation belongs to. + :vartype category_tags: list[str] + :param action_name: Name of action recommended by this object. + :type action_name: str + :param enabled: True if this recommendation is still valid (i.e. "actionable"). False if it is + invalid. + :type enabled: int + :param states: The list of states of this recommendation. If it's null then it should be + considered "Active". + :type states: list[str] + :param start_time: The beginning time in UTC of a range that the recommendation refers to. + :type start_time: ~datetime.datetime + :param end_time: The end time in UTC of a range that the recommendation refers to. + :type end_time: ~datetime.datetime + :param next_notification_time: When to notify this recommendation next in UTC. Null means that + this will never be notified anymore. + :type next_notification_time: ~datetime.datetime + :param notification_expiration_time: Date and time in UTC when this notification expires. + :type notification_expiration_time: ~datetime.datetime + :param notified_time: Last timestamp in UTC this instance was actually notified. Null means + that this recommendation hasn't been notified yet. + :type notified_time: ~datetime.datetime + :param score: A metric value measured by the rule. + :type score: float + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'creation_time': {'key': 'properties.creationTime', 'type': 'iso-8601'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'resource_id': {'key': 'properties.resourceId', 'type': 'str'}, + 'resource_scope': {'key': 'properties.resourceScope', 'type': 'str'}, + 'rule_name': {'key': 'properties.ruleName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'int'}, + 'states': {'key': 'properties.states', 'type': '[str]'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'next_notification_time': {'key': 'properties.nextNotificationTime', 'type': 'iso-8601'}, + 'notification_expiration_time': {'key': 'properties.notificationExpirationTime', 'type': 'iso-8601'}, + 'notified_time': {'key': 'properties.notifiedTime', 'type': 'iso-8601'}, + 'score': {'key': 'properties.score', 'type': 'float'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + creation_time: Optional[datetime.datetime] = None, + recommendation_id: Optional[str] = None, + resource_id: Optional[str] = None, + resource_scope: Optional[Union[str, "ResourceScopeType"]] = None, + rule_name: Optional[str] = None, + display_name: Optional[str] = None, + message: Optional[str] = None, + level: Optional[Union[str, "NotificationLevel"]] = None, + channels: Optional[Union[str, "Channels"]] = None, + action_name: Optional[str] = None, + enabled: Optional[int] = None, + states: Optional[List[str]] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + next_notification_time: Optional[datetime.datetime] = None, + notification_expiration_time: Optional[datetime.datetime] = None, + notified_time: Optional[datetime.datetime] = None, + score: Optional[float] = None, + is_dynamic: Optional[bool] = None, + extension_name: Optional[str] = None, + blade_name: Optional[str] = None, + forward_link: Optional[str] = None, + **kwargs + ): + super(Recommendation, self).__init__(kind=kind, **kwargs) + self.creation_time = creation_time + self.recommendation_id = recommendation_id + self.resource_id = resource_id + self.resource_scope = resource_scope + self.rule_name = rule_name + self.display_name = display_name + self.message = message + self.level = level + self.channels = channels + self.category_tags = None + self.action_name = action_name + self.enabled = enabled + self.states = states + self.start_time = start_time + self.end_time = end_time + self.next_notification_time = next_notification_time + self.notification_expiration_time = notification_expiration_time + self.notified_time = notified_time + self.score = score + self.is_dynamic = is_dynamic + self.extension_name = extension_name + self.blade_name = blade_name + self.forward_link = forward_link + + +class RecommendationCollection(msrest.serialization.Model): + """Collection of recommendations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Recommendation] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Recommendation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Recommendation"], + **kwargs + ): + super(RecommendationCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class RecommendationRule(ProxyOnlyResource): + """Represents a recommendation rule that the recommendation engine can perform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param recommendation_name: Unique name of the rule. + :type recommendation_name: str + :param display_name: UI friendly name of the rule. + :type display_name: str + :param message: Localized name of the rule (Good for UI). + :type message: str + :param recommendation_id: Recommendation ID of an associated recommendation object tied to the + rule, if exists. + If such an object doesn't exist, it is set to null. + :type recommendation_id: str + :param description: Localized detailed description of the rule. + :type description: str + :param action_name: Name of action that is recommended by this rule in string. + :type action_name: str + :param level: Level of impact indicating how critical this rule is. Possible values include: + "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_06_01.models.NotificationLevel + :param channels: List of available channels that this rule applies. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_06_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation rule belongs to. + :vartype category_tags: list[str] + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. Applicable to dynamic rule only. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. Applicable to dynamic rule only. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. Applicable + to dynamic rule only. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'recommendation_name': {'key': 'properties.recommendationName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + recommendation_name: Optional[str] = None, + display_name: Optional[str] = None, + message: Optional[str] = None, + recommendation_id: Optional[str] = None, + description: Optional[str] = None, + action_name: Optional[str] = None, + level: Optional[Union[str, "NotificationLevel"]] = None, + channels: Optional[Union[str, "Channels"]] = None, + is_dynamic: Optional[bool] = None, + extension_name: Optional[str] = None, + blade_name: Optional[str] = None, + forward_link: Optional[str] = None, + **kwargs + ): + super(RecommendationRule, self).__init__(kind=kind, **kwargs) + self.recommendation_name = recommendation_name + self.display_name = display_name + self.message = message + self.recommendation_id = recommendation_id + self.description = description + self.action_name = action_name + self.level = level + self.channels = channels + self.category_tags = None + self.is_dynamic = is_dynamic + self.extension_name = extension_name + self.blade_name = blade_name + self.forward_link = forward_link + + +class ReissueCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate reissue request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_size: Certificate Key Size. + :type key_size: int + :param delay_existing_revoke_in_hours: Delay in hours to revoke existing certificate after the + new certificate is issued. + :type delay_existing_revoke_in_hours: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'delay_existing_revoke_in_hours': {'key': 'properties.delayExistingRevokeInHours', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_size: Optional[int] = None, + delay_existing_revoke_in_hours: Optional[int] = None, + csr: Optional[str] = None, + is_private_key_external: Optional[bool] = None, + **kwargs + ): + super(ReissueCertificateOrderRequest, self).__init__(kind=kind, **kwargs) + self.key_size = key_size + self.delay_existing_revoke_in_hours = delay_existing_revoke_in_hours + self.csr = csr + self.is_private_key_external = is_private_key_external + + +class RelayServiceConnectionEntity(ProxyOnlyResource): + """Hybrid Connection for an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param entity_name: + :type entity_name: str + :param entity_connection_string: + :type entity_connection_string: str + :param resource_type: + :type resource_type: str + :param resource_connection_string: + :type resource_connection_string: str + :param hostname: + :type hostname: str + :param port: + :type port: int + :param biztalk_uri: + :type biztalk_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'entity_name': {'key': 'properties.entityName', 'type': 'str'}, + 'entity_connection_string': {'key': 'properties.entityConnectionString', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'resource_connection_string': {'key': 'properties.resourceConnectionString', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'biztalk_uri': {'key': 'properties.biztalkUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + entity_name: Optional[str] = None, + entity_connection_string: Optional[str] = None, + resource_type: Optional[str] = None, + resource_connection_string: Optional[str] = None, + hostname: Optional[str] = None, + port: Optional[int] = None, + biztalk_uri: Optional[str] = None, + **kwargs + ): + super(RelayServiceConnectionEntity, self).__init__(kind=kind, **kwargs) + self.entity_name = entity_name + self.entity_connection_string = entity_connection_string + self.resource_type = resource_type + self.resource_connection_string = resource_connection_string + self.hostname = hostname + self.port = port + self.biztalk_uri = biztalk_uri + + +class Rendering(msrest.serialization.Model): + """Instructions for rendering the data. + + :param type: Rendering Type. Possible values include: "NoGraph", "Table", "TimeSeries", + "TimeSeriesPerInstance". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.RenderingType + :param title: Title of data. + :type title: str + :param description: Description of the data that will help it be interpreted. + :type description: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "RenderingType"]] = None, + title: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(Rendering, self).__init__(**kwargs) + self.type = type + self.title = title + self.description = description + + +class RenewCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate renew request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param key_size: Certificate Key Size. + :type key_size: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_size: Optional[int] = None, + csr: Optional[str] = None, + is_private_key_external: Optional[bool] = None, + **kwargs + ): + super(RenewCertificateOrderRequest, self).__init__(kind=kind, **kwargs) + self.key_size = key_size + self.csr = csr + self.is_private_key_external = is_private_key_external + + +class RequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on total requests. + + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(RequestsBasedTrigger, self).__init__(**kwargs) + self.count = count + self.time_interval = time_interval + + +class ResourceCollection(msrest.serialization.Model): + """Collection of resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[str] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[str]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List[str], + **kwargs + ): + super(ResourceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceHealthMetadata(ProxyOnlyResource): + """Used for getting ResourceHealthCheck settings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param category: The category that the resource matches in the RHC Policy File. + :type category: str + :param signal_availability: Is there a health signal for the resource. + :type signal_availability: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'category': {'key': 'properties.category', 'type': 'str'}, + 'signal_availability': {'key': 'properties.signalAvailability', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + category: Optional[str] = None, + signal_availability: Optional[bool] = None, + **kwargs + ): + super(ResourceHealthMetadata, self).__init__(kind=kind, **kwargs) + self.category = category + self.signal_availability = signal_availability + + +class ResourceHealthMetadataCollection(msrest.serialization.Model): + """Collection of resource health metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceHealthMetadata]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ResourceHealthMetadata"], + **kwargs + ): + super(ResourceHealthMetadataCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceMetricAvailability(msrest.serialization.Model): + """Metrics availability and retention. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time_grain: Time grain . + :vartype time_grain: str + :ivar retention: Retention period for the current time grain. + :vartype retention: str + """ + + _validation = { + 'time_grain': {'readonly': True}, + 'retention': {'readonly': True}, + } + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricAvailability, self).__init__(**kwargs) + self.time_grain = None + self.retention = None + + +class ResourceMetricDefinition(ProxyOnlyResource): + """Metadata for the metrics. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar unit: Unit of the metric. + :vartype unit: str + :ivar primary_aggregation_type: Primary aggregation type. + :vartype primary_aggregation_type: str + :ivar metric_availabilities: List of time grains supported for the metric together with + retention period. + :vartype metric_availabilities: + list[~azure.mgmt.web.v2020_06_01.models.ResourceMetricAvailability] + :ivar resource_uri: Resource URI. + :vartype resource_uri: str + :ivar properties: Resource metric definition properties. + :vartype properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'unit': {'readonly': True}, + 'primary_aggregation_type': {'readonly': True}, + 'metric_availabilities': {'readonly': True}, + 'resource_uri': {'readonly': True}, + 'properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'primary_aggregation_type': {'key': 'properties.primaryAggregationType', 'type': 'str'}, + 'metric_availabilities': {'key': 'properties.metricAvailabilities', 'type': '[ResourceMetricAvailability]'}, + 'resource_uri': {'key': 'properties.resourceUri', 'type': 'str'}, + 'properties': {'key': 'properties.properties', 'type': '{str}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(ResourceMetricDefinition, self).__init__(kind=kind, **kwargs) + self.unit = None + self.primary_aggregation_type = None + self.metric_availabilities = None + self.resource_uri = None + self.properties = None + + +class ResourceMetricDefinitionCollection(msrest.serialization.Model): + """Collection of metric definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceMetricDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ResourceMetricDefinition"], + **kwargs + ): + super(ResourceMetricDefinitionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceNameAvailability(msrest.serialization.Model): + """Information regarding availability of a resource name. + + :param name_available: :code:`true` indicates name is valid and available. + :code:`false` indicates the name is invalid, unavailable, or both. + :type name_available: bool + :param reason: :code:`Invalid` indicates the name provided does not match Azure + App Service naming requirements. :code:`AlreadyExists` indicates that the name is + already in use and is therefore unavailable. Possible values include: "Invalid", + "AlreadyExists". + :type reason: str or ~azure.mgmt.web.v2020_06_01.models.InAvailabilityReasonType + :param message: If reason == invalid, provide the user with the reason why the given name is + invalid, and provide the resource naming requirements so that the user can select a valid name. + If reason == AlreadyExists, explain that resource name is already in use, and direct them to + select a different name. + :type message: str + """ + + _attribute_map = { + 'name_available': {'key': 'nameAvailable', 'type': 'bool'}, + 'reason': {'key': 'reason', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + name_available: Optional[bool] = None, + reason: Optional[Union[str, "InAvailabilityReasonType"]] = None, + message: Optional[str] = None, + **kwargs + ): + super(ResourceNameAvailability, self).__init__(**kwargs) + self.name_available = name_available + self.reason = reason + self.message = message + + +class ResourceNameAvailabilityRequest(msrest.serialization.Model): + """Resource name availability request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: "Site", + "Slot", "HostingEnvironment", "PublishingUser", "Microsoft.Web/sites", + "Microsoft.Web/sites/slots", "Microsoft.Web/hostingEnvironments", + "Microsoft.Web/publishingUsers". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_fqdn': {'key': 'isFqdn', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: str, + type: Union[str, "CheckNameResourceTypes"], + is_fqdn: Optional[bool] = None, + **kwargs + ): + super(ResourceNameAvailabilityRequest, self).__init__(**kwargs) + self.name = name + self.type = type + self.is_fqdn = is_fqdn + + +class ResponseMetaData(msrest.serialization.Model): + """ResponseMetaData. + + :param data_source: Source of the Data. + :type data_source: ~azure.mgmt.web.v2020_06_01.models.DataSource + """ + + _attribute_map = { + 'data_source': {'key': 'dataSource', 'type': 'DataSource'}, + } + + def __init__( + self, + *, + data_source: Optional["DataSource"] = None, + **kwargs + ): + super(ResponseMetaData, self).__init__(**kwargs) + self.data_source = data_source + + +class RestoreRequest(ProxyOnlyResource): + """Description of a restore request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param blob_name: Name of a blob which contains the backup. + :type blob_name: str + :param overwrite: :code:`true` if the restore operation can overwrite target app; + otherwise, :code:`false`. :code:`true` is needed if trying to restore + over an existing app. + :type overwrite: bool + :param site_name: Name of an app. + :type site_name: str + :param databases: Collection of databases which should be restored. This list has to match the + list of databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_06_01.models.DatabaseBackupSetting] + :param ignore_conflicting_host_names: Changes a logic when restoring an app with custom + domains. :code:`true` to remove custom domains automatically. If + :code:`false`, custom domains are added to + the app's object when it is being restored, but that might fail due to conflicts during the + operation. + :type ignore_conflicting_host_names: bool + :param ignore_databases: Ignore the databases and only restore the site content. + :type ignore_databases: bool + :param app_service_plan: Specify app service plan that will own restored site. + :type app_service_plan: str + :param operation_type: Operation type. Possible values include: "Default", "Clone", + "Relocation", "Snapshot", "CloudFS". Default value: "Default". + :type operation_type: str or ~azure.mgmt.web.v2020_06_01.models.BackupRestoreOperationType + :param adjust_connection_strings: :code:`true` if SiteConfig.ConnectionStrings + should be set in new app; otherwise, :code:`false`. + :type adjust_connection_strings: bool + :param hosting_environment: App Service Environment name, if needed (only when restoring an app + to an App Service Environment). + :type hosting_environment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'ignore_databases': {'key': 'properties.ignoreDatabases', 'type': 'bool'}, + 'app_service_plan': {'key': 'properties.appServicePlan', 'type': 'str'}, + 'operation_type': {'key': 'properties.operationType', 'type': 'str'}, + 'adjust_connection_strings': {'key': 'properties.adjustConnectionStrings', 'type': 'bool'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + storage_account_url: Optional[str] = None, + blob_name: Optional[str] = None, + overwrite: Optional[bool] = None, + site_name: Optional[str] = None, + databases: Optional[List["DatabaseBackupSetting"]] = None, + ignore_conflicting_host_names: Optional[bool] = False, + ignore_databases: Optional[bool] = False, + app_service_plan: Optional[str] = None, + operation_type: Optional[Union[str, "BackupRestoreOperationType"]] = "Default", + adjust_connection_strings: Optional[bool] = None, + hosting_environment: Optional[str] = None, + **kwargs + ): + super(RestoreRequest, self).__init__(kind=kind, **kwargs) + self.storage_account_url = storage_account_url + self.blob_name = blob_name + self.overwrite = overwrite + self.site_name = site_name + self.databases = databases + self.ignore_conflicting_host_names = ignore_conflicting_host_names + self.ignore_databases = ignore_databases + self.app_service_plan = app_service_plan + self.operation_type = operation_type + self.adjust_connection_strings = adjust_connection_strings + self.hosting_environment = hosting_environment + + +class ServiceSpecification(msrest.serialization.Model): + """Resource metrics service provided by Microsoft.Insights resource provider. + + :param metric_specifications: + :type metric_specifications: list[~azure.mgmt.web.v2020_06_01.models.MetricSpecification] + :param log_specifications: + :type log_specifications: list[~azure.mgmt.web.v2020_06_01.models.LogSpecification] + """ + + _attribute_map = { + 'metric_specifications': {'key': 'metricSpecifications', 'type': '[MetricSpecification]'}, + 'log_specifications': {'key': 'logSpecifications', 'type': '[LogSpecification]'}, + } + + def __init__( + self, + *, + metric_specifications: Optional[List["MetricSpecification"]] = None, + log_specifications: Optional[List["LogSpecification"]] = None, + **kwargs + ): + super(ServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = metric_specifications + self.log_specifications = log_specifications + + +class Site(Resource): + """A web app, a mobile app backend, or an API app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_06_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_06_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_06_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_06_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_06_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_06_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_06_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + enabled: Optional[bool] = None, + host_name_ssl_states: Optional[List["HostNameSslState"]] = None, + server_farm_id: Optional[str] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + site_config: Optional["SiteConfig"] = None, + scm_site_also_stopped: Optional[bool] = False, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + client_affinity_enabled: Optional[bool] = None, + client_cert_enabled: Optional[bool] = None, + client_cert_mode: Optional[Union[str, "ClientCertMode"]] = None, + client_cert_exclusion_paths: Optional[str] = None, + host_names_disabled: Optional[bool] = None, + custom_domain_verification_id: Optional[str] = None, + container_size: Optional[int] = None, + daily_memory_time_quota: Optional[int] = None, + cloning_info: Optional["CloningInfo"] = None, + https_only: Optional[bool] = None, + redundancy_mode: Optional[Union[str, "RedundancyMode"]] = None, + **kwargs + ): + super(Site, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.identity = identity + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = enabled + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = host_name_ssl_states + self.server_farm_id = server_farm_id + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.last_modified_time_utc = None + self.site_config = site_config + self.traffic_manager_host_names = None + self.scm_site_also_stopped = scm_site_also_stopped + self.target_swap_slot = None + self.hosting_environment_profile = hosting_environment_profile + self.client_affinity_enabled = client_affinity_enabled + self.client_cert_enabled = client_cert_enabled + self.client_cert_mode = client_cert_mode + self.client_cert_exclusion_paths = client_cert_exclusion_paths + self.host_names_disabled = host_names_disabled + self.custom_domain_verification_id = custom_domain_verification_id + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = container_size + self.daily_memory_time_quota = daily_memory_time_quota + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = cloning_info + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = https_only + self.redundancy_mode = redundancy_mode + self.in_progress_operation_id = None + + +class SiteAuthSettings(ProxyOnlyResource): + """Configuration settings for the Azure App Service Authentication / Authorization feature. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: :code:`true` if the Authentication / Authorization feature is + enabled for the current app; otherwise, :code:`false`. + :type enabled: bool + :param runtime_version: The RuntimeVersion of the Authentication / Authorization feature in use + for the current app. + The setting in this value can control the behavior of certain features in the Authentication / + Authorization module. + :type runtime_version: str + :param unauthenticated_client_action: The action to take when an unauthenticated client + attempts to access the app. Possible values include: "RedirectToLoginPage", "AllowAnonymous". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_06_01.models.UnauthenticatedClientAction + :param token_store_enabled: :code:`true` to durably store platform-specific + security tokens that are obtained during login flows; otherwise, :code:`false`. + The default is :code:`false`. + :type token_store_enabled: bool + :param allowed_external_redirect_urls: External URLs that can be redirected to as part of + logging in or logging out of the app. Note that the query string part of the URL is ignored. + This is an advanced setting typically only needed by Windows Store application backends. + Note that URLs within the current domain are always implicitly allowed. + :type allowed_external_redirect_urls: list[str] + :param default_provider: The default authentication provider to use when multiple providers are + configured. + This setting is only needed if multiple providers are configured and the unauthenticated + client + action is set to "RedirectToLoginPage". Possible values include: "AzureActiveDirectory", + "Facebook", "Google", "MicrosoftAccount", "Twitter", "Github". + :type default_provider: str or ~azure.mgmt.web.v2020_06_01.models.BuiltInAuthenticationProvider + :param token_refresh_extension_hours: The number of hours after session token expiration that a + session token can be used to + call the token refresh API. The default is 72 hours. + :type token_refresh_extension_hours: float + :param client_id: The Client ID of this relying party application, known as the client_id. + This setting is required for enabling OpenID Connection authentication with Azure Active + Directory or + other 3rd party OpenID Connect providers. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_id: str + :param client_secret: The Client Secret of this relying party application (in Azure Active + Directory, this is also referred to as the Key). + This setting is optional. If no client secret is configured, the OpenID Connect implicit auth + flow is used to authenticate end users. + Otherwise, the OpenID Connect Authorization Code Flow is used to authenticate end users. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_secret: str + :param client_secret_setting_name: The app setting name that contains the client secret of the + relying party application. + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: An alternative to the client secret, that is the + thumbprint of a certificate used for signing purposes. This property acts as + a replacement for the Client Secret. It is also optional. + :type client_secret_certificate_thumbprint: str + :param issuer: The OpenID Connect Issuer URI that represents the entity which issues access + tokens for this application. + When using Azure Active Directory, this value is the URI of the directory tenant, e.g. + https://sts.windows.net/{tenant-guid}/. + This URI is a case-sensitive identifier for the token issuer. + More information on OpenID Connect Discovery: http://openid.net/specs/openid-connect- + discovery-1_0.html. + :type issuer: str + :param validate_issuer: Gets a value indicating whether the issuer should be a valid HTTPS url + and be validated as such. + :type validate_issuer: bool + :param allowed_audiences: Allowed audience values to consider when validating JWTs issued by + Azure Active Directory. Note that the :code:`ClientID` value is always considered + an + allowed audience, regardless of this setting. + :type allowed_audiences: list[str] + :param additional_login_params: Login parameters to send to the OpenID Connect authorization + endpoint when + a user logs in. Each parameter must be in the form "key=value". + :type additional_login_params: list[str] + :param aad_claims_authorization: Gets a JSON string containing the Azure AD Acl settings. + :type aad_claims_authorization: str + :param google_client_id: The OpenID Connect Client ID for the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_id: str + :param google_client_secret: The client secret associated with the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_secret: str + :param google_client_secret_setting_name: The app setting name that contains the client secret + associated with + the Google web application. + :type google_client_secret_setting_name: str + :param google_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Google + Sign-In authentication. + This setting is optional. If not specified, "openid", "profile", and "email" are used as + default scopes. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_o_auth_scopes: list[str] + :param facebook_app_id: The App ID of the Facebook app used for login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_id: str + :param facebook_app_secret: The App Secret of the Facebook app used for Facebook Login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_secret: str + :param facebook_app_secret_setting_name: The app setting name that contains the app secret used + for Facebook Login. + :type facebook_app_secret_setting_name: str + :param facebook_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Facebook + Login authentication. + This setting is optional. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_o_auth_scopes: list[str] + :param git_hub_client_id: The Client Id of the GitHub app used for login. + This setting is required for enabling Github login. + :type git_hub_client_id: str + :param git_hub_client_secret: The Client Secret of the GitHub app used for Github Login. + This setting is required for enabling Github login. + :type git_hub_client_secret: str + :param git_hub_client_secret_setting_name: The app setting name that contains the client secret + of the Github + app used for GitHub Login. + :type git_hub_client_secret_setting_name: str + :param git_hub_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of GitHub + Login authentication. + This setting is optional. + :type git_hub_o_auth_scopes: list[str] + :param twitter_consumer_key: The OAuth 1.0a consumer key of the Twitter application used for + sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_key: str + :param twitter_consumer_secret: The OAuth 1.0a consumer secret of the Twitter application used + for sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_secret: str + :param twitter_consumer_secret_setting_name: The app setting name that contains the OAuth 1.0a + consumer secret of the Twitter + application used for sign-in. + :type twitter_consumer_secret_setting_name: str + :param microsoft_account_client_id: The OAuth 2.0 client ID that was created for the app used + for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_id: str + :param microsoft_account_client_secret: The OAuth 2.0 client secret that was created for the + app used for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_secret: str + :param microsoft_account_client_secret_setting_name: The app setting name containing the OAuth + 2.0 client secret that was created for the + app used for authentication. + :type microsoft_account_client_secret_setting_name: str + :param microsoft_account_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of + Microsoft Account authentication. + This setting is optional. If not specified, "wl.basic" is used as the default scope. + Microsoft Account Scopes and permissions documentation: https://msdn.microsoft.com/en- + us/library/dn631845.aspx. + :type microsoft_account_o_auth_scopes: list[str] + :param is_auth_from_file: "true" if the auth config settings should be read from a file, + "false" otherwise. + :type is_auth_from_file: str + :param auth_file_path: The path of the config file containing auth settings. + If the path is relative, base will the site's root directory. + :type auth_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'token_store_enabled': {'key': 'properties.tokenStoreEnabled', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'default_provider': {'key': 'properties.defaultProvider', 'type': 'str'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret': {'key': 'properties.clientSecret', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'validate_issuer': {'key': 'properties.validateIssuer', 'type': 'bool'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + 'additional_login_params': {'key': 'properties.additionalLoginParams', 'type': '[str]'}, + 'aad_claims_authorization': {'key': 'properties.aadClaimsAuthorization', 'type': 'str'}, + 'google_client_id': {'key': 'properties.googleClientId', 'type': 'str'}, + 'google_client_secret': {'key': 'properties.googleClientSecret', 'type': 'str'}, + 'google_client_secret_setting_name': {'key': 'properties.googleClientSecretSettingName', 'type': 'str'}, + 'google_o_auth_scopes': {'key': 'properties.googleOAuthScopes', 'type': '[str]'}, + 'facebook_app_id': {'key': 'properties.facebookAppId', 'type': 'str'}, + 'facebook_app_secret': {'key': 'properties.facebookAppSecret', 'type': 'str'}, + 'facebook_app_secret_setting_name': {'key': 'properties.facebookAppSecretSettingName', 'type': 'str'}, + 'facebook_o_auth_scopes': {'key': 'properties.facebookOAuthScopes', 'type': '[str]'}, + 'git_hub_client_id': {'key': 'properties.gitHubClientId', 'type': 'str'}, + 'git_hub_client_secret': {'key': 'properties.gitHubClientSecret', 'type': 'str'}, + 'git_hub_client_secret_setting_name': {'key': 'properties.gitHubClientSecretSettingName', 'type': 'str'}, + 'git_hub_o_auth_scopes': {'key': 'properties.gitHubOAuthScopes', 'type': '[str]'}, + 'twitter_consumer_key': {'key': 'properties.twitterConsumerKey', 'type': 'str'}, + 'twitter_consumer_secret': {'key': 'properties.twitterConsumerSecret', 'type': 'str'}, + 'twitter_consumer_secret_setting_name': {'key': 'properties.twitterConsumerSecretSettingName', 'type': 'str'}, + 'microsoft_account_client_id': {'key': 'properties.microsoftAccountClientId', 'type': 'str'}, + 'microsoft_account_client_secret': {'key': 'properties.microsoftAccountClientSecret', 'type': 'str'}, + 'microsoft_account_client_secret_setting_name': {'key': 'properties.microsoftAccountClientSecretSettingName', 'type': 'str'}, + 'microsoft_account_o_auth_scopes': {'key': 'properties.microsoftAccountOAuthScopes', 'type': '[str]'}, + 'is_auth_from_file': {'key': 'properties.isAuthFromFile', 'type': 'str'}, + 'auth_file_path': {'key': 'properties.authFilePath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + runtime_version: Optional[str] = None, + unauthenticated_client_action: Optional[Union[str, "UnauthenticatedClientAction"]] = None, + token_store_enabled: Optional[bool] = None, + allowed_external_redirect_urls: Optional[List[str]] = None, + default_provider: Optional[Union[str, "BuiltInAuthenticationProvider"]] = None, + token_refresh_extension_hours: Optional[float] = None, + client_id: Optional[str] = None, + client_secret: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + client_secret_certificate_thumbprint: Optional[str] = None, + issuer: Optional[str] = None, + validate_issuer: Optional[bool] = None, + allowed_audiences: Optional[List[str]] = None, + additional_login_params: Optional[List[str]] = None, + aad_claims_authorization: Optional[str] = None, + google_client_id: Optional[str] = None, + google_client_secret: Optional[str] = None, + google_client_secret_setting_name: Optional[str] = None, + google_o_auth_scopes: Optional[List[str]] = None, + facebook_app_id: Optional[str] = None, + facebook_app_secret: Optional[str] = None, + facebook_app_secret_setting_name: Optional[str] = None, + facebook_o_auth_scopes: Optional[List[str]] = None, + git_hub_client_id: Optional[str] = None, + git_hub_client_secret: Optional[str] = None, + git_hub_client_secret_setting_name: Optional[str] = None, + git_hub_o_auth_scopes: Optional[List[str]] = None, + twitter_consumer_key: Optional[str] = None, + twitter_consumer_secret: Optional[str] = None, + twitter_consumer_secret_setting_name: Optional[str] = None, + microsoft_account_client_id: Optional[str] = None, + microsoft_account_client_secret: Optional[str] = None, + microsoft_account_client_secret_setting_name: Optional[str] = None, + microsoft_account_o_auth_scopes: Optional[List[str]] = None, + is_auth_from_file: Optional[str] = None, + auth_file_path: Optional[str] = None, + **kwargs + ): + super(SiteAuthSettings, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.runtime_version = runtime_version + self.unauthenticated_client_action = unauthenticated_client_action + self.token_store_enabled = token_store_enabled + self.allowed_external_redirect_urls = allowed_external_redirect_urls + self.default_provider = default_provider + self.token_refresh_extension_hours = token_refresh_extension_hours + self.client_id = client_id + self.client_secret = client_secret + self.client_secret_setting_name = client_secret_setting_name + self.client_secret_certificate_thumbprint = client_secret_certificate_thumbprint + self.issuer = issuer + self.validate_issuer = validate_issuer + self.allowed_audiences = allowed_audiences + self.additional_login_params = additional_login_params + self.aad_claims_authorization = aad_claims_authorization + self.google_client_id = google_client_id + self.google_client_secret = google_client_secret + self.google_client_secret_setting_name = google_client_secret_setting_name + self.google_o_auth_scopes = google_o_auth_scopes + self.facebook_app_id = facebook_app_id + self.facebook_app_secret = facebook_app_secret + self.facebook_app_secret_setting_name = facebook_app_secret_setting_name + self.facebook_o_auth_scopes = facebook_o_auth_scopes + self.git_hub_client_id = git_hub_client_id + self.git_hub_client_secret = git_hub_client_secret + self.git_hub_client_secret_setting_name = git_hub_client_secret_setting_name + self.git_hub_o_auth_scopes = git_hub_o_auth_scopes + self.twitter_consumer_key = twitter_consumer_key + self.twitter_consumer_secret = twitter_consumer_secret + self.twitter_consumer_secret_setting_name = twitter_consumer_secret_setting_name + self.microsoft_account_client_id = microsoft_account_client_id + self.microsoft_account_client_secret = microsoft_account_client_secret + self.microsoft_account_client_secret_setting_name = microsoft_account_client_secret_setting_name + self.microsoft_account_o_auth_scopes = microsoft_account_o_auth_scopes + self.is_auth_from_file = is_auth_from_file + self.auth_file_path = auth_file_path + + +class SiteAuthSettingsV2(ProxyOnlyResource): + """SiteAuthSettingsV2. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param platform: + :type platform: ~azure.mgmt.web.v2020_06_01.models.AuthPlatform + :param global_validation: + :type global_validation: ~azure.mgmt.web.v2020_06_01.models.GlobalValidation + :param identity_providers: + :type identity_providers: ~azure.mgmt.web.v2020_06_01.models.IdentityProviders + :param login: + :type login: ~azure.mgmt.web.v2020_06_01.models.Login + :param http_settings: + :type http_settings: ~azure.mgmt.web.v2020_06_01.models.HttpSettings + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'platform': {'key': 'properties.platform', 'type': 'AuthPlatform'}, + 'global_validation': {'key': 'properties.globalValidation', 'type': 'GlobalValidation'}, + 'identity_providers': {'key': 'properties.identityProviders', 'type': 'IdentityProviders'}, + 'login': {'key': 'properties.login', 'type': 'Login'}, + 'http_settings': {'key': 'properties.httpSettings', 'type': 'HttpSettings'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + platform: Optional["AuthPlatform"] = None, + global_validation: Optional["GlobalValidation"] = None, + identity_providers: Optional["IdentityProviders"] = None, + login: Optional["Login"] = None, + http_settings: Optional["HttpSettings"] = None, + **kwargs + ): + super(SiteAuthSettingsV2, self).__init__(kind=kind, **kwargs) + self.platform = platform + self.global_validation = global_validation + self.identity_providers = identity_providers + self.login = login + self.http_settings = http_settings + + +class SiteCloneability(msrest.serialization.Model): + """Represents whether or not an app is cloneable. + + :param result: Name of app. Possible values include: "Cloneable", "PartiallyCloneable", + "NotCloneable". + :type result: str or ~azure.mgmt.web.v2020_06_01.models.CloneAbilityResult + :param blocking_features: List of features enabled on app that prevent cloning. + :type blocking_features: list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + :param unsupported_features: List of features enabled on app that are non-blocking but cannot + be cloned. The app can still be cloned + but the features in this list will not be set up on cloned app. + :type unsupported_features: list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + :param blocking_characteristics: List of blocking application characteristics. + :type blocking_characteristics: + list[~azure.mgmt.web.v2020_06_01.models.SiteCloneabilityCriterion] + """ + + _attribute_map = { + 'result': {'key': 'result', 'type': 'str'}, + 'blocking_features': {'key': 'blockingFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'unsupported_features': {'key': 'unsupportedFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'blocking_characteristics': {'key': 'blockingCharacteristics', 'type': '[SiteCloneabilityCriterion]'}, + } + + def __init__( + self, + *, + result: Optional[Union[str, "CloneAbilityResult"]] = None, + blocking_features: Optional[List["SiteCloneabilityCriterion"]] = None, + unsupported_features: Optional[List["SiteCloneabilityCriterion"]] = None, + blocking_characteristics: Optional[List["SiteCloneabilityCriterion"]] = None, + **kwargs + ): + super(SiteCloneability, self).__init__(**kwargs) + self.result = result + self.blocking_features = blocking_features + self.unsupported_features = unsupported_features + self.blocking_characteristics = blocking_characteristics + + +class SiteCloneabilityCriterion(msrest.serialization.Model): + """An app cloneability criterion. + + :param name: Name of criterion. + :type name: str + :param description: Description of criterion. + :type description: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(SiteCloneabilityCriterion, self).__init__(**kwargs) + self.name = name + self.description = description + + +class SiteConfig(msrest.serialization.Model): + """Configuration of an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_06_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_06_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_06_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_06_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_06_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_06_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_06_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_06_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_06_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_06_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_06_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_06_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_06_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_06_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'number_of_workers': {'key': 'numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'phpVersion', 'type': 'str'}, + 'python_version': {'key': 'pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'javaVersion', 'type': 'str'}, + 'java_container': {'key': 'javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'experiments', 'type': 'Experiments'}, + 'limits': {'key': 'limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'cors', 'type': 'CorsSettings'}, + 'push': {'key': 'push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + *, + number_of_workers: Optional[int] = None, + default_documents: Optional[List[str]] = None, + net_framework_version: Optional[str] = "v4.6", + php_version: Optional[str] = None, + python_version: Optional[str] = None, + node_version: Optional[str] = None, + power_shell_version: Optional[str] = None, + linux_fx_version: Optional[str] = None, + windows_fx_version: Optional[str] = None, + request_tracing_enabled: Optional[bool] = None, + request_tracing_expiration_time: Optional[datetime.datetime] = None, + remote_debugging_enabled: Optional[bool] = None, + remote_debugging_version: Optional[str] = None, + http_logging_enabled: Optional[bool] = None, + logs_directory_size_limit: Optional[int] = None, + detailed_error_logging_enabled: Optional[bool] = None, + publishing_username: Optional[str] = None, + app_settings: Optional[List["NameValuePair"]] = None, + connection_strings: Optional[List["ConnStringInfo"]] = None, + handler_mappings: Optional[List["HandlerMapping"]] = None, + document_root: Optional[str] = None, + scm_type: Optional[Union[str, "ScmType"]] = None, + use32_bit_worker_process: Optional[bool] = None, + web_sockets_enabled: Optional[bool] = None, + always_on: Optional[bool] = None, + java_version: Optional[str] = None, + java_container: Optional[str] = None, + java_container_version: Optional[str] = None, + app_command_line: Optional[str] = None, + managed_pipeline_mode: Optional[Union[str, "ManagedPipelineMode"]] = None, + virtual_applications: Optional[List["VirtualApplication"]] = None, + load_balancing: Optional[Union[str, "SiteLoadBalancing"]] = None, + experiments: Optional["Experiments"] = None, + limits: Optional["SiteLimits"] = None, + auto_heal_enabled: Optional[bool] = None, + auto_heal_rules: Optional["AutoHealRules"] = None, + tracing_options: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_route_all_enabled: Optional[bool] = None, + vnet_private_ports_count: Optional[int] = None, + cors: Optional["CorsSettings"] = None, + push: Optional["PushSettings"] = None, + api_definition: Optional["ApiDefinitionInfo"] = None, + api_management_config: Optional["ApiManagementConfig"] = None, + auto_swap_slot_name: Optional[str] = None, + local_my_sql_enabled: Optional[bool] = False, + managed_service_identity_id: Optional[int] = None, + x_managed_service_identity_id: Optional[int] = None, + ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions_use_main: Optional[bool] = None, + http20_enabled: Optional[bool] = True, + min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + scm_min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + ftps_state: Optional[Union[str, "FtpsState"]] = None, + pre_warmed_instance_count: Optional[int] = None, + health_check_path: Optional[str] = None, + **kwargs + ): + super(SiteConfig, self).__init__(**kwargs) + self.number_of_workers = number_of_workers + self.default_documents = default_documents + self.net_framework_version = net_framework_version + self.php_version = php_version + self.python_version = python_version + self.node_version = node_version + self.power_shell_version = power_shell_version + self.linux_fx_version = linux_fx_version + self.windows_fx_version = windows_fx_version + self.request_tracing_enabled = request_tracing_enabled + self.request_tracing_expiration_time = request_tracing_expiration_time + self.remote_debugging_enabled = remote_debugging_enabled + self.remote_debugging_version = remote_debugging_version + self.http_logging_enabled = http_logging_enabled + self.logs_directory_size_limit = logs_directory_size_limit + self.detailed_error_logging_enabled = detailed_error_logging_enabled + self.publishing_username = publishing_username + self.app_settings = app_settings + self.connection_strings = connection_strings + self.machine_key = None + self.handler_mappings = handler_mappings + self.document_root = document_root + self.scm_type = scm_type + self.use32_bit_worker_process = use32_bit_worker_process + self.web_sockets_enabled = web_sockets_enabled + self.always_on = always_on + self.java_version = java_version + self.java_container = java_container + self.java_container_version = java_container_version + self.app_command_line = app_command_line + self.managed_pipeline_mode = managed_pipeline_mode + self.virtual_applications = virtual_applications + self.load_balancing = load_balancing + self.experiments = experiments + self.limits = limits + self.auto_heal_enabled = auto_heal_enabled + self.auto_heal_rules = auto_heal_rules + self.tracing_options = tracing_options + self.vnet_name = vnet_name + self.vnet_route_all_enabled = vnet_route_all_enabled + self.vnet_private_ports_count = vnet_private_ports_count + self.cors = cors + self.push = push + self.api_definition = api_definition + self.api_management_config = api_management_config + self.auto_swap_slot_name = auto_swap_slot_name + self.local_my_sql_enabled = local_my_sql_enabled + self.managed_service_identity_id = managed_service_identity_id + self.x_managed_service_identity_id = x_managed_service_identity_id + self.ip_security_restrictions = ip_security_restrictions + self.scm_ip_security_restrictions = scm_ip_security_restrictions + self.scm_ip_security_restrictions_use_main = scm_ip_security_restrictions_use_main + self.http20_enabled = http20_enabled + self.min_tls_version = min_tls_version + self.scm_min_tls_version = scm_min_tls_version + self.ftps_state = ftps_state + self.pre_warmed_instance_count = pre_warmed_instance_count + self.health_check_path = health_check_path + + +class SiteConfigResource(ProxyOnlyResource): + """Web app configuration ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_06_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_06_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_06_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_06_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_06_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_06_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_06_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_06_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_06_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_06_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_06_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_06_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_06_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_06_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_06_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_06_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_06_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'number_of_workers': {'key': 'properties.numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'properties.defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'properties.netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'properties.phpVersion', 'type': 'str'}, + 'python_version': {'key': 'properties.pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'properties.nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'properties.powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'properties.linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'properties.windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'properties.requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'properties.requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'properties.remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'properties.remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'properties.httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'properties.logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'properties.detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'properties.publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'properties.appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'properties.connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'properties.machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'properties.handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'properties.documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'properties.scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'properties.use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'properties.webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'properties.alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'properties.javaVersion', 'type': 'str'}, + 'java_container': {'key': 'properties.javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'properties.javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'properties.appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'properties.managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'properties.virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'properties.loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'properties.experiments', 'type': 'Experiments'}, + 'limits': {'key': 'properties.limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'properties.autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'properties.autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'properties.tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'properties.vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'properties.vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'properties.cors', 'type': 'CorsSettings'}, + 'push': {'key': 'properties.push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'properties.apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'properties.apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'properties.autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'properties.managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'properties.xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'properties.ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'properties.scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'properties.scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'properties.http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'properties.minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'properties.scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'properties.ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'properties.preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'properties.healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + number_of_workers: Optional[int] = None, + default_documents: Optional[List[str]] = None, + net_framework_version: Optional[str] = "v4.6", + php_version: Optional[str] = None, + python_version: Optional[str] = None, + node_version: Optional[str] = None, + power_shell_version: Optional[str] = None, + linux_fx_version: Optional[str] = None, + windows_fx_version: Optional[str] = None, + request_tracing_enabled: Optional[bool] = None, + request_tracing_expiration_time: Optional[datetime.datetime] = None, + remote_debugging_enabled: Optional[bool] = None, + remote_debugging_version: Optional[str] = None, + http_logging_enabled: Optional[bool] = None, + logs_directory_size_limit: Optional[int] = None, + detailed_error_logging_enabled: Optional[bool] = None, + publishing_username: Optional[str] = None, + app_settings: Optional[List["NameValuePair"]] = None, + connection_strings: Optional[List["ConnStringInfo"]] = None, + handler_mappings: Optional[List["HandlerMapping"]] = None, + document_root: Optional[str] = None, + scm_type: Optional[Union[str, "ScmType"]] = None, + use32_bit_worker_process: Optional[bool] = None, + web_sockets_enabled: Optional[bool] = None, + always_on: Optional[bool] = None, + java_version: Optional[str] = None, + java_container: Optional[str] = None, + java_container_version: Optional[str] = None, + app_command_line: Optional[str] = None, + managed_pipeline_mode: Optional[Union[str, "ManagedPipelineMode"]] = None, + virtual_applications: Optional[List["VirtualApplication"]] = None, + load_balancing: Optional[Union[str, "SiteLoadBalancing"]] = None, + experiments: Optional["Experiments"] = None, + limits: Optional["SiteLimits"] = None, + auto_heal_enabled: Optional[bool] = None, + auto_heal_rules: Optional["AutoHealRules"] = None, + tracing_options: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_route_all_enabled: Optional[bool] = None, + vnet_private_ports_count: Optional[int] = None, + cors: Optional["CorsSettings"] = None, + push: Optional["PushSettings"] = None, + api_definition: Optional["ApiDefinitionInfo"] = None, + api_management_config: Optional["ApiManagementConfig"] = None, + auto_swap_slot_name: Optional[str] = None, + local_my_sql_enabled: Optional[bool] = False, + managed_service_identity_id: Optional[int] = None, + x_managed_service_identity_id: Optional[int] = None, + ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions_use_main: Optional[bool] = None, + http20_enabled: Optional[bool] = True, + min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + scm_min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + ftps_state: Optional[Union[str, "FtpsState"]] = None, + pre_warmed_instance_count: Optional[int] = None, + health_check_path: Optional[str] = None, + **kwargs + ): + super(SiteConfigResource, self).__init__(kind=kind, **kwargs) + self.number_of_workers = number_of_workers + self.default_documents = default_documents + self.net_framework_version = net_framework_version + self.php_version = php_version + self.python_version = python_version + self.node_version = node_version + self.power_shell_version = power_shell_version + self.linux_fx_version = linux_fx_version + self.windows_fx_version = windows_fx_version + self.request_tracing_enabled = request_tracing_enabled + self.request_tracing_expiration_time = request_tracing_expiration_time + self.remote_debugging_enabled = remote_debugging_enabled + self.remote_debugging_version = remote_debugging_version + self.http_logging_enabled = http_logging_enabled + self.logs_directory_size_limit = logs_directory_size_limit + self.detailed_error_logging_enabled = detailed_error_logging_enabled + self.publishing_username = publishing_username + self.app_settings = app_settings + self.connection_strings = connection_strings + self.machine_key = None + self.handler_mappings = handler_mappings + self.document_root = document_root + self.scm_type = scm_type + self.use32_bit_worker_process = use32_bit_worker_process + self.web_sockets_enabled = web_sockets_enabled + self.always_on = always_on + self.java_version = java_version + self.java_container = java_container + self.java_container_version = java_container_version + self.app_command_line = app_command_line + self.managed_pipeline_mode = managed_pipeline_mode + self.virtual_applications = virtual_applications + self.load_balancing = load_balancing + self.experiments = experiments + self.limits = limits + self.auto_heal_enabled = auto_heal_enabled + self.auto_heal_rules = auto_heal_rules + self.tracing_options = tracing_options + self.vnet_name = vnet_name + self.vnet_route_all_enabled = vnet_route_all_enabled + self.vnet_private_ports_count = vnet_private_ports_count + self.cors = cors + self.push = push + self.api_definition = api_definition + self.api_management_config = api_management_config + self.auto_swap_slot_name = auto_swap_slot_name + self.local_my_sql_enabled = local_my_sql_enabled + self.managed_service_identity_id = managed_service_identity_id + self.x_managed_service_identity_id = x_managed_service_identity_id + self.ip_security_restrictions = ip_security_restrictions + self.scm_ip_security_restrictions = scm_ip_security_restrictions + self.scm_ip_security_restrictions_use_main = scm_ip_security_restrictions_use_main + self.http20_enabled = http20_enabled + self.min_tls_version = min_tls_version + self.scm_min_tls_version = scm_min_tls_version + self.ftps_state = ftps_state + self.pre_warmed_instance_count = pre_warmed_instance_count + self.health_check_path = health_check_path + + +class SiteConfigResourceCollection(msrest.serialization.Model): + """Collection of site configurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteConfigResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteConfigResource"], + **kwargs + ): + super(SiteConfigResourceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteConfigurationSnapshotInfo(ProxyOnlyResource): + """A snapshot of a web app configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar time: The time the snapshot was taken. + :vartype time: ~datetime.datetime + :ivar snapshot_id: The id of the snapshot. + :vartype snapshot_id: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'time': {'readonly': True}, + 'snapshot_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'time': {'key': 'properties.time', 'type': 'iso-8601'}, + 'snapshot_id': {'key': 'properties.snapshotId', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(SiteConfigurationSnapshotInfo, self).__init__(kind=kind, **kwargs) + self.time = None + self.snapshot_id = None + + +class SiteConfigurationSnapshotInfoCollection(msrest.serialization.Model): + """Collection of metadata for the app configuration snapshots that can be restored. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigurationSnapshotInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteConfigurationSnapshotInfo"], + **kwargs + ): + super(SiteConfigurationSnapshotInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteExtensionInfo(ProxyOnlyResource): + """Site Extension Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param extension_id: Site extension ID. + :type extension_id: str + :param title: + :type title: str + :param extension_type: Site extension type. Possible values include: "Gallery", "WebRoot". + :type extension_type: str or ~azure.mgmt.web.v2020_06_01.models.SiteExtensionType + :param summary: Summary description. + :type summary: str + :param description: Detailed description. + :type description: str + :param version: Version information. + :type version: str + :param extension_url: Extension URL. + :type extension_url: str + :param project_url: Project URL. + :type project_url: str + :param icon_url: Icon URL. + :type icon_url: str + :param license_url: License URL. + :type license_url: str + :param feed_url: Feed URL. + :type feed_url: str + :param authors: List of authors. + :type authors: list[str] + :param installer_command_line_params: Installer command line parameters. + :type installer_command_line_params: str + :param published_date_time: Published timestamp. + :type published_date_time: ~datetime.datetime + :param download_count: Count of downloads. + :type download_count: int + :param local_is_latest_version: :code:`true` if the local version is the latest + version; :code:`false` otherwise. + :type local_is_latest_version: bool + :param local_path: Local path. + :type local_path: str + :param installed_date_time: Installed timestamp. + :type installed_date_time: ~datetime.datetime + :param provisioning_state: Provisioning state. + :type provisioning_state: str + :param comment: Site Extension comment. + :type comment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'extension_id': {'key': 'properties.extension_id', 'type': 'str'}, + 'title': {'key': 'properties.title', 'type': 'str'}, + 'extension_type': {'key': 'properties.extension_type', 'type': 'str'}, + 'summary': {'key': 'properties.summary', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'extension_url': {'key': 'properties.extension_url', 'type': 'str'}, + 'project_url': {'key': 'properties.project_url', 'type': 'str'}, + 'icon_url': {'key': 'properties.icon_url', 'type': 'str'}, + 'license_url': {'key': 'properties.license_url', 'type': 'str'}, + 'feed_url': {'key': 'properties.feed_url', 'type': 'str'}, + 'authors': {'key': 'properties.authors', 'type': '[str]'}, + 'installer_command_line_params': {'key': 'properties.installer_command_line_params', 'type': 'str'}, + 'published_date_time': {'key': 'properties.published_date_time', 'type': 'iso-8601'}, + 'download_count': {'key': 'properties.download_count', 'type': 'int'}, + 'local_is_latest_version': {'key': 'properties.local_is_latest_version', 'type': 'bool'}, + 'local_path': {'key': 'properties.local_path', 'type': 'str'}, + 'installed_date_time': {'key': 'properties.installed_date_time', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'comment': {'key': 'properties.comment', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + extension_id: Optional[str] = None, + title: Optional[str] = None, + extension_type: Optional[Union[str, "SiteExtensionType"]] = None, + summary: Optional[str] = None, + description: Optional[str] = None, + version: Optional[str] = None, + extension_url: Optional[str] = None, + project_url: Optional[str] = None, + icon_url: Optional[str] = None, + license_url: Optional[str] = None, + feed_url: Optional[str] = None, + authors: Optional[List[str]] = None, + installer_command_line_params: Optional[str] = None, + published_date_time: Optional[datetime.datetime] = None, + download_count: Optional[int] = None, + local_is_latest_version: Optional[bool] = None, + local_path: Optional[str] = None, + installed_date_time: Optional[datetime.datetime] = None, + provisioning_state: Optional[str] = None, + comment: Optional[str] = None, + **kwargs + ): + super(SiteExtensionInfo, self).__init__(kind=kind, **kwargs) + self.extension_id = extension_id + self.title = title + self.extension_type = extension_type + self.summary = summary + self.description = description + self.version = version + self.extension_url = extension_url + self.project_url = project_url + self.icon_url = icon_url + self.license_url = license_url + self.feed_url = feed_url + self.authors = authors + self.installer_command_line_params = installer_command_line_params + self.published_date_time = published_date_time + self.download_count = download_count + self.local_is_latest_version = local_is_latest_version + self.local_path = local_path + self.installed_date_time = installed_date_time + self.provisioning_state = provisioning_state + self.comment = comment + + +class SiteExtensionInfoCollection(msrest.serialization.Model): + """Collection of Kudu site extension information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteExtensionInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteExtensionInfo"], + **kwargs + ): + super(SiteExtensionInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteLimits(msrest.serialization.Model): + """Metric limits set on an app. + + :param max_percentage_cpu: Maximum allowed CPU usage percentage. + :type max_percentage_cpu: float + :param max_memory_in_mb: Maximum allowed memory usage in MB. + :type max_memory_in_mb: long + :param max_disk_size_in_mb: Maximum allowed disk size usage in MB. + :type max_disk_size_in_mb: long + """ + + _attribute_map = { + 'max_percentage_cpu': {'key': 'maxPercentageCpu', 'type': 'float'}, + 'max_memory_in_mb': {'key': 'maxMemoryInMb', 'type': 'long'}, + 'max_disk_size_in_mb': {'key': 'maxDiskSizeInMb', 'type': 'long'}, + } + + def __init__( + self, + *, + max_percentage_cpu: Optional[float] = None, + max_memory_in_mb: Optional[int] = None, + max_disk_size_in_mb: Optional[int] = None, + **kwargs + ): + super(SiteLimits, self).__init__(**kwargs) + self.max_percentage_cpu = max_percentage_cpu + self.max_memory_in_mb = max_memory_in_mb + self.max_disk_size_in_mb = max_disk_size_in_mb + + +class SiteLogsConfig(ProxyOnlyResource): + """Configuration of App Service site logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param application_logs: Application logs configuration. + :type application_logs: ~azure.mgmt.web.v2020_06_01.models.ApplicationLogsConfig + :param http_logs: HTTP logs configuration. + :type http_logs: ~azure.mgmt.web.v2020_06_01.models.HttpLogsConfig + :param failed_requests_tracing: Failed requests tracing configuration. + :type failed_requests_tracing: ~azure.mgmt.web.v2020_06_01.models.EnabledConfig + :param detailed_error_messages: Detailed error messages configuration. + :type detailed_error_messages: ~azure.mgmt.web.v2020_06_01.models.EnabledConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'application_logs': {'key': 'properties.applicationLogs', 'type': 'ApplicationLogsConfig'}, + 'http_logs': {'key': 'properties.httpLogs', 'type': 'HttpLogsConfig'}, + 'failed_requests_tracing': {'key': 'properties.failedRequestsTracing', 'type': 'EnabledConfig'}, + 'detailed_error_messages': {'key': 'properties.detailedErrorMessages', 'type': 'EnabledConfig'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + application_logs: Optional["ApplicationLogsConfig"] = None, + http_logs: Optional["HttpLogsConfig"] = None, + failed_requests_tracing: Optional["EnabledConfig"] = None, + detailed_error_messages: Optional["EnabledConfig"] = None, + **kwargs + ): + super(SiteLogsConfig, self).__init__(kind=kind, **kwargs) + self.application_logs = application_logs + self.http_logs = http_logs + self.failed_requests_tracing = failed_requests_tracing + self.detailed_error_messages = detailed_error_messages + + +class SiteMachineKey(msrest.serialization.Model): + """MachineKey of an app. + + :param validation: MachineKey validation. + :type validation: str + :param validation_key: Validation key. + :type validation_key: str + :param decryption: Algorithm used for decryption. + :type decryption: str + :param decryption_key: Decryption key. + :type decryption_key: str + """ + + _attribute_map = { + 'validation': {'key': 'validation', 'type': 'str'}, + 'validation_key': {'key': 'validationKey', 'type': 'str'}, + 'decryption': {'key': 'decryption', 'type': 'str'}, + 'decryption_key': {'key': 'decryptionKey', 'type': 'str'}, + } + + def __init__( + self, + *, + validation: Optional[str] = None, + validation_key: Optional[str] = None, + decryption: Optional[str] = None, + decryption_key: Optional[str] = None, + **kwargs + ): + super(SiteMachineKey, self).__init__(**kwargs) + self.validation = validation + self.validation_key = validation_key + self.decryption = decryption + self.decryption_key = decryption_key + + +class SitePatchResource(ProxyOnlyResource): + """ARM resource for a site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_06_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_06_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_06_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_06_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_06_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_06_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_06_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_06_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + identity: Optional["ManagedServiceIdentity"] = None, + enabled: Optional[bool] = None, + host_name_ssl_states: Optional[List["HostNameSslState"]] = None, + server_farm_id: Optional[str] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + site_config: Optional["SiteConfig"] = None, + scm_site_also_stopped: Optional[bool] = False, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + client_affinity_enabled: Optional[bool] = None, + client_cert_enabled: Optional[bool] = None, + client_cert_mode: Optional[Union[str, "ClientCertMode"]] = None, + client_cert_exclusion_paths: Optional[str] = None, + host_names_disabled: Optional[bool] = None, + custom_domain_verification_id: Optional[str] = None, + container_size: Optional[int] = None, + daily_memory_time_quota: Optional[int] = None, + cloning_info: Optional["CloningInfo"] = None, + https_only: Optional[bool] = None, + redundancy_mode: Optional[Union[str, "RedundancyMode"]] = None, + **kwargs + ): + super(SitePatchResource, self).__init__(kind=kind, **kwargs) + self.identity = identity + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = enabled + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = host_name_ssl_states + self.server_farm_id = server_farm_id + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.last_modified_time_utc = None + self.site_config = site_config + self.traffic_manager_host_names = None + self.scm_site_also_stopped = scm_site_also_stopped + self.target_swap_slot = None + self.hosting_environment_profile = hosting_environment_profile + self.client_affinity_enabled = client_affinity_enabled + self.client_cert_enabled = client_cert_enabled + self.client_cert_mode = client_cert_mode + self.client_cert_exclusion_paths = client_cert_exclusion_paths + self.host_names_disabled = host_names_disabled + self.custom_domain_verification_id = custom_domain_verification_id + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = container_size + self.daily_memory_time_quota = daily_memory_time_quota + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = cloning_info + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = https_only + self.redundancy_mode = redundancy_mode + self.in_progress_operation_id = None + + +class SitePhpErrorLogFlag(ProxyOnlyResource): + """Used for getting PHP error logging flag. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param local_log_errors: Local log_errors setting. + :type local_log_errors: str + :param master_log_errors: Master log_errors setting. + :type master_log_errors: str + :param local_log_errors_max_length: Local log_errors_max_len setting. + :type local_log_errors_max_length: str + :param master_log_errors_max_length: Master log_errors_max_len setting. + :type master_log_errors_max_length: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'local_log_errors': {'key': 'properties.localLogErrors', 'type': 'str'}, + 'master_log_errors': {'key': 'properties.masterLogErrors', 'type': 'str'}, + 'local_log_errors_max_length': {'key': 'properties.localLogErrorsMaxLength', 'type': 'str'}, + 'master_log_errors_max_length': {'key': 'properties.masterLogErrorsMaxLength', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + local_log_errors: Optional[str] = None, + master_log_errors: Optional[str] = None, + local_log_errors_max_length: Optional[str] = None, + master_log_errors_max_length: Optional[str] = None, + **kwargs + ): + super(SitePhpErrorLogFlag, self).__init__(kind=kind, **kwargs) + self.local_log_errors = local_log_errors + self.master_log_errors = master_log_errors + self.local_log_errors_max_length = local_log_errors_max_length + self.master_log_errors_max_length = master_log_errors_max_length + + +class SiteSeal(msrest.serialization.Model): + """Site seal. + + All required parameters must be populated in order to send to Azure. + + :param html: Required. HTML snippet. + :type html: str + """ + + _validation = { + 'html': {'required': True}, + } + + _attribute_map = { + 'html': {'key': 'html', 'type': 'str'}, + } + + def __init__( + self, + *, + html: str, + **kwargs + ): + super(SiteSeal, self).__init__(**kwargs) + self.html = html + + +class SiteSealRequest(msrest.serialization.Model): + """Site seal request. + + :param light_theme: If :code:`true` use the light color theme for site seal; + otherwise, use the default color theme. + :type light_theme: bool + :param locale: Locale of site seal. + :type locale: str + """ + + _attribute_map = { + 'light_theme': {'key': 'lightTheme', 'type': 'bool'}, + 'locale': {'key': 'locale', 'type': 'str'}, + } + + def __init__( + self, + *, + light_theme: Optional[bool] = None, + locale: Optional[str] = None, + **kwargs + ): + super(SiteSealRequest, self).__init__(**kwargs) + self.light_theme = light_theme + self.locale = locale + + +class SiteSourceControl(ProxyOnlyResource): + """Source control configuration for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repo_url: Repository or source control URL. + :type repo_url: str + :param branch: Name of branch to use for deployment. + :type branch: str + :param is_manual_integration: :code:`true` to limit to manual integration; + :code:`false` to enable continuous integration (which configures webhooks into + online repos like GitHub). + :type is_manual_integration: bool + :param is_git_hub_action: :code:`true` if this is deployed via GitHub action. + :type is_git_hub_action: bool + :param deployment_rollback_enabled: :code:`true` to enable deployment rollback; + otherwise, :code:`false`. + :type deployment_rollback_enabled: bool + :param is_mercurial: :code:`true` for a Mercurial repository; + :code:`false` for a Git repository. + :type is_mercurial: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repo_url': {'key': 'properties.repoUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'is_manual_integration': {'key': 'properties.isManualIntegration', 'type': 'bool'}, + 'is_git_hub_action': {'key': 'properties.isGitHubAction', 'type': 'bool'}, + 'deployment_rollback_enabled': {'key': 'properties.deploymentRollbackEnabled', 'type': 'bool'}, + 'is_mercurial': {'key': 'properties.isMercurial', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repo_url: Optional[str] = None, + branch: Optional[str] = None, + is_manual_integration: Optional[bool] = None, + is_git_hub_action: Optional[bool] = None, + deployment_rollback_enabled: Optional[bool] = None, + is_mercurial: Optional[bool] = None, + **kwargs + ): + super(SiteSourceControl, self).__init__(kind=kind, **kwargs) + self.repo_url = repo_url + self.branch = branch + self.is_manual_integration = is_manual_integration + self.is_git_hub_action = is_git_hub_action + self.deployment_rollback_enabled = deployment_rollback_enabled + self.is_mercurial = is_mercurial + + +class SkuCapacity(msrest.serialization.Model): + """Description of the App Service plan scale options. + + :param minimum: Minimum number of workers for this App Service plan SKU. + :type minimum: int + :param maximum: Maximum number of workers for this App Service plan SKU. + :type maximum: int + :param default: Default number of workers for this App Service plan SKU. + :type default: int + :param scale_type: Available scale configurations for an App Service plan. + :type scale_type: str + """ + + _attribute_map = { + 'minimum': {'key': 'minimum', 'type': 'int'}, + 'maximum': {'key': 'maximum', 'type': 'int'}, + 'default': {'key': 'default', 'type': 'int'}, + 'scale_type': {'key': 'scaleType', 'type': 'str'}, + } + + def __init__( + self, + *, + minimum: Optional[int] = None, + maximum: Optional[int] = None, + default: Optional[int] = None, + scale_type: Optional[str] = None, + **kwargs + ): + super(SkuCapacity, self).__init__(**kwargs) + self.minimum = minimum + self.maximum = maximum + self.default = default + self.scale_type = scale_type + + +class SkuDescription(msrest.serialization.Model): + """Description of a SKU for a scalable resource. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Current number of instances assigned to the resource. + :type capacity: int + :param sku_capacity: Min, max, and default scale values of the SKU. + :type sku_capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_06_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + 'sku_capacity': {'key': 'skuCapacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[str] = None, + size: Optional[str] = None, + family: Optional[str] = None, + capacity: Optional[int] = None, + sku_capacity: Optional["SkuCapacity"] = None, + locations: Optional[List[str]] = None, + capabilities: Optional[List["Capability"]] = None, + **kwargs + ): + super(SkuDescription, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.size = size + self.family = family + self.capacity = capacity + self.sku_capacity = sku_capacity + self.locations = locations + self.capabilities = capabilities + + +class SkuInfo(msrest.serialization.Model): + """SKU discovery information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param sku: Name and tier of the SKU. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_06_01.models.SkuCapacity + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + sku: Optional["SkuDescription"] = None, + capacity: Optional["SkuCapacity"] = None, + **kwargs + ): + super(SkuInfo, self).__init__(**kwargs) + self.resource_type = resource_type + self.sku = sku + self.capacity = capacity + + +class SkuInfoCollection(msrest.serialization.Model): + """Collection of SKU information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SkuInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SkuInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SkuInfo"], + **kwargs + ): + super(SkuInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SkuInfos(msrest.serialization.Model): + """Collection of SKU information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param skus: List of SKUs the subscription is able to use. + :type skus: list[~azure.mgmt.web.v2020_06_01.models.GlobalCsmSkuDescription] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'skus': {'key': 'skus', 'type': '[GlobalCsmSkuDescription]'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + skus: Optional[List["GlobalCsmSkuDescription"]] = None, + **kwargs + ): + super(SkuInfos, self).__init__(**kwargs) + self.resource_type = resource_type + self.skus = skus + + +class SlotConfigNamesResource(ProxyOnlyResource): + """Slot Config names azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param connection_string_names: List of connection string names. + :type connection_string_names: list[str] + :param app_setting_names: List of application settings names. + :type app_setting_names: list[str] + :param azure_storage_config_names: List of external Azure storage account identifiers. + :type azure_storage_config_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'connection_string_names': {'key': 'properties.connectionStringNames', 'type': '[str]'}, + 'app_setting_names': {'key': 'properties.appSettingNames', 'type': '[str]'}, + 'azure_storage_config_names': {'key': 'properties.azureStorageConfigNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + connection_string_names: Optional[List[str]] = None, + app_setting_names: Optional[List[str]] = None, + azure_storage_config_names: Optional[List[str]] = None, + **kwargs + ): + super(SlotConfigNamesResource, self).__init__(kind=kind, **kwargs) + self.connection_string_names = connection_string_names + self.app_setting_names = app_setting_names + self.azure_storage_config_names = azure_storage_config_names + + +class SlotDifference(ProxyOnlyResource): + """A setting difference between two deployment slots of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar level: Level of the difference: Information, Warning or Error. + :vartype level: str + :ivar setting_type: The type of the setting: General, AppSetting or ConnectionString. + :vartype setting_type: str + :ivar diff_rule: Rule that describes how to process the setting difference during a slot swap. + :vartype diff_rule: str + :ivar setting_name: Name of the setting. + :vartype setting_name: str + :ivar value_in_current_slot: Value of the setting in the current slot. + :vartype value_in_current_slot: str + :ivar value_in_target_slot: Value of the setting in the target slot. + :vartype value_in_target_slot: str + :ivar description: Description of the setting difference. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'level': {'readonly': True}, + 'setting_type': {'readonly': True}, + 'diff_rule': {'readonly': True}, + 'setting_name': {'readonly': True}, + 'value_in_current_slot': {'readonly': True}, + 'value_in_target_slot': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'setting_type': {'key': 'properties.settingType', 'type': 'str'}, + 'diff_rule': {'key': 'properties.diffRule', 'type': 'str'}, + 'setting_name': {'key': 'properties.settingName', 'type': 'str'}, + 'value_in_current_slot': {'key': 'properties.valueInCurrentSlot', 'type': 'str'}, + 'value_in_target_slot': {'key': 'properties.valueInTargetSlot', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(SlotDifference, self).__init__(kind=kind, **kwargs) + self.level = None + self.setting_type = None + self.diff_rule = None + self.setting_name = None + self.value_in_current_slot = None + self.value_in_target_slot = None + self.description = None + + +class SlotDifferenceCollection(msrest.serialization.Model): + """Collection of slot differences. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SlotDifference] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SlotDifference]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SlotDifference"], + **kwargs + ): + super(SlotDifferenceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SlotSwapStatus(msrest.serialization.Model): + """The status of the last successful slot swap operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar timestamp_utc: The time the last successful slot swap completed. + :vartype timestamp_utc: ~datetime.datetime + :ivar source_slot_name: The source slot of the last swap operation. + :vartype source_slot_name: str + :ivar destination_slot_name: The destination slot of the last swap operation. + :vartype destination_slot_name: str + """ + + _validation = { + 'timestamp_utc': {'readonly': True}, + 'source_slot_name': {'readonly': True}, + 'destination_slot_name': {'readonly': True}, + } + + _attribute_map = { + 'timestamp_utc': {'key': 'timestampUtc', 'type': 'iso-8601'}, + 'source_slot_name': {'key': 'sourceSlotName', 'type': 'str'}, + 'destination_slot_name': {'key': 'destinationSlotName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotSwapStatus, self).__init__(**kwargs) + self.timestamp_utc = None + self.source_slot_name = None + self.destination_slot_name = None + + +class SlowRequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on request execution time. + + :param time_taken: Time taken. + :type time_taken: str + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'time_taken': {'key': 'timeTaken', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + time_taken: Optional[str] = None, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(SlowRequestsBasedTrigger, self).__init__(**kwargs) + self.time_taken = time_taken + self.count = count + self.time_interval = time_interval + + +class Snapshot(ProxyOnlyResource): + """A snapshot of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar time: The time the snapshot was taken. + :vartype time: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'time': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'time': {'key': 'properties.time', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(Snapshot, self).__init__(kind=kind, **kwargs) + self.time = None + + +class SnapshotCollection(msrest.serialization.Model): + """Collection of snapshots which can be used to revert an app to a previous time. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Snapshot] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Snapshot]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Snapshot"], + **kwargs + ): + super(SnapshotCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SnapshotRecoverySource(msrest.serialization.Model): + """Specifies the web app that snapshot contents will be retrieved from. + + :param location: Geographical location of the source web app, e.g. SouthEastAsia, + SouthCentralUS. + :type location: str + :param id: ARM resource ID of the source app. + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type id: str + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + id: Optional[str] = None, + **kwargs + ): + super(SnapshotRecoverySource, self).__init__(**kwargs) + self.location = location + self.id = id + + +class SnapshotRestoreRequest(ProxyOnlyResource): + """Details about app recovery operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param snapshot_time: Point in time in which the app restore should be done, formatted as a + DateTime string. + :type snapshot_time: str + :param recovery_source: Optional. Specifies the web app that snapshot contents will be + retrieved from. + If empty, the targeted web app will be used as the source. + :type recovery_source: ~azure.mgmt.web.v2020_06_01.models.SnapshotRecoverySource + :param overwrite: If :code:`true` the restore operation can overwrite source app; + otherwise, :code:`false`. + :type overwrite: bool + :param recover_configuration: If true, site configuration, in addition to content, will be + reverted. + :type recover_configuration: bool + :param ignore_conflicting_host_names: If true, custom hostname conflicts will be ignored when + recovering to a target web app. + This setting is only necessary when RecoverConfiguration is enabled. + :type ignore_conflicting_host_names: bool + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'recovery_source': {'key': 'properties.recoverySource', 'type': 'SnapshotRecoverySource'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + snapshot_time: Optional[str] = None, + recovery_source: Optional["SnapshotRecoverySource"] = None, + overwrite: Optional[bool] = None, + recover_configuration: Optional[bool] = None, + ignore_conflicting_host_names: Optional[bool] = None, + use_dr_secondary: Optional[bool] = None, + **kwargs + ): + super(SnapshotRestoreRequest, self).__init__(kind=kind, **kwargs) + self.snapshot_time = snapshot_time + self.recovery_source = recovery_source + self.overwrite = overwrite + self.recover_configuration = recover_configuration + self.ignore_conflicting_host_names = ignore_conflicting_host_names + self.use_dr_secondary = use_dr_secondary + + +class Solution(msrest.serialization.Model): + """Class Representing Solution for problems detected. + + :param id: Solution Id. + :type id: float + :param display_name: Display Name of the solution. + :type display_name: str + :param order: Order of the solution. + :type order: float + :param description: Description of the solution. + :type description: str + :param type: Type of Solution. Possible values include: "QuickSolution", "DeepInvestigation", + "BestPractices". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.SolutionType + :param data: Solution Data. + :type data: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + :param metadata: Solution Metadata. + :type metadata: list[list[~azure.mgmt.web.v2020_06_01.models.NameValuePair]] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'float'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'float'}, + 'description': {'key': 'description', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'metadata': {'key': 'metadata', 'type': '[[NameValuePair]]'}, + } + + def __init__( + self, + *, + id: Optional[float] = None, + display_name: Optional[str] = None, + order: Optional[float] = None, + description: Optional[str] = None, + type: Optional[Union[str, "SolutionType"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + metadata: Optional[List[List["NameValuePair"]]] = None, + **kwargs + ): + super(Solution, self).__init__(**kwargs) + self.id = id + self.display_name = display_name + self.order = order + self.description = description + self.type = type + self.data = data + self.metadata = metadata + + +class SourceControl(ProxyOnlyResource): + """The source control OAuth token. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param token: OAuth access token. + :type token: str + :param token_secret: OAuth access token secret. + :type token_secret: str + :param refresh_token: OAuth refresh token. + :type refresh_token: str + :param expiration_time: OAuth token expiration. + :type expiration_time: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'token': {'key': 'properties.token', 'type': 'str'}, + 'token_secret': {'key': 'properties.tokenSecret', 'type': 'str'}, + 'refresh_token': {'key': 'properties.refreshToken', 'type': 'str'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + token: Optional[str] = None, + token_secret: Optional[str] = None, + refresh_token: Optional[str] = None, + expiration_time: Optional[datetime.datetime] = None, + **kwargs + ): + super(SourceControl, self).__init__(kind=kind, **kwargs) + self.token = token + self.token_secret = token_secret + self.refresh_token = refresh_token + self.expiration_time = expiration_time + + +class SourceControlCollection(msrest.serialization.Model): + """Collection of source controls. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.SourceControl] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SourceControl]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SourceControl"], + **kwargs + ): + super(SourceControlCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StackMajorVersion(msrest.serialization.Model): + """Application stack major version. + + :param display_version: Application stack major version (display only). + :type display_version: str + :param runtime_version: Application stack major version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default major version; otherwise, + :code:`false`. + :type is_default: bool + :param minor_versions: Minor versions associated with the major version. + :type minor_versions: list[~azure.mgmt.web.v2020_06_01.models.StackMinorVersion] + :param application_insights: :code:`true` if this supports Application Insights; + otherwise, :code:`false`. + :type application_insights: bool + :param is_preview: :code:`true` if this stack is in Preview, otherwise + :code:`false`. + :type is_preview: bool + :param is_deprecated: :code:`true` if this stack has been deprecated, otherwise + :code:`false`. + :type is_deprecated: bool + :param is_hidden: :code:`true` if this stack should be hidden for new customers on + portal, otherwise :code:`false`. + :type is_hidden: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'minor_versions': {'key': 'minorVersions', 'type': '[StackMinorVersion]'}, + 'application_insights': {'key': 'applicationInsights', 'type': 'bool'}, + 'is_preview': {'key': 'isPreview', 'type': 'bool'}, + 'is_deprecated': {'key': 'isDeprecated', 'type': 'bool'}, + 'is_hidden': {'key': 'isHidden', 'type': 'bool'}, + } + + def __init__( + self, + *, + display_version: Optional[str] = None, + runtime_version: Optional[str] = None, + is_default: Optional[bool] = None, + minor_versions: Optional[List["StackMinorVersion"]] = None, + application_insights: Optional[bool] = None, + is_preview: Optional[bool] = None, + is_deprecated: Optional[bool] = None, + is_hidden: Optional[bool] = None, + **kwargs + ): + super(StackMajorVersion, self).__init__(**kwargs) + self.display_version = display_version + self.runtime_version = runtime_version + self.is_default = is_default + self.minor_versions = minor_versions + self.application_insights = application_insights + self.is_preview = is_preview + self.is_deprecated = is_deprecated + self.is_hidden = is_hidden + + +class StackMinorVersion(msrest.serialization.Model): + """Application stack minor version. + + :param display_version: Application stack minor version (display only). + :type display_version: str + :param runtime_version: Application stack minor version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default minor version; otherwise, + :code:`false`. + :type is_default: bool + :param is_remote_debugging_enabled: :code:`true` if this supports Remote + Debugging, otherwise :code:`false`. + :type is_remote_debugging_enabled: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'is_remote_debugging_enabled': {'key': 'isRemoteDebuggingEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + display_version: Optional[str] = None, + runtime_version: Optional[str] = None, + is_default: Optional[bool] = None, + is_remote_debugging_enabled: Optional[bool] = None, + **kwargs + ): + super(StackMinorVersion, self).__init__(**kwargs) + self.display_version = display_version + self.runtime_version = runtime_version + self.is_default = is_default + self.is_remote_debugging_enabled = is_remote_debugging_enabled + + +class StampCapacity(msrest.serialization.Model): + """Stamp capacity information. + + :param name: Name of the stamp. + :type name: str + :param available_capacity: Available capacity (# of machines, bytes of storage etc...). + :type available_capacity: long + :param total_capacity: Total capacity (# of machines, bytes of storage etc...). + :type total_capacity: long + :param unit: Name of the unit. + :type unit: str + :param compute_mode: Shared/dedicated workers. Possible values include: "Shared", "Dedicated", + "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: Size of the machines. Possible values include: "Small", "Medium", "Large", + "D1", "D2", "D3", "NestedSmall", "Default". + :type worker_size: str or ~azure.mgmt.web.v2020_06_01.models.WorkerSizeOptions + :param worker_size_id: Size ID of machines: + 0 - Small + 1 - Medium + 2 - Large. + :type worker_size_id: int + :param exclude_from_capacity_allocation: If :code:`true`, it includes basic apps. + Basic apps are not used for capacity allocation. + :type exclude_from_capacity_allocation: bool + :param is_applicable_for_all_compute_modes: :code:`true` if capacity is applicable + for all apps; otherwise, :code:`false`. + :type is_applicable_for_all_compute_modes: bool + :param site_mode: Shared or Dedicated. + :type site_mode: str + :param is_linux: Is this a linux stamp capacity. + :type is_linux: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available_capacity': {'key': 'availableCapacity', 'type': 'long'}, + 'total_capacity': {'key': 'totalCapacity', 'type': 'long'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'exclude_from_capacity_allocation': {'key': 'excludeFromCapacityAllocation', 'type': 'bool'}, + 'is_applicable_for_all_compute_modes': {'key': 'isApplicableForAllComputeModes', 'type': 'bool'}, + 'site_mode': {'key': 'siteMode', 'type': 'str'}, + 'is_linux': {'key': 'isLinux', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + available_capacity: Optional[int] = None, + total_capacity: Optional[int] = None, + unit: Optional[str] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[Union[str, "WorkerSizeOptions"]] = None, + worker_size_id: Optional[int] = None, + exclude_from_capacity_allocation: Optional[bool] = None, + is_applicable_for_all_compute_modes: Optional[bool] = None, + site_mode: Optional[str] = None, + is_linux: Optional[bool] = None, + **kwargs + ): + super(StampCapacity, self).__init__(**kwargs) + self.name = name + self.available_capacity = available_capacity + self.total_capacity = total_capacity + self.unit = unit + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_size_id = worker_size_id + self.exclude_from_capacity_allocation = exclude_from_capacity_allocation + self.is_applicable_for_all_compute_modes = is_applicable_for_all_compute_modes + self.site_mode = site_mode + self.is_linux = is_linux + + +class StampCapacityCollection(msrest.serialization.Model): + """Collection of stamp capacities. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StampCapacity] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StampCapacity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StampCapacity"], + **kwargs + ): + super(StampCapacityCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteARMResource(Resource): + """Static Site ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["SkuDescription"] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + repository_token: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSiteARMResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.default_hostname = None + self.repository_url = repository_url + self.branch = branch + self.custom_domains = None + self.repository_token = repository_token + self.build_properties = build_properties + + +class StaticSiteBuildARMResource(ProxyOnlyResource): + """Static Site Build ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar build_id: An identifier for the static site build. + :vartype build_id: str + :ivar source_branch: The source branch. + :vartype source_branch: str + :ivar pull_request_title: The title of a pull request that a static site build is related to. + :vartype pull_request_title: str + :ivar hostname: The hostname for a static site build. + :vartype hostname: str + :ivar created_time_utc: When this build was created. + :vartype created_time_utc: ~datetime.datetime + :ivar last_updated_on: When this build was updated. + :vartype last_updated_on: ~datetime.datetime + :ivar status: The status of the static site build. Possible values include: + "WaitingForDeployment", "Uploading", "Deploying", "Ready", "Failed", "Deleting", "Detached". + :vartype status: str or ~azure.mgmt.web.v2020_06_01.models.BuildStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'build_id': {'readonly': True}, + 'source_branch': {'readonly': True}, + 'pull_request_title': {'readonly': True}, + 'hostname': {'readonly': True}, + 'created_time_utc': {'readonly': True}, + 'last_updated_on': {'readonly': True}, + 'status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'build_id': {'key': 'properties.buildId', 'type': 'str'}, + 'source_branch': {'key': 'properties.sourceBranch', 'type': 'str'}, + 'pull_request_title': {'key': 'properties.pullRequestTitle', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'created_time_utc': {'key': 'properties.createdTimeUtc', 'type': 'iso-8601'}, + 'last_updated_on': {'key': 'properties.lastUpdatedOn', 'type': 'iso-8601'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteBuildARMResource, self).__init__(kind=kind, **kwargs) + self.build_id = None + self.source_branch = None + self.pull_request_title = None + self.hostname = None + self.created_time_utc = None + self.last_updated_on = None + self.status = None + + +class StaticSiteBuildCollection(msrest.serialization.Model): + """Collection of static site builds. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteBuildARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteBuildARMResource"], + **kwargs + ): + super(StaticSiteBuildCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteBuildProperties(msrest.serialization.Model): + """Build properties for the static site. + + :param app_location: The path to the app code within the repository. + :type app_location: str + :param api_location: The path to the api code within the repository. + :type api_location: str + :param app_artifact_location: The path of the app artifacts after building. + :type app_artifact_location: str + """ + + _attribute_map = { + 'app_location': {'key': 'appLocation', 'type': 'str'}, + 'api_location': {'key': 'apiLocation', 'type': 'str'}, + 'app_artifact_location': {'key': 'appArtifactLocation', 'type': 'str'}, + } + + def __init__( + self, + *, + app_location: Optional[str] = None, + api_location: Optional[str] = None, + app_artifact_location: Optional[str] = None, + **kwargs + ): + super(StaticSiteBuildProperties, self).__init__(**kwargs) + self.app_location = app_location + self.api_location = api_location + self.app_artifact_location = app_artifact_location + + +class StaticSiteCollection(msrest.serialization.Model): + """Collection of static sites. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteARMResource"], + **kwargs + ): + super(StaticSiteCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteCustomDomainOverviewARMResource(ProxyOnlyResource): + """Static Site Custom Domain Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar domain_name: The domain name for the static site custom domain. + :vartype domain_name: str + :ivar created_on: The date and time on which the custom domain was created for the static site. + :vartype created_on: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'domain_name': {'readonly': True}, + 'created_on': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'properties.domainName', 'type': 'str'}, + 'created_on': {'key': 'properties.createdOn', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteCustomDomainOverviewARMResource, self).__init__(kind=kind, **kwargs) + self.domain_name = None + self.created_on = None + + +class StaticSiteCustomDomainOverviewCollection(msrest.serialization.Model): + """Collection of static site custom domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteCustomDomainOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteCustomDomainOverviewARMResource"], + **kwargs + ): + super(StaticSiteCustomDomainOverviewCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteFunctionOverviewARMResource(ProxyOnlyResource): + """Static Site Function Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar function_name: The name for the function. + :vartype function_name: str + :ivar trigger_type: The trigger type of the function. Possible values include: "HttpTrigger", + "Unknown". + :vartype trigger_type: str or ~azure.mgmt.web.v2020_06_01.models.TriggerTypes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'function_name': {'readonly': True}, + 'trigger_type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'function_name': {'key': 'properties.functionName', 'type': 'str'}, + 'trigger_type': {'key': 'properties.triggerType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteFunctionOverviewARMResource, self).__init__(kind=kind, **kwargs) + self.function_name = None + self.trigger_type = None + + +class StaticSiteFunctionOverviewCollection(msrest.serialization.Model): + """Collection of static site functions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteFunctionOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteFunctionOverviewARMResource"], + **kwargs + ): + super(StaticSiteFunctionOverviewCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSitePatchResource(ProxyOnlyResource): + """ARM resource for a static site when patching. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + repository_token: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSitePatchResource, self).__init__(kind=kind, **kwargs) + self.default_hostname = None + self.repository_url = repository_url + self.branch = branch + self.custom_domains = None + self.repository_token = repository_token + self.build_properties = build_properties + + +class StaticSiteResetPropertiesARMResource(ProxyOnlyResource): + """Static Site Reset Properties ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repository_token: The token which proves admin privileges to the repository. + :type repository_token: str + :param should_update_repository: Determines whether the repository should be updated with the + new properties. + :type should_update_repository: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'should_update_repository': {'key': 'properties.shouldUpdateRepository', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_token: Optional[str] = None, + should_update_repository: Optional[bool] = None, + **kwargs + ): + super(StaticSiteResetPropertiesARMResource, self).__init__(kind=kind, **kwargs) + self.repository_token = repository_token + self.should_update_repository = should_update_repository + + +class StaticSitesWorkflowPreview(ProxyOnlyResource): + """Preview for the Static Site Workflow to be generated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar path: The path for the workflow file to be generated. + :vartype path: str + :ivar contents: The contents for the workflow file to be generated. + :vartype contents: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'path': {'readonly': True}, + 'contents': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'contents': {'key': 'properties.contents', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSitesWorkflowPreview, self).__init__(kind=kind, **kwargs) + self.path = None + self.contents = None + + +class StaticSitesWorkflowPreviewRequest(ProxyOnlyResource): + """Request entity for previewing the Static Site workflow. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSitesWorkflowPreviewRequest, self).__init__(kind=kind, **kwargs) + self.repository_url = repository_url + self.branch = branch + self.build_properties = build_properties + + +class StaticSiteUserARMResource(ProxyOnlyResource): + """Static Site User ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar provider: The identity provider for the static site user. + :vartype provider: str + :ivar user_id: The user id for the static site user. + :vartype user_id: str + :ivar display_name: The display name for the static site user. + :vartype display_name: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'provider': {'readonly': True}, + 'user_id': {'readonly': True}, + 'display_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_id': {'key': 'properties.userId', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + roles: Optional[str] = None, + **kwargs + ): + super(StaticSiteUserARMResource, self).__init__(kind=kind, **kwargs) + self.provider = None + self.user_id = None + self.display_name = None + self.roles = roles + + +class StaticSiteUserCollection(msrest.serialization.Model): + """Collection of static site custom users. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteUserARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteUserARMResource"], + **kwargs + ): + super(StaticSiteUserCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteUserInvitationRequestResource(ProxyOnlyResource): + """Static sites user roles invitation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param domain: The domain name for the static site custom domain. + :type domain: str + :param provider: The identity provider for the static site user. + :type provider: str + :param user_details: The user id for the static site user. + :type user_details: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + :param num_hours_to_expiration: The number of hours the sas token stays valid. + :type num_hours_to_expiration: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'domain': {'key': 'properties.domain', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_details': {'key': 'properties.userDetails', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + 'num_hours_to_expiration': {'key': 'properties.numHoursToExpiration', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + domain: Optional[str] = None, + provider: Optional[str] = None, + user_details: Optional[str] = None, + roles: Optional[str] = None, + num_hours_to_expiration: Optional[int] = None, + **kwargs + ): + super(StaticSiteUserInvitationRequestResource, self).__init__(kind=kind, **kwargs) + self.domain = domain + self.provider = provider + self.user_details = user_details + self.roles = roles + self.num_hours_to_expiration = num_hours_to_expiration + + +class StaticSiteUserInvitationResponseResource(ProxyOnlyResource): + """Static sites user roles invitation link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar expires_on: The expiration time of the invitation. + :vartype expires_on: ~datetime.datetime + :ivar invitation_url: The url for the invitation link. + :vartype invitation_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'expires_on': {'readonly': True}, + 'invitation_url': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'invitation_url': {'key': 'properties.invitationUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteUserInvitationResponseResource, self).__init__(kind=kind, **kwargs) + self.expires_on = None + self.invitation_url = None + + +class StatusCodesBasedTrigger(msrest.serialization.Model): + """Trigger based on status code. + + :param status: HTTP status code. + :type status: int + :param sub_status: Request Sub Status. + :type sub_status: int + :param win32_status: Win32 error code. + :type win32_status: int + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'int'}, + 'sub_status': {'key': 'subStatus', 'type': 'int'}, + 'win32_status': {'key': 'win32Status', 'type': 'int'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + status: Optional[int] = None, + sub_status: Optional[int] = None, + win32_status: Optional[int] = None, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(StatusCodesBasedTrigger, self).__init__(**kwargs) + self.status = status + self.sub_status = sub_status + self.win32_status = win32_status + self.count = count + self.time_interval = time_interval + + +class StorageMigrationOptions(ProxyOnlyResource): + """Options for app content migration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param azurefiles_connection_string: AzureFiles connection string. + :type azurefiles_connection_string: str + :param azurefiles_share: AzureFiles share. + :type azurefiles_share: str + :param switch_site_after_migration: :code:`true`if the app should be switched + over; otherwise, :code:`false`. + :type switch_site_after_migration: bool + :param block_write_access_to_site: :code:`true` if the app should be read only + during copy operation; otherwise, :code:`false`. + :type block_write_access_to_site: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'azurefiles_connection_string': {'key': 'properties.azurefilesConnectionString', 'type': 'str'}, + 'azurefiles_share': {'key': 'properties.azurefilesShare', 'type': 'str'}, + 'switch_site_after_migration': {'key': 'properties.switchSiteAfterMigration', 'type': 'bool'}, + 'block_write_access_to_site': {'key': 'properties.blockWriteAccessToSite', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + azurefiles_connection_string: Optional[str] = None, + azurefiles_share: Optional[str] = None, + switch_site_after_migration: Optional[bool] = False, + block_write_access_to_site: Optional[bool] = False, + **kwargs + ): + super(StorageMigrationOptions, self).__init__(kind=kind, **kwargs) + self.azurefiles_connection_string = azurefiles_connection_string + self.azurefiles_share = azurefiles_share + self.switch_site_after_migration = switch_site_after_migration + self.block_write_access_to_site = block_write_access_to_site + + +class StorageMigrationResponse(ProxyOnlyResource): + """Response for a migration of app content request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar operation_id: When server starts the migration process, it will return an operation ID + identifying that particular migration operation. + :vartype operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StorageMigrationResponse, self).__init__(kind=kind, **kwargs) + self.operation_id = None + + +class StringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param properties: Settings. + :type properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, str]] = None, + **kwargs + ): + super(StringDictionary, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class SwiftVirtualNetwork(ProxyOnlyResource): + """Swift Virtual Network Contract. This is used to enable the new Swift way of doing virtual network integration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param subnet_resource_id: The Virtual Network subnet's resource ID. This is the subnet that + this Web App will join. This subnet must have a delegation to Microsoft.Web/serverFarms defined + first. + :type subnet_resource_id: str + :param swift_supported: A flag that specifies if the scale unit this Web App is on supports + Swift integration. + :type swift_supported: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet_resource_id': {'key': 'properties.subnetResourceId', 'type': 'str'}, + 'swift_supported': {'key': 'properties.swiftSupported', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + subnet_resource_id: Optional[str] = None, + swift_supported: Optional[bool] = None, + **kwargs + ): + super(SwiftVirtualNetwork, self).__init__(kind=kind, **kwargs) + self.subnet_resource_id = subnet_resource_id + self.swift_supported = swift_supported + + +class TldLegalAgreement(msrest.serialization.Model): + """Legal agreement for a top level domain. + + All required parameters must be populated in order to send to Azure. + + :param agreement_key: Required. Unique identifier for the agreement. + :type agreement_key: str + :param title: Required. Agreement title. + :type title: str + :param content: Required. Agreement details. + :type content: str + :param url: URL where a copy of the agreement details is hosted. + :type url: str + """ + + _validation = { + 'agreement_key': {'required': True}, + 'title': {'required': True}, + 'content': {'required': True}, + } + + _attribute_map = { + 'agreement_key': {'key': 'agreementKey', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'content': {'key': 'content', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + *, + agreement_key: str, + title: str, + content: str, + url: Optional[str] = None, + **kwargs + ): + super(TldLegalAgreement, self).__init__(**kwargs) + self.agreement_key = agreement_key + self.title = title + self.content = content + self.url = url + + +class TldLegalAgreementCollection(msrest.serialization.Model): + """Collection of top-level domain legal agreements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TldLegalAgreement] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TldLegalAgreement]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TldLegalAgreement"], + **kwargs + ): + super(TldLegalAgreementCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TokenStore(ProxyOnlyResource): + """TokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param token_refresh_extension_hours: + :type token_refresh_extension_hours: float + :param file_system: + :type file_system: ~azure.mgmt.web.v2020_06_01.models.FileSystemTokenStore + :param azure_blob_storage: + :type azure_blob_storage: ~azure.mgmt.web.v2020_06_01.models.BlobStorageTokenStore + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'file_system': {'key': 'properties.fileSystem', 'type': 'FileSystemTokenStore'}, + 'azure_blob_storage': {'key': 'properties.azureBlobStorage', 'type': 'BlobStorageTokenStore'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + token_refresh_extension_hours: Optional[float] = None, + file_system: Optional["FileSystemTokenStore"] = None, + azure_blob_storage: Optional["BlobStorageTokenStore"] = None, + **kwargs + ): + super(TokenStore, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.token_refresh_extension_hours = token_refresh_extension_hours + self.file_system = file_system + self.azure_blob_storage = azure_blob_storage + + +class TopLevelDomain(ProxyOnlyResource): + """A top level domain object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param privacy: If :code:`true`, then the top level domain supports domain + privacy; otherwise, :code:`false`. + :type privacy: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + privacy: Optional[bool] = None, + **kwargs + ): + super(TopLevelDomain, self).__init__(kind=kind, **kwargs) + self.privacy = privacy + + +class TopLevelDomainAgreementOption(msrest.serialization.Model): + """Options for retrieving the list of top level domain legal agreements. + + :param include_privacy: If :code:`true`, then the list of agreements will include + agreements for domain privacy as well; otherwise, :code:`false`. + :type include_privacy: bool + :param for_transfer: If :code:`true`, then the list of agreements will include + agreements for domain transfer as well; otherwise, :code:`false`. + :type for_transfer: bool + """ + + _attribute_map = { + 'include_privacy': {'key': 'includePrivacy', 'type': 'bool'}, + 'for_transfer': {'key': 'forTransfer', 'type': 'bool'}, + } + + def __init__( + self, + *, + include_privacy: Optional[bool] = None, + for_transfer: Optional[bool] = None, + **kwargs + ): + super(TopLevelDomainAgreementOption, self).__init__(**kwargs) + self.include_privacy = include_privacy + self.for_transfer = for_transfer + + +class TopLevelDomainCollection(msrest.serialization.Model): + """Collection of Top-level domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TopLevelDomain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TopLevelDomain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TopLevelDomain"], + **kwargs + ): + super(TopLevelDomainCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TriggeredJobHistory(ProxyOnlyResource): + """Triggered Web Job History. List of Triggered Web Job Run Information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param runs: List of triggered web job runs. + :type runs: list[~azure.mgmt.web.v2020_06_01.models.TriggeredJobRun] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'runs': {'key': 'properties.runs', 'type': '[TriggeredJobRun]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + runs: Optional[List["TriggeredJobRun"]] = None, + **kwargs + ): + super(TriggeredJobHistory, self).__init__(kind=kind, **kwargs) + self.runs = runs + + +class TriggeredJobHistoryCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredJobHistory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TriggeredJobHistory"], + **kwargs + ): + super(TriggeredJobHistoryCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TriggeredJobRun(ProxyOnlyResource): + """Triggered Web Job Run Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param web_job_id: Job ID. + :type web_job_id: str + :param web_job_name: Job name. + :type web_job_name: str + :param status: Job status. Possible values include: "Success", "Failed", "Error". + :type status: str or ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobStatus + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param duration: Job duration. + :type duration: str + :param output_url: Output URL. + :type output_url: str + :param error_url: Error URL. + :type error_url: str + :param url: Job URL. + :type url: str + :param job_name: Job name. + :type job_name: str + :param trigger: Job trigger. + :type trigger: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'web_job_id': {'key': 'properties.web_job_id', 'type': 'str'}, + 'web_job_name': {'key': 'properties.web_job_name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'duration': {'key': 'properties.duration', 'type': 'str'}, + 'output_url': {'key': 'properties.output_url', 'type': 'str'}, + 'error_url': {'key': 'properties.error_url', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'job_name': {'key': 'properties.job_name', 'type': 'str'}, + 'trigger': {'key': 'properties.trigger', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + web_job_id: Optional[str] = None, + web_job_name: Optional[str] = None, + status: Optional[Union[str, "TriggeredWebJobStatus"]] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + duration: Optional[str] = None, + output_url: Optional[str] = None, + error_url: Optional[str] = None, + url: Optional[str] = None, + job_name: Optional[str] = None, + trigger: Optional[str] = None, + **kwargs + ): + super(TriggeredJobRun, self).__init__(kind=kind, **kwargs) + self.web_job_id = web_job_id + self.web_job_name = web_job_name + self.status = status + self.start_time = start_time + self.end_time = end_time + self.duration = duration + self.output_url = output_url + self.error_url = error_url + self.url = url + self.job_name = job_name + self.trigger = trigger + + +class TriggeredWebJob(ProxyOnlyResource): + """Triggered Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param latest_run: Latest job run information. + :type latest_run: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobRun + :param history_url: History URL. + :type history_url: str + :param scheduler_logs_url: Scheduler Logs URL. + :type scheduler_logs_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'latest_run': {'key': 'properties.latest_run', 'type': 'TriggeredJobRun'}, + 'history_url': {'key': 'properties.history_url', 'type': 'str'}, + 'scheduler_logs_url': {'key': 'properties.scheduler_logs_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + latest_run: Optional["TriggeredJobRun"] = None, + history_url: Optional[str] = None, + scheduler_logs_url: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(TriggeredWebJob, self).__init__(kind=kind, **kwargs) + self.latest_run = latest_run + self.history_url = history_url + self.scheduler_logs_url = scheduler_logs_url + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class TriggeredWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TriggeredWebJob"], + **kwargs + ): + super(TriggeredWebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Twitter(ProxyOnlyResource): + """Twitter. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_06_01.models.TwitterRegistration + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'TwitterRegistration'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["TwitterRegistration"] = None, + **kwargs + ): + super(Twitter, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + + +class TwitterRegistration(ProxyOnlyResource): + """TwitterRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param consumer_key: + :type consumer_key: str + :param consumer_secret_setting_name: + :type consumer_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'consumer_key': {'key': 'properties.consumerKey', 'type': 'str'}, + 'consumer_secret_setting_name': {'key': 'properties.consumerSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + consumer_key: Optional[str] = None, + consumer_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(TwitterRegistration, self).__init__(kind=kind, **kwargs) + self.consumer_key = consumer_key + self.consumer_secret_setting_name = consumer_secret_setting_name + + +class Usage(ProxyOnlyResource): + """Usage of the quota resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar display_name: Friendly name shown in the UI. + :vartype display_name: str + :ivar resource_name: Name of the quota resource. + :vartype resource_name: str + :ivar unit: Units of measurement for the quota resource. + :vartype unit: str + :ivar current_value: The current value of the resource counter. + :vartype current_value: long + :ivar limit: The resource limit. + :vartype limit: long + :ivar next_reset_time: Next reset time for the resource counter. + :vartype next_reset_time: ~datetime.datetime + :ivar compute_mode: Compute mode used for this usage. Possible values include: "Shared", + "Dedicated", "Dynamic". + :vartype compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :ivar site_mode: Site mode used for this usage. + :vartype site_mode: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'display_name': {'readonly': True}, + 'resource_name': {'readonly': True}, + 'unit': {'readonly': True}, + 'current_value': {'readonly': True}, + 'limit': {'readonly': True}, + 'next_reset_time': {'readonly': True}, + 'compute_mode': {'readonly': True}, + 'site_mode': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'resource_name': {'key': 'properties.resourceName', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'current_value': {'key': 'properties.currentValue', 'type': 'long'}, + 'limit': {'key': 'properties.limit', 'type': 'long'}, + 'next_reset_time': {'key': 'properties.nextResetTime', 'type': 'iso-8601'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'site_mode': {'key': 'properties.siteMode', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(Usage, self).__init__(kind=kind, **kwargs) + self.display_name = None + self.resource_name = None + self.unit = None + self.current_value = None + self.limit = None + self.next_reset_time = None + self.compute_mode = None + self.site_mode = None + + +class UsageCollection(msrest.serialization.Model): + """Collection of usages. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Usage] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Usage"], + **kwargs + ): + super(UsageCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class User(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param publishing_user_name: Username used for publishing. + :type publishing_user_name: str + :param publishing_password: Password used for publishing. + :type publishing_password: str + :param publishing_password_hash: Password hash used for publishing. + :type publishing_password_hash: str + :param publishing_password_hash_salt: Password hash salt used for publishing. + :type publishing_password_hash_salt: str + :param scm_uri: Url of SCM site. + :type scm_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'publishing_user_name': {'key': 'properties.publishingUserName', 'type': 'str'}, + 'publishing_password': {'key': 'properties.publishingPassword', 'type': 'str'}, + 'publishing_password_hash': {'key': 'properties.publishingPasswordHash', 'type': 'str'}, + 'publishing_password_hash_salt': {'key': 'properties.publishingPasswordHashSalt', 'type': 'str'}, + 'scm_uri': {'key': 'properties.scmUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + publishing_user_name: Optional[str] = None, + publishing_password: Optional[str] = None, + publishing_password_hash: Optional[str] = None, + publishing_password_hash_salt: Optional[str] = None, + scm_uri: Optional[str] = None, + **kwargs + ): + super(User, self).__init__(kind=kind, **kwargs) + self.publishing_user_name = publishing_user_name + self.publishing_password = publishing_password + self.publishing_password_hash = publishing_password_hash + self.publishing_password_hash_salt = publishing_password_hash_salt + self.scm_uri = scm_uri + + +class ValidateRequest(msrest.serialization.Model): + """Resource validation request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: + "ServerFarm", "Site". + :type type: str or ~azure.mgmt.web.v2020_06_01.models.ValidateResourceTypes + :param location: Required. Expected location of the resource. + :type location: str + :param server_farm_id: ARM resource ID of an App Service plan that would host the app. + :type server_farm_id: str + :param sku_name: Name of the target SKU for the App Service plan. + :type sku_name: str + :param need_linux_workers: :code:`true` if App Service plan is for Linux workers; + otherwise, :code:`false`. + :type need_linux_workers: bool + :param is_spot: :code:`true` if App Service plan is for Spot instances; otherwise, + :code:`false`. + :type is_spot: bool + :param capacity: Target capacity of the App Service plan (number of VMs). + :type capacity: int + :param hosting_environment: Name of App Service Environment where app or App Service plan + should be created. + :type hosting_environment: str + :param is_xenon: :code:`true` if App Service plan is running as a windows + container. + :type is_xenon: bool + :param container_registry_base_url: Base URL of the container registry. + :type container_registry_base_url: str + :param container_registry_username: Username for to access the container registry. + :type container_registry_username: str + :param container_registry_password: Password for to access the container registry. + :type container_registry_password: str + :param container_image_repository: Repository name (image name). + :type container_image_repository: str + :param container_image_tag: Image tag. + :type container_image_tag: str + :param container_image_platform: Platform (windows or linux). + :type container_image_platform: str + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + 'location': {'required': True}, + 'capacity': {'minimum': 1}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'sku_name': {'key': 'properties.skuName', 'type': 'str'}, + 'need_linux_workers': {'key': 'properties.needLinuxWorkers', 'type': 'bool'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'capacity': {'key': 'properties.capacity', 'type': 'int'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'container_registry_base_url': {'key': 'properties.containerRegistryBaseUrl', 'type': 'str'}, + 'container_registry_username': {'key': 'properties.containerRegistryUsername', 'type': 'str'}, + 'container_registry_password': {'key': 'properties.containerRegistryPassword', 'type': 'str'}, + 'container_image_repository': {'key': 'properties.containerImageRepository', 'type': 'str'}, + 'container_image_tag': {'key': 'properties.containerImageTag', 'type': 'str'}, + 'container_image_platform': {'key': 'properties.containerImagePlatform', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + type: Union[str, "ValidateResourceTypes"], + location: str, + server_farm_id: Optional[str] = None, + sku_name: Optional[str] = None, + need_linux_workers: Optional[bool] = None, + is_spot: Optional[bool] = None, + capacity: Optional[int] = None, + hosting_environment: Optional[str] = None, + is_xenon: Optional[bool] = None, + container_registry_base_url: Optional[str] = None, + container_registry_username: Optional[str] = None, + container_registry_password: Optional[str] = None, + container_image_repository: Optional[str] = None, + container_image_tag: Optional[str] = None, + container_image_platform: Optional[str] = None, + **kwargs + ): + super(ValidateRequest, self).__init__(**kwargs) + self.name = name + self.type = type + self.location = location + self.server_farm_id = server_farm_id + self.sku_name = sku_name + self.need_linux_workers = need_linux_workers + self.is_spot = is_spot + self.capacity = capacity + self.hosting_environment = hosting_environment + self.is_xenon = is_xenon + self.container_registry_base_url = container_registry_base_url + self.container_registry_username = container_registry_username + self.container_registry_password = container_registry_password + self.container_image_repository = container_image_repository + self.container_image_tag = container_image_tag + self.container_image_platform = container_image_platform + + +class ValidateResponse(msrest.serialization.Model): + """Describes the result of resource validation. + + :param status: Result of validation. + :type status: str + :param error: Error details for the case when validation fails. + :type error: ~azure.mgmt.web.v2020_06_01.models.ValidateResponseError + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ValidateResponseError'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + error: Optional["ValidateResponseError"] = None, + **kwargs + ): + super(ValidateResponse, self).__init__(**kwargs) + self.status = status + self.error = error + + +class ValidateResponseError(msrest.serialization.Model): + """Error details for when validation fails. + + :param code: Validation error code. + :type code: str + :param message: Validation error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ValidateResponseError, self).__init__(**kwargs) + self.code = code + self.message = message + + +class VirtualApplication(msrest.serialization.Model): + """Virtual application in an app. + + :param virtual_path: Virtual path. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + :param preload_enabled: :code:`true` if preloading is enabled; otherwise, + :code:`false`. + :type preload_enabled: bool + :param virtual_directories: Virtual directories for virtual application. + :type virtual_directories: list[~azure.mgmt.web.v2020_06_01.models.VirtualDirectory] + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + 'preload_enabled': {'key': 'preloadEnabled', 'type': 'bool'}, + 'virtual_directories': {'key': 'virtualDirectories', 'type': '[VirtualDirectory]'}, + } + + def __init__( + self, + *, + virtual_path: Optional[str] = None, + physical_path: Optional[str] = None, + preload_enabled: Optional[bool] = None, + virtual_directories: Optional[List["VirtualDirectory"]] = None, + **kwargs + ): + super(VirtualApplication, self).__init__(**kwargs) + self.virtual_path = virtual_path + self.physical_path = physical_path + self.preload_enabled = preload_enabled + self.virtual_directories = virtual_directories + + +class VirtualDirectory(msrest.serialization.Model): + """Directory for virtual application. + + :param virtual_path: Path to virtual application. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + } + + def __init__( + self, + *, + virtual_path: Optional[str] = None, + physical_path: Optional[str] = None, + **kwargs + ): + super(VirtualDirectory, self).__init__(**kwargs) + self.virtual_path = virtual_path + self.physical_path = physical_path + + +class VirtualIPMapping(msrest.serialization.Model): + """Virtual IP mapping. + + :param virtual_ip: Virtual IP address. + :type virtual_ip: str + :param internal_http_port: Internal HTTP port. + :type internal_http_port: int + :param internal_https_port: Internal HTTPS port. + :type internal_https_port: int + :param in_use: Is virtual IP mapping in use. + :type in_use: bool + :param service_name: name of the service that virtual IP is assigned to. + :type service_name: str + """ + + _attribute_map = { + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'internal_http_port': {'key': 'internalHttpPort', 'type': 'int'}, + 'internal_https_port': {'key': 'internalHttpsPort', 'type': 'int'}, + 'in_use': {'key': 'inUse', 'type': 'bool'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + *, + virtual_ip: Optional[str] = None, + internal_http_port: Optional[int] = None, + internal_https_port: Optional[int] = None, + in_use: Optional[bool] = None, + service_name: Optional[str] = None, + **kwargs + ): + super(VirtualIPMapping, self).__init__(**kwargs) + self.virtual_ip = virtual_ip + self.internal_http_port = internal_http_port + self.internal_https_port = internal_https_port + self.in_use = in_use + self.service_name = service_name + + +class VirtualNetworkProfile(msrest.serialization.Model): + """Specification for using a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource id of the Virtual Network. + :type id: str + :ivar name: Name of the Virtual Network (read-only). + :vartype name: str + :ivar type: Resource type of the Virtual Network (read-only). + :vartype type: str + :param subnet: Subnet within the Virtual Network. + :type subnet: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'subnet', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + subnet: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkProfile, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + self.subnet = subnet + + +class VnetGateway(ProxyOnlyResource): + """The Virtual Network gateway contract. This is used to give the Virtual Network gateway access to the VPN package. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_name: The Virtual Network name. + :type vnet_name: str + :param vpn_package_uri: The URI where the VPN package can be downloaded. + :type vpn_package_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vpn_package_uri': {'key': 'properties.vpnPackageUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_name: Optional[str] = None, + vpn_package_uri: Optional[str] = None, + **kwargs + ): + super(VnetGateway, self).__init__(kind=kind, **kwargs) + self.vnet_name = vnet_name + self.vpn_package_uri = vpn_package_uri + + +class VnetInfo(ProxyOnlyResource): + """Virtual Network information contract. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_resource_id: The Virtual Network's resource ID. + :type vnet_resource_id: str + :ivar cert_thumbprint: The client certificate thumbprint. + :vartype cert_thumbprint: str + :param cert_blob: A certificate file (.cer) blob containing the public key of the private key + used to authenticate a + Point-To-Site VPN connection. + :type cert_blob: str + :ivar routes: The routes that this Virtual Network connection uses. + :vartype routes: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] + :ivar resync_required: :code:`true` if a resync is required; otherwise, + :code:`false`. + :vartype resync_required: bool + :param dns_servers: DNS servers to be used by this Virtual Network. This should be a comma- + separated list of IP addresses. + :type dns_servers: str + :param is_swift: Flag that is used to denote if this is VNET injection. + :type is_swift: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'cert_thumbprint': {'readonly': True}, + 'routes': {'readonly': True}, + 'resync_required': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_resource_id': {'key': 'properties.vnetResourceId', 'type': 'str'}, + 'cert_thumbprint': {'key': 'properties.certThumbprint', 'type': 'str'}, + 'cert_blob': {'key': 'properties.certBlob', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VnetRoute]'}, + 'resync_required': {'key': 'properties.resyncRequired', 'type': 'bool'}, + 'dns_servers': {'key': 'properties.dnsServers', 'type': 'str'}, + 'is_swift': {'key': 'properties.isSwift', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_resource_id: Optional[str] = None, + cert_blob: Optional[str] = None, + dns_servers: Optional[str] = None, + is_swift: Optional[bool] = None, + **kwargs + ): + super(VnetInfo, self).__init__(kind=kind, **kwargs) + self.vnet_resource_id = vnet_resource_id + self.cert_thumbprint = None + self.cert_blob = cert_blob + self.routes = None + self.resync_required = None + self.dns_servers = dns_servers + self.is_swift = is_swift + + +class VnetParameters(ProxyOnlyResource): + """The required set of inputs to validate a VNET. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param vnet_resource_group: The Resource Group of the VNET to be validated. + :type vnet_resource_group: str + :param vnet_name: The name of the VNET to be validated. + :type vnet_name: str + :param vnet_subnet_name: The subnet name to be validated. + :type vnet_subnet_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'vnet_resource_group': {'key': 'properties.vnetResourceGroup', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_resource_group: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + **kwargs + ): + super(VnetParameters, self).__init__(kind=kind, **kwargs) + self.vnet_resource_group = vnet_resource_group + self.vnet_name = vnet_name + self.vnet_subnet_name = vnet_subnet_name + + +class VnetRoute(ProxyOnlyResource): + """Virtual Network route contract used to pass routing information for a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param start_address: The starting address for this route. This may also include a CIDR + notation, in which case the end address must not be specified. + :type start_address: str + :param end_address: The ending address for this route. If the start address is specified in + CIDR notation, this must be omitted. + :type end_address: str + :param route_type: The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + Possible values include: "DEFAULT", "INHERITED", "STATIC". + :type route_type: str or ~azure.mgmt.web.v2020_06_01.models.RouteType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'start_address': {'key': 'properties.startAddress', 'type': 'str'}, + 'end_address': {'key': 'properties.endAddress', 'type': 'str'}, + 'route_type': {'key': 'properties.routeType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_address: Optional[str] = None, + end_address: Optional[str] = None, + route_type: Optional[Union[str, "RouteType"]] = None, + **kwargs + ): + super(VnetRoute, self).__init__(kind=kind, **kwargs) + self.start_address = start_address + self.end_address = end_address + self.route_type = route_type + + +class VnetValidationFailureDetails(ProxyOnlyResource): + """A class that describes the reason for a validation failure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param failed: A flag describing whether or not validation failed. + :type failed: bool + :param failed_tests: A list of tests that failed in the validation. + :type failed_tests: list[~azure.mgmt.web.v2020_06_01.models.VnetValidationTestFailure] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'failed': {'key': 'properties.failed', 'type': 'bool'}, + 'failed_tests': {'key': 'properties.failedTests', 'type': '[VnetValidationTestFailure]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + failed: Optional[bool] = None, + failed_tests: Optional[List["VnetValidationTestFailure"]] = None, + **kwargs + ): + super(VnetValidationFailureDetails, self).__init__(kind=kind, **kwargs) + self.failed = failed + self.failed_tests = failed_tests + + +class VnetValidationTestFailure(ProxyOnlyResource): + """A class that describes a test that failed during NSG and UDR validation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param test_name: The name of the test that failed. + :type test_name: str + :param details: The details of what caused the failure, e.g. the blocking rule name, etc. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'test_name': {'key': 'properties.testName', 'type': 'str'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + test_name: Optional[str] = None, + details: Optional[str] = None, + **kwargs + ): + super(VnetValidationTestFailure, self).__init__(kind=kind, **kwargs) + self.test_name = test_name + self.details = details + + +class WebAppCollection(msrest.serialization.Model): + """Collection of App Service apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.Site] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Site]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Site"], + **kwargs + ): + super(WebAppCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebAppInstanceStatusCollection(msrest.serialization.Model): + """Collection of app instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebSiteInstanceStatus]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WebSiteInstanceStatus"], + **kwargs + ): + super(WebAppInstanceStatusCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebJob(ProxyOnlyResource): + """Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_06_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(WebJob, self).__init__(kind=kind, **kwargs) + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class WebJobCollection(msrest.serialization.Model): + """Collection of Kudu web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WebJob"], + **kwargs + ): + super(WebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebSiteInstanceStatus(ProxyOnlyResource): + """WebSiteInstanceStatus. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param state: Possible values include: "READY", "STOPPED", "UNKNOWN". + :type state: str or ~azure.mgmt.web.v2020_06_01.models.SiteRuntimeState + :param status_url: Link to the GetStatusApi in Kudu. + :type status_url: str + :param detector_url: Link to the Diagnose and Solve Portal. + :type detector_url: str + :param console_url: Link to the console to web app instance. + :type console_url: str + :param health_check_url: Link to the console to web app instance. + :type health_check_url: str + :param containers: Dictionary of :code:``. + :type containers: dict[str, ~azure.mgmt.web.v2020_06_01.models.ContainerInfo] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'status_url': {'key': 'properties.statusUrl', 'type': 'str'}, + 'detector_url': {'key': 'properties.detectorUrl', 'type': 'str'}, + 'console_url': {'key': 'properties.consoleUrl', 'type': 'str'}, + 'health_check_url': {'key': 'properties.healthCheckUrl', 'type': 'str'}, + 'containers': {'key': 'properties.containers', 'type': '{ContainerInfo}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + state: Optional[Union[str, "SiteRuntimeState"]] = None, + status_url: Optional[str] = None, + detector_url: Optional[str] = None, + console_url: Optional[str] = None, + health_check_url: Optional[str] = None, + containers: Optional[Dict[str, "ContainerInfo"]] = None, + **kwargs + ): + super(WebSiteInstanceStatus, self).__init__(kind=kind, **kwargs) + self.state = state + self.status_url = status_url + self.detector_url = detector_url + self.console_url = console_url + self.health_check_url = health_check_url + self.containers = containers + + +class WorkerPool(msrest.serialization.Model): + """Worker pool of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_count': {'key': 'workerCount', 'type': 'int'}, + 'instance_names': {'key': 'instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + worker_size_id: Optional[int] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[str] = None, + worker_count: Optional[int] = None, + **kwargs + ): + super(WorkerPool, self).__init__(**kwargs) + self.worker_size_id = worker_size_id + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_count = worker_count + self.instance_names = None + + +class WorkerPoolCollection(msrest.serialization.Model): + """Collection of worker pools. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WorkerPoolResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WorkerPoolResource"], + **kwargs + ): + super(WorkerPoolCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WorkerPoolResource(ProxyOnlyResource): + """Worker pool of an App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_06_01.models.SkuDescription + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_06_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_size_id': {'key': 'properties.workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'worker_size': {'key': 'properties.workerSize', 'type': 'str'}, + 'worker_count': {'key': 'properties.workerCount', 'type': 'int'}, + 'instance_names': {'key': 'properties.instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional["SkuDescription"] = None, + worker_size_id: Optional[int] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[str] = None, + worker_count: Optional[int] = None, + **kwargs + ): + super(WorkerPoolResource, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.worker_size_id = worker_size_id + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_count = worker_count + self.instance_names = None diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_web_site_management_client_enums.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_web_site_management_client_enums.py new file mode 100644 index 000000000000..68859ecad0b0 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/models/_web_site_management_client_enums.py @@ -0,0 +1,751 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from enum import Enum, EnumMeta +from six import with_metaclass + +class _CaseInsensitiveEnumMeta(EnumMeta): + def __getitem__(self, name): + return super().__getitem__(name.upper()) + + def __getattr__(cls, name): + """Return the enum member matching `name` + We use __getattr__ instead of descriptors or inserting into the enum + class' __dict__ in order to support `name` and `value` being both + properties for enum members (which live in the class' __dict__) and + enum members themselves. + """ + try: + return cls._member_map_[name.upper()] + except KeyError: + raise AttributeError(name) + + +class AccessControlEntryAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Action object. + """ + + PERMIT = "Permit" + DENY = "Deny" + +class AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class AppServicePlanRestrictions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """App Service plans this offer is restricted to. + """ + + NONE = "None" + FREE = "Free" + SHARED = "Shared" + BASIC = "Basic" + STANDARD = "Standard" + PREMIUM = "Premium" + +class AutoHealActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Predefined action to be taken. + """ + + RECYCLE = "Recycle" + LOG_EVENT = "LogEvent" + CUSTOM_ACTION = "CustomAction" + +class AzureResourceType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the Azure resource the hostname is assigned to. + """ + + WEBSITE = "Website" + TRAFFIC_MANAGER = "TrafficManager" + +class AzureStorageState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State of the storage account. + """ + + OK = "Ok" + INVALID_CREDENTIALS = "InvalidCredentials" + INVALID_SHARE = "InvalidShare" + +class AzureStorageType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of storage. + """ + + AZURE_FILES = "AzureFiles" + AZURE_BLOB = "AzureBlob" + +class BackupItemStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Backup status. + """ + + IN_PROGRESS = "InProgress" + FAILED = "Failed" + SUCCEEDED = "Succeeded" + TIMED_OUT = "TimedOut" + CREATED = "Created" + SKIPPED = "Skipped" + PARTIALLY_SUCCEEDED = "PartiallySucceeded" + DELETE_IN_PROGRESS = "DeleteInProgress" + DELETE_FAILED = "DeleteFailed" + DELETED = "Deleted" + +class BackupRestoreOperationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Operation type. + """ + + DEFAULT = "Default" + CLONE = "Clone" + RELOCATION = "Relocation" + SNAPSHOT = "Snapshot" + CLOUD_FS = "CloudFS" + +class BuildStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The status of the static site build. + """ + + WAITING_FOR_DEPLOYMENT = "WaitingForDeployment" + UPLOADING = "Uploading" + DEPLOYING = "Deploying" + READY = "Ready" + FAILED = "Failed" + DELETING = "Deleting" + DETACHED = "Detached" + +class BuiltInAuthenticationProvider(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The default authentication provider to use when multiple providers are configured. + This setting is only needed if multiple providers are configured and the unauthenticated client + action is set to "RedirectToLoginPage". + """ + + AZURE_ACTIVE_DIRECTORY = "AzureActiveDirectory" + FACEBOOK = "Facebook" + GOOGLE = "Google" + MICROSOFT_ACCOUNT = "MicrosoftAccount" + TWITTER = "Twitter" + GITHUB = "Github" + +class CertificateOrderActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Action type. + """ + + CERTIFICATE_ISSUED = "CertificateIssued" + CERTIFICATE_ORDER_CANCELED = "CertificateOrderCanceled" + CERTIFICATE_ORDER_CREATED = "CertificateOrderCreated" + CERTIFICATE_REVOKED = "CertificateRevoked" + DOMAIN_VALIDATION_COMPLETE = "DomainValidationComplete" + FRAUD_DETECTED = "FraudDetected" + ORG_NAME_CHANGE = "OrgNameChange" + ORG_VALIDATION_COMPLETE = "OrgValidationComplete" + SAN_DROP = "SanDrop" + FRAUD_CLEARED = "FraudCleared" + CERTIFICATE_EXPIRED = "CertificateExpired" + CERTIFICATE_EXPIRATION_WARNING = "CertificateExpirationWarning" + FRAUD_DOCUMENTATION_REQUIRED = "FraudDocumentationRequired" + UNKNOWN = "Unknown" + +class CertificateOrderStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current order status. + """ + + PENDINGISSUANCE = "Pendingissuance" + ISSUED = "Issued" + REVOKED = "Revoked" + CANCELED = "Canceled" + DENIED = "Denied" + PENDINGREVOCATION = "Pendingrevocation" + PENDING_REKEY = "PendingRekey" + UNUSED = "Unused" + EXPIRED = "Expired" + NOT_SUBMITTED = "NotSubmitted" + +class CertificateProductType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Certificate product type. + """ + + STANDARD_DOMAIN_VALIDATED_SSL = "StandardDomainValidatedSsl" + STANDARD_DOMAIN_VALIDATED_WILD_CARD_SSL = "StandardDomainValidatedWildCardSsl" + +class Channels(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """List of channels that this recommendation can apply. + """ + + NOTIFICATION = "Notification" + API = "Api" + EMAIL = "Email" + WEBHOOK = "Webhook" + ALL = "All" + +class CheckNameResourceTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Resource type used for verification. + """ + + SITE = "Site" + SLOT = "Slot" + HOSTING_ENVIRONMENT = "HostingEnvironment" + PUBLISHING_USER = "PublishingUser" + MICROSOFT_WEB_SITES = "Microsoft.Web/sites" + MICROSOFT_WEB_SITES_SLOTS = "Microsoft.Web/sites/slots" + MICROSOFT_WEB_HOSTING_ENVIRONMENTS = "Microsoft.Web/hostingEnvironments" + MICROSOFT_WEB_PUBLISHING_USERS = "Microsoft.Web/publishingUsers" + +class ClientCertMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. + """ + + REQUIRED = "Required" + OPTIONAL = "Optional" + +class CloneAbilityResult(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of app. + """ + + CLONEABLE = "Cloneable" + PARTIALLY_CLONEABLE = "PartiallyCloneable" + NOT_CLONEABLE = "NotCloneable" + +class ComputeModeOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Shared/dedicated workers. + """ + + SHARED = "Shared" + DEDICATED = "Dedicated" + DYNAMIC = "Dynamic" + +class ConnectionStringType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of database. + """ + + MY_SQL = "MySql" + SQL_SERVER = "SQLServer" + SQL_AZURE = "SQLAzure" + CUSTOM = "Custom" + NOTIFICATION_HUB = "NotificationHub" + SERVICE_BUS = "ServiceBus" + EVENT_HUB = "EventHub" + API_HUB = "ApiHub" + DOC_DB = "DocDb" + REDIS_CACHE = "RedisCache" + POSTGRE_SQL = "PostgreSQL" + +class ContinuousWebJobStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job status. + """ + + INITIALIZING = "Initializing" + STARTING = "Starting" + RUNNING = "Running" + PENDING_RESTART = "PendingRestart" + STOPPED = "Stopped" + +class CookieExpirationConvention(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + FIXED_TIME = "FixedTime" + IDENTITY_PROVIDER_DERIVED = "IdentityProviderDerived" + +class CustomHostNameDnsRecordType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the DNS record. + """ + + C_NAME = "CName" + A = "A" + +class DatabaseType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Database type (e.g. SqlAzure / MySql). + """ + + SQL_AZURE = "SqlAzure" + MY_SQL = "MySql" + LOCAL_MY_SQL = "LocalMySql" + POSTGRE_SQL = "PostgreSql" + +class DnsType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current DNS type + """ + + AZURE_DNS = "AzureDns" + DEFAULT_DOMAIN_REGISTRAR_DNS = "DefaultDomainRegistrarDns" + +class DnsVerificationTestResult(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """DNS verification test result. + """ + + PASSED = "Passed" + FAILED = "Failed" + SKIPPED = "Skipped" + +class DomainPatchResourcePropertiesDomainNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class DomainPropertiesDomainNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class DomainStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Domain registration status. + """ + + ACTIVE = "Active" + AWAITING = "Awaiting" + CANCELLED = "Cancelled" + CONFISCATED = "Confiscated" + DISABLED = "Disabled" + EXCLUDED = "Excluded" + EXPIRED = "Expired" + FAILED = "Failed" + HELD = "Held" + LOCKED = "Locked" + PARKED = "Parked" + PENDING = "Pending" + RESERVED = "Reserved" + REVERTED = "Reverted" + SUSPENDED = "Suspended" + TRANSFERRED = "Transferred" + UNKNOWN = "Unknown" + UNLOCKED = "Unlocked" + UNPARKED = "Unparked" + UPDATED = "Updated" + JSON_CONVERTER_FAILED = "JsonConverterFailed" + +class DomainType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Valid values are Regular domain: Azure will charge the full price of domain registration, + SoftDeleted: Purchasing this domain will simply restore it and this operation will not cost + anything. + """ + + REGULAR = "Regular" + SOFT_DELETED = "SoftDeleted" + +class Enum4(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + WINDOWS = "Windows" + LINUX = "Linux" + WINDOWS_FUNCTIONS = "WindowsFunctions" + LINUX_FUNCTIONS = "LinuxFunctions" + +class Enum5(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + WINDOWS = "Windows" + LINUX = "Linux" + WINDOWS_FUNCTIONS = "WindowsFunctions" + LINUX_FUNCTIONS = "LinuxFunctions" + +class ForwardProxyConvention(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + NO_PROXY = "NoProxy" + STANDARD = "Standard" + CUSTOM = "Custom" + +class FrequencyUnit(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The unit of time for how often the backup should be executed (e.g. for weekly backup, this + should be set to Day and FrequencyInterval should be set to 7) + """ + + DAY = "Day" + HOUR = "Hour" + +class FtpsState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State of FTP / FTPS service + """ + + ALL_ALLOWED = "AllAllowed" + FTPS_ONLY = "FtpsOnly" + DISABLED = "Disabled" + +class HostingEnvironmentStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current status of the App Service Environment. + """ + + PREPARING = "Preparing" + READY = "Ready" + SCALING = "Scaling" + DELETING = "Deleting" + +class HostNameType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the hostname. + """ + + VERIFIED = "Verified" + MANAGED = "Managed" + +class HostType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Indicates whether the hostname is a standard or repository hostname. + """ + + STANDARD = "Standard" + REPOSITORY = "Repository" + +class InAvailabilityReasonType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """:code:`Invalid` indicates the name provided does not match Azure App Service + naming requirements. :code:`AlreadyExists` indicates that the name is already in + use and is therefore unavailable. + """ + + INVALID = "Invalid" + ALREADY_EXISTS = "AlreadyExists" + +class IpFilterTag(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Defines what this IP filter will be used for. This is to support IP filtering on proxies. + """ + + DEFAULT = "Default" + XFF_PROXY = "XffProxy" + SERVICE_TAG = "ServiceTag" + +class IssueType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Represents the type of the Detector + """ + + SERVICE_INCIDENT = "ServiceIncident" + APP_DEPLOYMENT = "AppDeployment" + APP_CRASH = "AppCrash" + RUNTIME_ISSUE_DETECTED = "RuntimeIssueDetected" + ASE_DEPLOYMENT = "AseDeployment" + USER_ISSUE = "UserIssue" + PLATFORM_ISSUE = "PlatformIssue" + OTHER = "Other" + +class KeyVaultSecretStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of the Key Vault secret. + """ + + INITIALIZED = "Initialized" + WAITING_ON_CERTIFICATE_ORDER = "WaitingOnCertificateOrder" + SUCCEEDED = "Succeeded" + CERTIFICATE_ORDER_FAILED = "CertificateOrderFailed" + OPERATION_NOT_PERMITTED_ON_KEY_VAULT = "OperationNotPermittedOnKeyVault" + AZURE_SERVICE_UNAUTHORIZED_TO_ACCESS_KEY_VAULT = "AzureServiceUnauthorizedToAccessKeyVault" + KEY_VAULT_DOES_NOT_EXIST = "KeyVaultDoesNotExist" + KEY_VAULT_SECRET_DOES_NOT_EXIST = "KeyVaultSecretDoesNotExist" + UNKNOWN_ERROR = "UnknownError" + EXTERNAL_PRIVATE_KEY = "ExternalPrivateKey" + UNKNOWN = "Unknown" + +class LoadBalancingMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Specifies which endpoints to serve internally in the Virtual Network for the App Service + Environment. + """ + + NONE = "None" + WEB = "Web" + PUBLISHING = "Publishing" + WEB_PUBLISHING = "Web,Publishing" + +class LogLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Log level. + """ + + OFF = "Off" + VERBOSE = "Verbose" + INFORMATION = "Information" + WARNING = "Warning" + ERROR = "Error" + +class ManagedPipelineMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Managed pipeline mode. + """ + + INTEGRATED = "Integrated" + CLASSIC = "Classic" + +class ManagedServiceIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of managed service identity. + """ + + SYSTEM_ASSIGNED = "SystemAssigned" + USER_ASSIGNED = "UserAssigned" + SYSTEM_ASSIGNED_USER_ASSIGNED = "SystemAssigned, UserAssigned" + NONE = "None" + +class MSDeployLogEntryType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Log entry type + """ + + MESSAGE = "Message" + WARNING = "Warning" + ERROR = "Error" + +class MSDeployProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Provisioning state + """ + + ACCEPTED = "accepted" + RUNNING = "running" + SUCCEEDED = "succeeded" + FAILED = "failed" + CANCELED = "canceled" + +class MySqlMigrationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of migration operation to be done + """ + + LOCAL_TO_REMOTE = "LocalToRemote" + REMOTE_TO_LOCAL = "RemoteToLocal" + +class NotificationLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Level indicating how critical this recommendation can impact. + """ + + CRITICAL = "Critical" + WARNING = "Warning" + INFORMATION = "Information" + NON_URGENT_SUGGESTION = "NonUrgentSuggestion" + +class OperationStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current status of the operation. + """ + + IN_PROGRESS = "InProgress" + FAILED = "Failed" + SUCCEEDED = "Succeeded" + TIMED_OUT = "TimedOut" + CREATED = "Created" + +class ProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of certificate order. + """ + + SUCCEEDED = "Succeeded" + FAILED = "Failed" + CANCELED = "Canceled" + IN_PROGRESS = "InProgress" + DELETING = "Deleting" + +class PublicCertificateLocation(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Public Certificate Location + """ + + CURRENT_USER_MY = "CurrentUserMy" + LOCAL_MACHINE_MY = "LocalMachineMy" + UNKNOWN = "Unknown" + +class PublishingProfileFormat(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp + """ + + FILE_ZILLA3 = "FileZilla3" + WEB_DEPLOY = "WebDeploy" + FTP = "Ftp" + +class RedundancyMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site redundancy mode + """ + + NONE = "None" + MANUAL = "Manual" + FAILOVER = "Failover" + ACTIVE_ACTIVE = "ActiveActive" + GEO_REDUNDANT = "GeoRedundant" + +class RenderingType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Rendering Type + """ + + NO_GRAPH = "NoGraph" + TABLE = "Table" + TIME_SERIES = "TimeSeries" + TIME_SERIES_PER_INSTANCE = "TimeSeriesPerInstance" + +class ResourceScopeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of a resource type this recommendation applies, e.g. Subscription, ServerFarm, Site. + """ + + SERVER_FARM = "ServerFarm" + SUBSCRIPTION = "Subscription" + WEB_SITE = "WebSite" + +class RouteType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + """ + + DEFAULT = "DEFAULT" + INHERITED = "INHERITED" + STATIC = "STATIC" + +class ScmType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """SCM type. + """ + + NONE = "None" + DROPBOX = "Dropbox" + TFS = "Tfs" + LOCAL_GIT = "LocalGit" + GIT_HUB = "GitHub" + CODE_PLEX_GIT = "CodePlexGit" + CODE_PLEX_HG = "CodePlexHg" + BITBUCKET_GIT = "BitbucketGit" + BITBUCKET_HG = "BitbucketHg" + EXTERNAL_GIT = "ExternalGit" + EXTERNAL_HG = "ExternalHg" + ONE_DRIVE = "OneDrive" + VSO = "VSO" + VSTSRM = "VSTSRM" + +class SiteAvailabilityState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Management information availability state for the app. + """ + + NORMAL = "Normal" + LIMITED = "Limited" + DISASTER_RECOVERY_MODE = "DisasterRecoveryMode" + +class SiteExtensionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site extension type. + """ + + GALLERY = "Gallery" + WEB_ROOT = "WebRoot" + +class SiteLoadBalancing(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site load balancing. + """ + + WEIGHTED_ROUND_ROBIN = "WeightedRoundRobin" + LEAST_REQUESTS = "LeastRequests" + LEAST_RESPONSE_TIME = "LeastResponseTime" + WEIGHTED_TOTAL_TRAFFIC = "WeightedTotalTraffic" + REQUEST_HASH = "RequestHash" + +class SiteRuntimeState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + READY = "READY" + STOPPED = "STOPPED" + UNKNOWN = "UNKNOWN" + +class SkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + FREE = "Free" + SHARED = "Shared" + BASIC = "Basic" + STANDARD = "Standard" + PREMIUM = "Premium" + DYNAMIC = "Dynamic" + ISOLATED = "Isolated" + PREMIUM_V2 = "PremiumV2" + ELASTIC_PREMIUM = "ElasticPremium" + ELASTIC_ISOLATED = "ElasticIsolated" + +class SolutionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of Solution + """ + + QUICK_SOLUTION = "QuickSolution" + DEEP_INVESTIGATION = "DeepInvestigation" + BEST_PRACTICES = "BestPractices" + +class SslState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """SSL type. + """ + + DISABLED = "Disabled" + SNI_ENABLED = "SniEnabled" + IP_BASED_ENABLED = "IpBasedEnabled" + +class StatusOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """App Service plan status. + """ + + READY = "Ready" + PENDING = "Pending" + CREATING = "Creating" + +class SupportedTlsVersions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """MinTlsVersion: configures the minimum version of TLS required for SSL requests + """ + + ONE0 = "1.0" + ONE1 = "1.1" + ONE2 = "1.2" + +class TriggeredWebJobStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job status. + """ + + SUCCESS = "Success" + FAILED = "Failed" + ERROR = "Error" + +class TriggerTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The trigger type of the function + """ + + HTTP_TRIGGER = "HttpTrigger" + UNKNOWN = "Unknown" + +class UnauthenticatedClientAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action to take when an unauthenticated client attempts to access the app. + """ + + REDIRECT_TO_LOGIN_PAGE = "RedirectToLoginPage" + ALLOW_ANONYMOUS = "AllowAnonymous" + +class UnauthenticatedClientActionV2(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REDIRECT_TO_LOGIN_PAGE = "RedirectToLoginPage" + ALLOW_ANONYMOUS = "AllowAnonymous" + RETURN401 = "Return401" + RETURN403 = "Return403" + +class UsageState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State indicating whether the app has exceeded its quota usage. Read-only. + """ + + NORMAL = "Normal" + EXCEEDED = "Exceeded" + +class ValidateResourceTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Resource type used for verification. + """ + + SERVER_FARM = "ServerFarm" + SITE = "Site" + +class WebJobType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job type. + """ + + CONTINUOUS = "Continuous" + TRIGGERED = "Triggered" + +class WorkerSizeOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Size of the machines. + """ + + SMALL = "Small" + MEDIUM = "Medium" + LARGE = "Large" + D1 = "D1" + D2 = "D2" + D3 = "D3" + NESTED_SMALL = "NestedSmall" + DEFAULT = "Default" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/__init__.py new file mode 100644 index 000000000000..8f414125deed --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/__init__.py @@ -0,0 +1,43 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._app_service_certificate_orders_operations import AppServiceCertificateOrdersOperations +from ._certificate_registration_provider_operations import CertificateRegistrationProviderOperations +from ._domains_operations import DomainsOperations +from ._top_level_domains_operations import TopLevelDomainsOperations +from ._domain_registration_provider_operations import DomainRegistrationProviderOperations +from ._certificates_operations import CertificatesOperations +from ._deleted_web_apps_operations import DeletedWebAppsOperations +from ._diagnostics_operations import DiagnosticsOperations +from ._provider_operations import ProviderOperations +from ._recommendations_operations import RecommendationsOperations +from ._web_site_management_client_operations import WebSiteManagementClientOperationsMixin +from ._web_apps_operations import WebAppsOperations +from ._static_sites_operations import StaticSitesOperations +from ._app_service_environments_operations import AppServiceEnvironmentsOperations +from ._app_service_plans_operations import AppServicePlansOperations +from ._resource_health_metadata_operations import ResourceHealthMetadataOperations + +__all__ = [ + 'AppServiceCertificateOrdersOperations', + 'CertificateRegistrationProviderOperations', + 'DomainsOperations', + 'TopLevelDomainsOperations', + 'DomainRegistrationProviderOperations', + 'CertificatesOperations', + 'DeletedWebAppsOperations', + 'DiagnosticsOperations', + 'ProviderOperations', + 'RecommendationsOperations', + 'WebSiteManagementClientOperationsMixin', + 'WebAppsOperations', + 'StaticSitesOperations', + 'AppServiceEnvironmentsOperations', + 'AppServicePlansOperations', + 'ResourceHealthMetadataOperations', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_certificate_orders_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_certificate_orders_operations.py new file mode 100644 index 000000000000..78f6d06ad982 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_certificate_orders_operations.py @@ -0,0 +1,1517 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceCertificateOrdersOperations(object): + """AppServiceCertificateOrdersOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateOrderCollection"] + """List all certificate orders in a subscription. + + Description for List all certificate orders in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + def validate_purchase_information( + self, + app_service_certificate_order, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> None + """Validate information for a certificate order. + + Description for Validate information for a certificate order. + + :param app_service_certificate_order: Information for a certificate order. + :type app_service_certificate_order: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_purchase_information.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_certificate_order, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_purchase_information.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/validateCertificateRegistrationInformation'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateOrderCollection"] + """Get certificate orders in a resource group. + + Description for Get certificate orders in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + def get( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + """Get a certificate order. + + Description for Get a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order.. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceCertificateOrder"] + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceCertificateOrder or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + certificate_distinguished_name=certificate_distinguished_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete an existing certificate order. + + Description for Delete an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrderPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrderPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrderPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def list_certificates( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateCollection"] + """List all certificates associated with a certificate order. + + Description for List all certificates associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates'} # type: ignore + + def get_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + """Get the certificate associated with a certificate order. + + Description for Get the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def _create_or_update_certificate_initial( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificateResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_certificate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificateResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_certificate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def begin_create_or_update_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificateResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceCertificateResource"] + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceCertificateResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_certificate_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + name=name, + key_vault_certificate=key_vault_certificate, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def delete_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete the certificate associated with a certificate order. + + Description for Delete the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def update_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificatePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def reissue( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + reissue_certificate_order_request, # type: "_models.ReissueCertificateOrderRequest" + **kwargs # type: Any + ): + # type: (...) -> None + """Reissue an existing certificate order. + + Description for Reissue an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param reissue_certificate_order_request: Parameters for the reissue. + :type reissue_certificate_order_request: ~azure.mgmt.web.v2020_06_01.models.ReissueCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reissue.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reissue_certificate_order_request, 'ReissueCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reissue.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/reissue'} # type: ignore + + def renew( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + renew_certificate_order_request, # type: "_models.RenewCertificateOrderRequest" + **kwargs # type: Any + ): + # type: (...) -> None + """Renew an existing certificate order. + + Description for Renew an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param renew_certificate_order_request: Renew parameters. + :type renew_certificate_order_request: ~azure.mgmt.web.v2020_06_01.models.RenewCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(renew_certificate_order_request, 'RenewCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/renew'} # type: ignore + + def resend_email( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resend certificate email. + + Description for Resend certificate email. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.resend_email.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_email.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendEmail'} # type: ignore + + def resend_request_emails( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name_identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> None + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name_identifier: Email address. + :type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.resend_request_emails.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_request_emails.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendRequestEmails'} # type: ignore + + def retrieve_site_seal( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + site_seal_request, # type: "_models.SiteSealRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSeal" + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param site_seal_request: Site seal request. + :type site_seal_request: ~azure.mgmt.web.v2020_06_01.models.SiteSealRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSeal, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSeal + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSeal"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.retrieve_site_seal.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_seal_request, 'SiteSealRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteSeal', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_site_seal.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/retrieveSiteSeal'} # type: ignore + + def verify_domain_ownership( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.verify_domain_ownership.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + verify_domain_ownership.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/verifyDomainOwnership'} # type: ignore + + def retrieve_certificate_actions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.CertificateOrderAction"] + """Retrieve the list of certificate actions. + + Description for Retrieve the list of certificate actions. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateOrderAction, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.CertificateOrderAction] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateOrderAction"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_actions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateOrderAction]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_actions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveCertificateActions'} # type: ignore + + def retrieve_certificate_email_history( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.CertificateEmail"] + """Retrieve email history. + + Description for Retrieve email history. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateEmail, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.CertificateEmail] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateEmail"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_email_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateEmail]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_email_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveEmailHistory'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_environments_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_environments_operations.py new file mode 100644 index 000000000000..b0774386d12a --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_environments_operations.py @@ -0,0 +1,3293 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceEnvironmentsOperations(object): + """AppServiceEnvironmentsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceEnvironmentCollection"] + """Get all App Service Environments for a subscription. + + Description for Get all App Service Environments for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceEnvironmentCollection"] + """Get all App Service Environments in a resource group. + + Description for Get all App Service Environments in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + """Get the properties of an App Service Environment. + + Description for Get the properties of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceEnvironmentResource"] + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceEnvironmentResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + hosting_environment_envelope=hosting_environment_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + name, # type: str + force_delete=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_delete is not None: + query_parameters['forceDelete'] = self._serialize.query("force_delete", force_delete, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + name, # type: str + force_delete=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Delete an App Service Environment. + + Description for Delete an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param force_delete: Specify :code:`true` to force the deletion even if the App + Service Environment contains resources. The default is :code:`false`. + :type force_delete: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + name=name, + force_delete=force_delete, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def list_capacities( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StampCapacityCollection"] + """Get the used, available, and total worker capacity an App Service Environment. + + Description for Get the used, available, and total worker capacity an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StampCapacityCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StampCapacityCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StampCapacityCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_capacities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StampCapacityCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_capacities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/compute'} # type: ignore + + def get_vip_info( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AddressResponse" + """Get IP addresses assigned to an App Service Environment. + + Description for Get IP addresses assigned to an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AddressResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AddressResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AddressResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vip_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AddressResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vip_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/virtualip'} # type: ignore + + def _change_vnet_initial( + self, + resource_group_name, # type: str + name, # type: str + vnet_info, # type: "_models.VirtualNetworkProfile" + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._change_vnet_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _change_vnet_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + def begin_change_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_info, # type: "_models.VirtualNetworkProfile" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Move an App Service Environment to a different VNET. + + Description for Move an App Service Environment to a different VNET. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param vnet_info: Details for the new virtual network. + :type vnet_info: ~azure.mgmt.web.v2020_06_01.models.VirtualNetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.change_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._change_vnet_initial( + resource_group_name=resource_group_name, + name=name, + vnet_info=vnet_info, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_change_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + def list_diagnostics( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.HostingEnvironmentDiagnostics"] + """Get diagnostic information for an App Service Environment. + + Description for Get diagnostic information for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDiagnostics] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.HostingEnvironmentDiagnostics"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_diagnostics.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[HostingEnvironmentDiagnostics]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_diagnostics.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics'} # type: ignore + + def get_diagnostics_item( + self, + resource_group_name, # type: str + name, # type: str + diagnostics_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostingEnvironmentDiagnostics" + """Get a diagnostics item for an App Service Environment. + + Description for Get a diagnostics item for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param diagnostics_name: Name of the diagnostics item. + :type diagnostics_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostingEnvironmentDiagnostics + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostingEnvironmentDiagnostics"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostics_item.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'diagnosticsName': self._serialize.url("diagnostics_name", diagnostics_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostingEnvironmentDiagnostics', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostics_item.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics/{diagnosticsName}'} # type: ignore + + def get_inbound_network_dependencies_endpoints( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.InboundEnvironmentEndpointCollection"] + """Get the network endpoints of all inbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all inbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.InboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_inbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('InboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_inbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/inboundNetworkDependenciesEndpoints'} # type: ignore + + def list_multi_role_pools( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WorkerPoolCollection"] + """Get all multi-role pools. + + Description for Get all multi-role pools. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools'} # type: ignore + + def get_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Get properties of a multi-role pool. + + Description for Get properties of a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def _create_or_update_multi_role_pool_initial( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_multi_role_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_multi_role_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def begin_create_or_update_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WorkerPoolResource"] + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_multi_role_pool_initial( + resource_group_name=resource_group_name, + name=name, + multi_role_pool_envelope=multi_role_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def update_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def list_multi_role_pool_instance_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + instance, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a specific instance of a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a multi-role pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param instance: Name of the instance in the multi-role pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/instances/{instance}/metricdefinitions'} # type: ignore + + def list_multi_role_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/metricdefinitions'} # type: ignore + + def list_multi_role_pool_skus( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SkuInfoCollection"] + """Get available SKUs for scaling a multi-role pool. + + Description for Get available SKUs for scaling a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/skus'} # type: ignore + + def list_multi_role_usages( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.UsageCollection"] + """Get usage metrics for a multi-role pool of an App Service Environment. + + Description for Get usage metrics for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/usages'} # type: ignore + + def list_operations( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.Operation"] + """List all currently running operations on the App Service Environment. + + Description for List all currently running operations on the App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Operation, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.Operation] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Operation"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Operation]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_operations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/operations'} # type: ignore + + def get_outbound_network_dependencies_endpoints( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.OutboundEnvironmentEndpointCollection"] + """Get the network endpoints of all outbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all outbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OutboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.OutboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_outbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('OutboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_outbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/outboundNetworkDependenciesEndpoints'} # type: ignore + + def reboot( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reboot all machines in an App Service Environment. + + Description for Reboot all machines in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reboot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/reboot'} # type: ignore + + def _resume_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._resume_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _resume_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def begin_resume( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Resume an App Service Environment. + + Description for Resume an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.resume.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._resume_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_resume.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def list_app_service_plans( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans in an App Service Environment. + + Description for Get all App Service plans in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_app_service_plans.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_app_service_plans.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/serverfarms'} # type: ignore + + def list_web_apps( + self, + resource_group_name, # type: str + name, # type: str + properties_to_include=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps in an App Service Environment. + + Description for Get all apps in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param properties_to_include: Comma separated list of app properties to include. + :type properties_to_include: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if properties_to_include is not None: + query_parameters['propertiesToInclude'] = self._serialize.query("properties_to_include", properties_to_include, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/sites'} # type: ignore + + def _suspend_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._suspend_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _suspend_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def begin_suspend( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Suspend an App Service Environment. + + Description for Suspend an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.suspend.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._suspend_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_suspend.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Get global usage metrics of an App Service Environment. + + Description for Get global usage metrics of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/usages'} # type: ignore + + def list_worker_pools( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WorkerPoolCollection"] + """Get all worker pools of an App Service Environment. + + Description for Get all worker pools of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools'} # type: ignore + + def get_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Get properties of a worker pool. + + Description for Get properties of a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def _create_or_update_worker_pool_initial( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_worker_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_worker_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def begin_create_or_update_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WorkerPoolResource"] + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_worker_pool_initial( + resource_group_name=resource_group_name, + name=name, + worker_pool_name=worker_pool_name, + worker_pool_envelope=worker_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def update_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def list_worker_pool_instance_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + instance, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a specific instance of a worker pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a worker pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param instance: Name of the instance in the worker pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/instances/{instance}/metricdefinitions'} # type: ignore + + def list_web_worker_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a worker pool of an App Service Environment. + + Description for Get metric definitions for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_worker_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/metricdefinitions'} # type: ignore + + def list_worker_pool_skus( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SkuInfoCollection"] + """Get available SKUs for scaling a worker pool. + + Description for Get available SKUs for scaling a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/skus'} # type: ignore + + def list_web_worker_usages( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.UsageCollection"] + """Get usage metrics for a worker pool of an App Service Environment. + + Description for Get usage metrics for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_worker_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/usages'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_plans_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_plans_operations.py new file mode 100644 index 000000000000..58ecb5153169 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_app_service_plans_operations.py @@ -0,0 +1,2039 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServicePlansOperations(object): + """AppServicePlansOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + detailed=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans for a subscription. + + Description for Get all App Service plans for a subscription. + + :param detailed: Specify :code:`true` to return all App Service plan properties. + The default is :code:`false`, which returns a subset of the properties. + Retrieval of all properties may increase the API latency. + :type detailed: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if detailed is not None: + query_parameters['detailed'] = self._serialize.query("detailed", detailed, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans in a resource group. + + Description for Get all App Service plans in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.AppServicePlan"] + """Get an App Service plan. + + Description for Get an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AppServicePlan"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlan" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServicePlan" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlan') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlan" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServicePlan"] + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServicePlan or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.AppServicePlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + app_service_plan=app_service_plan, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete an App Service plan. + + Description for Delete an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlanPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServicePlan" + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_06_01.models.AppServicePlanPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AppServicePlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlanPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def list_capabilities( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.Capability"] + """List all capabilities of an App Service plan. + + Description for List all capabilities of an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Capability, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.Capability] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Capability"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_capabilities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Capability]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_capabilities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/capabilities'} # type: ignore + + def get_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieve a Hybrid Connection in use in an App Service plan. + + Description for Retrieve a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a Hybrid Connection in use in an App Service plan. + + Description for Delete a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connection_keys( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnectionKey" + """Get the send key name and value of a Hybrid Connection. + + Description for Get the send key name and value of a Hybrid Connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: The name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionKey, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnectionKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connection_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connection_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/listKeys'} # type: ignore + + def list_web_apps_by_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceCollection"] + """Get all apps that use a Hybrid Connection in an App Service Plan. + + Description for Get all apps that use a Hybrid Connection in an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Hybrid Connection namespace. + :type namespace_name: str + :param relay_name: Name of the Hybrid Connection relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps_by_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps_by_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/sites'} # type: ignore + + def get_hybrid_connection_plan_limit( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnectionLimits" + """Get the maximum number of Hybrid Connections allowed in an App Service plan. + + Description for Get the maximum number of Hybrid Connections allowed in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionLimits, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnectionLimits + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionLimits"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_plan_limit.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionLimits', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_plan_limit.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionPlanLimits/limit'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HybridConnectionCollection"] + """Retrieve all Hybrid Connections in use in an App Service plan. + + Description for Retrieve all Hybrid Connections in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HybridConnectionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.HybridConnectionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HybridConnectionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionRelays'} # type: ignore + + def restart_web_apps( + self, + resource_group_name, # type: str + name, # type: str + soft_restart=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restart all apps in an App Service plan. + + Description for Restart all apps in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param soft_restart: Specify :code:`true` to perform a soft restart, applies the + configuration settings and restarts the apps if necessary. The default is + :code:`false`, which always restarts and reprovisions the apps. + :type soft_restart: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/restartSites'} # type: ignore + + def list_web_apps( + self, + resource_group_name, # type: str + name, # type: str + skip_token=None, # type: Optional[str] + filter=None, # type: Optional[str] + top=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps associated with an App Service plan. + + Description for Get all apps associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param skip_token: Skip to a web app in the list of webapps associated with app service plan. + If specified, the resulting list will contain web apps starting from (including) the skipToken. + Otherwise, the resulting list contains web apps from the start of the list. + :type skip_token: str + :param filter: Supported filter: $filter=state eq running. Returns only web apps that are + currently running. + :type filter: str + :param top: List page size. If specified, results are paged. + :type top: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if skip_token is not None: + query_parameters['$skipToken'] = self._serialize.query("skip_token", skip_token, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/sites'} # type: ignore + + def get_server_farm_skus( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> object + """Gets all selectable SKUs for a given App Service Plan. + + Description for Gets all selectable SKUs for a given App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: object, or the result of cls(response) + :rtype: object + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_server_farm_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_server_farm_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/skus'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets server farm usage information. + + Description for Gets server farm usage information. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2'). + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/usages'} # type: ignore + + def list_vnets( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Get all Virtual Networks associated with an App Service plan. + + Description for Get all Virtual Networks associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections'} # type: ignore + + def get_vnet_from_server_farm( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetInfo"] + """Get a Virtual Network associated with an App Service plan. + + Description for Get a Virtual Network associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_from_server_farm.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_from_server_farm.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Get a Virtual Network gateway. + + Description for Get a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Update a Virtual Network gateway. + + Description for Update a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :param connection_envelope: Definition of the gateway. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_routes_for_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetRoute"] + """Get all routes that are associated with a Virtual Network in an App Service plan. + + Description for Get all routes that are associated with a Virtual Network in an App Service + plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_routes_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_routes_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes'} # type: ignore + + def get_route_for_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[List["_models.VnetRoute"]] + """Get a Virtual Network route in an App Service plan. + + Description for Get a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetRoute] or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[List["_models.VnetRoute"]]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_route_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_route_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def create_or_update_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + route, # type: "_models.VnetRoute" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetRoute"] + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_06_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def delete_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a Virtual Network route in an App Service plan. + + Description for Delete a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def update_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + route, # type: "_models.VnetRoute" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetRoute"] + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_06_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def reboot_worker( + self, + resource_group_name, # type: str + name, # type: str + worker_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reboot a worker machine in an App Service plan. + + Description for Reboot a worker machine in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param worker_name: Name of worker machine, which typically starts with RD. + :type worker_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reboot_worker.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerName': self._serialize.url("worker_name", worker_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot_worker.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/workers/{workerName}/reboot'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificate_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificate_registration_provider_operations.py new file mode 100644 index 000000000000..fd50f5bb7a39 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificate_registration_provider_operations.py @@ -0,0 +1,113 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class CertificateRegistrationProviderOperations(object): + """CertificateRegistrationProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.CertificateRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificates_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificates_operations.py new file mode 100644 index 000000000000..366917731345 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_certificates_operations.py @@ -0,0 +1,451 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class CertificatesOperations(object): + """CertificatesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CertificateCollection"] + """Get all certificates for a subscription. + + Description for Get all certificates for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/certificates'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CertificateCollection"] + """Get all certificates in a resource group. + + Description for Get all certificates in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Get a certificate. + + Description for Get a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + name, # type: str + certificate_envelope, # type: "_models.Certificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_06_01.models.Certificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'Certificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a certificate. + + Description for Delete a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + certificate_envelope, # type: "_models.CertificatePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_06_01.models.CertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'CertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_deleted_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_deleted_web_apps_operations.py new file mode 100644 index 000000000000..d5b6fb4b5625 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_deleted_web_apps_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DeletedWebAppsOperations(object): + """DeletedWebAppsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeletedWebAppCollection"] + """Get all deleted apps for a subscription. + + Description for Get all deleted apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deletedSites'} # type: ignore + + def list_by_location( + self, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeletedWebAppCollection"] + """Get all deleted apps for a subscription at location. + + Description for Get all deleted apps for a subscription at location. + + :param location: + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites'} # type: ignore + + def get_deleted_web_app_by_location( + self, + location, # type: str + deleted_site_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeletedSite" + """Get deleted app for a subscription at location. + + Description for Get deleted app for a subscription at location. + + :param location: + :type location: str + :param deleted_site_id: The numeric ID of the deleted app, e.g. 12345. + :type deleted_site_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeletedSite, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DeletedSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deleted_web_app_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'deletedSiteId': self._serialize.url("deleted_site_id", deleted_site_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeletedSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deleted_web_app_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites/{deletedSiteId}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_diagnostics_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_diagnostics_operations.py new file mode 100644 index 000000000000..2f99e8b6520d --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_diagnostics_operations.py @@ -0,0 +1,1800 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +import datetime +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DiagnosticsOperations(object): + """DiagnosticsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_hosting_environment_detector_responses( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Hosting Environment Detector Responses. + + Description for List Hosting Environment Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hosting_environment_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_hosting_environment_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors'} # type: ignore + + def get_hosting_environment_detector_response( + self, + resource_group_name, # type: str + name, # type: str + detector_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get Hosting Environment Detector Response. + + Description for Get Hosting Environment Detector Response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: App Service Environment Name. + :type name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hosting_environment_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hosting_environment_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors/{detectorName}'} # type: ignore + + def list_site_detector_responses( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors'} # type: ignore + + def get_site_detector_response( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticCategoryCollection"] + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics'} # type: ignore + + def get_site_diagnostic_category( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticCategory" + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticAnalysisCollection"] + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_analyses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + def get_site_analysis( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AnalysisDefinition" + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + def execute_site_analysis( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticAnalysis" + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticDetectorCollection"] + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detectors.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + def get_site_detector( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + detector_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorDefinition" + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + def execute_site_detector( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + diagnostic_category, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticDetectorResponse" + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore + + def list_site_detector_responses_slot( + self, + resource_group_name, # type: str + site_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detector_responses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors'} # type: ignore + + def get_site_detector_response_slot( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories_slot( + self, + resource_group_name, # type: str + site_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticCategoryCollection"] + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics'} # type: ignore + + def get_site_diagnostic_category_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticCategory" + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticAnalysisCollection"] + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_analyses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + def get_site_analysis_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AnalysisDefinition" + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :param slot: Slot - optional. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + def execute_site_analysis_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticAnalysis" + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticDetectorCollection"] + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detectors_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + def get_site_detector_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + detector_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorDefinition" + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + def execute_site_detector_slot( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + diagnostic_category, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticDetectorResponse" + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domain_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domain_registration_provider_operations.py new file mode 100644 index 000000000000..ac90a866057e --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domain_registration_provider_operations.py @@ -0,0 +1,113 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DomainRegistrationProviderOperations(object): + """DomainRegistrationProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.DomainRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domains_operations.py new file mode 100644 index 000000000000..0f7cb4687633 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_domains_operations.py @@ -0,0 +1,1139 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DomainsOperations(object): + """DomainsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def check_availability( + self, + identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainAvailabilityCheckResult" + """Check if a domain is available for registration. + + Description for Check if a domain is available for registration. + + :param identifier: Name of the domain. + :type identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainAvailabilityCheckResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainAvailabilityCheckResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainAvailabilityCheckResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainAvailabilityCheckResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/checkDomainAvailability'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainCollection"] + """Get all domains in a subscription. + + Description for Get all domains in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + def get_control_center_sso_request( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainControlCenterSsoRequest" + """Generate a single sign-on request for the domain management portal. + + Description for Generate a single sign-on request for the domain management portal. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainControlCenterSsoRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainControlCenterSsoRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainControlCenterSsoRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_control_center_sso_request.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainControlCenterSsoRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_control_center_sso_request.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/generateSsoRequest'} # type: ignore + + def list_recommendations( + self, + parameters, # type: "_models.DomainRecommendationSearchParameters" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NameIdentifierCollection"] + """Get domain name recommendations based on keywords. + + Description for Get domain name recommendations based on keywords. + + :param parameters: Search parameters for domain name recommendations. + :type parameters: ~azure.mgmt.web.v2020_06_01.models.DomainRecommendationSearchParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NameIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.NameIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NameIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommendations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NameIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommendations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/listDomainRecommendations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainCollection"] + """Get all domains in a resource group. + + Description for Get all domains in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + def get( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + """Get a domain. + + Description for Get a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.Domain" + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'Domain') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.Domain" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Domain"] + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_06_01.models.Domain + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Domain or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.Domain] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + domain_name=domain_name, + domain=domain, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + domain_name, # type: str + force_hard_delete_domain=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a domain. + + Description for Delete a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param force_hard_delete_domain: Specify :code:`true` to delete the domain + immediately. The default is :code:`false` which deletes the domain after 24 hours. + :type force_hard_delete_domain: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_hard_delete_domain is not None: + query_parameters['forceHardDeleteDomain'] = self._serialize.query("force_hard_delete_domain", force_hard_delete_domain, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.DomainPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_06_01.models.DomainPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'DomainPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def list_ownership_identifiers( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainOwnershipIdentifierCollection"] + """Lists domain ownership identifiers. + + Description for Lists domain ownership identifiers. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainOwnershipIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainOwnershipIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers'} # type: ignore + + def get_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Get ownership identifier for domain. + + Description for Get ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def create_or_update_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + domain_ownership_identifier, # type: "_models.DomainOwnershipIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def delete_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete ownership identifier for domain. + + Description for Delete ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def update_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + domain_ownership_identifier, # type: "_models.DomainOwnershipIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def renew( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Renew a domain. + + Description for Renew a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/renew'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_provider_operations.py new file mode 100644 index 000000000000..4a22cac9c13f --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_provider_operations.py @@ -0,0 +1,259 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ProviderOperations(object): + """ProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_available_stacks( + self, + os_type_selected=None, # type: Optional[Union[str, "_models.Enum4"]] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationStackCollection"] + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_06_01.models.Enum4 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_available_stacks.metadata = {'url': '/providers/Microsoft.Web/availableStacks'} # type: ignore + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Gets all available operations for the Microsoft.Web resource provider. Also exposes resource metric definitions. + + Description for Gets all available operations for the Microsoft.Web resource provider. Also + exposes resource metric definitions. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Web/operations'} # type: ignore + + def get_available_stacks_on_prem( + self, + os_type_selected=None, # type: Optional[Union[str, "_models.Enum5"]] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationStackCollection"] + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_06_01.models.Enum5 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks_on_prem.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_available_stacks_on_prem.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/availableStacks'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_recommendations_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_recommendations_operations.py new file mode 100644 index 000000000000..c664f0153794 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_recommendations_operations.py @@ -0,0 +1,1128 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class RecommendationsOperations(object): + """RecommendationsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """List all recommendations for a subscription. + + Description for List all recommendations for a subscription. + + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations'} # type: ignore + + def reset_all_filters( + self, + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for a subscription. + + Description for Reset all recommendation opt-out settings for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/reset'} # type: ignore + + def disable_recommendation_for_subscription( + self, + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specified rule so it will not apply to a subscription in the future. + + Description for Disables the specified rule so it will not apply to a subscription in the + future. + + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/{name}/disable'} # type: ignore + + def list_history_for_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + expired_only=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_history_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get all recommendations for a hosting environment. + + Description for Get all recommendations for a hosting environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the app. + :type hosting_environment_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations'} # type: ignore + + def disable_all_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/disable'} # type: ignore + + def reset_all_filters_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/reset'} # type: ignore + + def get_rule_details_by_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + name, # type: str + update_seen=None, # type: Optional[bool] + recommendation_id=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RecommendationRule" + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}'} # type: ignore + + def disable_recommendation_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Site name. + :type environment_name: str + :param name: Rule name. + :type name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}/disable'} # type: ignore + + def list_history_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + expired_only=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_history_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get all recommendations for an app. + + Description for Get all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations'} # type: ignore + + def disable_all_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/disable'} # type: ignore + + def reset_all_filters_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/reset'} # type: ignore + + def get_rule_details_by_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + name, # type: str + update_seen=None, # type: Optional[bool] + recommendation_id=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RecommendationRule" + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}'} # type: ignore + + def disable_recommendation_for_site( + self, + resource_group_name, # type: str + site_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site name. + :type site_name: str + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}/disable'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_resource_health_metadata_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_resource_health_metadata_operations.py new file mode 100644 index 000000000000..0b4e8d6febfd --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_resource_health_metadata_operations.py @@ -0,0 +1,481 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ResourceHealthMetadataOperations(object): + """ResourceHealthMetadataOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """List all ResourceHealthMetadata for all sites in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """List all ResourceHealthMetadata for all sites in the resource group in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the resource group in the + subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata'} # type: ignore + + def get_by_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceHealthMetadata" + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata/default'} # type: ignore + + def list_by_site_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata'} # type: ignore + + def get_by_site_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceHealthMetadata" + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata/default'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_static_sites_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_static_sites_operations.py new file mode 100644 index 000000000000..1929ae73b9fa --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_static_sites_operations.py @@ -0,0 +1,1944 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class StaticSitesOperations(object): + """StaticSitesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def preview_workflow( + self, + location, # type: str + static_sites_workflow_preview_request, # type: "_models.StaticSitesWorkflowPreviewRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSitesWorkflowPreview" + """Generates a preview workflow file for the static site. + + Description for Generates a preview workflow file for the static site. + + :param location: Location where you plan to create the static site. + :type location: str + :param static_sites_workflow_preview_request: A JSON representation of the + StaticSitesWorkflowPreviewRequest properties. See example. + :type static_sites_workflow_preview_request: ~azure.mgmt.web.v2020_06_01.models.StaticSitesWorkflowPreviewRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSitesWorkflowPreview, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSitesWorkflowPreview + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSitesWorkflowPreview"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.preview_workflow.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_sites_workflow_preview_request, 'StaticSitesWorkflowPreviewRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSitesWorkflowPreview', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + preview_workflow.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/previewStaticSiteWorkflowFile'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCollection"] + """Get all Static Sites for a subscription. + + Description for Get all Static Sites for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_sites_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCollection"] + """Gets all static sites in the specified resource group. + + Description for Gets all static sites in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_sites_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_static_sites_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Gets the details of a static site. + + Description for Gets the details of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def create_or_update_static_site( + self, + resource_group_name, # type: str + name, # type: str + static_site_envelope, # type: "_models.StaticSiteARMResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSiteARMResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def delete_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a static site. + + Description for Deletes a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to delete. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def update_static_site( + self, + resource_group_name, # type: str + name, # type: str + static_site_envelope, # type: "_models.StaticSitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def list_static_site_users( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteUserCollection"] + """Gets the list of users of a static site. + + Description for Gets the list of users of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for the users. + :type authprovider: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteUserCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteUserCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_users.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteUserCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_users.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/listUsers'} # type: ignore + + def delete_static_site_user( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + userid, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the user entry from the static site. + + Description for Deletes the user entry from the static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the staticsite. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def update_static_site_user( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + userid, # type: str + static_site_user_envelope, # type: "_models.StaticSiteUserARMResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteUserARMResource" + """Updates a user entry with the listed roles. + + Description for Updates a user entry with the listed roles. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :param static_site_user_envelope: A JSON representation of the StaticSiteUser properties. See + example. + :type static_site_user_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_envelope, 'StaticSiteUserARMResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def get_static_site_builds( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteBuildCollection"] + """Gets all static site builds for a particular static site. + + Description for Gets all static site builds for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteBuildCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_site_builds.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteBuildCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_static_site_builds.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds'} # type: ignore + + def get_static_site_build( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteBuildARMResource" + """Gets the details of a static site build. + + Description for Gets the details of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteBuildARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteBuildARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteBuildARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + def delete_static_site_build( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a static site build. + + Description for Deletes a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + def create_or_update_static_site_build_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Creates or updates the function app settings of a static site build. + + Description for Creates or updates the function app settings of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/config/functionappsettings'} # type: ignore + + def list_static_site_build_functions( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteFunctionOverviewCollection"] + """Gets the functions of a particular static site build. + + Description for Gets the functions of a particular static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_build_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_build_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/functions'} # type: ignore + + def list_static_site_build_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/listFunctionAppSettings'} # type: ignore + + def create_or_update_static_site_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Creates or updates the function app settings of a static site. + + Description for Creates or updates the function app settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/config/functionappsettings'} # type: ignore + + def create_user_roles_invitation_link( + self, + resource_group_name, # type: str + name, # type: str + static_site_user_roles_invitation_envelope, # type: "_models.StaticSiteUserInvitationRequestResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteUserInvitationResponseResource" + """Creates an invitation link for a user with the role. + + Description for Creates an invitation link for a user with the role. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param static_site_user_roles_invitation_envelope: + :type static_site_user_roles_invitation_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserInvitationRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserInvitationResponseResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteUserInvitationResponseResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserInvitationResponseResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_user_roles_invitation_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_roles_invitation_envelope, 'StaticSiteUserInvitationRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserInvitationResponseResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_user_roles_invitation_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/createUserInvitation'} # type: ignore + + def list_static_site_custom_domains( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCustomDomainOverviewCollection"] + """Gets all static site custom domains for a particular static site. + + Description for Gets all static site custom domains for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site resource to search in. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCustomDomainOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_custom_domains.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCustomDomainOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_custom_domains.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains'} # type: ignore + + def create_or_update_static_site_custom_domain( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteCustomDomainOverviewARMResource" + """Creates a new static site custom domain in an existing resource group and static site. + + Description for Creates a new static site custom domain in an existing resource group and + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to create. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteCustomDomainOverviewARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StaticSiteCustomDomainOverviewARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + def delete_static_site_custom_domain( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a custom domain. + + Description for Deletes a custom domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to delete. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + def validate_custom_domain_can_be_added_to_static_site( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Validates a particular custom domain can be added to a static site. + + Description for Validates a particular custom domain can be added to a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to validate. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.validate_custom_domain_can_be_added_to_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_custom_domain_can_be_added_to_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}/validate'} # type: ignore + + def detach_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Detaches a static site. + + Description for Detaches a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to detach. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.detach_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + detach_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/detach'} # type: ignore + + def list_static_site_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteFunctionOverviewCollection"] + """Gets the functions of a static site. + + Description for Gets the functions of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/functions'} # type: ignore + + def list_static_site_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listFunctionAppSettings'} # type: ignore + + def list_static_site_secrets( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Lists the secrets for an existing static site. + + Description for Lists the secrets for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listSecrets'} # type: ignore + + def reset_static_site_api_key( + self, + resource_group_name, # type: str + name, # type: str + reset_properties_envelope, # type: "_models.StaticSiteResetPropertiesARMResource" + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the api key for an existing static site. + + Description for Resets the api key for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param reset_properties_envelope: + :type reset_properties_envelope: ~azure.mgmt.web.v2020_06_01.models.StaticSiteResetPropertiesARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reset_static_site_api_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reset_properties_envelope, 'StaticSiteResetPropertiesARMResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_static_site_api_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/resetapikey'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_top_level_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_top_level_domains_operations.py new file mode 100644 index 000000000000..b99cc1c4a7bd --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_top_level_domains_operations.py @@ -0,0 +1,259 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class TopLevelDomainsOperations(object): + """TopLevelDomainsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TopLevelDomainCollection"] + """Get all top-level domains supported for registration. + + Description for Get all top-level domains supported for registration. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TopLevelDomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TopLevelDomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TopLevelDomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains'} # type: ignore + + def get( + self, + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.TopLevelDomain" + """Get details of a top-level domain. + + Description for Get details of a top-level domain. + + :param name: Name of the top-level domain. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TopLevelDomain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TopLevelDomain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TopLevelDomain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}'} # type: ignore + + def list_agreements( + self, + name, # type: str + agreement_option, # type: "_models.TopLevelDomainAgreementOption" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TldLegalAgreementCollection"] + """Gets all legal agreements that user needs to accept before purchasing a domain. + + Description for Gets all legal agreements that user needs to accept before purchasing a domain. + + :param name: Name of the top-level domain. + :type name: str + :param agreement_option: Domain agreement options. + :type agreement_option: ~azure.mgmt.web.v2020_06_01.models.TopLevelDomainAgreementOption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TldLegalAgreementCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TldLegalAgreementCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TldLegalAgreementCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_agreements.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TldLegalAgreementCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_agreements.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}/listAgreements'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_apps_operations.py new file mode 100644 index 000000000000..53947f7d55cf --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_apps_operations.py @@ -0,0 +1,28958 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, IO, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class WebAppsOperations(object): + """WebAppsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_06_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps for a subscription. + + Description for Get all apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/sites'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + include_slots=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Gets all web, mobile, and API apps in the specified resource group. + + Description for Gets all web, mobile, and API apps in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param include_slots: Specify :code:`true` to include deployment slots in + results. The default is false, which only gives you the production slot of all apps. + :type include_slots: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if include_slots is not None: + query_parameters['includeSlots'] = self._serialize.query("include_slots", include_slots, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.Site"] + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Site"] + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + delete_metrics=None, # type: Optional[bool] + delete_empty_server_farm=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify false if you want to keep empty App Service plan. By + default, empty App Service plan is deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.SitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def analyze_custom_hostname( + self, + resource_group_name, # type: str + name, # type: str + host_name=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomHostnameAnalysisResult" + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/analyzeCustomHostname'} # type: ignore + + def apply_slot_config_to_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_config_to_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_config_to_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/applySlotConfig'} # type: ignore + + def backup( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backup'} # type: ignore + + def list_backups( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups'} # type: ignore + + def get_backup_status( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + def delete_backup( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + def list_backup_status_secrets( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/list'} # type: ignore + + def _restore_initial( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + def begin_restore( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + def get_basic_publishing_credentials_policies( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesCollection" + """Returns whether Scm basic auth is allowed and whether Ftp is allowed for a given site. + + Description for Returns whether Scm basic auth is allowed and whether Ftp is allowed for a + given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesCollection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesCollection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_basic_publishing_credentials_policies.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_basic_publishing_credentials_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies'} # type: ignore + + def get_ftp_allowed( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Returns whether FTP is allowed on the site or not. + + Description for Returns whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + def update_ftp_allowed( + self, + resource_group_name, # type: str + name, # type: str + csm_publishing_access_policies_entity, # type: "_models.CsmPublishingCredentialsPoliciesEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Updates whether FTP is allowed on the site or not. + + Description for Updates whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + def get_scm_allowed( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Returns whether Scm basic auth is allowed on the site or not. + + Description for Returns whether Scm basic auth is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def update_scm_allowed( + self, + resource_group_name, # type: str + name, # type: str + csm_publishing_access_policies_entity, # type: "_models.CsmPublishingCredentialsPoliciesEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Updates whether user publishing credentials are allowed on the site or not. + + Description for Updates whether user publishing credentials are allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def list_configurations( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigResourceCollection"] + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config'} # type: ignore + + def update_application_settings( + self, + resource_group_name, # type: str + name, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings'} # type: ignore + + def list_application_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings/list'} # type: ignore + + def update_auth_settings( + self, + resource_group_name, # type: str + name, # type: str + site_auth_settings, # type: "_models.SiteAuthSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings'} # type: ignore + + def get_auth_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings/list'} # type: ignore + + def update_auth_settings_v2( + self, + resource_group_name, # type: str + name, # type: str + site_auth_settings_v2, # type: "_models.SiteAuthSettingsV2" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2'} # type: ignore + + def get_auth_settings_v2( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2/list'} # type: ignore + + def update_azure_storage_accounts( + self, + resource_group_name, # type: str + name, # type: str + azure_storage_accounts, # type: "_models.AzureStoragePropertyDictionaryResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts'} # type: ignore + + def list_azure_storage_accounts( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts/list'} # type: ignore + + def update_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + def delete_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + def get_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup/list'} # type: ignore + + def update_connection_strings( + self, + resource_group_name, # type: str + name, # type: str + connection_strings, # type: "_models.ConnectionStringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings'} # type: ignore + + def list_connection_strings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings/list'} # type: ignore + + def get_diagnostic_logs_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + def update_diagnostic_logs_config( + self, + resource_group_name, # type: str + name, # type: str + site_logs_config, # type: "_models.SiteLogsConfig" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + def update_metadata( + self, + resource_group_name, # type: str + name, # type: str + metadata, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata'} # type: ignore + + def list_metadata( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata/list'} # type: ignore + + def _list_publishing_credentials_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + def begin_list_publishing_credentials( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.User"] + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._list_publishing_credentials_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + def update_site_push_settings( + self, + resource_group_name, # type: str + name, # type: str + push_settings, # type: "_models.PushSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings'} # type: ignore + + def list_site_push_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings/list'} # type: ignore + + def list_slot_configuration_names( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SlotConfigNamesResource" + """Gets the names of app settings and connection strings that stick to the slot (not swapped). + + Description for Gets the names of app settings and connection strings that stick to the slot + (not swapped). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + def update_slot_configuration_names( + self, + resource_group_name, # type: str + name, # type: str + slot_config_names, # type: "_models.SlotConfigNamesResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SlotConfigNamesResource" + """Updates the names of application settings and connection string that remain with the slot during swap operation. + + Description for Updates the names of application settings and connection string that remain + with the slot during swap operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_config_names: Names of application settings and connection strings. See example. + :type slot_config_names: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_config_names, 'SlotConfigNamesResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + def get_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def create_or_update_configuration( + self, + resource_group_name, # type: str + name, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def update_configuration( + self, + resource_group_name, # type: str + name, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def list_configuration_snapshot_info( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigurationSnapshotInfoCollection"] + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots'} # type: ignore + + def get_configuration_snapshot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}'} # type: ignore + + def recover_site_configuration_snapshot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + def get_web_site_container_logs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs'} # type: ignore + + def get_container_logs_zip( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ContinuousWebJobCollection"] + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs'} # type: ignore + + def get_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ContinuousWebJob"] + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + def delete_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + def start_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/start'} # type: ignore + + def stop_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentCollection"] + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_deployments.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments'} # type: ignore + + def get_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def create_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + deployment, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_06_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def delete_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def list_deployment_log( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}/log'} # type: ignore + + def discover_backup( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.RestoreRequest" + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers'} # type: ignore + + def get_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def create_or_update_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def delete_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def update_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def get_ms_deploy_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def _create_ms_deploy_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def begin_create_ms_deploy_operation( + self, + resource_group_name, # type: str + name, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def get_ms_deploy_log( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy/log'} # type: ignore + + def list_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FunctionEnvelopeCollection"] + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions'} # type: ignore + + def get_functions_admin_token( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> str + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/admin/token'} # type: ignore + + def get_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.FunctionEnvelope"] + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def _create_function_initial( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionEnvelope" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_function_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_function_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def begin_create_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FunctionEnvelope"] + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_function_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def delete_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def create_or_update_function_secret( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def delete_function_secret( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def list_function_keys( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listkeys'} # type: ignore + + def list_function_secrets( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listsecrets'} # type: ignore + + def list_host_keys( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostKeys" + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listkeys'} # type: ignore + + def list_sync_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listsyncstatus'} # type: ignore + + def sync_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/sync'} # type: ignore + + def create_or_update_host_secret( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def delete_host_secret( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HostNameBindingCollection"] + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_host_name_bindings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings'} # type: ignore + + def get_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def create_or_update_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + host_name_binding, # type: "_models.HostNameBinding" + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def delete_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def get_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def create_or_update_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def update_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionRelays'} # type: ignore + + def list_relay_service_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection'} # type: ignore + + def get_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def create_or_update_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def delete_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def update_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppInstanceStatusCollection"] + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances'} # type: ignore + + def get_instance_info( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebSiteInstanceStatus" + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}'} # type: ignore + + def get_instance_ms_deploy_status( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def _create_instance_ms_deploy_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def begin_create_instance_ms_deploy_operation( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def get_instance_ms_deploy_log( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes'} # type: ignore + + def get_instance_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def delete_instance_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def get_instance_process_dump( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + def get_instance_process_module( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + def is_cloneable( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteCloneability" + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/iscloneable'} # type: ignore + + def list_site_backups( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listbackups'} # type: ignore + + def list_sync_function_triggers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listsyncfunctiontriggerstatus'} # type: ignore + + def _migrate_storage_initial( + self, + subscription_name, # type: str + resource_group_name, # type: str + name, # type: str + migration_options, # type: "_models.StorageMigrationOptions" + **kwargs # type: Any + ): + # type: (...) -> "_models.StorageMigrationResponse" + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_storage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['subscriptionName'] = self._serialize.query("subscription_name", subscription_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_options, 'StorageMigrationOptions') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_storage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + def begin_migrate_storage( + self, + subscription_name, # type: str + resource_group_name, # type: str + name, # type: str + migration_options, # type: "_models.StorageMigrationOptions" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.StorageMigrationResponse"] + """Restores a web app. + + Description for Restores a web app. + + :param subscription_name: Azure subscription. + :type subscription_name: str + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_options: Migration migrationOptions. + :type migration_options: ~azure.mgmt.web.v2020_06_01.models.StorageMigrationOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either StorageMigrationResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.StorageMigrationResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._migrate_storage_initial( + subscription_name=subscription_name, + resource_group_name=resource_group_name, + name=name, + migration_options=migration_options, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_storage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + def _migrate_my_sql_initial( + self, + resource_group_name, # type: str + name, # type: str + migration_request_envelope, # type: "_models.MigrateMySqlRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.Operation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_my_sql_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_request_envelope, 'MigrateMySqlRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_my_sql_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + def begin_migrate_my_sql( + self, + resource_group_name, # type: str + name, # type: str + migration_request_envelope, # type: "_models.MigrateMySqlRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Operation"] + """Migrates a local (in-app) MySql database to a remote MySql database. + + Description for Migrates a local (in-app) MySql database to a remote MySql database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_request_envelope: MySql migration options. + :type migration_request_envelope: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Operation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.Operation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._migrate_my_sql_initial( + resource_group_name=resource_group_name, + name=name, + migration_request_envelope=migration_request_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_my_sql.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + def get_migrate_my_sql_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MigrateMySqlStatus" + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql/status'} # type: ignore + + def get_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def create_or_update_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def delete_swift_virtual_network( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def update_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def list_network_features( + self, + resource_group_name, # type: str + name, # type: str + view, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.NetworkFeatures"] + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkFeatures/{view}'} # type: ignore + + def get_network_trace_operation( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/operationresults/{operationId}'} # type: ignore + + def start_web_site_network_trace( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> str + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/start'} # type: ignore + + def _start_web_site_network_trace_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + def begin_start_web_site_network_trace_operation( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_web_site_network_trace_operation_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + def stop_web_site_network_trace( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/stop'} # type: ignore + + def get_network_traces( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/{operationId}'} # type: ignore + + def get_network_trace_operation_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + def get_network_traces_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/{operationId}'} # type: ignore + + def generate_new_site_publishing_password( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/newpassword'} # type: ignore + + def list_perf_mon_counters( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PerfMonCounterCollection"] + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_perf_mon_counters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/perfcounters'} # type: ignore + + def get_site_php_error_log_flag( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SitePhpErrorLogFlag" + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/phplogging'} # type: ignore + + def list_premier_add_ons( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons'} # type: ignore + + def get_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def add_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + premier_add_on, # type: "_models.PremierAddOn" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def delete_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def update_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + premier_add_on, # type: "_models.PremierAddOnPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def get_private_access( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def put_private_access_vnet( + self, + resource_group_name, # type: str + name, # type: str + access, # type: "_models.PrivateAccess" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def list_processes( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes'} # type: ignore + + def get_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + def delete_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + def get_process_dump( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/dump'} # type: ignore + + def list_process_modules( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules'} # type: ignore + + def get_process_module( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicCertificateCollection"] + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_public_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates'} # type: ignore + + def get_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def create_or_update_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + public_certificate, # type: "_models.PublicCertificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def delete_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def list_publishing_profile_xml_with_secrets( + self, + resource_group_name, # type: str + name, # type: str + publishing_profile_options, # type: "_models.CsmPublishingProfileOptions" + **kwargs # type: Any + ): + # type: (...) -> IO + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publishxml'} # type: ignore + + def reset_production_slot_config( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_production_slot_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_production_slot_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resetSlotConfig'} # type: ignore + + def restart( + self, + resource_group_name, # type: str + name, # type: str + soft_restart=None, # type: Optional[bool] + synchronous=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restart'} # type: ignore + + def _restore_from_backup_blob_initial( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + def begin_restore_from_backup_blob( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_backup_blob_initial( + resource_group_name=resource_group_name, + name=name, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + def _restore_from_deleted_app_initial( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + def begin_restore_from_deleted_app( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_deleted_app_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + def _restore_snapshot_initial( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def begin_restore_snapshot( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_snapshot_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def list_site_extensions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteExtensionInfoCollection"] + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_extensions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions'} # type: ignore + + def get_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def _install_site_extension_initial( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def begin_install_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteExtensionInfo"] + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._install_site_extension_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def delete_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def _copy_production_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_production_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_production_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def begin_copy_production_slot( + self, + resource_group_name, # type: str + name, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_06_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._copy_production_slot_initial( + resource_group_name=resource_group_name, + name=name, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_production_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def list_slots( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Gets an app's deployment slots. + + Description for Gets an app's deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots'} # type: ignore + + def get_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.Site"] + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def _create_or_update_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def begin_create_or_update_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Site"] + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def delete_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + delete_metrics=None, # type: Optional[bool] + delete_empty_server_farm=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param slot: Name of the deployment slot to delete. By default, the API deletes the production + slot. + :type slot: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify true if the App Service plan will be empty after app + deletion and you want to delete the empty App Service plan. By default, the empty App Service + plan is not deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def update_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.SitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_06_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def analyze_custom_hostname_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomHostnameAnalysisResult" + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/analyzeCustomHostname'} # type: ignore + + def apply_slot_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/applySlotConfig'} # type: ignore + + def backup_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + backup for the production slot. + :type slot: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backup'} # type: ignore + + def list_backups_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups'} # type: ignore + + def get_backup_status_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a backup + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + def delete_backup_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + backup of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + def list_backup_status_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/list'} # type: ignore + + def _restore_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def begin_restore_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_slot_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def list_configurations_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigResourceCollection"] + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configurations_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config'} # type: ignore + + def update_application_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + application settings for the production slot. + :type slot: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings'} # type: ignore + + def list_application_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + application settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings/list'} # type: ignore + + def update_auth_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_auth_settings, # type: "_models.SiteAuthSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings'} # type: ignore + + def get_auth_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings/list'} # type: ignore + + def update_auth_settings_v2_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_auth_settings_v2, # type: "_models.SiteAuthSettingsV2" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2'} # type: ignore + + def get_auth_settings_v2_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2/list'} # type: ignore + + def update_azure_storage_accounts_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + azure_storage_accounts, # type: "_models.AzureStoragePropertyDictionaryResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts'} # type: ignore + + def list_azure_storage_accounts_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts/list'} # type: ignore + + def update_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + backup configuration for the production slot. + :type slot: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + def delete_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + def get_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup/list'} # type: ignore + + def update_connection_strings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_strings, # type: "_models.ConnectionStringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + connection settings for the production slot. + :type slot: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings'} # type: ignore + + def list_connection_strings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + connection settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings/list'} # type: ignore + + def get_diagnostic_logs_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + logging configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + def update_diagnostic_logs_config_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_logs_config, # type: "_models.SiteLogsConfig" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + logging configuration for the production slot. + :type slot: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + def update_metadata_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + metadata, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + metadata for the production slot. + :type slot: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata'} # type: ignore + + def list_metadata_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + metadata for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata/list'} # type: ignore + + def _list_publishing_credentials_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + def begin_list_publishing_credentials_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.User"] + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing credentials for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._list_publishing_credentials_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + def update_site_push_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + push_settings, # type: "_models.PushSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings'} # type: ignore + + def list_site_push_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings/list'} # type: ignore + + def get_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def create_or_update_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def update_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def list_configuration_snapshot_info_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigurationSnapshotInfoCollection"] + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots'} # type: ignore + + def get_configuration_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}'} # type: ignore + + def recover_site_configuration_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + def get_web_site_container_logs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs'} # type: ignore + + def get_container_logs_zip_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ContinuousWebJobCollection"] + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs'} # type: ignore + + def get_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ContinuousWebJob"] + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + def delete_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + def start_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/start'} # type: ignore + + def stop_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentCollection"] + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_deployments_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments'} # type: ignore + + def get_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets a deployment + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def create_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + deployment, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API creates a + deployment for the production slot. + :type slot: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_06_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def delete_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def list_deployment_log_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}/log'} # type: ignore + + def discover_backup_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.RestoreRequest" + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will perform + discovery for the production slot. + :type slot: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers'} # type: ignore + + def get_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def create_or_update_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def delete_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def update_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_06_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def get_ms_deploy_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def _create_ms_deploy_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def begin_create_ms_deploy_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def get_ms_deploy_log_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_functions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FunctionEnvelopeCollection"] + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions'} # type: ignore + + def get_functions_admin_token_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> str + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/admin/token'} # type: ignore + + def get_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.FunctionEnvelope"] + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def _create_instance_function_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionEnvelope" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_function_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_function_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def begin_create_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FunctionEnvelope"] + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_function_slot_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + slot=slot, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def delete_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def create_or_update_function_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + slot, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def delete_function_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def list_function_keys_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listkeys'} # type: ignore + + def list_function_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listsecrets'} # type: ignore + + def list_host_keys_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostKeys" + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listkeys'} # type: ignore + + def list_sync_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listsyncstatus'} # type: ignore + + def sync_functions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/sync'} # type: ignore + + def create_or_update_host_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + slot, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def delete_host_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HostNameBindingCollection"] + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_host_name_bindings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings'} # type: ignore + + def get_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def create_or_update_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + slot, # type: str + host_name_binding, # type: "_models.HostNameBinding" + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def delete_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def get_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def create_or_update_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def update_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionRelays'} # type: ignore + + def list_relay_service_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get hybrid + connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection'} # type: ignore + + def get_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a hybrid + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def create_or_update_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def delete_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + hybrid connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def update_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppInstanceStatusCollection"] + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances'} # type: ignore + + def get_instance_info_slot( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebSiteInstanceStatus" + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}'} # type: ignore + + def get_instance_ms_deploy_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def _create_instance_ms_deploy_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def begin_create_instance_ms_deploy_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_06_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def get_instance_ms_deploy_log_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes'} # type: ignore + + def get_instance_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def delete_instance_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def get_instance_process_dump_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + def get_instance_process_module_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + def is_cloneable_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteCloneability" + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns information on the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/iscloneable'} # type: ignore + + def list_site_backups_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listbackups'} # type: ignore + + def list_sync_function_triggers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listsyncfunctiontriggerstatus'} # type: ignore + + def get_migrate_my_sql_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MigrateMySqlStatus" + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/migratemysql/status'} # type: ignore + + def get_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def create_or_update_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def delete_swift_virtual_network_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def update_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def list_network_features_slot( + self, + resource_group_name, # type: str + name, # type: str + view, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.NetworkFeatures"] + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get network + features for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkFeatures/{view}'} # type: ignore + + def get_network_trace_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/operationresults/{operationId}'} # type: ignore + + def start_web_site_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> str + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/start'} # type: ignore + + def _start_web_site_network_trace_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + def begin_start_web_site_network_trace_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_web_site_network_trace_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + def stop_web_site_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/stop'} # type: ignore + + def get_network_traces_slot( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/{operationId}'} # type: ignore + + def get_network_trace_operation_slot_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + def get_network_traces_slot_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/{operationId}'} # type: ignore + + def generate_new_site_publishing_password_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API generate a new + publishing password for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/newpassword'} # type: ignore + + def list_perf_mon_counters_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PerfMonCounterCollection"] + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_perf_mon_counters_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/perfcounters'} # type: ignore + + def get_site_php_error_log_flag_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SitePhpErrorLogFlag" + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/phplogging'} # type: ignore + + def list_premier_add_ons_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + premier add-ons for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons'} # type: ignore + + def get_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def add_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + premier_add_on, # type: "_models.PremierAddOn" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def delete_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def update_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + premier_add_on, # type: "_models.PremierAddOnPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_06_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def get_private_access_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + def put_private_access_vnet_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + access, # type: "_models.PrivateAccess" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + def get_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnectionResource" + """Gets a private endpoint connection. + + Description for Gets a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnectionResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateEndpointConnectionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def _approve_or_reject_private_endpoint_connection_initial( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + private_endpoint_wrapper, # type: "_models.PrivateLinkConnectionApprovalRequestResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnectionResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._approve_or_reject_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(private_endpoint_wrapper, 'PrivateLinkConnectionApprovalRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _approve_or_reject_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def begin_approve_or_reject_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + private_endpoint_wrapper, # type: "_models.PrivateLinkConnectionApprovalRequestResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateEndpointConnectionResource"] + """Approves or rejects a private endpoint connection. + + Description for Approves or rejects a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :param private_endpoint_wrapper: + :type private_endpoint_wrapper: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkConnectionApprovalRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either PrivateEndpointConnectionResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.PrivateEndpointConnectionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._approve_or_reject_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + private_endpoint_wrapper=private_endpoint_wrapper, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_approve_or_reject_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def _delete_private_endpoint_connection_initial( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> object + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._delete_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 204: + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def begin_delete_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[object] + """Deletes a private endpoint connection. + + Description for Deletes a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either object or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[object] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[object] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def get_private_link_resources( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateLinkResourcesWrapper" + """Gets the private link resources. + + Description for Gets the private link resources. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkResourcesWrapper, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PrivateLinkResourcesWrapper + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkResourcesWrapper"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_private_link_resources.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkResourcesWrapper', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_link_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateLinkResources'} # type: ignore + + def list_processes_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes'} # type: ignore + + def get_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + def delete_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + def get_process_dump_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/dump'} # type: ignore + + def list_process_modules_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules'} # type: ignore + + def get_process_module_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicCertificateCollection"] + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_public_certificates_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates'} # type: ignore + + def get_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def create_or_update_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + slot, # type: str + public_certificate, # type: "_models.PublicCertificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def delete_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def list_publishing_profile_xml_with_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + publishing_profile_options, # type: "_models.CsmPublishingProfileOptions" + **kwargs # type: Any + ): + # type: (...) -> IO + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing profile for the production slot. + :type slot: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_06_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publishxml'} # type: ignore + + def reset_slot_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API resets + configuration settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.reset_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resetSlotConfig'} # type: ignore + + def restart_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + soft_restart=None, # type: Optional[bool] + synchronous=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restart the + production slot. + :type slot: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.restart_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restart'} # type: ignore + + def _restore_from_backup_blob_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + def begin_restore_from_backup_blob_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_06_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_backup_blob_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + def _restore_from_deleted_app_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + def begin_restore_from_deleted_app_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_deleted_app_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + def _restore_snapshot_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def begin_restore_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_06_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_snapshot_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def list_site_extensions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteExtensionInfoCollection"] + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_extensions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions'} # type: ignore + + def get_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def _install_site_extension_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def begin_install_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteExtensionInfo"] + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._install_site_extension_slot_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def delete_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def _copy_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def begin_copy_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_06_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._copy_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def list_slot_differences_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SlotDifferenceCollection"] + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slot_differences_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsdiffs'} # type: ignore + + def _swap_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def begin_swap_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._swap_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def list_snapshots_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshotsdr'} # type: ignore + + def get_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def _create_or_update_source_control_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def begin_create_or_update_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteSourceControl"] + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_source_control_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def delete_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def update_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def start_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will start the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/start'} # type: ignore + + def _start_network_trace_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + def begin_start_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_network_trace_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + def stop_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will stop the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stop'} # type: ignore + + def stop_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stopNetworkTrace'} # type: ignore + + def sync_repository_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sync'} # type: ignore + + def sync_function_triggers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredWebJobCollection"] + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs'} # type: ignore + + def get_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredWebJob"] + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def delete_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes web job + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredJobHistoryCollection"] + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + def get_triggered_web_job_history_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredJobHistory"] + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + def run_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get quota + information of the production slot. + :type slot: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/usages'} # type: ignore + + def list_vnet_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get virtual + network connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections'} # type: ignore + + def get_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named virtual network for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def create_or_update_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def delete_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def update_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetGateway"] + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def create_or_update_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebJobCollection"] + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs'} # type: ignore + + def get_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebJob" + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs/{webJobName}'} # type: ignore + + def list_slot_differences_from_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SlotDifferenceCollection"] + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_from_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slot_differences_from_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsdiffs'} # type: ignore + + def _swap_slot_with_production_initial( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_with_production_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_with_production_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def begin_swap_slot_with_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_06_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._swap_slot_with_production_initial( + resource_group_name=resource_group_name, + name=name, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot_with_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def list_snapshots( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshotsdr'} # type: ignore + + def get_source_control( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def _create_or_update_source_control_initial( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def begin_create_or_update_source_control( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteSourceControl"] + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_06_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_source_control_initial( + resource_group_name=resource_group_name, + name=name, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def delete_source_control( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def update_source_control( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def start( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.start.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/start'} # type: ignore + + def _start_network_trace_initial( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + def begin_start_network_trace( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_06_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_network_trace_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + def stop( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stop'} # type: ignore + + def stop_network_trace( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stopNetworkTrace'} # type: ignore + + def sync_repository( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sync'} # type: ignore + + def sync_function_triggers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredWebJobCollection"] + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs'} # type: ignore + + def get_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredWebJob"] + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def delete_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredJobHistoryCollection"] + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + def get_triggered_web_job_history( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredJobHistory"] + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + def run_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/usages'} # type: ignore + + def list_vnet_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_06_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections'} # type: ignore + + def get_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def create_or_update_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def delete_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def update_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetGateway"] + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def create_or_update_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebJobCollection"] + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs'} # type: ignore + + def get_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebJob" + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs/{webJobName}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_site_management_client_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_site_management_client_operations.py new file mode 100644 index 000000000000..cf7559bc0c76 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/operations/_web_site_management_client_operations.py @@ -0,0 +1,1079 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class WebSiteManagementClientOperationsMixin(object): + + def get_publishing_user( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + """Gets publishing user. + + Description for Gets publishing user. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def update_publishing_user( + self, + user_details, # type: "_models.User" + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + """Updates publishing user. + + Description for Updates publishing user. + + :param user_details: Details of publishing user. + :type user_details: ~azure.mgmt.web.v2020_06_01.models.User + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(user_details, 'User') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def list_source_controls( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SourceControlCollection"] + """Gets the source controls available for Azure websites. + + Description for Gets the source controls available for Azure websites. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SourceControlCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.SourceControlCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControlCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_source_controls.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SourceControlCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_source_controls.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols'} # type: ignore + + def get_source_control( + self, + source_control_type, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SourceControl" + """Gets source control token. + + Description for Gets source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def update_source_control( + self, + source_control_type, # type: str + request_message, # type: "_models.SourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SourceControl" + """Updates source control token. + + Description for Updates source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :param request_message: Source control token information. + :type request_message: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request_message, 'SourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def list_billing_meters( + self, + billing_location=None, # type: Optional[str] + os_type=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BillingMeterCollection"] + """Gets a list of meters for a given location. + + Description for Gets a list of meters for a given location. + + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param os_type: App Service OS type meters used for. + :type os_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.BillingMeterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BillingMeterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_billing_meters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if billing_location is not None: + query_parameters['billingLocation'] = self._serialize.query("billing_location", billing_location, 'str') + if os_type is not None: + query_parameters['osType'] = self._serialize.query("os_type", os_type, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BillingMeterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_billing_meters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/billingMeters'} # type: ignore + + def check_name_availability( + self, + name, # type: str + type, # type: Union[str, "_models.CheckNameResourceTypes"] + is_fqdn=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceNameAvailability" + """Check if a resource name is available. + + Description for Check if a resource name is available. + + :param name: Resource name to verify. + :type name: str + :param type: Resource type used for verification. + :type type: str or ~azure.mgmt.web.v2020_06_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNameAvailability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ResourceNameAvailability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNameAvailability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.ResourceNameAvailabilityRequest(name=name, type=type, is_fqdn=is_fqdn) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_name_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'ResourceNameAvailabilityRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceNameAvailability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/checknameavailability'} # type: ignore + + def get_subscription_deployment_locations( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentLocations" + """Gets list of available geo regions plus ministamps. + + Description for Gets list of available geo regions plus ministamps. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentLocations, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.DeploymentLocations + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentLocations"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.get_subscription_deployment_locations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentLocations', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_subscription_deployment_locations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deploymentLocations'} # type: ignore + + def list_geo_regions( + self, + sku=None, # type: Optional[Union[str, "_models.SkuName"]] + linux_workers_enabled=None, # type: Optional[bool] + xenon_workers_enabled=None, # type: Optional[bool] + linux_dynamic_workers_enabled=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.GeoRegionCollection"] + """Get a list of available geographical regions. + + Description for Get a list of available geographical regions. + + :param sku: Name of SKU used to filter the regions. + :type sku: str or ~azure.mgmt.web.v2020_06_01.models.SkuName + :param linux_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Linux workers. + :type linux_workers_enabled: bool + :param xenon_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Xenon workers. + :type xenon_workers_enabled: bool + :param linux_dynamic_workers_enabled: Specify :code:`true` if you want to filter + to only regions that support Linux Consumption Workers. + :type linux_dynamic_workers_enabled: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.GeoRegionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GeoRegionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_geo_regions.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if sku is not None: + query_parameters['sku'] = self._serialize.query("sku", sku, 'str') + if linux_workers_enabled is not None: + query_parameters['linuxWorkersEnabled'] = self._serialize.query("linux_workers_enabled", linux_workers_enabled, 'bool') + if xenon_workers_enabled is not None: + query_parameters['xenonWorkersEnabled'] = self._serialize.query("xenon_workers_enabled", xenon_workers_enabled, 'bool') + if linux_dynamic_workers_enabled is not None: + query_parameters['linuxDynamicWorkersEnabled'] = self._serialize.query("linux_dynamic_workers_enabled", linux_dynamic_workers_enabled, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('GeoRegionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_geo_regions.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/geoRegions'} # type: ignore + + def list_site_identifiers_assigned_to_host_name( + self, + name_identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """List all apps that are assigned to a hostname. + + Description for List all apps that are assigned to a hostname. + + :param name_identifier: Hostname information. + :type name_identifier: ~azure.mgmt.web.v2020_06_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_identifiers_assigned_to_host_name.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_identifiers_assigned_to_host_name.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/listSitesAssignedToHostName'} # type: ignore + + def list_premier_add_on_offers( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PremierAddOnOfferCollection"] + """List all premier add-on offers. + + Description for List all premier add-on offers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_06_01.models.PremierAddOnOfferCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOnOfferCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_premier_add_on_offers.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PremierAddOnOfferCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_premier_add_on_offers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/premieraddonoffers'} # type: ignore + + def list_skus( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.SkuInfos" + """List all SKUs. + + Description for List all SKUs. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SkuInfos, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.SkuInfos + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfos"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.list_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SkuInfos', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_skus.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/skus'} # type: ignore + + def verify_hosting_environment_vnet( + self, + parameters, # type: "_models.VnetParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetValidationFailureDetails" + """Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules. + + Description for Verifies if this VNET is compatible with an App Service Environment by + analyzing the Network Security Group rules. + + :param parameters: VNET information. + :type parameters: ~azure.mgmt.web.v2020_06_01.models.VnetParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetValidationFailureDetails, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.VnetValidationFailureDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetValidationFailureDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.verify_hosting_environment_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'VnetParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetValidationFailureDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + verify_hosting_environment_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/verifyHostingEnvironmentVnet'} # type: ignore + + def move( + self, + resource_group_name, # type: str + move_resource_envelope, # type: "_models.CsmMoveResourceEnvelope" + **kwargs # type: Any + ): + # type: (...) -> None + """Move resources between resource groups. + + Description for Move resources between resource groups. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/moveResources'} # type: ignore + + def validate( + self, + resource_group_name, # type: str + validate_request, # type: "_models.ValidateRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.ValidateResponse" + """Validate if a resource can be created. + + Description for Validate if a resource can be created. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param validate_request: Request with the resources to validate. + :type validate_request: ~azure.mgmt.web.v2020_06_01.models.ValidateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ValidateResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_06_01.models.ValidateResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ValidateResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(validate_request, 'ValidateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ValidateResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/validate'} # type: ignore + + def validate_move( + self, + resource_group_name, # type: str + move_resource_envelope, # type: "_models.CsmMoveResourceEnvelope" + **kwargs # type: Any + ): + # type: (...) -> None + """Validate whether a resource can be moved. + + Description for Validate whether a resource can be moved. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_06_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/validateMoveResources'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/py.typed b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_06_01/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/__init__.py similarity index 69% rename from sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_version.py rename to sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/__init__.py index 5c14e0d8303d..32779ae9e1b0 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2016_08_01/_version.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/__init__.py @@ -6,4 +6,11 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- -VERSION = "0.42.0" +from ._web_site_management_client import WebSiteManagementClient +__all__ = ['WebSiteManagementClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_configuration.py new file mode 100644 index 000000000000..7d1aa8d0daa7 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_configuration.py @@ -0,0 +1,70 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + + from azure.core.credentials import TokenCredential + +VERSION = "unknown" + +class WebSiteManagementClientConfiguration(Configuration): + """Configuration for WebSiteManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(WebSiteManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-09-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-web/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_metadata.json b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_metadata.json new file mode 100644 index 000000000000..421e5a53f91c --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_metadata.json @@ -0,0 +1,279 @@ +{ + "chosen_version": "2020-09-01", + "total_api_version_list": ["2020-09-01"], + "client": { + "name": "WebSiteManagementClient", + "filename": "_web_site_management_client", + "description": "WebSite Management Client.", + "base_url": "\u0027https://management.azure.com\u0027", + "custom_base_url": null, + "azure_arm": true, + "has_lro_operations": true, + "client_side_validation": false + }, + "global_parameters": { + "sync": { + "credential": { + "signature": "credential, # type: \"TokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials.TokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000).", + "docstring_type": "str", + "required": true + } + }, + "async": { + "credential": { + "signature": "credential, # type: \"AsyncTokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000).", + "docstring_type": "str", + "required": true + } + }, + "constant": { + }, + "call": "credential, subscription_id" + }, + "config": { + "credential": true, + "credential_scopes": ["https://management.azure.com/.default"], + "credential_default_policy_type": "BearerTokenCredentialPolicy", + "credential_default_policy_type_has_async_version": true, + "credential_key_header_name": null + }, + "operation_groups": { + "app_service_certificate_orders": "AppServiceCertificateOrdersOperations", + "certificate_registration_provider": "CertificateRegistrationProviderOperations", + "domains": "DomainsOperations", + "top_level_domains": "TopLevelDomainsOperations", + "domain_registration_provider": "DomainRegistrationProviderOperations", + "certificates": "CertificatesOperations", + "deleted_web_apps": "DeletedWebAppsOperations", + "diagnostics": "DiagnosticsOperations", + "provider": "ProviderOperations", + "recommendations": "RecommendationsOperations", + "web_apps": "WebAppsOperations", + "static_sites": "StaticSitesOperations", + "app_service_environments": "AppServiceEnvironmentsOperations", + "app_service_plans": "AppServicePlansOperations", + "resource_health_metadata": "ResourceHealthMetadataOperations" + }, + "operation_mixins": { + "generate_github_access_token_for_appservice_cli_async" : { + "sync": { + "signature": "def generate_github_access_token_for_appservice_cli_async(\n self,\n code, # type: str\n state, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Exchange code for GitHub access token for AppService CLI.\n\nDescription for Exchange code for GitHub access token for AppService CLI.\n\n:param code: Code string to exchange for Github Access token.\n:type code: str\n:param state: State string used for verification.\n:type state: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: AppserviceGithubToken, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def generate_github_access_token_for_appservice_cli_async(\n self,\n code: str,\n state: str,\n **kwargs\n) -\u003e \"_models.AppserviceGithubToken\":\n", + "doc": "\"\"\"Exchange code for GitHub access token for AppService CLI.\n\nDescription for Exchange code for GitHub access token for AppService CLI.\n\n:param code: Code string to exchange for Github Access token.\n:type code: str\n:param state: State string used for verification.\n:type state: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: AppserviceGithubToken, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "code, state" + }, + "get_publishing_user" : { + "sync": { + "signature": "def get_publishing_user(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets publishing user.\n\nDescription for Gets publishing user.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_publishing_user(\n self,\n **kwargs\n) -\u003e \"_models.User\":\n", + "doc": "\"\"\"Gets publishing user.\n\nDescription for Gets publishing user.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "update_publishing_user" : { + "sync": { + "signature": "def update_publishing_user(\n self,\n user_details, # type: \"_models.User\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Updates publishing user.\n\nDescription for Updates publishing user.\n\n:param user_details: Details of publishing user.\n:type user_details: ~azure.mgmt.web.v2020_09_01.models.User\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def update_publishing_user(\n self,\n user_details: \"_models.User\",\n **kwargs\n) -\u003e \"_models.User\":\n", + "doc": "\"\"\"Updates publishing user.\n\nDescription for Updates publishing user.\n\n:param user_details: Details of publishing user.\n:type user_details: ~azure.mgmt.web.v2020_09_01.models.User\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: User, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.User\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "user_details" + }, + "list_source_controls" : { + "sync": { + "signature": "def list_source_controls(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets the source controls available for Azure websites.\n\nDescription for Gets the source controls available for Azure websites.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either SourceControlCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_source_controls(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.SourceControlCollection\"]:\n", + "doc": "\"\"\"Gets the source controls available for Azure websites.\n\nDescription for Gets the source controls available for Azure websites.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either SourceControlCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "get_source_control" : { + "sync": { + "signature": "def get_source_control(\n self,\n source_control_type, # type: str\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets source control token.\n\nDescription for Gets source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_source_control(\n self,\n source_control_type: str,\n **kwargs\n) -\u003e \"_models.SourceControl\":\n", + "doc": "\"\"\"Gets source control token.\n\nDescription for Gets source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "source_control_type" + }, + "update_source_control" : { + "sync": { + "signature": "def update_source_control(\n self,\n source_control_type, # type: str\n request_message, # type: \"_models.SourceControl\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Updates source control token.\n\nDescription for Updates source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:param request_message: Source control token information.\n:type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def update_source_control(\n self,\n source_control_type: str,\n request_message: \"_models.SourceControl\",\n **kwargs\n) -\u003e \"_models.SourceControl\":\n", + "doc": "\"\"\"Updates source control token.\n\nDescription for Updates source control token.\n\n:param source_control_type: Type of source control.\n:type source_control_type: str\n:param request_message: Source control token information.\n:type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SourceControl, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "source_control_type, request_message" + }, + "list_billing_meters" : { + "sync": { + "signature": "def list_billing_meters(\n self,\n billing_location=None, # type: Optional[str]\n os_type=None, # type: Optional[str]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets a list of meters for a given location.\n\nDescription for Gets a list of meters for a given location.\n\n:param billing_location: Azure Location of billable resource.\n:type billing_location: str\n:param os_type: App Service OS type meters used for.\n:type os_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BillingMeterCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_billing_meters(\n self,\n billing_location: Optional[str] = None,\n os_type: Optional[str] = None,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.BillingMeterCollection\"]:\n", + "doc": "\"\"\"Gets a list of meters for a given location.\n\nDescription for Gets a list of meters for a given location.\n\n:param billing_location: Azure Location of billable resource.\n:type billing_location: str\n:param os_type: App Service OS type meters used for.\n:type os_type: str\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either BillingMeterCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "billing_location, os_type" + }, + "check_name_availability" : { + "sync": { + "signature": "def check_name_availability(\n self,\n name, # type: str\n type, # type: Union[str, \"_models.CheckNameResourceTypes\"]\n is_fqdn=None, # type: Optional[bool]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Check if a resource name is available.\n\nDescription for Check if a resource name is available.\n\n:param name: Resource name to verify.\n:type name: str\n:param type: Resource type used for verification.\n:type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes\n:param is_fqdn: Is fully qualified domain name.\n:type is_fqdn: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ResourceNameAvailability, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def check_name_availability(\n self,\n name: str,\n type: Union[str, \"_models.CheckNameResourceTypes\"],\n is_fqdn: Optional[bool] = None,\n **kwargs\n) -\u003e \"_models.ResourceNameAvailability\":\n", + "doc": "\"\"\"Check if a resource name is available.\n\nDescription for Check if a resource name is available.\n\n:param name: Resource name to verify.\n:type name: str\n:param type: Resource type used for verification.\n:type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes\n:param is_fqdn: Is fully qualified domain name.\n:type is_fqdn: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ResourceNameAvailability, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "name, type, is_fqdn" + }, + "get_subscription_deployment_locations" : { + "sync": { + "signature": "def get_subscription_deployment_locations(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Gets list of available geo regions plus ministamps.\n\nDescription for Gets list of available geo regions plus ministamps.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DeploymentLocations, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def get_subscription_deployment_locations(\n self,\n **kwargs\n) -\u003e \"_models.DeploymentLocations\":\n", + "doc": "\"\"\"Gets list of available geo regions plus ministamps.\n\nDescription for Gets list of available geo regions plus ministamps.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: DeploymentLocations, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "list_geo_regions" : { + "sync": { + "signature": "def list_geo_regions(\n self,\n sku=None, # type: Optional[Union[str, \"_models.SkuName\"]]\n linux_workers_enabled=None, # type: Optional[bool]\n xenon_workers_enabled=None, # type: Optional[bool]\n linux_dynamic_workers_enabled=None, # type: Optional[bool]\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Get a list of available geographical regions.\n\nDescription for Get a list of available geographical regions.\n\n:param sku: Name of SKU used to filter the regions.\n:type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName\n:param linux_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Linux workers.\n:type linux_workers_enabled: bool\n:param xenon_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Xenon workers.\n:type xenon_workers_enabled: bool\n:param linux_dynamic_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter\n to only regions that support Linux Consumption Workers.\n:type linux_dynamic_workers_enabled: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either GeoRegionCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_geo_regions(\n self,\n sku: Optional[Union[str, \"_models.SkuName\"]] = None,\n linux_workers_enabled: Optional[bool] = None,\n xenon_workers_enabled: Optional[bool] = None,\n linux_dynamic_workers_enabled: Optional[bool] = None,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.GeoRegionCollection\"]:\n", + "doc": "\"\"\"Get a list of available geographical regions.\n\nDescription for Get a list of available geographical regions.\n\n:param sku: Name of SKU used to filter the regions.\n:type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName\n:param linux_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Linux workers.\n:type linux_workers_enabled: bool\n:param xenon_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter to only\n regions that support Xenon workers.\n:type xenon_workers_enabled: bool\n:param linux_dynamic_workers_enabled: Specify :code:`\u003ccode\u003etrue\u003c/code\u003e` if you want to filter\n to only regions that support Linux Consumption Workers.\n:type linux_dynamic_workers_enabled: bool\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either GeoRegionCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "sku, linux_workers_enabled, xenon_workers_enabled, linux_dynamic_workers_enabled" + }, + "list_site_identifiers_assigned_to_host_name" : { + "sync": { + "signature": "def list_site_identifiers_assigned_to_host_name(\n self,\n name_identifier, # type: \"_models.NameIdentifier\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all apps that are assigned to a hostname.\n\nDescription for List all apps that are assigned to a hostname.\n\n:param name_identifier: Hostname information.\n:type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either IdentifierCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_site_identifiers_assigned_to_host_name(\n self,\n name_identifier: \"_models.NameIdentifier\",\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.IdentifierCollection\"]:\n", + "doc": "\"\"\"List all apps that are assigned to a hostname.\n\nDescription for List all apps that are assigned to a hostname.\n\n:param name_identifier: Hostname information.\n:type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either IdentifierCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "name_identifier" + }, + "list_premier_add_on_offers" : { + "sync": { + "signature": "def list_premier_add_on_offers(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all premier add-on offers.\n\nDescription for List all premier add-on offers.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_premier_add_on_offers(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.PremierAddOnOfferCollection\"]:\n", + "doc": "\"\"\"List all premier add-on offers.\n\nDescription for List all premier add-on offers.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "list_skus" : { + "sync": { + "signature": "def list_skus(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"List all SKUs.\n\nDescription for List all SKUs.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SkuInfos, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def list_skus(\n self,\n **kwargs\n) -\u003e \"_models.SkuInfos\":\n", + "doc": "\"\"\"List all SKUs.\n\nDescription for List all SKUs.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: SkuInfos, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + }, + "verify_hosting_environment_vnet" : { + "sync": { + "signature": "def verify_hosting_environment_vnet(\n self,\n parameters, # type: \"_models.VnetParameters\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules.\n\nDescription for Verifies if this VNET is compatible with an App Service Environment by\nanalyzing the Network Security Group rules.\n\n:param parameters: VNET information.\n:type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VnetValidationFailureDetails, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def verify_hosting_environment_vnet(\n self,\n parameters: \"_models.VnetParameters\",\n **kwargs\n) -\u003e \"_models.VnetValidationFailureDetails\":\n", + "doc": "\"\"\"Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules.\n\nDescription for Verifies if this VNET is compatible with an App Service Environment by\nanalyzing the Network Security Group rules.\n\n:param parameters: VNET information.\n:type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: VnetValidationFailureDetails, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "parameters" + }, + "move" : { + "sync": { + "signature": "def move(\n self,\n resource_group_name, # type: str\n move_resource_envelope, # type: \"_models.CsmMoveResourceEnvelope\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Move resources between resource groups.\n\nDescription for Move resources between resource groups.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def move(\n self,\n resource_group_name: str,\n move_resource_envelope: \"_models.CsmMoveResourceEnvelope\",\n **kwargs\n) -\u003e None:\n", + "doc": "\"\"\"Move resources between resource groups.\n\nDescription for Move resources between resource groups.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, move_resource_envelope" + }, + "validate" : { + "sync": { + "signature": "def validate(\n self,\n resource_group_name, # type: str\n validate_request, # type: \"_models.ValidateRequest\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Validate if a resource can be created.\n\nDescription for Validate if a resource can be created.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param validate_request: Request with the resources to validate.\n:type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ValidateResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def validate(\n self,\n resource_group_name: str,\n validate_request: \"_models.ValidateRequest\",\n **kwargs\n) -\u003e \"_models.ValidateResponse\":\n", + "doc": "\"\"\"Validate if a resource can be created.\n\nDescription for Validate if a resource can be created.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param validate_request: Request with the resources to validate.\n:type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: ValidateResponse, or the result of cls(response)\n:rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, validate_request" + }, + "validate_move" : { + "sync": { + "signature": "def validate_move(\n self,\n resource_group_name, # type: str\n move_resource_envelope, # type: \"_models.CsmMoveResourceEnvelope\"\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Validate whether a resource can be moved.\n\nDescription for Validate whether a resource can be moved.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": true, + "signature": "async def validate_move(\n self,\n resource_group_name: str,\n move_resource_envelope: \"_models.CsmMoveResourceEnvelope\",\n **kwargs\n) -\u003e None:\n", + "doc": "\"\"\"Validate whether a resource can be moved.\n\nDescription for Validate whether a resource can be moved.\n\n:param resource_group_name: Name of the resource group to which the resource belongs.\n:type resource_group_name: str\n:param move_resource_envelope: Object that represents the resource to move.\n:type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: None, or the result of cls(response)\n:rtype: None\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "resource_group_name, move_resource_envelope" + } + }, + "sync_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"HttpRequest\", \"HttpResponse\"], \"azure.core.paging\": [\"ItemPaged\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"Callable\", \"Dict\", \"Generic\", \"Iterable\", \"Optional\", \"TypeVar\", \"Union\"]}}}", + "async_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"AsyncHttpResponse\", \"HttpRequest\"], \"azure.core.async_paging\": [\"AsyncItemPaged\", \"AsyncList\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"AsyncIterable\", \"Callable\", \"Dict\", \"Generic\", \"Optional\", \"TypeVar\", \"Union\"]}}}" +} \ No newline at end of file diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_web_site_management_client.py new file mode 100644 index 000000000000..349db70b7430 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/_web_site_management_client.py @@ -0,0 +1,141 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.mgmt.core import ARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + + from azure.core.credentials import TokenCredential + +from ._configuration import WebSiteManagementClientConfiguration +from .operations import AppServiceCertificateOrdersOperations +from .operations import CertificateRegistrationProviderOperations +from .operations import DomainsOperations +from .operations import TopLevelDomainsOperations +from .operations import DomainRegistrationProviderOperations +from .operations import CertificatesOperations +from .operations import DeletedWebAppsOperations +from .operations import DiagnosticsOperations +from .operations import ProviderOperations +from .operations import RecommendationsOperations +from .operations import WebSiteManagementClientOperationsMixin +from .operations import WebAppsOperations +from .operations import StaticSitesOperations +from .operations import AppServiceEnvironmentsOperations +from .operations import AppServicePlansOperations +from .operations import ResourceHealthMetadataOperations +from . import models + + +class WebSiteManagementClient(WebSiteManagementClientOperationsMixin): + """WebSite Management Client. + + :ivar app_service_certificate_orders: AppServiceCertificateOrdersOperations operations + :vartype app_service_certificate_orders: azure.mgmt.web.v2020_09_01.operations.AppServiceCertificateOrdersOperations + :ivar certificate_registration_provider: CertificateRegistrationProviderOperations operations + :vartype certificate_registration_provider: azure.mgmt.web.v2020_09_01.operations.CertificateRegistrationProviderOperations + :ivar domains: DomainsOperations operations + :vartype domains: azure.mgmt.web.v2020_09_01.operations.DomainsOperations + :ivar top_level_domains: TopLevelDomainsOperations operations + :vartype top_level_domains: azure.mgmt.web.v2020_09_01.operations.TopLevelDomainsOperations + :ivar domain_registration_provider: DomainRegistrationProviderOperations operations + :vartype domain_registration_provider: azure.mgmt.web.v2020_09_01.operations.DomainRegistrationProviderOperations + :ivar certificates: CertificatesOperations operations + :vartype certificates: azure.mgmt.web.v2020_09_01.operations.CertificatesOperations + :ivar deleted_web_apps: DeletedWebAppsOperations operations + :vartype deleted_web_apps: azure.mgmt.web.v2020_09_01.operations.DeletedWebAppsOperations + :ivar diagnostics: DiagnosticsOperations operations + :vartype diagnostics: azure.mgmt.web.v2020_09_01.operations.DiagnosticsOperations + :ivar provider: ProviderOperations operations + :vartype provider: azure.mgmt.web.v2020_09_01.operations.ProviderOperations + :ivar recommendations: RecommendationsOperations operations + :vartype recommendations: azure.mgmt.web.v2020_09_01.operations.RecommendationsOperations + :ivar web_apps: WebAppsOperations operations + :vartype web_apps: azure.mgmt.web.v2020_09_01.operations.WebAppsOperations + :ivar static_sites: StaticSitesOperations operations + :vartype static_sites: azure.mgmt.web.v2020_09_01.operations.StaticSitesOperations + :ivar app_service_environments: AppServiceEnvironmentsOperations operations + :vartype app_service_environments: azure.mgmt.web.v2020_09_01.operations.AppServiceEnvironmentsOperations + :ivar app_service_plans: AppServicePlansOperations operations + :vartype app_service_plans: azure.mgmt.web.v2020_09_01.operations.AppServicePlansOperations + :ivar resource_health_metadata: ResourceHealthMetadataOperations operations + :vartype resource_health_metadata: azure.mgmt.web.v2020_09_01.operations.ResourceHealthMetadataOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://management.azure.com' + self._config = WebSiteManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + self.app_service_certificate_orders = AppServiceCertificateOrdersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificate_registration_provider = CertificateRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domains = DomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.top_level_domains = TopLevelDomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domain_registration_provider = DomainRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificates = CertificatesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deleted_web_apps = DeletedWebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.diagnostics = DiagnosticsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider = ProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.recommendations = RecommendationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_apps = WebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.static_sites = StaticSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_environments = AppServiceEnvironmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_plans = AppServicePlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_health_metadata = ResourceHealthMetadataOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> WebSiteManagementClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_version.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/__init__.py similarity index 81% rename from sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_version.py rename to sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/__init__.py index 5c14e0d8303d..fc106a4f3d78 100644 --- a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2015_08_01/_version.py +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/__init__.py @@ -6,4 +6,5 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- -VERSION = "0.42.0" +from ._web_site_management_client import WebSiteManagementClient +__all__ = ['WebSiteManagementClient'] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_configuration.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_configuration.py new file mode 100644 index 000000000000..43ef6707eb52 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_configuration.py @@ -0,0 +1,66 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +VERSION = "unknown" + +class WebSiteManagementClientConfiguration(Configuration): + """Configuration for WebSiteManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + **kwargs: Any + ) -> None: + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(WebSiteManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-09-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-web/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_web_site_management_client.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_web_site_management_client.py new file mode 100644 index 000000000000..d4a0aa96e900 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/_web_site_management_client.py @@ -0,0 +1,135 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional, TYPE_CHECKING + +from azure.mgmt.core import AsyncARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +from ._configuration import WebSiteManagementClientConfiguration +from .operations import AppServiceCertificateOrdersOperations +from .operations import CertificateRegistrationProviderOperations +from .operations import DomainsOperations +from .operations import TopLevelDomainsOperations +from .operations import DomainRegistrationProviderOperations +from .operations import CertificatesOperations +from .operations import DeletedWebAppsOperations +from .operations import DiagnosticsOperations +from .operations import ProviderOperations +from .operations import RecommendationsOperations +from .operations import WebSiteManagementClientOperationsMixin +from .operations import WebAppsOperations +from .operations import StaticSitesOperations +from .operations import AppServiceEnvironmentsOperations +from .operations import AppServicePlansOperations +from .operations import ResourceHealthMetadataOperations +from .. import models + + +class WebSiteManagementClient(WebSiteManagementClientOperationsMixin): + """WebSite Management Client. + + :ivar app_service_certificate_orders: AppServiceCertificateOrdersOperations operations + :vartype app_service_certificate_orders: azure.mgmt.web.v2020_09_01.aio.operations.AppServiceCertificateOrdersOperations + :ivar certificate_registration_provider: CertificateRegistrationProviderOperations operations + :vartype certificate_registration_provider: azure.mgmt.web.v2020_09_01.aio.operations.CertificateRegistrationProviderOperations + :ivar domains: DomainsOperations operations + :vartype domains: azure.mgmt.web.v2020_09_01.aio.operations.DomainsOperations + :ivar top_level_domains: TopLevelDomainsOperations operations + :vartype top_level_domains: azure.mgmt.web.v2020_09_01.aio.operations.TopLevelDomainsOperations + :ivar domain_registration_provider: DomainRegistrationProviderOperations operations + :vartype domain_registration_provider: azure.mgmt.web.v2020_09_01.aio.operations.DomainRegistrationProviderOperations + :ivar certificates: CertificatesOperations operations + :vartype certificates: azure.mgmt.web.v2020_09_01.aio.operations.CertificatesOperations + :ivar deleted_web_apps: DeletedWebAppsOperations operations + :vartype deleted_web_apps: azure.mgmt.web.v2020_09_01.aio.operations.DeletedWebAppsOperations + :ivar diagnostics: DiagnosticsOperations operations + :vartype diagnostics: azure.mgmt.web.v2020_09_01.aio.operations.DiagnosticsOperations + :ivar provider: ProviderOperations operations + :vartype provider: azure.mgmt.web.v2020_09_01.aio.operations.ProviderOperations + :ivar recommendations: RecommendationsOperations operations + :vartype recommendations: azure.mgmt.web.v2020_09_01.aio.operations.RecommendationsOperations + :ivar web_apps: WebAppsOperations operations + :vartype web_apps: azure.mgmt.web.v2020_09_01.aio.operations.WebAppsOperations + :ivar static_sites: StaticSitesOperations operations + :vartype static_sites: azure.mgmt.web.v2020_09_01.aio.operations.StaticSitesOperations + :ivar app_service_environments: AppServiceEnvironmentsOperations operations + :vartype app_service_environments: azure.mgmt.web.v2020_09_01.aio.operations.AppServiceEnvironmentsOperations + :ivar app_service_plans: AppServicePlansOperations operations + :vartype app_service_plans: azure.mgmt.web.v2020_09_01.aio.operations.AppServicePlansOperations + :ivar resource_health_metadata: ResourceHealthMetadataOperations operations + :vartype resource_health_metadata: azure.mgmt.web.v2020_09_01.aio.operations.ResourceHealthMetadataOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: Your Azure subscription ID. This is a GUID-formatted string (e.g. 00000000-0000-0000-0000-000000000000). + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://management.azure.com' + self._config = WebSiteManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._serialize.client_side_validation = False + self._deserialize = Deserializer(client_models) + + self.app_service_certificate_orders = AppServiceCertificateOrdersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificate_registration_provider = CertificateRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domains = DomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.top_level_domains = TopLevelDomainsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.domain_registration_provider = DomainRegistrationProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.certificates = CertificatesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deleted_web_apps = DeletedWebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.diagnostics = DiagnosticsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider = ProviderOperations( + self._client, self._config, self._serialize, self._deserialize) + self.recommendations = RecommendationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.web_apps = WebAppsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.static_sites = StaticSitesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_environments = AppServiceEnvironmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.app_service_plans = AppServicePlansOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_health_metadata = ResourceHealthMetadataOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "WebSiteManagementClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/__init__.py new file mode 100644 index 000000000000..8f414125deed --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/__init__.py @@ -0,0 +1,43 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._app_service_certificate_orders_operations import AppServiceCertificateOrdersOperations +from ._certificate_registration_provider_operations import CertificateRegistrationProviderOperations +from ._domains_operations import DomainsOperations +from ._top_level_domains_operations import TopLevelDomainsOperations +from ._domain_registration_provider_operations import DomainRegistrationProviderOperations +from ._certificates_operations import CertificatesOperations +from ._deleted_web_apps_operations import DeletedWebAppsOperations +from ._diagnostics_operations import DiagnosticsOperations +from ._provider_operations import ProviderOperations +from ._recommendations_operations import RecommendationsOperations +from ._web_site_management_client_operations import WebSiteManagementClientOperationsMixin +from ._web_apps_operations import WebAppsOperations +from ._static_sites_operations import StaticSitesOperations +from ._app_service_environments_operations import AppServiceEnvironmentsOperations +from ._app_service_plans_operations import AppServicePlansOperations +from ._resource_health_metadata_operations import ResourceHealthMetadataOperations + +__all__ = [ + 'AppServiceCertificateOrdersOperations', + 'CertificateRegistrationProviderOperations', + 'DomainsOperations', + 'TopLevelDomainsOperations', + 'DomainRegistrationProviderOperations', + 'CertificatesOperations', + 'DeletedWebAppsOperations', + 'DiagnosticsOperations', + 'ProviderOperations', + 'RecommendationsOperations', + 'WebSiteManagementClientOperationsMixin', + 'WebAppsOperations', + 'StaticSitesOperations', + 'AppServiceEnvironmentsOperations', + 'AppServicePlansOperations', + 'ResourceHealthMetadataOperations', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_certificate_orders_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_certificate_orders_operations.py new file mode 100644 index 000000000000..6e39e565b9c5 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_certificate_orders_operations.py @@ -0,0 +1,1491 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceCertificateOrdersOperations: + """AppServiceCertificateOrdersOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateOrderCollection"]: + """List all certificate orders in a subscription. + + Description for List all certificate orders in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + async def validate_purchase_information( + self, + app_service_certificate_order: "_models.AppServiceCertificateOrder", + **kwargs + ) -> None: + """Validate information for a certificate order. + + Description for Validate information for a certificate order. + + :param app_service_certificate_order: Information for a certificate order. + :type app_service_certificate_order: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_purchase_information.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_certificate_order, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_purchase_information.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/validateCertificateRegistrationInformation'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateOrderCollection"]: + """Get certificate orders in a resource group. + + Description for Get certificate orders in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + async def get( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> "_models.AppServiceCertificateOrder": + """Get a certificate order. + + Description for Get a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order.. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrder", + **kwargs + ) -> "_models.AppServiceCertificateOrder": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrder", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceCertificateOrder"]: + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceCertificateOrder or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + certificate_distinguished_name=certificate_distinguished_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Delete an existing certificate order. + + Description for Delete an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + certificate_order_name: str, + certificate_distinguished_name: "_models.AppServiceCertificateOrderPatchResource", + **kwargs + ) -> "_models.AppServiceCertificateOrder": + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrderPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def list_certificates( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceCertificateCollection"]: + """List all certificates associated with a certificate order. + + Description for List all certificates associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates'} # type: ignore + + async def get_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + **kwargs + ) -> "_models.AppServiceCertificateResource": + """Get the certificate associated with a certificate order. + + Description for Get the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def _create_or_update_certificate_initial( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificateResource", + **kwargs + ) -> "_models.AppServiceCertificateResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_certificate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificateResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_certificate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def begin_create_or_update_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificateResource", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceCertificateResource"]: + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceCertificateResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_certificate_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + name=name, + key_vault_certificate=key_vault_certificate, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def delete_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + **kwargs + ) -> None: + """Delete the certificate associated with a certificate order. + + Description for Delete the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def update_certificate( + self, + resource_group_name: str, + certificate_order_name: str, + name: str, + key_vault_certificate: "_models.AppServiceCertificatePatchResource", + **kwargs + ) -> "_models.AppServiceCertificateResource": + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + async def reissue( + self, + resource_group_name: str, + certificate_order_name: str, + reissue_certificate_order_request: "_models.ReissueCertificateOrderRequest", + **kwargs + ) -> None: + """Reissue an existing certificate order. + + Description for Reissue an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param reissue_certificate_order_request: Parameters for the reissue. + :type reissue_certificate_order_request: ~azure.mgmt.web.v2020_09_01.models.ReissueCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reissue.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reissue_certificate_order_request, 'ReissueCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reissue.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/reissue'} # type: ignore + + async def renew( + self, + resource_group_name: str, + certificate_order_name: str, + renew_certificate_order_request: "_models.RenewCertificateOrderRequest", + **kwargs + ) -> None: + """Renew an existing certificate order. + + Description for Renew an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param renew_certificate_order_request: Renew parameters. + :type renew_certificate_order_request: ~azure.mgmt.web.v2020_09_01.models.RenewCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(renew_certificate_order_request, 'RenewCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/renew'} # type: ignore + + async def resend_email( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Resend certificate email. + + Description for Resend certificate email. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.resend_email.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_email.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendEmail'} # type: ignore + + async def resend_request_emails( + self, + resource_group_name: str, + certificate_order_name: str, + name_identifier: "_models.NameIdentifier", + **kwargs + ) -> None: + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name_identifier: Email address. + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.resend_request_emails.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_request_emails.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendRequestEmails'} # type: ignore + + async def retrieve_site_seal( + self, + resource_group_name: str, + certificate_order_name: str, + site_seal_request: "_models.SiteSealRequest", + **kwargs + ) -> "_models.SiteSeal": + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param site_seal_request: Site seal request. + :type site_seal_request: ~azure.mgmt.web.v2020_09_01.models.SiteSealRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSeal, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSeal + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSeal"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.retrieve_site_seal.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_seal_request, 'SiteSealRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteSeal', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_site_seal.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/retrieveSiteSeal'} # type: ignore + + async def verify_domain_ownership( + self, + resource_group_name: str, + certificate_order_name: str, + **kwargs + ) -> None: + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.verify_domain_ownership.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + verify_domain_ownership.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/verifyDomainOwnership'} # type: ignore + + async def retrieve_certificate_actions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.CertificateOrderAction"]: + """Retrieve the list of certificate actions. + + Description for Retrieve the list of certificate actions. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateOrderAction, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.CertificateOrderAction] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateOrderAction"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_actions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateOrderAction]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_actions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveCertificateActions'} # type: ignore + + async def retrieve_certificate_email_history( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.CertificateEmail"]: + """Retrieve email history. + + Description for Retrieve email history. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateEmail, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.CertificateEmail] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateEmail"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_email_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateEmail]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_email_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveEmailHistory'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_environments_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_environments_operations.py new file mode 100644 index 000000000000..cf98ca3dcaf1 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_environments_operations.py @@ -0,0 +1,3246 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceEnvironmentsOperations: + """AppServiceEnvironmentsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.AppServiceEnvironmentCollection"]: + """Get all App Service Environments for a subscription. + + Description for Get all App Service Environments for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServiceEnvironmentCollection"]: + """Get all App Service Environments in a resource group. + + Description for Get all App Service Environments in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + """Get the properties of an App Service Environment. + + Description for Get the properties of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentResource", + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentResource", + **kwargs + ) -> AsyncLROPoller["_models.AppServiceEnvironmentResource"]: + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServiceEnvironmentResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + hosting_environment_envelope=hosting_environment_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + name: str, + force_delete: Optional[bool] = None, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_delete is not None: + query_parameters['forceDelete'] = self._serialize.query("force_delete", force_delete, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + name: str, + force_delete: Optional[bool] = None, + **kwargs + ) -> AsyncLROPoller[None]: + """Delete an App Service Environment. + + Description for Delete an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param force_delete: Specify :code:`true` to force the deletion even if the App + Service Environment contains resources. The default is :code:`false`. + :type force_delete: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + name=name, + force_delete=force_delete, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + hosting_environment_envelope: "_models.AppServiceEnvironmentPatchResource", + **kwargs + ) -> "_models.AppServiceEnvironmentResource": + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def list_capacities( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StampCapacityCollection"]: + """Get the used, available, and total worker capacity an App Service Environment. + + Description for Get the used, available, and total worker capacity an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StampCapacityCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StampCapacityCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StampCapacityCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_capacities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StampCapacityCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_capacities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/compute'} # type: ignore + + async def get_vip_info( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AddressResponse": + """Get IP addresses assigned to an App Service Environment. + + Description for Get IP addresses assigned to an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AddressResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AddressResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AddressResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vip_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AddressResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vip_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/virtualip'} # type: ignore + + async def _change_vnet_initial( + self, + resource_group_name: str, + name: str, + vnet_info: "_models.VirtualNetworkProfile", + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._change_vnet_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _change_vnet_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + async def begin_change_vnet( + self, + resource_group_name: str, + name: str, + vnet_info: "_models.VirtualNetworkProfile", + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Move an App Service Environment to a different VNET. + + Description for Move an App Service Environment to a different VNET. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param vnet_info: Details for the new virtual network. + :type vnet_info: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.change_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._change_vnet_initial( + resource_group_name=resource_group_name, + name=name, + vnet_info=vnet_info, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_change_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + async def list_diagnostics( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.HostingEnvironmentDiagnostics"]: + """Get diagnostic information for an App Service Environment. + + Description for Get diagnostic information for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDiagnostics] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.HostingEnvironmentDiagnostics"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_diagnostics.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[HostingEnvironmentDiagnostics]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_diagnostics.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics'} # type: ignore + + async def get_diagnostics_item( + self, + resource_group_name: str, + name: str, + diagnostics_name: str, + **kwargs + ) -> "_models.HostingEnvironmentDiagnostics": + """Get a diagnostics item for an App Service Environment. + + Description for Get a diagnostics item for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param diagnostics_name: Name of the diagnostics item. + :type diagnostics_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDiagnostics + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostingEnvironmentDiagnostics"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostics_item.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'diagnosticsName': self._serialize.url("diagnostics_name", diagnostics_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostingEnvironmentDiagnostics', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostics_item.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics/{diagnosticsName}'} # type: ignore + + def get_inbound_network_dependencies_endpoints( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.InboundEnvironmentEndpointCollection"]: + """Get the network endpoints of all inbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all inbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.InboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_inbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('InboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_inbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/inboundNetworkDependenciesEndpoints'} # type: ignore + + def list_multi_role_pools( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WorkerPoolCollection"]: + """Get all multi-role pools. + + Description for Get all multi-role pools. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools'} # type: ignore + + async def get_multi_role_pool( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WorkerPoolResource": + """Get properties of a multi-role pool. + + Description for Get properties of a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def _create_or_update_multi_role_pool_initial( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_multi_role_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_multi_role_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def begin_create_or_update_multi_role_pool( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> AsyncLROPoller["_models.WorkerPoolResource"]: + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_multi_role_pool_initial( + resource_group_name=resource_group_name, + name=name, + multi_role_pool_envelope=multi_role_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + async def update_multi_role_pool( + self, + resource_group_name: str, + name: str, + multi_role_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def list_multi_role_pool_instance_metric_definitions( + self, + resource_group_name: str, + name: str, + instance: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a specific instance of a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a multi-role pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param instance: Name of the instance in the multi-role pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/instances/{instance}/metricdefinitions'} # type: ignore + + def list_multi_role_metric_definitions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/metricdefinitions'} # type: ignore + + def list_multi_role_pool_skus( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SkuInfoCollection"]: + """Get available SKUs for scaling a multi-role pool. + + Description for Get available SKUs for scaling a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/skus'} # type: ignore + + def list_multi_role_usages( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.UsageCollection"]: + """Get usage metrics for a multi-role pool of an App Service Environment. + + Description for Get usage metrics for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_multi_role_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/usages'} # type: ignore + + async def list_operations( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.Operation"]: + """List all currently running operations on the App Service Environment. + + Description for List all currently running operations on the App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Operation, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.Operation] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Operation"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Operation]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_operations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/operations'} # type: ignore + + def get_outbound_network_dependencies_endpoints( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.OutboundEnvironmentEndpointCollection"]: + """Get the network endpoints of all outbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all outbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OutboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.OutboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_outbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('OutboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_outbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/outboundNetworkDependenciesEndpoints'} # type: ignore + + async def reboot( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Reboot all machines in an App Service Environment. + + Description for Reboot all machines in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reboot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/reboot'} # type: ignore + + async def _resume_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._resume_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _resume_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + async def begin_resume( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Resume an App Service Environment. + + Description for Resume an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.resume.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._resume_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_resume.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def list_app_service_plans( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans in an App Service Environment. + + Description for Get all App Service plans in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_app_service_plans.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_app_service_plans.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/serverfarms'} # type: ignore + + def list_web_apps( + self, + resource_group_name: str, + name: str, + properties_to_include: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps in an App Service Environment. + + Description for Get all apps in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param properties_to_include: Comma separated list of app properties to include. + :type properties_to_include: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if properties_to_include is not None: + query_parameters['propertiesToInclude'] = self._serialize.query("properties_to_include", properties_to_include, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/sites'} # type: ignore + + async def _suspend_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.WebAppCollection": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._suspend_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _suspend_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + async def begin_suspend( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller[AsyncItemPaged["_models.WebAppCollection"]]: + """Suspend an App Service Environment. + + Description for Suspend an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.suspend.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._suspend_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + async def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return await get_next(next_link) + + return AsyncItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_suspend.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Get global usage metrics of an App Service Environment. + + Description for Get global usage metrics of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/usages'} # type: ignore + + def list_worker_pools( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WorkerPoolCollection"]: + """Get all worker pools of an App Service Environment. + + Description for Get all worker pools of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools'} # type: ignore + + async def get_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> "_models.WorkerPoolResource": + """Get properties of a worker pool. + + Description for Get properties of a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def _create_or_update_worker_pool_initial( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_worker_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_worker_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def begin_create_or_update_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> AsyncLROPoller["_models.WorkerPoolResource"]: + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_worker_pool_initial( + resource_group_name=resource_group_name, + name=name, + worker_pool_name=worker_pool_name, + worker_pool_envelope=worker_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + async def update_worker_pool( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + worker_pool_envelope: "_models.WorkerPoolResource", + **kwargs + ) -> "_models.WorkerPoolResource": + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def list_worker_pool_instance_metric_definitions( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + instance: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a specific instance of a worker pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a worker pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param instance: Name of the instance in the worker pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/instances/{instance}/metricdefinitions'} # type: ignore + + def list_web_worker_metric_definitions( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceMetricDefinitionCollection"]: + """Get metric definitions for a worker pool of an App Service Environment. + + Description for Get metric definitions for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_worker_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/metricdefinitions'} # type: ignore + + def list_worker_pool_skus( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.SkuInfoCollection"]: + """Get available SKUs for scaling a worker pool. + + Description for Get available SKUs for scaling a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_worker_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/skus'} # type: ignore + + def list_web_worker_usages( + self, + resource_group_name: str, + name: str, + worker_pool_name: str, + **kwargs + ) -> AsyncIterable["_models.UsageCollection"]: + """Get usage metrics for a worker pool of an App Service Environment. + + Description for Get usage metrics for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_worker_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/usages'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_plans_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_plans_operations.py new file mode 100644 index 000000000000..72cfe2c63901 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_app_service_plans_operations.py @@ -0,0 +1,2007 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class AppServicePlansOperations: + """AppServicePlansOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + detailed: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans for a subscription. + + Description for Get all App Service plans for a subscription. + + :param detailed: Specify :code:`true` to return all App Service plan properties. + The default is :code:`false`, which returns a subset of the properties. + Retrieval of all properties may increase the API latency. + :type detailed: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if detailed is not None: + query_parameters['detailed'] = self._serialize.query("detailed", detailed, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.AppServicePlanCollection"]: + """Get all App Service plans in a resource group. + + Description for Get all App Service plans in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.AppServicePlan"]: + """Get an App Service plan. + + Description for Get an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AppServicePlan"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlan", + **kwargs + ) -> "_models.AppServicePlan": + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlan') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlan", + **kwargs + ) -> AsyncLROPoller["_models.AppServicePlan"]: + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either AppServicePlan or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.AppServicePlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + app_service_plan=app_service_plan, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Delete an App Service plan. + + Description for Delete an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + app_service_plan: "_models.AppServicePlanPatchResource", + **kwargs + ) -> "_models.AppServicePlan": + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_09_01.models.AppServicePlanPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlanPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + async def list_capabilities( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.Capability"]: + """List all capabilities of an App Service plan. + + Description for List all capabilities of an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Capability, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.Capability] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Capability"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_capabilities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Capability]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_capabilities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/capabilities'} # type: ignore + + async def get_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieve a Hybrid Connection in use in an App Service plan. + + Description for Retrieve a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> None: + """Delete a Hybrid Connection in use in an App Service plan. + + Description for Delete a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connection_keys( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnectionKey": + """Get the send key name and value of a Hybrid Connection. + + Description for Get the send key name and value of a Hybrid Connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: The name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionKey, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnectionKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connection_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connection_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/listKeys'} # type: ignore + + def list_web_apps_by_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceCollection"]: + """Get all apps that use a Hybrid Connection in an App Service Plan. + + Description for Get all apps that use a Hybrid Connection in an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Hybrid Connection namespace. + :type namespace_name: str + :param relay_name: Name of the Hybrid Connection relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps_by_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps_by_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/sites'} # type: ignore + + async def get_hybrid_connection_plan_limit( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HybridConnectionLimits": + """Get the maximum number of Hybrid Connections allowed in an App Service plan. + + Description for Get the maximum number of Hybrid Connections allowed in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionLimits, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnectionLimits + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionLimits"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_plan_limit.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionLimits', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_plan_limit.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionPlanLimits/limit'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.HybridConnectionCollection"]: + """Retrieve all Hybrid Connections in use in an App Service plan. + + Description for Retrieve all Hybrid Connections in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HybridConnectionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.HybridConnectionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HybridConnectionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionRelays'} # type: ignore + + async def restart_web_apps( + self, + resource_group_name: str, + name: str, + soft_restart: Optional[bool] = None, + **kwargs + ) -> None: + """Restart all apps in an App Service plan. + + Description for Restart all apps in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param soft_restart: Specify :code:`true` to perform a soft restart, applies the + configuration settings and restarts the apps if necessary. The default is + :code:`false`, which always restarts and reprovisions the apps. + :type soft_restart: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/restartSites'} # type: ignore + + def list_web_apps( + self, + resource_group_name: str, + name: str, + skip_token: Optional[str] = None, + filter: Optional[str] = None, + top: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps associated with an App Service plan. + + Description for Get all apps associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param skip_token: Skip to a web app in the list of webapps associated with app service plan. + If specified, the resulting list will contain web apps starting from (including) the skipToken. + Otherwise, the resulting list contains web apps from the start of the list. + :type skip_token: str + :param filter: Supported filter: $filter=state eq running. Returns only web apps that are + currently running. + :type filter: str + :param top: List page size. If specified, results are paged. + :type top: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if skip_token is not None: + query_parameters['$skipToken'] = self._serialize.query("skip_token", skip_token, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/sites'} # type: ignore + + async def get_server_farm_skus( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> object: + """Gets all selectable SKUs for a given App Service Plan. + + Description for Gets all selectable SKUs for a given App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: object, or the result of cls(response) + :rtype: object + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_server_farm_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_server_farm_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/skus'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets server farm usage information. + + Description for Gets server farm usage information. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2'). + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/usages'} # type: ignore + + async def list_vnets( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Get all Virtual Networks associated with an App Service plan. + + Description for Get all Virtual Networks associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_from_server_farm( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> Optional["_models.VnetInfo"]: + """Get a Virtual Network associated with an App Service plan. + + Description for Get a Virtual Network associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_from_server_farm.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_from_server_farm.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + **kwargs + ) -> "_models.VnetGateway": + """Get a Virtual Network gateway. + + Description for Get a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Update a Virtual Network gateway. + + Description for Update a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :param connection_envelope: Definition of the gateway. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def list_routes_for_vnet( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> List["_models.VnetRoute"]: + """Get all routes that are associated with a Virtual Network in an App Service plan. + + Description for Get all routes that are associated with a Virtual Network in an App Service + plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_routes_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_routes_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes'} # type: ignore + + async def get_route_for_vnet( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + **kwargs + ) -> Optional[List["_models.VnetRoute"]]: + """Get a Virtual Network route in an App Service plan. + + Description for Get a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[List["_models.VnetRoute"]]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_route_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_route_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def create_or_update_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + route: "_models.VnetRoute", + **kwargs + ) -> Optional["_models.VnetRoute"]: + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_09_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def delete_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + **kwargs + ) -> None: + """Delete a Virtual Network route in an App Service plan. + + Description for Delete a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def update_vnet_route( + self, + resource_group_name: str, + name: str, + vnet_name: str, + route_name: str, + route: "_models.VnetRoute", + **kwargs + ) -> Optional["_models.VnetRoute"]: + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_09_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + async def reboot_worker( + self, + resource_group_name: str, + name: str, + worker_name: str, + **kwargs + ) -> None: + """Reboot a worker machine in an App Service plan. + + Description for Reboot a worker machine in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param worker_name: Name of worker machine, which typically starts with RD. + :type worker_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reboot_worker.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerName': self._serialize.url("worker_name", worker_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot_worker.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/workers/{workerName}/reboot'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificate_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificate_registration_provider_operations.py new file mode 100644 index 000000000000..590540ed7050 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificate_registration_provider_operations.py @@ -0,0 +1,108 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class CertificateRegistrationProviderOperations: + """CertificateRegistrationProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.CertificateRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificates_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificates_operations.py new file mode 100644 index 000000000000..5026824326f7 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_certificates_operations.py @@ -0,0 +1,441 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class CertificatesOperations: + """CertificatesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.CertificateCollection"]: + """Get all certificates for a subscription. + + Description for Get all certificates for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/certificates'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.CertificateCollection"]: + """Get all certificates in a resource group. + + Description for Get all certificates in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.Certificate": + """Get a certificate. + + Description for Get a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + name: str, + certificate_envelope: "_models.Certificate", + **kwargs + ) -> "_models.Certificate": + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_09_01.models.Certificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'Certificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Delete a certificate. + + Description for Delete a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + certificate_envelope: "_models.CertificatePatchResource", + **kwargs + ) -> "_models.Certificate": + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_09_01.models.CertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'CertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_deleted_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_deleted_web_apps_operations.py new file mode 100644 index 000000000000..c64b4fc69963 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_deleted_web_apps_operations.py @@ -0,0 +1,245 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DeletedWebAppsOperations: + """DeletedWebAppsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.DeletedWebAppCollection"]: + """Get all deleted apps for a subscription. + + Description for Get all deleted apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deletedSites'} # type: ignore + + def list_by_location( + self, + location: str, + **kwargs + ) -> AsyncIterable["_models.DeletedWebAppCollection"]: + """Get all deleted apps for a subscription at location. + + Description for Get all deleted apps for a subscription at location. + + :param location: + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites'} # type: ignore + + async def get_deleted_web_app_by_location( + self, + location: str, + deleted_site_id: str, + **kwargs + ) -> "_models.DeletedSite": + """Get deleted app for a subscription at location. + + Description for Get deleted app for a subscription at location. + + :param location: + :type location: str + :param deleted_site_id: The numeric ID of the deleted app, e.g. 12345. + :type deleted_site_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeletedSite, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeletedSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deleted_web_app_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'deletedSiteId': self._serialize.url("deleted_site_id", deleted_site_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeletedSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deleted_web_app_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites/{deletedSiteId}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_diagnostics_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_diagnostics_operations.py new file mode 100644 index 000000000000..dd7ac8f0e1e4 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_diagnostics_operations.py @@ -0,0 +1,1774 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +import datetime +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DiagnosticsOperations: + """DiagnosticsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_hosting_environment_detector_responses( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Hosting Environment Detector Responses. + + Description for List Hosting Environment Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hosting_environment_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_hosting_environment_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors'} # type: ignore + + async def get_hosting_environment_detector_response( + self, + resource_group_name: str, + name: str, + detector_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get Hosting Environment Detector Response. + + Description for Get Hosting Environment Detector Response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: App Service Environment Name. + :type name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hosting_environment_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hosting_environment_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors/{detectorName}'} # type: ignore + + def list_site_detector_responses( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors'} # type: ignore + + async def get_site_detector_response( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticCategoryCollection"]: + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics'} # type: ignore + + async def get_site_diagnostic_category( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> "_models.DiagnosticCategory": + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticAnalysisCollection"]: + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_analyses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + async def get_site_analysis( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + **kwargs + ) -> "_models.AnalysisDefinition": + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + async def execute_site_analysis( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticAnalysis": + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticDetectorCollection"]: + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detectors.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + async def get_site_detector( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + detector_name: str, + **kwargs + ) -> "_models.DetectorDefinition": + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + async def execute_site_detector( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + diagnostic_category: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticDetectorResponse": + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore + + def list_site_detector_responses_slot( + self, + resource_group_name: str, + site_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DetectorResponseCollection"]: + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detector_responses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors'} # type: ignore + + async def get_site_detector_response_slot( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DetectorResponse": + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories_slot( + self, + resource_group_name: str, + site_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticCategoryCollection"]: + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics'} # type: ignore + + async def get_site_diagnostic_category_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> "_models.DiagnosticCategory": + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticAnalysisCollection"]: + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_analyses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + async def get_site_analysis_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + slot: str, + **kwargs + ) -> "_models.AnalysisDefinition": + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :param slot: Slot - optional. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + async def execute_site_analysis_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + analysis_name: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticAnalysis": + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DiagnosticDetectorCollection"]: + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_detectors_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + async def get_site_detector_slot( + self, + resource_group_name: str, + site_name: str, + diagnostic_category: str, + detector_name: str, + slot: str, + **kwargs + ) -> "_models.DetectorDefinition": + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + async def execute_site_detector_slot( + self, + resource_group_name: str, + site_name: str, + detector_name: str, + diagnostic_category: str, + slot: str, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + **kwargs + ) -> "_models.DiagnosticDetectorResponse": + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domain_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domain_registration_provider_operations.py new file mode 100644 index 000000000000..8572356db15d --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domain_registration_provider_operations.py @@ -0,0 +1,108 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DomainRegistrationProviderOperations: + """DomainRegistrationProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.DomainRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domains_operations.py new file mode 100644 index 000000000000..f7fae46156e3 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_domains_operations.py @@ -0,0 +1,1119 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DomainsOperations: + """DomainsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def check_availability( + self, + identifier: "_models.NameIdentifier", + **kwargs + ) -> "_models.DomainAvailabilityCheckResult": + """Check if a domain is available for registration. + + Description for Check if a domain is available for registration. + + :param identifier: Name of the domain. + :type identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainAvailabilityCheckResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainAvailabilityCheckResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainAvailabilityCheckResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainAvailabilityCheckResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/checkDomainAvailability'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.DomainCollection"]: + """Get all domains in a subscription. + + Description for Get all domains in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + async def get_control_center_sso_request( + self, + **kwargs + ) -> "_models.DomainControlCenterSsoRequest": + """Generate a single sign-on request for the domain management portal. + + Description for Generate a single sign-on request for the domain management portal. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainControlCenterSsoRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainControlCenterSsoRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainControlCenterSsoRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_control_center_sso_request.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainControlCenterSsoRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_control_center_sso_request.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/generateSsoRequest'} # type: ignore + + def list_recommendations( + self, + parameters: "_models.DomainRecommendationSearchParameters", + **kwargs + ) -> AsyncIterable["_models.NameIdentifierCollection"]: + """Get domain name recommendations based on keywords. + + Description for Get domain name recommendations based on keywords. + + :param parameters: Search parameters for domain name recommendations. + :type parameters: ~azure.mgmt.web.v2020_09_01.models.DomainRecommendationSearchParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NameIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.NameIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NameIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommendations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NameIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommendations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/listDomainRecommendations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.DomainCollection"]: + """Get all domains in a resource group. + + Description for Get all domains in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + async def get( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> "_models.Domain": + """Get a domain. + + Description for Get a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.Domain", + **kwargs + ) -> "_models.Domain": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'Domain') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.Domain", + **kwargs + ) -> AsyncLROPoller["_models.Domain"]: + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_09_01.models.Domain + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Domain or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.Domain] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + domain_name=domain_name, + domain=domain, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + domain_name: str, + force_hard_delete_domain: Optional[bool] = None, + **kwargs + ) -> None: + """Delete a domain. + + Description for Delete a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param force_hard_delete_domain: Specify :code:`true` to delete the domain + immediately. The default is :code:`false` which deletes the domain after 24 hours. + :type force_hard_delete_domain: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_hard_delete_domain is not None: + query_parameters['forceHardDeleteDomain'] = self._serialize.query("force_hard_delete_domain", force_hard_delete_domain, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + domain_name: str, + domain: "_models.DomainPatchResource", + **kwargs + ) -> "_models.Domain": + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_09_01.models.DomainPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'DomainPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def list_ownership_identifiers( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> AsyncIterable["_models.DomainOwnershipIdentifierCollection"]: + """Lists domain ownership identifiers. + + Description for Lists domain ownership identifiers. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainOwnershipIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DomainOwnershipIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers'} # type: ignore + + async def get_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Get ownership identifier for domain. + + Description for Get ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def create_or_update_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + domain_ownership_identifier: "_models.DomainOwnershipIdentifier", + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def delete_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + **kwargs + ) -> None: + """Delete ownership identifier for domain. + + Description for Delete ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def update_ownership_identifier( + self, + resource_group_name: str, + domain_name: str, + name: str, + domain_ownership_identifier: "_models.DomainOwnershipIdentifier", + **kwargs + ) -> "_models.DomainOwnershipIdentifier": + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + async def renew( + self, + resource_group_name: str, + domain_name: str, + **kwargs + ) -> None: + """Renew a domain. + + Description for Renew a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/renew'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_provider_operations.py new file mode 100644 index 000000000000..82d217246b84 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_provider_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ProviderOperations: + """ProviderOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_available_stacks( + self, + os_type_selected: Optional[Union[str, "_models.Enum5"]] = None, + **kwargs + ) -> AsyncIterable["_models.ApplicationStackCollection"]: + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_09_01.models.Enum5 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_available_stacks.metadata = {'url': '/providers/Microsoft.Web/availableStacks'} # type: ignore + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.CsmOperationCollection"]: + """Gets all available operations for the Microsoft.Web resource provider. Also exposes resource metric definitions. + + Description for Gets all available operations for the Microsoft.Web resource provider. Also + exposes resource metric definitions. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Web/operations'} # type: ignore + + def get_available_stacks_on_prem( + self, + os_type_selected: Optional[Union[str, "_models.Enum6"]] = None, + **kwargs + ) -> AsyncIterable["_models.ApplicationStackCollection"]: + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_09_01.models.Enum6 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks_on_prem.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_available_stacks_on_prem.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/availableStacks'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_recommendations_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_recommendations_operations.py new file mode 100644 index 000000000000..31dcf46197d8 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_recommendations_operations.py @@ -0,0 +1,1109 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class RecommendationsOperations: + """RecommendationsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """List all recommendations for a subscription. + + Description for List all recommendations for a subscription. + + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations'} # type: ignore + + async def reset_all_filters( + self, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for a subscription. + + Description for Reset all recommendation opt-out settings for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/reset'} # type: ignore + + async def disable_recommendation_for_subscription( + self, + name: str, + **kwargs + ) -> None: + """Disables the specified rule so it will not apply to a subscription in the future. + + Description for Disables the specified rule so it will not apply to a subscription in the + future. + + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/{name}/disable'} # type: ignore + + def list_history_for_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + expired_only: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_history_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get all recommendations for a hosting environment. + + Description for Get all recommendations for a hosting environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the app. + :type hosting_environment_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations'} # type: ignore + + async def disable_all_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/disable'} # type: ignore + + async def reset_all_filters_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/reset'} # type: ignore + + async def get_rule_details_by_hosting_environment( + self, + resource_group_name: str, + hosting_environment_name: str, + name: str, + update_seen: Optional[bool] = None, + recommendation_id: Optional[str] = None, + **kwargs + ) -> "_models.RecommendationRule": + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}'} # type: ignore + + async def disable_recommendation_for_hosting_environment( + self, + resource_group_name: str, + environment_name: str, + name: str, + hosting_environment_name: str, + **kwargs + ) -> None: + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Site name. + :type environment_name: str + :param name: Rule name. + :type name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}/disable'} # type: ignore + + def list_history_for_web_app( + self, + resource_group_name: str, + site_name: str, + expired_only: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_history_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_web_app( + self, + resource_group_name: str, + site_name: str, + featured: Optional[bool] = None, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.RecommendationCollection"]: + """Get all recommendations for an app. + + Description for Get all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations'} # type: ignore + + async def disable_all_for_web_app( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> None: + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/disable'} # type: ignore + + async def reset_all_filters_for_web_app( + self, + resource_group_name: str, + site_name: str, + **kwargs + ) -> None: + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/reset'} # type: ignore + + async def get_rule_details_by_web_app( + self, + resource_group_name: str, + site_name: str, + name: str, + update_seen: Optional[bool] = None, + recommendation_id: Optional[str] = None, + **kwargs + ) -> "_models.RecommendationRule": + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}'} # type: ignore + + async def disable_recommendation_for_site( + self, + resource_group_name: str, + site_name: str, + name: str, + **kwargs + ) -> None: + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site name. + :type site_name: str + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}/disable'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_resource_health_metadata_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_resource_health_metadata_operations.py new file mode 100644 index 000000000000..dfea6e1d22b0 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_resource_health_metadata_operations.py @@ -0,0 +1,471 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ResourceHealthMetadataOperations: + """ResourceHealthMetadataOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """List all ResourceHealthMetadata for all sites in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """List all ResourceHealthMetadata for all sites in the resource group in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the resource group in the + subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata'} # type: ignore + + async def get_by_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.ResourceHealthMetadata": + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata/default'} # type: ignore + + def list_by_site_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ResourceHealthMetadataCollection"]: + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata'} # type: ignore + + async def get_by_site_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.ResourceHealthMetadata": + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata/default'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_static_sites_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_static_sites_operations.py new file mode 100644 index 000000000000..4a6fccf9f856 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_static_sites_operations.py @@ -0,0 +1,1913 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class StaticSitesOperations: + """StaticSitesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def preview_workflow( + self, + location: str, + static_sites_workflow_preview_request: "_models.StaticSitesWorkflowPreviewRequest", + **kwargs + ) -> "_models.StaticSitesWorkflowPreview": + """Generates a preview workflow file for the static site. + + Description for Generates a preview workflow file for the static site. + + :param location: Location where you plan to create the static site. + :type location: str + :param static_sites_workflow_preview_request: A JSON representation of the + StaticSitesWorkflowPreviewRequest properties. See example. + :type static_sites_workflow_preview_request: ~azure.mgmt.web.v2020_09_01.models.StaticSitesWorkflowPreviewRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSitesWorkflowPreview, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSitesWorkflowPreview + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSitesWorkflowPreview"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.preview_workflow.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_sites_workflow_preview_request, 'StaticSitesWorkflowPreviewRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSitesWorkflowPreview', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + preview_workflow.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/previewStaticSiteWorkflowFile'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCollection"]: + """Get all Static Sites for a subscription. + + Description for Get all Static Sites for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_sites_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCollection"]: + """Gets all static sites in the specified resource group. + + Description for Gets all static sites in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_sites_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_static_sites_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites'} # type: ignore + + async def get_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StaticSiteARMResource": + """Gets the details of a static site. + + Description for Gets the details of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def create_or_update_static_site( + self, + resource_group_name: str, + name: str, + static_site_envelope: "_models.StaticSiteARMResource", + **kwargs + ) -> "_models.StaticSiteARMResource": + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSiteARMResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def delete_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes a static site. + + Description for Deletes a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to delete. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + async def update_static_site( + self, + resource_group_name: str, + name: str, + static_site_envelope: "_models.StaticSitePatchResource", + **kwargs + ) -> "_models.StaticSiteARMResource": + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def list_static_site_users( + self, + resource_group_name: str, + name: str, + authprovider: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteUserCollection"]: + """Gets the list of users of a static site. + + Description for Gets the list of users of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for the users. + :type authprovider: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteUserCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteUserCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_users.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteUserCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_users.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/listUsers'} # type: ignore + + async def delete_static_site_user( + self, + resource_group_name: str, + name: str, + authprovider: str, + userid: str, + **kwargs + ) -> None: + """Deletes the user entry from the static site. + + Description for Deletes the user entry from the static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the staticsite. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + async def update_static_site_user( + self, + resource_group_name: str, + name: str, + authprovider: str, + userid: str, + static_site_user_envelope: "_models.StaticSiteUserARMResource", + **kwargs + ) -> "_models.StaticSiteUserARMResource": + """Updates a user entry with the listed roles. + + Description for Updates a user entry with the listed roles. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :param static_site_user_envelope: A JSON representation of the StaticSiteUser properties. See + example. + :type static_site_user_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_envelope, 'StaticSiteUserARMResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def get_static_site_builds( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteBuildCollection"]: + """Gets all static site builds for a particular static site. + + Description for Gets all static site builds for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteBuildCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_site_builds.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteBuildCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + get_static_site_builds.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds'} # type: ignore + + async def get_static_site_build( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> "_models.StaticSiteBuildARMResource": + """Gets the details of a static site build. + + Description for Gets the details of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteBuildARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteBuildARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + async def delete_static_site_build( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> None: + """Deletes a static site build. + + Description for Deletes a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + async def create_or_update_static_site_build_function_app_settings( + self, + resource_group_name: str, + name: str, + pr_id: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Creates or updates the function app settings of a static site build. + + Description for Creates or updates the function app settings of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/config/functionappsettings'} # type: ignore + + def list_static_site_build_functions( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteFunctionOverviewCollection"]: + """Gets the functions of a particular static site build. + + Description for Gets the functions of a particular static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_build_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_build_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/functions'} # type: ignore + + async def list_static_site_build_function_app_settings( + self, + resource_group_name: str, + name: str, + pr_id: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/listFunctionAppSettings'} # type: ignore + + async def create_or_update_static_site_function_app_settings( + self, + resource_group_name: str, + name: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Creates or updates the function app settings of a static site. + + Description for Creates or updates the function app settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/config/functionappsettings'} # type: ignore + + async def create_user_roles_invitation_link( + self, + resource_group_name: str, + name: str, + static_site_user_roles_invitation_envelope: "_models.StaticSiteUserInvitationRequestResource", + **kwargs + ) -> "_models.StaticSiteUserInvitationResponseResource": + """Creates an invitation link for a user with the role. + + Description for Creates an invitation link for a user with the role. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param static_site_user_roles_invitation_envelope: + :type static_site_user_roles_invitation_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserInvitationRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserInvitationResponseResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserInvitationResponseResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserInvitationResponseResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_user_roles_invitation_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_roles_invitation_envelope, 'StaticSiteUserInvitationRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserInvitationResponseResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_user_roles_invitation_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/createUserInvitation'} # type: ignore + + def list_static_site_custom_domains( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteCustomDomainOverviewCollection"]: + """Gets all static site custom domains for a particular static site. + + Description for Gets all static site custom domains for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site resource to search in. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCustomDomainOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_custom_domains.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCustomDomainOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_custom_domains.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains'} # type: ignore + + async def create_or_update_static_site_custom_domain( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> "_models.StaticSiteCustomDomainOverviewARMResource": + """Creates a new static site custom domain in an existing resource group and static site. + + Description for Creates a new static site custom domain in an existing resource group and + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to create. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteCustomDomainOverviewARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + async def delete_static_site_custom_domain( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> None: + """Deletes a custom domain. + + Description for Deletes a custom domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to delete. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + async def validate_custom_domain_can_be_added_to_static_site( + self, + resource_group_name: str, + name: str, + domain_name: str, + **kwargs + ) -> None: + """Validates a particular custom domain can be added to a static site. + + Description for Validates a particular custom domain can be added to a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to validate. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.validate_custom_domain_can_be_added_to_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_custom_domain_can_be_added_to_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}/validate'} # type: ignore + + async def detach_static_site( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Detaches a static site. + + Description for Detaches a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to detach. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.detach_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + detach_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/detach'} # type: ignore + + def list_static_site_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.StaticSiteFunctionOverviewCollection"]: + """Gets the functions of a static site. + + Description for Gets the functions of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_static_site_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/functions'} # type: ignore + + async def list_static_site_function_app_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listFunctionAppSettings'} # type: ignore + + async def list_static_site_secrets( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Lists the secrets for an existing static site. + + Description for Lists the secrets for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listSecrets'} # type: ignore + + async def reset_static_site_api_key( + self, + resource_group_name: str, + name: str, + reset_properties_envelope: "_models.StaticSiteResetPropertiesARMResource", + **kwargs + ) -> None: + """Resets the api key for an existing static site. + + Description for Resets the api key for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param reset_properties_envelope: + :type reset_properties_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteResetPropertiesARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reset_static_site_api_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reset_properties_envelope, 'StaticSiteResetPropertiesARMResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_static_site_api_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/resetapikey'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_top_level_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_top_level_domains_operations.py new file mode 100644 index 000000000000..94e084ef3912 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_top_level_domains_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class TopLevelDomainsOperations: + """TopLevelDomainsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.TopLevelDomainCollection"]: + """Get all top-level domains supported for registration. + + Description for Get all top-level domains supported for registration. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TopLevelDomainCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TopLevelDomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TopLevelDomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains'} # type: ignore + + async def get( + self, + name: str, + **kwargs + ) -> "_models.TopLevelDomain": + """Get details of a top-level domain. + + Description for Get details of a top-level domain. + + :param name: Name of the top-level domain. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TopLevelDomain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TopLevelDomain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TopLevelDomain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}'} # type: ignore + + def list_agreements( + self, + name: str, + agreement_option: "_models.TopLevelDomainAgreementOption", + **kwargs + ) -> AsyncIterable["_models.TldLegalAgreementCollection"]: + """Gets all legal agreements that user needs to accept before purchasing a domain. + + Description for Gets all legal agreements that user needs to accept before purchasing a domain. + + :param name: Name of the top-level domain. + :type name: str + :param agreement_option: Domain agreement options. + :type agreement_option: ~azure.mgmt.web.v2020_09_01.models.TopLevelDomainAgreementOption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TldLegalAgreementCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TldLegalAgreementCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TldLegalAgreementCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_agreements.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TldLegalAgreementCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_agreements.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}/listAgreements'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_apps_operations.py new file mode 100644 index 000000000000..fda74b1b16cc --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_apps_operations.py @@ -0,0 +1,28546 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, IO, List, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class WebAppsOperations: + """WebAppsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Get all apps for a subscription. + + Description for Get all apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/sites'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + include_slots: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Gets all web, mobile, and API apps in the specified resource group. + + Description for Gets all web, mobile, and API apps in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param include_slots: Specify :code:`true` to include deployment slots in + results. The default is false, which only gives you the production slot of all apps. + :type include_slots: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if include_slots is not None: + query_parameters['includeSlots'] = self._serialize.query("include_slots", include_slots, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites'} # type: ignore + + async def get( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.Site"]: + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.Site", + **kwargs + ) -> "_models.Site": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.Site", + **kwargs + ) -> AsyncLROPoller["_models.Site"]: + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def delete( + self, + resource_group_name: str, + name: str, + delete_metrics: Optional[bool] = None, + delete_empty_server_farm: Optional[bool] = None, + **kwargs + ) -> None: + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify false if you want to keep empty App Service plan. By + default, empty App Service plan is deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def update( + self, + resource_group_name: str, + name: str, + site_envelope: "_models.SitePatchResource", + **kwargs + ) -> "_models.Site": + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + async def analyze_custom_hostname( + self, + resource_group_name: str, + name: str, + host_name: Optional[str] = None, + **kwargs + ) -> "_models.CustomHostnameAnalysisResult": + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/analyzeCustomHostname'} # type: ignore + + async def apply_slot_config_to_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_config_to_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_config_to_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/applySlotConfig'} # type: ignore + + async def backup( + self, + resource_group_name: str, + name: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backup'} # type: ignore + + def list_backups( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups'} # type: ignore + + async def get_backup_status( + self, + resource_group_name: str, + name: str, + backup_id: str, + **kwargs + ) -> "_models.BackupItem": + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + async def delete_backup( + self, + resource_group_name: str, + name: str, + backup_id: str, + **kwargs + ) -> None: + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + async def list_backup_status_secrets( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/list'} # type: ignore + + async def _restore_initial( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + async def begin_restore( + self, + resource_group_name: str, + name: str, + backup_id: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + async def get_basic_publishing_credentials_policies( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesCollection": + """Returns whether Scm basic auth is allowed and whether Ftp is allowed for a given site. + + Description for Returns whether Scm basic auth is allowed and whether Ftp is allowed for a + given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesCollection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesCollection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_basic_publishing_credentials_policies.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_basic_publishing_credentials_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies'} # type: ignore + + async def get_ftp_allowed( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Returns whether FTP is allowed on the site or not. + + Description for Returns whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + async def update_ftp_allowed( + self, + resource_group_name: str, + name: str, + csm_publishing_access_policies_entity: "_models.CsmPublishingCredentialsPoliciesEntity", + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Updates whether FTP is allowed on the site or not. + + Description for Updates whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + async def get_scm_allowed( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Returns whether Scm basic auth is allowed on the site or not. + + Description for Returns whether Scm basic auth is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + async def update_scm_allowed( + self, + resource_group_name: str, + name: str, + csm_publishing_access_policies_entity: "_models.CsmPublishingCredentialsPoliciesEntity", + **kwargs + ) -> "_models.CsmPublishingCredentialsPoliciesEntity": + """Updates whether user publishing credentials are allowed on the site or not. + + Description for Updates whether user publishing credentials are allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def list_configurations( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigResourceCollection"]: + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config'} # type: ignore + + async def update_application_settings( + self, + resource_group_name: str, + name: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings'} # type: ignore + + async def list_application_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings/list'} # type: ignore + + async def update_auth_settings( + self, + resource_group_name: str, + name: str, + site_auth_settings: "_models.SiteAuthSettings", + **kwargs + ) -> "_models.SiteAuthSettings": + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings'} # type: ignore + + async def get_auth_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteAuthSettings": + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings/list'} # type: ignore + + async def update_auth_settings_v2( + self, + resource_group_name: str, + name: str, + site_auth_settings_v2: "_models.SiteAuthSettingsV2", + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2'} # type: ignore + + async def get_auth_settings_v2( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2/list'} # type: ignore + + async def update_azure_storage_accounts( + self, + resource_group_name: str, + name: str, + azure_storage_accounts: "_models.AzureStoragePropertyDictionaryResource", + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts'} # type: ignore + + async def list_azure_storage_accounts( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts/list'} # type: ignore + + async def update_backup_configuration( + self, + resource_group_name: str, + name: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupRequest": + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + async def delete_backup_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + async def get_backup_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.BackupRequest": + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup/list'} # type: ignore + + async def update_connection_strings( + self, + resource_group_name: str, + name: str, + connection_strings: "_models.ConnectionStringDictionary", + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings'} # type: ignore + + async def list_connection_strings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings/list'} # type: ignore + + async def get_diagnostic_logs_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteLogsConfig": + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + async def update_diagnostic_logs_config( + self, + resource_group_name: str, + name: str, + site_logs_config: "_models.SiteLogsConfig", + **kwargs + ) -> "_models.SiteLogsConfig": + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + async def update_metadata( + self, + resource_group_name: str, + name: str, + metadata: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata'} # type: ignore + + async def list_metadata( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata/list'} # type: ignore + + async def _list_publishing_credentials_initial( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.User": + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + async def begin_list_publishing_credentials( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncLROPoller["_models.User"]: + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._list_publishing_credentials_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + async def update_site_push_settings( + self, + resource_group_name: str, + name: str, + push_settings: "_models.PushSettings", + **kwargs + ) -> "_models.PushSettings": + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings'} # type: ignore + + async def list_site_push_settings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PushSettings": + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings/list'} # type: ignore + + async def list_slot_configuration_names( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SlotConfigNamesResource": + """Gets the names of app settings and connection strings that stick to the slot (not swapped). + + Description for Gets the names of app settings and connection strings that stick to the slot + (not swapped). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + async def update_slot_configuration_names( + self, + resource_group_name: str, + name: str, + slot_config_names: "_models.SlotConfigNamesResource", + **kwargs + ) -> "_models.SlotConfigNamesResource": + """Updates the names of application settings and connection string that remain with the slot during swap operation. + + Description for Updates the names of application settings and connection string that remain + with the slot during swap operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_config_names: Names of application settings and connection strings. See example. + :type slot_config_names: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_config_names, 'SlotConfigNamesResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + async def get_configuration( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + async def create_or_update_configuration( + self, + resource_group_name: str, + name: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + async def update_configuration( + self, + resource_group_name: str, + name: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def list_configuration_snapshot_info( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigurationSnapshotInfoCollection"]: + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots'} # type: ignore + + async def get_configuration_snapshot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}'} # type: ignore + + async def recover_site_configuration_snapshot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + **kwargs + ) -> None: + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + async def get_web_site_container_logs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional[IO]: + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs'} # type: ignore + + async def get_container_logs_zip( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional[IO]: + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ContinuousWebJobCollection"]: + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs'} # type: ignore + + async def get_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> Optional["_models.ContinuousWebJob"]: + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + async def delete_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + async def start_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/start'} # type: ignore + + async def stop_continuous_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.DeploymentCollection"]: + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_deployments.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments'} # type: ignore + + async def get_deployment( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> "_models.Deployment": + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def create_deployment( + self, + resource_group_name: str, + name: str, + id: str, + deployment: "_models.Deployment", + **kwargs + ) -> "_models.Deployment": + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_09_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def delete_deployment( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> None: + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + async def list_deployment_log( + self, + resource_group_name: str, + name: str, + id: str, + **kwargs + ) -> "_models.Deployment": + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}/log'} # type: ignore + + async def discover_backup( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> "_models.RestoreRequest": + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers'} # type: ignore + + async def get_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + **kwargs + ) -> "_models.Identifier": + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def create_or_update_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def delete_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + **kwargs + ) -> None: + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def update_domain_ownership_identifier( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def get_ms_deploy_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def _create_ms_deploy_operation_initial( + self, + resource_group_name: str, + name: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def begin_create_ms_deploy_operation( + self, + resource_group_name: str, + name: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + async def get_ms_deploy_log( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy/log'} # type: ignore + + def list_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.FunctionEnvelopeCollection"]: + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions'} # type: ignore + + async def get_functions_admin_token( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> str: + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/admin/token'} # type: ignore + + async def get_function( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> Optional["_models.FunctionEnvelope"]: + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def _create_function_initial( + self, + resource_group_name: str, + name: str, + function_name: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> "_models.FunctionEnvelope": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_function_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_function_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def begin_create_function( + self, + resource_group_name: str, + name: str, + function_name: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> AsyncLROPoller["_models.FunctionEnvelope"]: + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_function_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def delete_function( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> None: + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + async def create_or_update_function_secret( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def delete_function_secret( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + **kwargs + ) -> None: + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def list_function_keys( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> "_models.StringDictionary": + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listkeys'} # type: ignore + + async def list_function_secrets( + self, + resource_group_name: str, + name: str, + function_name: str, + **kwargs + ) -> "_models.FunctionSecrets": + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listsecrets'} # type: ignore + + async def list_host_keys( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HostKeys": + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listkeys'} # type: ignore + + async def list_sync_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listsyncstatus'} # type: ignore + + async def sync_functions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/sync'} # type: ignore + + async def create_or_update_host_secret( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + async def delete_host_secret( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + **kwargs + ) -> None: + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.HostNameBindingCollection"]: + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_host_name_bindings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings'} # type: ignore + + async def get_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + **kwargs + ) -> "_models.HostNameBinding": + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def create_or_update_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + host_name_binding: "_models.HostNameBinding", + **kwargs + ) -> "_models.HostNameBinding": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def delete_host_name_binding( + self, + resource_group_name: str, + name: str, + host_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + async def get_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def create_or_update_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + **kwargs + ) -> None: + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def update_hybrid_connection( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionRelays'} # type: ignore + + async def list_relay_service_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection'} # type: ignore + + async def get_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def create_or_update_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def delete_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + **kwargs + ) -> None: + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + async def update_relay_service_connection( + self, + resource_group_name: str, + name: str, + entity_name: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebAppInstanceStatusCollection"]: + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances'} # type: ignore + + async def get_instance_info( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> "_models.WebSiteInstanceStatus": + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}'} # type: ignore + + async def get_instance_ms_deploy_status( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def _create_instance_ms_deploy_operation_initial( + self, + resource_group_name: str, + name: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def begin_create_instance_ms_deploy_operation( + self, + resource_group_name: str, + name: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def get_instance_ms_deploy_log( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes( + self, + resource_group_name: str, + name: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes'} # type: ignore + + async def get_instance_process( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def delete_instance_process( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def get_instance_process_dump( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + async def get_instance_process_module( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads( + self, + resource_group_name: str, + name: str, + process_id: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + async def is_cloneable( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteCloneability": + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/iscloneable'} # type: ignore + + def list_site_backups( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listbackups'} # type: ignore + + async def list_sync_function_triggers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.FunctionSecrets": + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listsyncfunctiontriggerstatus'} # type: ignore + + async def _migrate_storage_initial( + self, + subscription_name: str, + resource_group_name: str, + name: str, + migration_options: "_models.StorageMigrationOptions", + **kwargs + ) -> "_models.StorageMigrationResponse": + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_storage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['subscriptionName'] = self._serialize.query("subscription_name", subscription_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_options, 'StorageMigrationOptions') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_storage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + async def begin_migrate_storage( + self, + subscription_name: str, + resource_group_name: str, + name: str, + migration_options: "_models.StorageMigrationOptions", + **kwargs + ) -> AsyncLROPoller["_models.StorageMigrationResponse"]: + """Restores a web app. + + Description for Restores a web app. + + :param subscription_name: Azure subscription. + :type subscription_name: str + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_options: Migration migrationOptions. + :type migration_options: ~azure.mgmt.web.v2020_09_01.models.StorageMigrationOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either StorageMigrationResponse or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.StorageMigrationResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._migrate_storage_initial( + subscription_name=subscription_name, + resource_group_name=resource_group_name, + name=name, + migration_options=migration_options, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_storage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + async def _migrate_my_sql_initial( + self, + resource_group_name: str, + name: str, + migration_request_envelope: "_models.MigrateMySqlRequest", + **kwargs + ) -> "_models.Operation": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_my_sql_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_request_envelope, 'MigrateMySqlRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_my_sql_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + async def begin_migrate_my_sql( + self, + resource_group_name: str, + name: str, + migration_request_envelope: "_models.MigrateMySqlRequest", + **kwargs + ) -> AsyncLROPoller["_models.Operation"]: + """Migrates a local (in-app) MySql database to a remote MySql database. + + Description for Migrates a local (in-app) MySql database to a remote MySql database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_request_envelope: MySql migration options. + :type migration_request_envelope: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Operation or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.Operation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._migrate_my_sql_initial( + resource_group_name=resource_group_name, + name=name, + migration_request_envelope=migration_request_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_my_sql.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + async def get_migrate_my_sql_status( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.MigrateMySqlStatus": + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql/status'} # type: ignore + + async def get_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def create_or_update_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def delete_swift_virtual_network( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def update_swift_virtual_network_connection( + self, + resource_group_name: str, + name: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + async def list_network_features( + self, + resource_group_name: str, + name: str, + view: str, + **kwargs + ) -> Optional["_models.NetworkFeatures"]: + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkFeatures/{view}'} # type: ignore + + async def get_network_trace_operation( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/operationresults/{operationId}'} # type: ignore + + async def start_web_site_network_trace( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> str: + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/start'} # type: ignore + + async def _start_web_site_network_trace_operation_initial( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + async def begin_start_web_site_network_trace_operation( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_web_site_network_trace_operation_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + async def stop_web_site_network_trace( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/stop'} # type: ignore + + async def get_network_traces( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/{operationId}'} # type: ignore + + async def get_network_trace_operation_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + async def get_network_traces_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/{operationId}'} # type: ignore + + async def generate_new_site_publishing_password( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/newpassword'} # type: ignore + + def list_perf_mon_counters( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PerfMonCounterCollection"]: + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_perf_mon_counters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/perfcounters'} # type: ignore + + async def get_site_php_error_log_flag( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SitePhpErrorLogFlag": + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/phplogging'} # type: ignore + + async def list_premier_add_ons( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons'} # type: ignore + + async def get_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def add_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + premier_add_on: "_models.PremierAddOn", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def delete_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + **kwargs + ) -> None: + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def update_premier_add_on( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + premier_add_on: "_models.PremierAddOnPatchResource", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + async def get_private_access( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PrivateAccess": + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + async def put_private_access_vnet( + self, + resource_group_name: str, + name: str, + access: "_models.PrivateAccess", + **kwargs + ) -> "_models.PrivateAccess": + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def list_processes( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes'} # type: ignore + + async def get_process( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + async def delete_process( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + async def get_process_dump( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/dump'} # type: ignore + + def list_process_modules( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules'} # type: ignore + + async def get_process_module( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads( + self, + resource_group_name: str, + name: str, + process_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.PublicCertificateCollection"]: + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_public_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates'} # type: ignore + + async def get_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + **kwargs + ) -> "_models.PublicCertificate": + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def create_or_update_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + public_certificate: "_models.PublicCertificate", + **kwargs + ) -> "_models.PublicCertificate": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def delete_public_certificate( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def list_publishing_profile_xml_with_secrets( + self, + resource_group_name: str, + name: str, + publishing_profile_options: "_models.CsmPublishingProfileOptions", + **kwargs + ) -> IO: + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publishxml'} # type: ignore + + async def reset_production_slot_config( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_production_slot_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_production_slot_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resetSlotConfig'} # type: ignore + + async def restart( + self, + resource_group_name: str, + name: str, + soft_restart: Optional[bool] = None, + synchronous: Optional[bool] = None, + **kwargs + ) -> None: + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restart'} # type: ignore + + async def _restore_from_backup_blob_initial( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + async def begin_restore_from_backup_blob( + self, + resource_group_name: str, + name: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_backup_blob_initial( + resource_group_name=resource_group_name, + name=name, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + async def _restore_from_deleted_app_initial( + self, + resource_group_name: str, + name: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + async def begin_restore_from_deleted_app( + self, + resource_group_name: str, + name: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_deleted_app_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + async def _restore_snapshot_initial( + self, + resource_group_name: str, + name: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + async def begin_restore_snapshot( + self, + resource_group_name: str, + name: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_snapshot_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def list_site_extensions( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SiteExtensionInfoCollection"]: + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_extensions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions'} # type: ignore + + async def get_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _install_site_extension_initial( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def begin_install_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> AsyncLROPoller["_models.SiteExtensionInfo"]: + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._install_site_extension_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def delete_site_extension( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + **kwargs + ) -> None: + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _copy_production_slot_initial( + self, + resource_group_name: str, + name: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_production_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_production_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + async def begin_copy_production_slot( + self, + resource_group_name: str, + name: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_09_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._copy_production_slot_initial( + resource_group_name=resource_group_name, + name=name, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_production_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def list_slots( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebAppCollection"]: + """Gets an app's deployment slots. + + Description for Gets an app's deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots'} # type: ignore + + async def get_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional["_models.Site"]: + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def _create_or_update_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.Site", + **kwargs + ) -> "_models.Site": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def begin_create_or_update_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.Site", + **kwargs + ) -> AsyncLROPoller["_models.Site"]: + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def delete_slot( + self, + resource_group_name: str, + name: str, + slot: str, + delete_metrics: Optional[bool] = None, + delete_empty_server_farm: Optional[bool] = None, + **kwargs + ) -> None: + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param slot: Name of the deployment slot to delete. By default, the API deletes the production + slot. + :type slot: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify true if the App Service plan will be empty after app + deletion and you want to delete the empty App Service plan. By default, the empty App Service + plan is not deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def update_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_envelope: "_models.SitePatchResource", + **kwargs + ) -> "_models.Site": + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + async def analyze_custom_hostname_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: Optional[str] = None, + **kwargs + ) -> "_models.CustomHostnameAnalysisResult": + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/analyzeCustomHostname'} # type: ignore + + async def apply_slot_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/applySlotConfig'} # type: ignore + + async def backup_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + backup for the production slot. + :type slot: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backup'} # type: ignore + + def list_backups_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups'} # type: ignore + + async def get_backup_status_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + **kwargs + ) -> "_models.BackupItem": + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a backup + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + async def delete_backup_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + **kwargs + ) -> None: + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + backup of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + async def list_backup_status_secrets_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupItem": + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/list'} # type: ignore + + async def _restore_slot_initial( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + async def begin_restore_slot( + self, + resource_group_name: str, + name: str, + backup_id: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_slot_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def list_configurations_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigResourceCollection"]: + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configurations_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config'} # type: ignore + + async def update_application_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + app_settings: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + application settings for the production slot. + :type slot: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings'} # type: ignore + + async def list_application_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + application settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings/list'} # type: ignore + + async def update_auth_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_auth_settings: "_models.SiteAuthSettings", + **kwargs + ) -> "_models.SiteAuthSettings": + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings'} # type: ignore + + async def get_auth_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteAuthSettings": + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings/list'} # type: ignore + + async def update_auth_settings_v2_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_auth_settings_v2: "_models.SiteAuthSettingsV2", + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2'} # type: ignore + + async def get_auth_settings_v2_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteAuthSettingsV2": + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2/list'} # type: ignore + + async def update_azure_storage_accounts_slot( + self, + resource_group_name: str, + name: str, + slot: str, + azure_storage_accounts: "_models.AzureStoragePropertyDictionaryResource", + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts'} # type: ignore + + async def list_azure_storage_accounts_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.AzureStoragePropertyDictionaryResource": + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts/list'} # type: ignore + + async def update_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.BackupRequest", + **kwargs + ) -> "_models.BackupRequest": + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + backup configuration for the production slot. + :type slot: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + async def delete_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + async def get_backup_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.BackupRequest": + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup/list'} # type: ignore + + async def update_connection_strings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_strings: "_models.ConnectionStringDictionary", + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + connection settings for the production slot. + :type slot: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings'} # type: ignore + + async def list_connection_strings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.ConnectionStringDictionary": + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + connection settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings/list'} # type: ignore + + async def get_diagnostic_logs_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteLogsConfig": + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + logging configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + async def update_diagnostic_logs_config_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_logs_config: "_models.SiteLogsConfig", + **kwargs + ) -> "_models.SiteLogsConfig": + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + logging configuration for the production slot. + :type slot: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + async def update_metadata_slot( + self, + resource_group_name: str, + name: str, + slot: str, + metadata: "_models.StringDictionary", + **kwargs + ) -> "_models.StringDictionary": + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + metadata for the production slot. + :type slot: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata'} # type: ignore + + async def list_metadata_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + metadata for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata/list'} # type: ignore + + async def _list_publishing_credentials_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.User": + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + async def begin_list_publishing_credentials_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncLROPoller["_models.User"]: + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing credentials for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._list_publishing_credentials_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + async def update_site_push_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + push_settings: "_models.PushSettings", + **kwargs + ) -> "_models.PushSettings": + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings'} # type: ignore + + async def list_site_push_settings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PushSettings": + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings/list'} # type: ignore + + async def get_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + async def create_or_update_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + async def update_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_config: "_models.SiteConfigResource", + **kwargs + ) -> "_models.SiteConfigResource": + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def list_configuration_snapshot_info_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteConfigurationSnapshotInfoCollection"]: + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots'} # type: ignore + + async def get_configuration_snapshot_slot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + slot: str, + **kwargs + ) -> "_models.SiteConfigResource": + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}'} # type: ignore + + async def recover_site_configuration_snapshot_slot( + self, + resource_group_name: str, + name: str, + snapshot_id: str, + slot: str, + **kwargs + ) -> None: + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + async def get_web_site_container_logs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs'} # type: ignore + + async def get_container_logs_zip_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ContinuousWebJobCollection"]: + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs'} # type: ignore + + async def get_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> Optional["_models.ContinuousWebJob"]: + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + async def delete_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + async def start_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/start'} # type: ignore + + async def stop_continuous_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.DeploymentCollection"]: + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_deployments_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments'} # type: ignore + + async def get_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> "_models.Deployment": + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets a deployment + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def create_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + deployment: "_models.Deployment", + **kwargs + ) -> "_models.Deployment": + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API creates a + deployment for the production slot. + :type slot: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_09_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def delete_deployment_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> None: + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + async def list_deployment_log_slot( + self, + resource_group_name: str, + name: str, + id: str, + slot: str, + **kwargs + ) -> "_models.Deployment": + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}/log'} # type: ignore + + async def discover_backup_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> "_models.RestoreRequest": + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will perform + discovery for the production slot. + :type slot: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers'} # type: ignore + + async def get_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + **kwargs + ) -> "_models.Identifier": + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def create_or_update_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def delete_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def update_domain_ownership_identifier_slot( + self, + resource_group_name: str, + name: str, + domain_ownership_identifier_name: str, + slot: str, + domain_ownership_identifier: "_models.Identifier", + **kwargs + ) -> "_models.Identifier": + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + async def get_ms_deploy_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def _create_ms_deploy_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def begin_create_ms_deploy_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + async def get_ms_deploy_log_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_functions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.FunctionEnvelopeCollection"]: + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions'} # type: ignore + + async def get_functions_admin_token_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> str: + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/admin/token'} # type: ignore + + async def get_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> Optional["_models.FunctionEnvelope"]: + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def _create_instance_function_slot_initial( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> "_models.FunctionEnvelope": + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_function_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_function_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def begin_create_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + function_envelope: "_models.FunctionEnvelope", + **kwargs + ) -> AsyncLROPoller["_models.FunctionEnvelope"]: + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_function_slot_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + slot=slot, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def delete_instance_function_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + async def create_or_update_function_secret_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + slot: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def delete_function_secret_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + key_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + async def list_function_keys_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> "_models.StringDictionary": + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listkeys'} # type: ignore + + async def list_function_secrets_slot( + self, + resource_group_name: str, + name: str, + function_name: str, + slot: str, + **kwargs + ) -> "_models.FunctionSecrets": + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listsecrets'} # type: ignore + + async def list_host_keys_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.HostKeys": + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listkeys'} # type: ignore + + async def list_sync_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listsyncstatus'} # type: ignore + + async def sync_functions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/sync'} # type: ignore + + async def create_or_update_host_secret_slot( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + slot: str, + key: "_models.KeyInfo", + **kwargs + ) -> "_models.KeyInfo": + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + async def delete_host_secret_slot( + self, + resource_group_name: str, + name: str, + key_type: str, + key_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.HostNameBindingCollection"]: + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_host_name_bindings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings'} # type: ignore + + async def get_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: str, + **kwargs + ) -> "_models.HostNameBinding": + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def create_or_update_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + host_name: str, + slot: str, + host_name_binding: "_models.HostNameBinding", + **kwargs + ) -> "_models.HostNameBinding": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def delete_host_name_binding_slot( + self, + resource_group_name: str, + name: str, + slot: str, + host_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + async def get_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def create_or_update_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def delete_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + **kwargs + ) -> None: + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def update_hybrid_connection_slot( + self, + resource_group_name: str, + name: str, + namespace_name: str, + relay_name: str, + slot: str, + connection_envelope: "_models.HybridConnection", + **kwargs + ) -> "_models.HybridConnection": + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + async def list_hybrid_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.HybridConnection": + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionRelays'} # type: ignore + + async def list_relay_service_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get hybrid + connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection'} # type: ignore + + async def get_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a hybrid + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def create_or_update_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def delete_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + hybrid connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + async def update_relay_service_connection_slot( + self, + resource_group_name: str, + name: str, + entity_name: str, + slot: str, + connection_envelope: "_models.RelayServiceConnectionEntity", + **kwargs + ) -> "_models.RelayServiceConnectionEntity": + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.WebAppInstanceStatusCollection"]: + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances'} # type: ignore + + async def get_instance_info_slot( + self, + resource_group_name: str, + name: str, + instance_id: str, + slot: str, + **kwargs + ) -> "_models.WebSiteInstanceStatus": + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}'} # type: ignore + + async def get_instance_ms_deploy_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> "_models.MSDeployStatus": + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def _create_instance_ms_deploy_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> Optional["_models.MSDeployStatus"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def begin_create_instance_ms_deploy_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + ms_deploy: "_models.MSDeploy", + **kwargs + ) -> AsyncLROPoller["_models.MSDeployStatus"]: + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_instance_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + async def get_instance_ms_deploy_log_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.MSDeployLog"]: + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes_slot( + self, + resource_group_name: str, + name: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes'} # type: ignore + + async def get_instance_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def delete_instance_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + async def get_instance_process_dump_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + async def get_instance_process_module_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + slot: str, + instance_id: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + instance_id: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_instance_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + async def is_cloneable_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteCloneability": + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns information on the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/iscloneable'} # type: ignore + + def list_site_backups_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.BackupItemCollection"]: + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listbackups'} # type: ignore + + async def list_sync_function_triggers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.FunctionSecrets": + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listsyncfunctiontriggerstatus'} # type: ignore + + async def get_migrate_my_sql_status_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.MigrateMySqlStatus": + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/migratemysql/status'} # type: ignore + + async def get_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def create_or_update_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def delete_swift_virtual_network_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def update_swift_virtual_network_connection_slot( + self, + resource_group_name: str, + name: str, + slot: str, + connection_envelope: "_models.SwiftVirtualNetwork", + **kwargs + ) -> "_models.SwiftVirtualNetwork": + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + async def list_network_features_slot( + self, + resource_group_name: str, + name: str, + view: str, + slot: str, + **kwargs + ) -> Optional["_models.NetworkFeatures"]: + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get network + features for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkFeatures/{view}'} # type: ignore + + async def get_network_trace_operation_slot( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/operationresults/{operationId}'} # type: ignore + + async def start_web_site_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> str: + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/start'} # type: ignore + + async def _start_web_site_network_trace_operation_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + async def begin_start_web_site_network_trace_operation_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_web_site_network_trace_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + async def stop_web_site_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/stop'} # type: ignore + + async def get_network_traces_slot( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/{operationId}'} # type: ignore + + async def get_network_trace_operation_slot_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + async def get_network_traces_slot_v2( + self, + resource_group_name: str, + name: str, + operation_id: str, + slot: str, + **kwargs + ) -> List["_models.NetworkTrace"]: + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/{operationId}'} # type: ignore + + async def generate_new_site_publishing_password_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API generate a new + publishing password for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/newpassword'} # type: ignore + + def list_perf_mon_counters_slot( + self, + resource_group_name: str, + name: str, + slot: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PerfMonCounterCollection"]: + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_perf_mon_counters_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/perfcounters'} # type: ignore + + async def get_site_php_error_log_flag_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SitePhpErrorLogFlag": + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/phplogging'} # type: ignore + + async def list_premier_add_ons_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + premier add-ons for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons'} # type: ignore + + async def get_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + **kwargs + ) -> "_models.PremierAddOn": + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def add_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + premier_add_on: "_models.PremierAddOn", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def delete_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def update_premier_add_on_slot( + self, + resource_group_name: str, + name: str, + premier_add_on_name: str, + slot: str, + premier_add_on: "_models.PremierAddOnPatchResource", + **kwargs + ) -> "_models.PremierAddOn": + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + async def get_private_access_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.PrivateAccess": + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + async def put_private_access_vnet_slot( + self, + resource_group_name: str, + name: str, + slot: str, + access: "_models.PrivateAccess", + **kwargs + ) -> "_models.PrivateAccess": + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + async def get_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> "_models.PrivateEndpointConnectionResource": + """Gets a private endpoint connection. + + Description for Gets a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnectionResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateEndpointConnectionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def _approve_or_reject_private_endpoint_connection_initial( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + private_endpoint_wrapper: "_models.PrivateLinkConnectionApprovalRequestResource", + **kwargs + ) -> "_models.PrivateEndpointConnectionResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._approve_or_reject_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(private_endpoint_wrapper, 'PrivateLinkConnectionApprovalRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _approve_or_reject_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def begin_approve_or_reject_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + private_endpoint_wrapper: "_models.PrivateLinkConnectionApprovalRequestResource", + **kwargs + ) -> AsyncLROPoller["_models.PrivateEndpointConnectionResource"]: + """Approves or rejects a private endpoint connection. + + Description for Approves or rejects a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :param private_endpoint_wrapper: + :type private_endpoint_wrapper: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionApprovalRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either PrivateEndpointConnectionResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.PrivateEndpointConnectionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._approve_or_reject_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + private_endpoint_wrapper=private_endpoint_wrapper, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_approve_or_reject_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def _delete_private_endpoint_connection_initial( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> object: + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._delete_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 204: + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def begin_delete_private_endpoint_connection( + self, + resource_group_name: str, + name: str, + private_endpoint_connection_name: str, + **kwargs + ) -> AsyncLROPoller[object]: + """Deletes a private endpoint connection. + + Description for Deletes a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either object or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[object] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[object] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + async def get_private_link_resources( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.PrivateLinkResourcesWrapper": + """Gets the private link resources. + + Description for Gets the private link resources. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkResourcesWrapper, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkResourcesWrapper + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkResourcesWrapper"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_link_resources.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkResourcesWrapper', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_link_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateLinkResources'} # type: ignore + + def list_processes_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessInfoCollection"]: + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes'} # type: ignore + + async def get_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> Optional["_models.ProcessInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + async def delete_process_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> None: + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + async def get_process_dump_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> Optional[IO]: + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/dump'} # type: ignore + + def list_process_modules_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessModuleInfoCollection"]: + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules'} # type: ignore + + async def get_process_module_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + base_address: str, + slot: str, + **kwargs + ) -> Optional["_models.ProcessModuleInfo"]: + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads_slot( + self, + resource_group_name: str, + name: str, + process_id: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.ProcessThreadInfoCollection"]: + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.PublicCertificateCollection"]: + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_public_certificates_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates'} # type: ignore + + async def get_public_certificate_slot( + self, + resource_group_name: str, + name: str, + slot: str, + public_certificate_name: str, + **kwargs + ) -> "_models.PublicCertificate": + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def create_or_update_public_certificate_slot( + self, + resource_group_name: str, + name: str, + public_certificate_name: str, + slot: str, + public_certificate: "_models.PublicCertificate", + **kwargs + ) -> "_models.PublicCertificate": + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def delete_public_certificate_slot( + self, + resource_group_name: str, + name: str, + slot: str, + public_certificate_name: str, + **kwargs + ) -> None: + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + async def list_publishing_profile_xml_with_secrets_slot( + self, + resource_group_name: str, + name: str, + slot: str, + publishing_profile_options: "_models.CsmPublishingProfileOptions", + **kwargs + ) -> IO: + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing profile for the production slot. + :type slot: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publishxml'} # type: ignore + + async def reset_slot_configuration_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API resets + configuration settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resetSlotConfig'} # type: ignore + + async def restart_slot( + self, + resource_group_name: str, + name: str, + slot: str, + soft_restart: Optional[bool] = None, + synchronous: Optional[bool] = None, + **kwargs + ) -> None: + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restart the + production slot. + :type slot: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restart'} # type: ignore + + async def _restore_from_backup_blob_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + async def begin_restore_from_backup_blob_slot( + self, + resource_group_name: str, + name: str, + slot: str, + request: "_models.RestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_backup_blob_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + async def _restore_from_deleted_app_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + async def begin_restore_from_deleted_app_slot( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.DeletedAppRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_from_deleted_app_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + async def _restore_snapshot_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + async def begin_restore_snapshot_slot( + self, + resource_group_name: str, + name: str, + slot: str, + restore_request: "_models.SnapshotRestoreRequest", + **kwargs + ) -> AsyncLROPoller[None]: + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restore_snapshot_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def list_site_extensions_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SiteExtensionInfoCollection"]: + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_extensions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions'} # type: ignore + + async def get_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _install_site_extension_slot_initial( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> Optional["_models.SiteExtensionInfo"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def begin_install_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> AsyncLROPoller["_models.SiteExtensionInfo"]: + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._install_site_extension_slot_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def delete_site_extension_slot( + self, + resource_group_name: str, + name: str, + site_extension_id: str, + slot: str, + **kwargs + ) -> None: + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + async def _copy_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + async def begin_copy_slot( + self, + resource_group_name: str, + name: str, + slot: str, + copy_slot_entity: "_models.CsmCopySlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_09_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._copy_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def list_slot_differences_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncIterable["_models.SlotDifferenceCollection"]: + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slot_differences_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsdiffs'} # type: ignore + + async def _swap_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + async def begin_swap_slot( + self, + resource_group_name: str, + name: str, + slot: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._swap_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def list_snapshots_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshotsdr'} # type: ignore + + async def get_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> "_models.SiteSourceControl": + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def _create_or_update_source_control_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def begin_create_or_update_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> AsyncLROPoller["_models.SiteSourceControl"]: + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_source_control_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def delete_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def update_source_control_slot( + self, + resource_group_name: str, + name: str, + slot: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + async def start_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will start the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/start'} # type: ignore + + async def _start_network_trace_slot_initial( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + async def begin_start_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_network_trace_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + async def stop_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will stop the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stop'} # type: ignore + + async def stop_network_trace_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stopNetworkTrace'} # type: ignore + + async def sync_repository_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sync'} # type: ignore + + async def sync_function_triggers_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredWebJobCollection"]: + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs'} # type: ignore + + async def get_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> Optional["_models.TriggeredWebJob"]: + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + async def delete_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes web job + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredJobHistoryCollection"]: + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + async def get_triggered_web_job_history_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + id: str, + slot: str, + **kwargs + ) -> Optional["_models.TriggeredJobHistory"]: + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + async def run_triggered_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> None: + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages_slot( + self, + resource_group_name: str, + name: str, + slot: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get quota + information of the production slot. + :type slot: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/usages'} # type: ignore + + async def list_vnet_connections_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get virtual + network connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + **kwargs + ) -> "_models.VnetInfo": + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named virtual network for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def create_or_update_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def delete_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + **kwargs + ) -> None: + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def update_vnet_connection_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + slot: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + **kwargs + ) -> Optional["_models.VnetGateway"]: + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def create_or_update_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_connection_gateway_slot( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + slot: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs_slot( + self, + resource_group_name: str, + name: str, + slot: str, + **kwargs + ) -> AsyncIterable["_models.WebJobCollection"]: + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs'} # type: ignore + + async def get_web_job_slot( + self, + resource_group_name: str, + name: str, + web_job_name: str, + slot: str, + **kwargs + ) -> "_models.WebJob": + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs/{webJobName}'} # type: ignore + + def list_slot_differences_from_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncIterable["_models.SlotDifferenceCollection"]: + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_from_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_slot_differences_from_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsdiffs'} # type: ignore + + async def _swap_slot_with_production_initial( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_with_production_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_with_production_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + async def begin_swap_slot_with_production( + self, + resource_group_name: str, + name: str, + slot_swap_entity: "_models.CsmSlotEntity", + **kwargs + ) -> AsyncLROPoller[None]: + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._swap_slot_with_production_initial( + resource_group_name=resource_group_name, + name=name, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot_with_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def list_snapshots( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.SnapshotCollection"]: + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshotsdr'} # type: ignore + + async def get_source_control( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> "_models.SiteSourceControl": + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def _create_or_update_source_control_initial( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def begin_create_or_update_source_control( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> AsyncLROPoller["_models.SiteSourceControl"]: + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.web.v2020_09_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_source_control_initial( + resource_group_name=resource_group_name, + name=name, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def delete_source_control( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def update_source_control( + self, + resource_group_name: str, + name: str, + site_source_control: "_models.SiteSourceControl", + **kwargs + ) -> "_models.SiteSourceControl": + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + async def start( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/start'} # type: ignore + + async def _start_network_trace_initial( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> List["_models.NetworkTrace"]: + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + async def begin_start_network_trace( + self, + resource_group_name: str, + name: str, + duration_in_seconds: Optional[int] = None, + max_frame_length: Optional[int] = None, + sas_url: Optional[str] = None, + **kwargs + ) -> AsyncLROPoller[List["_models.NetworkTrace"]]: + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._start_network_trace_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + async def stop( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stop'} # type: ignore + + async def stop_network_trace( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stopNetworkTrace'} # type: ignore + + async def sync_repository( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sync'} # type: ignore + + async def sync_function_triggers( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> None: + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredWebJobCollection"]: + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs'} # type: ignore + + async def get_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> Optional["_models.TriggeredWebJob"]: + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + async def delete_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> AsyncIterable["_models.TriggeredJobHistoryCollection"]: + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + async def get_triggered_web_job_history( + self, + resource_group_name: str, + name: str, + web_job_name: str, + id: str, + **kwargs + ) -> Optional["_models.TriggeredJobHistory"]: + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + async def run_triggered_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> None: + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages( + self, + resource_group_name: str, + name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.CsmUsageQuotaCollection"]: + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/usages'} # type: ignore + + async def list_vnet_connections( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> List["_models.VnetInfo"]: + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections'} # type: ignore + + async def get_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> "_models.VnetInfo": + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def create_or_update_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def delete_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + **kwargs + ) -> None: + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def update_vnet_connection( + self, + resource_group_name: str, + name: str, + vnet_name: str, + connection_envelope: "_models.VnetInfo", + **kwargs + ) -> "_models.VnetInfo": + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + async def get_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + **kwargs + ) -> Optional["_models.VnetGateway"]: + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def create_or_update_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + async def update_vnet_connection_gateway( + self, + resource_group_name: str, + name: str, + vnet_name: str, + gateway_name: str, + connection_envelope: "_models.VnetGateway", + **kwargs + ) -> "_models.VnetGateway": + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs( + self, + resource_group_name: str, + name: str, + **kwargs + ) -> AsyncIterable["_models.WebJobCollection"]: + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs'} # type: ignore + + async def get_web_job( + self, + resource_group_name: str, + name: str, + web_job_name: str, + **kwargs + ) -> "_models.WebJob": + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs/{webJobName}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_site_management_client_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_site_management_client_operations.py new file mode 100644 index 000000000000..5a1f074debd8 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/aio/operations/_web_site_management_client_operations.py @@ -0,0 +1,1121 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class WebSiteManagementClientOperationsMixin: + + async def generate_github_access_token_for_appservice_cli_async( + self, + code: str, + state: str, + **kwargs + ) -> "_models.AppserviceGithubToken": + """Exchange code for GitHub access token for AppService CLI. + + Description for Exchange code for GitHub access token for AppService CLI. + + :param code: Code string to exchange for Github Access token. + :type code: str + :param state: State string used for verification. + :type state: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppserviceGithubToken, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppserviceGithubToken"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.AppserviceGithubTokenRequest(code=code, state=state) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.generate_github_access_token_for_appservice_cli_async.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'AppserviceGithubTokenRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppserviceGithubToken', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + generate_github_access_token_for_appservice_cli_async.metadata = {'url': '/providers/Microsoft.Web/generateGithubAccessTokenForAppserviceCLI'} # type: ignore + + async def get_publishing_user( + self, + **kwargs + ) -> "_models.User": + """Gets publishing user. + + Description for Gets publishing user. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + async def update_publishing_user( + self, + user_details: "_models.User", + **kwargs + ) -> "_models.User": + """Updates publishing user. + + Description for Updates publishing user. + + :param user_details: Details of publishing user. + :type user_details: ~azure.mgmt.web.v2020_09_01.models.User + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(user_details, 'User') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def list_source_controls( + self, + **kwargs + ) -> AsyncIterable["_models.SourceControlCollection"]: + """Gets the source controls available for Azure websites. + + Description for Gets the source controls available for Azure websites. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SourceControlCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControlCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_source_controls.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('SourceControlCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_source_controls.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols'} # type: ignore + + async def get_source_control( + self, + source_control_type: str, + **kwargs + ) -> "_models.SourceControl": + """Gets source control token. + + Description for Gets source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + async def update_source_control( + self, + source_control_type: str, + request_message: "_models.SourceControl", + **kwargs + ) -> "_models.SourceControl": + """Updates source control token. + + Description for Updates source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :param request_message: Source control token information. + :type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request_message, 'SourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def list_billing_meters( + self, + billing_location: Optional[str] = None, + os_type: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.BillingMeterCollection"]: + """Gets a list of meters for a given location. + + Description for Gets a list of meters for a given location. + + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param os_type: App Service OS type meters used for. + :type os_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BillingMeterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_billing_meters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if billing_location is not None: + query_parameters['billingLocation'] = self._serialize.query("billing_location", billing_location, 'str') + if os_type is not None: + query_parameters['osType'] = self._serialize.query("os_type", os_type, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('BillingMeterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_billing_meters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/billingMeters'} # type: ignore + + async def check_name_availability( + self, + name: str, + type: Union[str, "_models.CheckNameResourceTypes"], + is_fqdn: Optional[bool] = None, + **kwargs + ) -> "_models.ResourceNameAvailability": + """Check if a resource name is available. + + Description for Check if a resource name is available. + + :param name: Resource name to verify. + :type name: str + :param type: Resource type used for verification. + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNameAvailability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNameAvailability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.ResourceNameAvailabilityRequest(name=name, type=type, is_fqdn=is_fqdn) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_name_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'ResourceNameAvailabilityRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceNameAvailability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/checknameavailability'} # type: ignore + + async def get_subscription_deployment_locations( + self, + **kwargs + ) -> "_models.DeploymentLocations": + """Gets list of available geo regions plus ministamps. + + Description for Gets list of available geo regions plus ministamps. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentLocations, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentLocations"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_subscription_deployment_locations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentLocations', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_subscription_deployment_locations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deploymentLocations'} # type: ignore + + def list_geo_regions( + self, + sku: Optional[Union[str, "_models.SkuName"]] = None, + linux_workers_enabled: Optional[bool] = None, + xenon_workers_enabled: Optional[bool] = None, + linux_dynamic_workers_enabled: Optional[bool] = None, + **kwargs + ) -> AsyncIterable["_models.GeoRegionCollection"]: + """Get a list of available geographical regions. + + Description for Get a list of available geographical regions. + + :param sku: Name of SKU used to filter the regions. + :type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName + :param linux_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Linux workers. + :type linux_workers_enabled: bool + :param xenon_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Xenon workers. + :type xenon_workers_enabled: bool + :param linux_dynamic_workers_enabled: Specify :code:`true` if you want to filter + to only regions that support Linux Consumption Workers. + :type linux_dynamic_workers_enabled: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GeoRegionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_geo_regions.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if sku is not None: + query_parameters['sku'] = self._serialize.query("sku", sku, 'str') + if linux_workers_enabled is not None: + query_parameters['linuxWorkersEnabled'] = self._serialize.query("linux_workers_enabled", linux_workers_enabled, 'bool') + if xenon_workers_enabled is not None: + query_parameters['xenonWorkersEnabled'] = self._serialize.query("xenon_workers_enabled", xenon_workers_enabled, 'bool') + if linux_dynamic_workers_enabled is not None: + query_parameters['linuxDynamicWorkersEnabled'] = self._serialize.query("linux_dynamic_workers_enabled", linux_dynamic_workers_enabled, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('GeoRegionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_geo_regions.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/geoRegions'} # type: ignore + + def list_site_identifiers_assigned_to_host_name( + self, + name_identifier: "_models.NameIdentifier", + **kwargs + ) -> AsyncIterable["_models.IdentifierCollection"]: + """List all apps that are assigned to a hostname. + + Description for List all apps that are assigned to a hostname. + + :param name_identifier: Hostname information. + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_identifiers_assigned_to_host_name.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_site_identifiers_assigned_to_host_name.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/listSitesAssignedToHostName'} # type: ignore + + def list_premier_add_on_offers( + self, + **kwargs + ) -> AsyncIterable["_models.PremierAddOnOfferCollection"]: + """List all premier add-on offers. + + Description for List all premier add-on offers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOnOfferCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_premier_add_on_offers.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PremierAddOnOfferCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_premier_add_on_offers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/premieraddonoffers'} # type: ignore + + async def list_skus( + self, + **kwargs + ) -> "_models.SkuInfos": + """List all SKUs. + + Description for List all SKUs. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SkuInfos, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfos"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SkuInfos', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_skus.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/skus'} # type: ignore + + async def verify_hosting_environment_vnet( + self, + parameters: "_models.VnetParameters", + **kwargs + ) -> "_models.VnetValidationFailureDetails": + """Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules. + + Description for Verifies if this VNET is compatible with an App Service Environment by + analyzing the Network Security Group rules. + + :param parameters: VNET information. + :type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetValidationFailureDetails, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetValidationFailureDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.verify_hosting_environment_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'VnetParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetValidationFailureDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + verify_hosting_environment_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/verifyHostingEnvironmentVnet'} # type: ignore + + async def move( + self, + resource_group_name: str, + move_resource_envelope: "_models.CsmMoveResourceEnvelope", + **kwargs + ) -> None: + """Move resources between resource groups. + + Description for Move resources between resource groups. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/moveResources'} # type: ignore + + async def validate( + self, + resource_group_name: str, + validate_request: "_models.ValidateRequest", + **kwargs + ) -> "_models.ValidateResponse": + """Validate if a resource can be created. + + Description for Validate if a resource can be created. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param validate_request: Request with the resources to validate. + :type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ValidateResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ValidateResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(validate_request, 'ValidateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ValidateResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/validate'} # type: ignore + + async def validate_move( + self, + resource_group_name: str, + move_resource_envelope: "_models.CsmMoveResourceEnvelope", + **kwargs + ) -> None: + """Validate whether a resource can be moved. + + Description for Validate whether a resource can be moved. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/validateMoveResources'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/__init__.py new file mode 100644 index 000000000000..0bb56e63d805 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/__init__.py @@ -0,0 +1,1210 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import AbnormalTimePeriod + from ._models_py3 import Address + from ._models_py3 import AddressResponse + from ._models_py3 import AllowedAudiencesValidation + from ._models_py3 import AnalysisData + from ._models_py3 import AnalysisDefinition + from ._models_py3 import ApiDefinitionInfo + from ._models_py3 import ApiManagementConfig + from ._models_py3 import AppRegistration + from ._models_py3 import AppServiceCertificate + from ._models_py3 import AppServiceCertificateCollection + from ._models_py3 import AppServiceCertificateOrder + from ._models_py3 import AppServiceCertificateOrderCollection + from ._models_py3 import AppServiceCertificateOrderPatchResource + from ._models_py3 import AppServiceCertificatePatchResource + from ._models_py3 import AppServiceCertificateResource + from ._models_py3 import AppServiceEnvironment + from ._models_py3 import AppServiceEnvironmentCollection + from ._models_py3 import AppServiceEnvironmentPatchResource + from ._models_py3 import AppServiceEnvironmentResource + from ._models_py3 import AppServicePlan + from ._models_py3 import AppServicePlanCollection + from ._models_py3 import AppServicePlanPatchResource + from ._models_py3 import ApplicationLogsConfig + from ._models_py3 import ApplicationStack + from ._models_py3 import ApplicationStackCollection + from ._models_py3 import ApplicationStackResource + from ._models_py3 import AppserviceGithubToken + from ._models_py3 import AppserviceGithubTokenRequest + from ._models_py3 import ArmIdWrapper + from ._models_py3 import AuthPlatform + from ._models_py3 import AutoHealActions + from ._models_py3 import AutoHealCustomAction + from ._models_py3 import AutoHealRules + from ._models_py3 import AutoHealTriggers + from ._models_py3 import AzureActiveDirectory + from ._models_py3 import AzureActiveDirectoryLogin + from ._models_py3 import AzureActiveDirectoryRegistration + from ._models_py3 import AzureActiveDirectoryValidation + from ._models_py3 import AzureBlobStorageApplicationLogsConfig + from ._models_py3 import AzureBlobStorageHttpLogsConfig + from ._models_py3 import AzureStorageInfoValue + from ._models_py3 import AzureStoragePropertyDictionaryResource + from ._models_py3 import AzureTableStorageApplicationLogsConfig + from ._models_py3 import BackupItem + from ._models_py3 import BackupItemCollection + from ._models_py3 import BackupRequest + from ._models_py3 import BackupSchedule + from ._models_py3 import BillingMeter + from ._models_py3 import BillingMeterCollection + from ._models_py3 import BlobStorageTokenStore + from ._models_py3 import Capability + from ._models_py3 import Certificate + from ._models_py3 import CertificateCollection + from ._models_py3 import CertificateDetails + from ._models_py3 import CertificateEmail + from ._models_py3 import CertificateOrderAction + from ._models_py3 import CertificatePatchResource + from ._models_py3 import ClientRegistration + from ._models_py3 import CloningInfo + from ._models_py3 import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties + from ._models_py3 import ConnStringInfo + from ._models_py3 import ConnStringValueTypePair + from ._models_py3 import ConnectionStringDictionary + from ._models_py3 import Contact + from ._models_py3 import ContainerCpuStatistics + from ._models_py3 import ContainerCpuUsage + from ._models_py3 import ContainerInfo + from ._models_py3 import ContainerMemoryStatistics + from ._models_py3 import ContainerNetworkInterfaceStatistics + from ._models_py3 import ContainerThrottlingData + from ._models_py3 import ContinuousWebJob + from ._models_py3 import ContinuousWebJobCollection + from ._models_py3 import CookieExpiration + from ._models_py3 import CorsSettings + from ._models_py3 import CsmCopySlotEntity + from ._models_py3 import CsmMoveResourceEnvelope + from ._models_py3 import CsmOperationCollection + from ._models_py3 import CsmOperationDescription + from ._models_py3 import CsmOperationDescriptionProperties + from ._models_py3 import CsmOperationDisplay + from ._models_py3 import CsmPublishingCredentialsPoliciesCollection + from ._models_py3 import CsmPublishingCredentialsPoliciesEntity + from ._models_py3 import CsmPublishingProfileOptions + from ._models_py3 import CsmSlotEntity + from ._models_py3 import CsmUsageQuota + from ._models_py3 import CsmUsageQuotaCollection + from ._models_py3 import CustomHostnameAnalysisResult + from ._models_py3 import CustomOpenIdConnectProvider + from ._models_py3 import DataSource + from ._models_py3 import DataTableResponseColumn + from ._models_py3 import DataTableResponseObject + from ._models_py3 import DatabaseBackupSetting + from ._models_py3 import DefaultErrorResponse + from ._models_py3 import DefaultErrorResponseError + from ._models_py3 import DefaultErrorResponseErrorDetailsItem + from ._models_py3 import DeletedAppRestoreRequest + from ._models_py3 import DeletedSite + from ._models_py3 import DeletedWebAppCollection + from ._models_py3 import Deployment + from ._models_py3 import DeploymentCollection + from ._models_py3 import DeploymentLocations + from ._models_py3 import DetectorAbnormalTimePeriod + from ._models_py3 import DetectorDefinition + from ._models_py3 import DetectorInfo + from ._models_py3 import DetectorResponse + from ._models_py3 import DetectorResponseCollection + from ._models_py3 import DiagnosticAnalysis + from ._models_py3 import DiagnosticAnalysisCollection + from ._models_py3 import DiagnosticCategory + from ._models_py3 import DiagnosticCategoryCollection + from ._models_py3 import DiagnosticData + from ._models_py3 import DiagnosticDetectorCollection + from ._models_py3 import DiagnosticDetectorResponse + from ._models_py3 import DiagnosticMetricSample + from ._models_py3 import DiagnosticMetricSet + from ._models_py3 import Dimension + from ._models_py3 import Domain + from ._models_py3 import DomainAvailabilityCheckResult + from ._models_py3 import DomainCollection + from ._models_py3 import DomainControlCenterSsoRequest + from ._models_py3 import DomainOwnershipIdentifier + from ._models_py3 import DomainOwnershipIdentifierCollection + from ._models_py3 import DomainPatchResource + from ._models_py3 import DomainPurchaseConsent + from ._models_py3 import DomainRecommendationSearchParameters + from ._models_py3 import EnabledConfig + from ._models_py3 import EndpointDependency + from ._models_py3 import EndpointDetail + from ._models_py3 import ErrorEntity + from ._models_py3 import Experiments + from ._models_py3 import Facebook + from ._models_py3 import FileSystemApplicationLogsConfig + from ._models_py3 import FileSystemHttpLogsConfig + from ._models_py3 import FileSystemTokenStore + from ._models_py3 import ForwardProxy + from ._models_py3 import FunctionEnvelope + from ._models_py3 import FunctionEnvelopeCollection + from ._models_py3 import FunctionSecrets + from ._models_py3 import GeoRegion + from ._models_py3 import GeoRegionCollection + from ._models_py3 import GitHub + from ._models_py3 import GlobalCsmSkuDescription + from ._models_py3 import GlobalValidation + from ._models_py3 import Google + from ._models_py3 import HandlerMapping + from ._models_py3 import HostKeys + from ._models_py3 import HostName + from ._models_py3 import HostNameBinding + from ._models_py3 import HostNameBindingCollection + from ._models_py3 import HostNameSslState + from ._models_py3 import HostingEnvironmentDeploymentInfo + from ._models_py3 import HostingEnvironmentDiagnostics + from ._models_py3 import HostingEnvironmentProfile + from ._models_py3 import HttpLogsConfig + from ._models_py3 import HttpSettings + from ._models_py3 import HttpSettingsRoutes + from ._models_py3 import HybridConnection + from ._models_py3 import HybridConnectionCollection + from ._models_py3 import HybridConnectionKey + from ._models_py3 import HybridConnectionLimits + from ._models_py3 import Identifier + from ._models_py3 import IdentifierCollection + from ._models_py3 import IdentityProviders + from ._models_py3 import InboundEnvironmentEndpoint + from ._models_py3 import InboundEnvironmentEndpointCollection + from ._models_py3 import IpSecurityRestriction + from ._models_py3 import JwtClaimChecks + from ._models_py3 import KeyInfo + from ._models_py3 import LocalizableString + from ._models_py3 import LogSpecification + from ._models_py3 import Login + from ._models_py3 import LoginRoutes + from ._models_py3 import LoginScopes + from ._models_py3 import MSDeploy + from ._models_py3 import MSDeployLog + from ._models_py3 import MSDeployLogEntry + from ._models_py3 import MSDeployStatus + from ._models_py3 import ManagedServiceIdentity + from ._models_py3 import MetricAvailability + from ._models_py3 import MetricSpecification + from ._models_py3 import MigrateMySqlRequest + from ._models_py3 import MigrateMySqlStatus + from ._models_py3 import NameIdentifier + from ._models_py3 import NameIdentifierCollection + from ._models_py3 import NameValuePair + from ._models_py3 import NetworkAccessControlEntry + from ._models_py3 import NetworkFeatures + from ._models_py3 import NetworkTrace + from ._models_py3 import Nonce + from ._models_py3 import OpenIdConnectClientCredential + from ._models_py3 import OpenIdConnectConfig + from ._models_py3 import OpenIdConnectLogin + from ._models_py3 import OpenIdConnectRegistration + from ._models_py3 import Operation + from ._models_py3 import OutboundEnvironmentEndpoint + from ._models_py3 import OutboundEnvironmentEndpointCollection + from ._models_py3 import PerfMonCounterCollection + from ._models_py3 import PerfMonResponse + from ._models_py3 import PerfMonSample + from ._models_py3 import PerfMonSet + from ._models_py3 import PremierAddOn + from ._models_py3 import PremierAddOnOffer + from ._models_py3 import PremierAddOnOfferCollection + from ._models_py3 import PremierAddOnPatchResource + from ._models_py3 import PrivateAccess + from ._models_py3 import PrivateAccessSubnet + from ._models_py3 import PrivateAccessVirtualNetwork + from ._models_py3 import PrivateEndpointConnectionResource + from ._models_py3 import PrivateLinkConnectionApprovalRequestResource + from ._models_py3 import PrivateLinkConnectionState + from ._models_py3 import PrivateLinkResource + from ._models_py3 import PrivateLinkResourceProperties + from ._models_py3 import PrivateLinkResourcesWrapper + from ._models_py3 import ProcessInfo + from ._models_py3 import ProcessInfoCollection + from ._models_py3 import ProcessModuleInfo + from ._models_py3 import ProcessModuleInfoCollection + from ._models_py3 import ProcessThreadInfo + from ._models_py3 import ProcessThreadInfoCollection + from ._models_py3 import ProxyOnlyResource + from ._models_py3 import PublicCertificate + from ._models_py3 import PublicCertificateCollection + from ._models_py3 import PushSettings + from ._models_py3 import RampUpRule + from ._models_py3 import Recommendation + from ._models_py3 import RecommendationCollection + from ._models_py3 import RecommendationRule + from ._models_py3 import ReissueCertificateOrderRequest + from ._models_py3 import RelayServiceConnectionEntity + from ._models_py3 import Rendering + from ._models_py3 import RenewCertificateOrderRequest + from ._models_py3 import RequestsBasedTrigger + from ._models_py3 import Resource + from ._models_py3 import ResourceCollection + from ._models_py3 import ResourceHealthMetadata + from ._models_py3 import ResourceHealthMetadataCollection + from ._models_py3 import ResourceMetricAvailability + from ._models_py3 import ResourceMetricDefinition + from ._models_py3 import ResourceMetricDefinitionCollection + from ._models_py3 import ResourceNameAvailability + from ._models_py3 import ResourceNameAvailabilityRequest + from ._models_py3 import ResponseMetaData + from ._models_py3 import RestoreRequest + from ._models_py3 import ServiceSpecification + from ._models_py3 import Site + from ._models_py3 import SiteAuthSettings + from ._models_py3 import SiteAuthSettingsV2 + from ._models_py3 import SiteCloneability + from ._models_py3 import SiteCloneabilityCriterion + from ._models_py3 import SiteConfig + from ._models_py3 import SiteConfigResource + from ._models_py3 import SiteConfigResourceCollection + from ._models_py3 import SiteConfigurationSnapshotInfo + from ._models_py3 import SiteConfigurationSnapshotInfoCollection + from ._models_py3 import SiteExtensionInfo + from ._models_py3 import SiteExtensionInfoCollection + from ._models_py3 import SiteLimits + from ._models_py3 import SiteLogsConfig + from ._models_py3 import SiteMachineKey + from ._models_py3 import SitePatchResource + from ._models_py3 import SitePhpErrorLogFlag + from ._models_py3 import SiteSeal + from ._models_py3 import SiteSealRequest + from ._models_py3 import SiteSourceControl + from ._models_py3 import SkuCapacity + from ._models_py3 import SkuDescription + from ._models_py3 import SkuInfo + from ._models_py3 import SkuInfoCollection + from ._models_py3 import SkuInfos + from ._models_py3 import SlotConfigNamesResource + from ._models_py3 import SlotDifference + from ._models_py3 import SlotDifferenceCollection + from ._models_py3 import SlotSwapStatus + from ._models_py3 import SlowRequestsBasedTrigger + from ._models_py3 import Snapshot + from ._models_py3 import SnapshotCollection + from ._models_py3 import SnapshotRecoverySource + from ._models_py3 import SnapshotRestoreRequest + from ._models_py3 import Solution + from ._models_py3 import SourceControl + from ._models_py3 import SourceControlCollection + from ._models_py3 import StackMajorVersion + from ._models_py3 import StackMinorVersion + from ._models_py3 import StampCapacity + from ._models_py3 import StampCapacityCollection + from ._models_py3 import StaticSiteARMResource + from ._models_py3 import StaticSiteBuildARMResource + from ._models_py3 import StaticSiteBuildCollection + from ._models_py3 import StaticSiteBuildProperties + from ._models_py3 import StaticSiteCollection + from ._models_py3 import StaticSiteCustomDomainOverviewARMResource + from ._models_py3 import StaticSiteCustomDomainOverviewCollection + from ._models_py3 import StaticSiteFunctionOverviewARMResource + from ._models_py3 import StaticSiteFunctionOverviewCollection + from ._models_py3 import StaticSitePatchResource + from ._models_py3 import StaticSiteResetPropertiesARMResource + from ._models_py3 import StaticSiteUserARMResource + from ._models_py3 import StaticSiteUserCollection + from ._models_py3 import StaticSiteUserInvitationRequestResource + from ._models_py3 import StaticSiteUserInvitationResponseResource + from ._models_py3 import StaticSitesWorkflowPreview + from ._models_py3 import StaticSitesWorkflowPreviewRequest + from ._models_py3 import StatusCodesBasedTrigger + from ._models_py3 import StorageMigrationOptions + from ._models_py3 import StorageMigrationResponse + from ._models_py3 import StringDictionary + from ._models_py3 import SwiftVirtualNetwork + from ._models_py3 import SystemData + from ._models_py3 import TldLegalAgreement + from ._models_py3 import TldLegalAgreementCollection + from ._models_py3 import TokenStore + from ._models_py3 import TopLevelDomain + from ._models_py3 import TopLevelDomainAgreementOption + from ._models_py3 import TopLevelDomainCollection + from ._models_py3 import TriggeredJobHistory + from ._models_py3 import TriggeredJobHistoryCollection + from ._models_py3 import TriggeredJobRun + from ._models_py3 import TriggeredWebJob + from ._models_py3 import TriggeredWebJobCollection + from ._models_py3 import Twitter + from ._models_py3 import TwitterRegistration + from ._models_py3 import Usage + from ._models_py3 import UsageCollection + from ._models_py3 import User + from ._models_py3 import ValidateRequest + from ._models_py3 import ValidateResponse + from ._models_py3 import ValidateResponseError + from ._models_py3 import VirtualApplication + from ._models_py3 import VirtualDirectory + from ._models_py3 import VirtualIPMapping + from ._models_py3 import VirtualNetworkProfile + from ._models_py3 import VnetGateway + from ._models_py3 import VnetInfo + from ._models_py3 import VnetParameters + from ._models_py3 import VnetRoute + from ._models_py3 import VnetValidationFailureDetails + from ._models_py3 import VnetValidationTestFailure + from ._models_py3 import WebAppCollection + from ._models_py3 import WebAppInstanceStatusCollection + from ._models_py3 import WebJob + from ._models_py3 import WebJobCollection + from ._models_py3 import WebSiteInstanceStatus + from ._models_py3 import WorkerPool + from ._models_py3 import WorkerPoolCollection + from ._models_py3 import WorkerPoolResource +except (SyntaxError, ImportError): + from ._models import AbnormalTimePeriod # type: ignore + from ._models import Address # type: ignore + from ._models import AddressResponse # type: ignore + from ._models import AllowedAudiencesValidation # type: ignore + from ._models import AnalysisData # type: ignore + from ._models import AnalysisDefinition # type: ignore + from ._models import ApiDefinitionInfo # type: ignore + from ._models import ApiManagementConfig # type: ignore + from ._models import AppRegistration # type: ignore + from ._models import AppServiceCertificate # type: ignore + from ._models import AppServiceCertificateCollection # type: ignore + from ._models import AppServiceCertificateOrder # type: ignore + from ._models import AppServiceCertificateOrderCollection # type: ignore + from ._models import AppServiceCertificateOrderPatchResource # type: ignore + from ._models import AppServiceCertificatePatchResource # type: ignore + from ._models import AppServiceCertificateResource # type: ignore + from ._models import AppServiceEnvironment # type: ignore + from ._models import AppServiceEnvironmentCollection # type: ignore + from ._models import AppServiceEnvironmentPatchResource # type: ignore + from ._models import AppServiceEnvironmentResource # type: ignore + from ._models import AppServicePlan # type: ignore + from ._models import AppServicePlanCollection # type: ignore + from ._models import AppServicePlanPatchResource # type: ignore + from ._models import ApplicationLogsConfig # type: ignore + from ._models import ApplicationStack # type: ignore + from ._models import ApplicationStackCollection # type: ignore + from ._models import ApplicationStackResource # type: ignore + from ._models import AppserviceGithubToken # type: ignore + from ._models import AppserviceGithubTokenRequest # type: ignore + from ._models import ArmIdWrapper # type: ignore + from ._models import AuthPlatform # type: ignore + from ._models import AutoHealActions # type: ignore + from ._models import AutoHealCustomAction # type: ignore + from ._models import AutoHealRules # type: ignore + from ._models import AutoHealTriggers # type: ignore + from ._models import AzureActiveDirectory # type: ignore + from ._models import AzureActiveDirectoryLogin # type: ignore + from ._models import AzureActiveDirectoryRegistration # type: ignore + from ._models import AzureActiveDirectoryValidation # type: ignore + from ._models import AzureBlobStorageApplicationLogsConfig # type: ignore + from ._models import AzureBlobStorageHttpLogsConfig # type: ignore + from ._models import AzureStorageInfoValue # type: ignore + from ._models import AzureStoragePropertyDictionaryResource # type: ignore + from ._models import AzureTableStorageApplicationLogsConfig # type: ignore + from ._models import BackupItem # type: ignore + from ._models import BackupItemCollection # type: ignore + from ._models import BackupRequest # type: ignore + from ._models import BackupSchedule # type: ignore + from ._models import BillingMeter # type: ignore + from ._models import BillingMeterCollection # type: ignore + from ._models import BlobStorageTokenStore # type: ignore + from ._models import Capability # type: ignore + from ._models import Certificate # type: ignore + from ._models import CertificateCollection # type: ignore + from ._models import CertificateDetails # type: ignore + from ._models import CertificateEmail # type: ignore + from ._models import CertificateOrderAction # type: ignore + from ._models import CertificatePatchResource # type: ignore + from ._models import ClientRegistration # type: ignore + from ._models import CloningInfo # type: ignore + from ._models import Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties # type: ignore + from ._models import ConnStringInfo # type: ignore + from ._models import ConnStringValueTypePair # type: ignore + from ._models import ConnectionStringDictionary # type: ignore + from ._models import Contact # type: ignore + from ._models import ContainerCpuStatistics # type: ignore + from ._models import ContainerCpuUsage # type: ignore + from ._models import ContainerInfo # type: ignore + from ._models import ContainerMemoryStatistics # type: ignore + from ._models import ContainerNetworkInterfaceStatistics # type: ignore + from ._models import ContainerThrottlingData # type: ignore + from ._models import ContinuousWebJob # type: ignore + from ._models import ContinuousWebJobCollection # type: ignore + from ._models import CookieExpiration # type: ignore + from ._models import CorsSettings # type: ignore + from ._models import CsmCopySlotEntity # type: ignore + from ._models import CsmMoveResourceEnvelope # type: ignore + from ._models import CsmOperationCollection # type: ignore + from ._models import CsmOperationDescription # type: ignore + from ._models import CsmOperationDescriptionProperties # type: ignore + from ._models import CsmOperationDisplay # type: ignore + from ._models import CsmPublishingCredentialsPoliciesCollection # type: ignore + from ._models import CsmPublishingCredentialsPoliciesEntity # type: ignore + from ._models import CsmPublishingProfileOptions # type: ignore + from ._models import CsmSlotEntity # type: ignore + from ._models import CsmUsageQuota # type: ignore + from ._models import CsmUsageQuotaCollection # type: ignore + from ._models import CustomHostnameAnalysisResult # type: ignore + from ._models import CustomOpenIdConnectProvider # type: ignore + from ._models import DataSource # type: ignore + from ._models import DataTableResponseColumn # type: ignore + from ._models import DataTableResponseObject # type: ignore + from ._models import DatabaseBackupSetting # type: ignore + from ._models import DefaultErrorResponse # type: ignore + from ._models import DefaultErrorResponseError # type: ignore + from ._models import DefaultErrorResponseErrorDetailsItem # type: ignore + from ._models import DeletedAppRestoreRequest # type: ignore + from ._models import DeletedSite # type: ignore + from ._models import DeletedWebAppCollection # type: ignore + from ._models import Deployment # type: ignore + from ._models import DeploymentCollection # type: ignore + from ._models import DeploymentLocations # type: ignore + from ._models import DetectorAbnormalTimePeriod # type: ignore + from ._models import DetectorDefinition # type: ignore + from ._models import DetectorInfo # type: ignore + from ._models import DetectorResponse # type: ignore + from ._models import DetectorResponseCollection # type: ignore + from ._models import DiagnosticAnalysis # type: ignore + from ._models import DiagnosticAnalysisCollection # type: ignore + from ._models import DiagnosticCategory # type: ignore + from ._models import DiagnosticCategoryCollection # type: ignore + from ._models import DiagnosticData # type: ignore + from ._models import DiagnosticDetectorCollection # type: ignore + from ._models import DiagnosticDetectorResponse # type: ignore + from ._models import DiagnosticMetricSample # type: ignore + from ._models import DiagnosticMetricSet # type: ignore + from ._models import Dimension # type: ignore + from ._models import Domain # type: ignore + from ._models import DomainAvailabilityCheckResult # type: ignore + from ._models import DomainCollection # type: ignore + from ._models import DomainControlCenterSsoRequest # type: ignore + from ._models import DomainOwnershipIdentifier # type: ignore + from ._models import DomainOwnershipIdentifierCollection # type: ignore + from ._models import DomainPatchResource # type: ignore + from ._models import DomainPurchaseConsent # type: ignore + from ._models import DomainRecommendationSearchParameters # type: ignore + from ._models import EnabledConfig # type: ignore + from ._models import EndpointDependency # type: ignore + from ._models import EndpointDetail # type: ignore + from ._models import ErrorEntity # type: ignore + from ._models import Experiments # type: ignore + from ._models import Facebook # type: ignore + from ._models import FileSystemApplicationLogsConfig # type: ignore + from ._models import FileSystemHttpLogsConfig # type: ignore + from ._models import FileSystemTokenStore # type: ignore + from ._models import ForwardProxy # type: ignore + from ._models import FunctionEnvelope # type: ignore + from ._models import FunctionEnvelopeCollection # type: ignore + from ._models import FunctionSecrets # type: ignore + from ._models import GeoRegion # type: ignore + from ._models import GeoRegionCollection # type: ignore + from ._models import GitHub # type: ignore + from ._models import GlobalCsmSkuDescription # type: ignore + from ._models import GlobalValidation # type: ignore + from ._models import Google # type: ignore + from ._models import HandlerMapping # type: ignore + from ._models import HostKeys # type: ignore + from ._models import HostName # type: ignore + from ._models import HostNameBinding # type: ignore + from ._models import HostNameBindingCollection # type: ignore + from ._models import HostNameSslState # type: ignore + from ._models import HostingEnvironmentDeploymentInfo # type: ignore + from ._models import HostingEnvironmentDiagnostics # type: ignore + from ._models import HostingEnvironmentProfile # type: ignore + from ._models import HttpLogsConfig # type: ignore + from ._models import HttpSettings # type: ignore + from ._models import HttpSettingsRoutes # type: ignore + from ._models import HybridConnection # type: ignore + from ._models import HybridConnectionCollection # type: ignore + from ._models import HybridConnectionKey # type: ignore + from ._models import HybridConnectionLimits # type: ignore + from ._models import Identifier # type: ignore + from ._models import IdentifierCollection # type: ignore + from ._models import IdentityProviders # type: ignore + from ._models import InboundEnvironmentEndpoint # type: ignore + from ._models import InboundEnvironmentEndpointCollection # type: ignore + from ._models import IpSecurityRestriction # type: ignore + from ._models import JwtClaimChecks # type: ignore + from ._models import KeyInfo # type: ignore + from ._models import LocalizableString # type: ignore + from ._models import LogSpecification # type: ignore + from ._models import Login # type: ignore + from ._models import LoginRoutes # type: ignore + from ._models import LoginScopes # type: ignore + from ._models import MSDeploy # type: ignore + from ._models import MSDeployLog # type: ignore + from ._models import MSDeployLogEntry # type: ignore + from ._models import MSDeployStatus # type: ignore + from ._models import ManagedServiceIdentity # type: ignore + from ._models import MetricAvailability # type: ignore + from ._models import MetricSpecification # type: ignore + from ._models import MigrateMySqlRequest # type: ignore + from ._models import MigrateMySqlStatus # type: ignore + from ._models import NameIdentifier # type: ignore + from ._models import NameIdentifierCollection # type: ignore + from ._models import NameValuePair # type: ignore + from ._models import NetworkAccessControlEntry # type: ignore + from ._models import NetworkFeatures # type: ignore + from ._models import NetworkTrace # type: ignore + from ._models import Nonce # type: ignore + from ._models import OpenIdConnectClientCredential # type: ignore + from ._models import OpenIdConnectConfig # type: ignore + from ._models import OpenIdConnectLogin # type: ignore + from ._models import OpenIdConnectRegistration # type: ignore + from ._models import Operation # type: ignore + from ._models import OutboundEnvironmentEndpoint # type: ignore + from ._models import OutboundEnvironmentEndpointCollection # type: ignore + from ._models import PerfMonCounterCollection # type: ignore + from ._models import PerfMonResponse # type: ignore + from ._models import PerfMonSample # type: ignore + from ._models import PerfMonSet # type: ignore + from ._models import PremierAddOn # type: ignore + from ._models import PremierAddOnOffer # type: ignore + from ._models import PremierAddOnOfferCollection # type: ignore + from ._models import PremierAddOnPatchResource # type: ignore + from ._models import PrivateAccess # type: ignore + from ._models import PrivateAccessSubnet # type: ignore + from ._models import PrivateAccessVirtualNetwork # type: ignore + from ._models import PrivateEndpointConnectionResource # type: ignore + from ._models import PrivateLinkConnectionApprovalRequestResource # type: ignore + from ._models import PrivateLinkConnectionState # type: ignore + from ._models import PrivateLinkResource # type: ignore + from ._models import PrivateLinkResourceProperties # type: ignore + from ._models import PrivateLinkResourcesWrapper # type: ignore + from ._models import ProcessInfo # type: ignore + from ._models import ProcessInfoCollection # type: ignore + from ._models import ProcessModuleInfo # type: ignore + from ._models import ProcessModuleInfoCollection # type: ignore + from ._models import ProcessThreadInfo # type: ignore + from ._models import ProcessThreadInfoCollection # type: ignore + from ._models import ProxyOnlyResource # type: ignore + from ._models import PublicCertificate # type: ignore + from ._models import PublicCertificateCollection # type: ignore + from ._models import PushSettings # type: ignore + from ._models import RampUpRule # type: ignore + from ._models import Recommendation # type: ignore + from ._models import RecommendationCollection # type: ignore + from ._models import RecommendationRule # type: ignore + from ._models import ReissueCertificateOrderRequest # type: ignore + from ._models import RelayServiceConnectionEntity # type: ignore + from ._models import Rendering # type: ignore + from ._models import RenewCertificateOrderRequest # type: ignore + from ._models import RequestsBasedTrigger # type: ignore + from ._models import Resource # type: ignore + from ._models import ResourceCollection # type: ignore + from ._models import ResourceHealthMetadata # type: ignore + from ._models import ResourceHealthMetadataCollection # type: ignore + from ._models import ResourceMetricAvailability # type: ignore + from ._models import ResourceMetricDefinition # type: ignore + from ._models import ResourceMetricDefinitionCollection # type: ignore + from ._models import ResourceNameAvailability # type: ignore + from ._models import ResourceNameAvailabilityRequest # type: ignore + from ._models import ResponseMetaData # type: ignore + from ._models import RestoreRequest # type: ignore + from ._models import ServiceSpecification # type: ignore + from ._models import Site # type: ignore + from ._models import SiteAuthSettings # type: ignore + from ._models import SiteAuthSettingsV2 # type: ignore + from ._models import SiteCloneability # type: ignore + from ._models import SiteCloneabilityCriterion # type: ignore + from ._models import SiteConfig # type: ignore + from ._models import SiteConfigResource # type: ignore + from ._models import SiteConfigResourceCollection # type: ignore + from ._models import SiteConfigurationSnapshotInfo # type: ignore + from ._models import SiteConfigurationSnapshotInfoCollection # type: ignore + from ._models import SiteExtensionInfo # type: ignore + from ._models import SiteExtensionInfoCollection # type: ignore + from ._models import SiteLimits # type: ignore + from ._models import SiteLogsConfig # type: ignore + from ._models import SiteMachineKey # type: ignore + from ._models import SitePatchResource # type: ignore + from ._models import SitePhpErrorLogFlag # type: ignore + from ._models import SiteSeal # type: ignore + from ._models import SiteSealRequest # type: ignore + from ._models import SiteSourceControl # type: ignore + from ._models import SkuCapacity # type: ignore + from ._models import SkuDescription # type: ignore + from ._models import SkuInfo # type: ignore + from ._models import SkuInfoCollection # type: ignore + from ._models import SkuInfos # type: ignore + from ._models import SlotConfigNamesResource # type: ignore + from ._models import SlotDifference # type: ignore + from ._models import SlotDifferenceCollection # type: ignore + from ._models import SlotSwapStatus # type: ignore + from ._models import SlowRequestsBasedTrigger # type: ignore + from ._models import Snapshot # type: ignore + from ._models import SnapshotCollection # type: ignore + from ._models import SnapshotRecoverySource # type: ignore + from ._models import SnapshotRestoreRequest # type: ignore + from ._models import Solution # type: ignore + from ._models import SourceControl # type: ignore + from ._models import SourceControlCollection # type: ignore + from ._models import StackMajorVersion # type: ignore + from ._models import StackMinorVersion # type: ignore + from ._models import StampCapacity # type: ignore + from ._models import StampCapacityCollection # type: ignore + from ._models import StaticSiteARMResource # type: ignore + from ._models import StaticSiteBuildARMResource # type: ignore + from ._models import StaticSiteBuildCollection # type: ignore + from ._models import StaticSiteBuildProperties # type: ignore + from ._models import StaticSiteCollection # type: ignore + from ._models import StaticSiteCustomDomainOverviewARMResource # type: ignore + from ._models import StaticSiteCustomDomainOverviewCollection # type: ignore + from ._models import StaticSiteFunctionOverviewARMResource # type: ignore + from ._models import StaticSiteFunctionOverviewCollection # type: ignore + from ._models import StaticSitePatchResource # type: ignore + from ._models import StaticSiteResetPropertiesARMResource # type: ignore + from ._models import StaticSiteUserARMResource # type: ignore + from ._models import StaticSiteUserCollection # type: ignore + from ._models import StaticSiteUserInvitationRequestResource # type: ignore + from ._models import StaticSiteUserInvitationResponseResource # type: ignore + from ._models import StaticSitesWorkflowPreview # type: ignore + from ._models import StaticSitesWorkflowPreviewRequest # type: ignore + from ._models import StatusCodesBasedTrigger # type: ignore + from ._models import StorageMigrationOptions # type: ignore + from ._models import StorageMigrationResponse # type: ignore + from ._models import StringDictionary # type: ignore + from ._models import SwiftVirtualNetwork # type: ignore + from ._models import SystemData # type: ignore + from ._models import TldLegalAgreement # type: ignore + from ._models import TldLegalAgreementCollection # type: ignore + from ._models import TokenStore # type: ignore + from ._models import TopLevelDomain # type: ignore + from ._models import TopLevelDomainAgreementOption # type: ignore + from ._models import TopLevelDomainCollection # type: ignore + from ._models import TriggeredJobHistory # type: ignore + from ._models import TriggeredJobHistoryCollection # type: ignore + from ._models import TriggeredJobRun # type: ignore + from ._models import TriggeredWebJob # type: ignore + from ._models import TriggeredWebJobCollection # type: ignore + from ._models import Twitter # type: ignore + from ._models import TwitterRegistration # type: ignore + from ._models import Usage # type: ignore + from ._models import UsageCollection # type: ignore + from ._models import User # type: ignore + from ._models import ValidateRequest # type: ignore + from ._models import ValidateResponse # type: ignore + from ._models import ValidateResponseError # type: ignore + from ._models import VirtualApplication # type: ignore + from ._models import VirtualDirectory # type: ignore + from ._models import VirtualIPMapping # type: ignore + from ._models import VirtualNetworkProfile # type: ignore + from ._models import VnetGateway # type: ignore + from ._models import VnetInfo # type: ignore + from ._models import VnetParameters # type: ignore + from ._models import VnetRoute # type: ignore + from ._models import VnetValidationFailureDetails # type: ignore + from ._models import VnetValidationTestFailure # type: ignore + from ._models import WebAppCollection # type: ignore + from ._models import WebAppInstanceStatusCollection # type: ignore + from ._models import WebJob # type: ignore + from ._models import WebJobCollection # type: ignore + from ._models import WebSiteInstanceStatus # type: ignore + from ._models import WorkerPool # type: ignore + from ._models import WorkerPoolCollection # type: ignore + from ._models import WorkerPoolResource # type: ignore + +from ._web_site_management_client_enums import ( + AccessControlEntryAction, + AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem, + AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem, + AppServicePlanRestrictions, + AutoHealActionType, + AzureResourceType, + AzureStorageState, + AzureStorageType, + BackupItemStatus, + BackupRestoreOperationType, + BuildStatus, + BuiltInAuthenticationProvider, + CertificateOrderActionType, + CertificateOrderStatus, + CertificateProductType, + Channels, + CheckNameResourceTypes, + ClientCertMode, + CloneAbilityResult, + ComputeModeOptions, + ConnectionStringType, + ContinuousWebJobStatus, + CookieExpirationConvention, + CreatedByType, + CustomHostNameDnsRecordType, + DatabaseType, + DnsType, + DnsVerificationTestResult, + DomainPatchResourcePropertiesDomainNotRenewableReasonsItem, + DomainPropertiesDomainNotRenewableReasonsItem, + DomainStatus, + DomainType, + Enum5, + Enum6, + ForwardProxyConvention, + FrequencyUnit, + FtpsState, + HostNameType, + HostType, + HostingEnvironmentStatus, + InAvailabilityReasonType, + IpFilterTag, + IssueType, + KeyVaultSecretStatus, + LoadBalancingMode, + LogLevel, + MSDeployLogEntryType, + MSDeployProvisioningState, + ManagedPipelineMode, + ManagedServiceIdentityType, + MySqlMigrationType, + NotificationLevel, + OperationStatus, + ProvisioningState, + PublicCertificateLocation, + PublishingProfileFormat, + RedundancyMode, + RenderingType, + ResourceScopeType, + RouteType, + ScmType, + SiteAvailabilityState, + SiteExtensionType, + SiteLoadBalancing, + SiteRuntimeState, + SkuName, + SolutionType, + SslState, + StatusOptions, + SupportedTlsVersions, + TriggerTypes, + TriggeredWebJobStatus, + UnauthenticatedClientAction, + UnauthenticatedClientActionV2, + UsageState, + ValidateResourceTypes, + WebJobType, + WorkerSizeOptions, +) + +__all__ = [ + 'AbnormalTimePeriod', + 'Address', + 'AddressResponse', + 'AllowedAudiencesValidation', + 'AnalysisData', + 'AnalysisDefinition', + 'ApiDefinitionInfo', + 'ApiManagementConfig', + 'AppRegistration', + 'AppServiceCertificate', + 'AppServiceCertificateCollection', + 'AppServiceCertificateOrder', + 'AppServiceCertificateOrderCollection', + 'AppServiceCertificateOrderPatchResource', + 'AppServiceCertificatePatchResource', + 'AppServiceCertificateResource', + 'AppServiceEnvironment', + 'AppServiceEnvironmentCollection', + 'AppServiceEnvironmentPatchResource', + 'AppServiceEnvironmentResource', + 'AppServicePlan', + 'AppServicePlanCollection', + 'AppServicePlanPatchResource', + 'ApplicationLogsConfig', + 'ApplicationStack', + 'ApplicationStackCollection', + 'ApplicationStackResource', + 'AppserviceGithubToken', + 'AppserviceGithubTokenRequest', + 'ArmIdWrapper', + 'AuthPlatform', + 'AutoHealActions', + 'AutoHealCustomAction', + 'AutoHealRules', + 'AutoHealTriggers', + 'AzureActiveDirectory', + 'AzureActiveDirectoryLogin', + 'AzureActiveDirectoryRegistration', + 'AzureActiveDirectoryValidation', + 'AzureBlobStorageApplicationLogsConfig', + 'AzureBlobStorageHttpLogsConfig', + 'AzureStorageInfoValue', + 'AzureStoragePropertyDictionaryResource', + 'AzureTableStorageApplicationLogsConfig', + 'BackupItem', + 'BackupItemCollection', + 'BackupRequest', + 'BackupSchedule', + 'BillingMeter', + 'BillingMeterCollection', + 'BlobStorageTokenStore', + 'Capability', + 'Certificate', + 'CertificateCollection', + 'CertificateDetails', + 'CertificateEmail', + 'CertificateOrderAction', + 'CertificatePatchResource', + 'ClientRegistration', + 'CloningInfo', + 'Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties', + 'ConnStringInfo', + 'ConnStringValueTypePair', + 'ConnectionStringDictionary', + 'Contact', + 'ContainerCpuStatistics', + 'ContainerCpuUsage', + 'ContainerInfo', + 'ContainerMemoryStatistics', + 'ContainerNetworkInterfaceStatistics', + 'ContainerThrottlingData', + 'ContinuousWebJob', + 'ContinuousWebJobCollection', + 'CookieExpiration', + 'CorsSettings', + 'CsmCopySlotEntity', + 'CsmMoveResourceEnvelope', + 'CsmOperationCollection', + 'CsmOperationDescription', + 'CsmOperationDescriptionProperties', + 'CsmOperationDisplay', + 'CsmPublishingCredentialsPoliciesCollection', + 'CsmPublishingCredentialsPoliciesEntity', + 'CsmPublishingProfileOptions', + 'CsmSlotEntity', + 'CsmUsageQuota', + 'CsmUsageQuotaCollection', + 'CustomHostnameAnalysisResult', + 'CustomOpenIdConnectProvider', + 'DataSource', + 'DataTableResponseColumn', + 'DataTableResponseObject', + 'DatabaseBackupSetting', + 'DefaultErrorResponse', + 'DefaultErrorResponseError', + 'DefaultErrorResponseErrorDetailsItem', + 'DeletedAppRestoreRequest', + 'DeletedSite', + 'DeletedWebAppCollection', + 'Deployment', + 'DeploymentCollection', + 'DeploymentLocations', + 'DetectorAbnormalTimePeriod', + 'DetectorDefinition', + 'DetectorInfo', + 'DetectorResponse', + 'DetectorResponseCollection', + 'DiagnosticAnalysis', + 'DiagnosticAnalysisCollection', + 'DiagnosticCategory', + 'DiagnosticCategoryCollection', + 'DiagnosticData', + 'DiagnosticDetectorCollection', + 'DiagnosticDetectorResponse', + 'DiagnosticMetricSample', + 'DiagnosticMetricSet', + 'Dimension', + 'Domain', + 'DomainAvailabilityCheckResult', + 'DomainCollection', + 'DomainControlCenterSsoRequest', + 'DomainOwnershipIdentifier', + 'DomainOwnershipIdentifierCollection', + 'DomainPatchResource', + 'DomainPurchaseConsent', + 'DomainRecommendationSearchParameters', + 'EnabledConfig', + 'EndpointDependency', + 'EndpointDetail', + 'ErrorEntity', + 'Experiments', + 'Facebook', + 'FileSystemApplicationLogsConfig', + 'FileSystemHttpLogsConfig', + 'FileSystemTokenStore', + 'ForwardProxy', + 'FunctionEnvelope', + 'FunctionEnvelopeCollection', + 'FunctionSecrets', + 'GeoRegion', + 'GeoRegionCollection', + 'GitHub', + 'GlobalCsmSkuDescription', + 'GlobalValidation', + 'Google', + 'HandlerMapping', + 'HostKeys', + 'HostName', + 'HostNameBinding', + 'HostNameBindingCollection', + 'HostNameSslState', + 'HostingEnvironmentDeploymentInfo', + 'HostingEnvironmentDiagnostics', + 'HostingEnvironmentProfile', + 'HttpLogsConfig', + 'HttpSettings', + 'HttpSettingsRoutes', + 'HybridConnection', + 'HybridConnectionCollection', + 'HybridConnectionKey', + 'HybridConnectionLimits', + 'Identifier', + 'IdentifierCollection', + 'IdentityProviders', + 'InboundEnvironmentEndpoint', + 'InboundEnvironmentEndpointCollection', + 'IpSecurityRestriction', + 'JwtClaimChecks', + 'KeyInfo', + 'LocalizableString', + 'LogSpecification', + 'Login', + 'LoginRoutes', + 'LoginScopes', + 'MSDeploy', + 'MSDeployLog', + 'MSDeployLogEntry', + 'MSDeployStatus', + 'ManagedServiceIdentity', + 'MetricAvailability', + 'MetricSpecification', + 'MigrateMySqlRequest', + 'MigrateMySqlStatus', + 'NameIdentifier', + 'NameIdentifierCollection', + 'NameValuePair', + 'NetworkAccessControlEntry', + 'NetworkFeatures', + 'NetworkTrace', + 'Nonce', + 'OpenIdConnectClientCredential', + 'OpenIdConnectConfig', + 'OpenIdConnectLogin', + 'OpenIdConnectRegistration', + 'Operation', + 'OutboundEnvironmentEndpoint', + 'OutboundEnvironmentEndpointCollection', + 'PerfMonCounterCollection', + 'PerfMonResponse', + 'PerfMonSample', + 'PerfMonSet', + 'PremierAddOn', + 'PremierAddOnOffer', + 'PremierAddOnOfferCollection', + 'PremierAddOnPatchResource', + 'PrivateAccess', + 'PrivateAccessSubnet', + 'PrivateAccessVirtualNetwork', + 'PrivateEndpointConnectionResource', + 'PrivateLinkConnectionApprovalRequestResource', + 'PrivateLinkConnectionState', + 'PrivateLinkResource', + 'PrivateLinkResourceProperties', + 'PrivateLinkResourcesWrapper', + 'ProcessInfo', + 'ProcessInfoCollection', + 'ProcessModuleInfo', + 'ProcessModuleInfoCollection', + 'ProcessThreadInfo', + 'ProcessThreadInfoCollection', + 'ProxyOnlyResource', + 'PublicCertificate', + 'PublicCertificateCollection', + 'PushSettings', + 'RampUpRule', + 'Recommendation', + 'RecommendationCollection', + 'RecommendationRule', + 'ReissueCertificateOrderRequest', + 'RelayServiceConnectionEntity', + 'Rendering', + 'RenewCertificateOrderRequest', + 'RequestsBasedTrigger', + 'Resource', + 'ResourceCollection', + 'ResourceHealthMetadata', + 'ResourceHealthMetadataCollection', + 'ResourceMetricAvailability', + 'ResourceMetricDefinition', + 'ResourceMetricDefinitionCollection', + 'ResourceNameAvailability', + 'ResourceNameAvailabilityRequest', + 'ResponseMetaData', + 'RestoreRequest', + 'ServiceSpecification', + 'Site', + 'SiteAuthSettings', + 'SiteAuthSettingsV2', + 'SiteCloneability', + 'SiteCloneabilityCriterion', + 'SiteConfig', + 'SiteConfigResource', + 'SiteConfigResourceCollection', + 'SiteConfigurationSnapshotInfo', + 'SiteConfigurationSnapshotInfoCollection', + 'SiteExtensionInfo', + 'SiteExtensionInfoCollection', + 'SiteLimits', + 'SiteLogsConfig', + 'SiteMachineKey', + 'SitePatchResource', + 'SitePhpErrorLogFlag', + 'SiteSeal', + 'SiteSealRequest', + 'SiteSourceControl', + 'SkuCapacity', + 'SkuDescription', + 'SkuInfo', + 'SkuInfoCollection', + 'SkuInfos', + 'SlotConfigNamesResource', + 'SlotDifference', + 'SlotDifferenceCollection', + 'SlotSwapStatus', + 'SlowRequestsBasedTrigger', + 'Snapshot', + 'SnapshotCollection', + 'SnapshotRecoverySource', + 'SnapshotRestoreRequest', + 'Solution', + 'SourceControl', + 'SourceControlCollection', + 'StackMajorVersion', + 'StackMinorVersion', + 'StampCapacity', + 'StampCapacityCollection', + 'StaticSiteARMResource', + 'StaticSiteBuildARMResource', + 'StaticSiteBuildCollection', + 'StaticSiteBuildProperties', + 'StaticSiteCollection', + 'StaticSiteCustomDomainOverviewARMResource', + 'StaticSiteCustomDomainOverviewCollection', + 'StaticSiteFunctionOverviewARMResource', + 'StaticSiteFunctionOverviewCollection', + 'StaticSitePatchResource', + 'StaticSiteResetPropertiesARMResource', + 'StaticSiteUserARMResource', + 'StaticSiteUserCollection', + 'StaticSiteUserInvitationRequestResource', + 'StaticSiteUserInvitationResponseResource', + 'StaticSitesWorkflowPreview', + 'StaticSitesWorkflowPreviewRequest', + 'StatusCodesBasedTrigger', + 'StorageMigrationOptions', + 'StorageMigrationResponse', + 'StringDictionary', + 'SwiftVirtualNetwork', + 'SystemData', + 'TldLegalAgreement', + 'TldLegalAgreementCollection', + 'TokenStore', + 'TopLevelDomain', + 'TopLevelDomainAgreementOption', + 'TopLevelDomainCollection', + 'TriggeredJobHistory', + 'TriggeredJobHistoryCollection', + 'TriggeredJobRun', + 'TriggeredWebJob', + 'TriggeredWebJobCollection', + 'Twitter', + 'TwitterRegistration', + 'Usage', + 'UsageCollection', + 'User', + 'ValidateRequest', + 'ValidateResponse', + 'ValidateResponseError', + 'VirtualApplication', + 'VirtualDirectory', + 'VirtualIPMapping', + 'VirtualNetworkProfile', + 'VnetGateway', + 'VnetInfo', + 'VnetParameters', + 'VnetRoute', + 'VnetValidationFailureDetails', + 'VnetValidationTestFailure', + 'WebAppCollection', + 'WebAppInstanceStatusCollection', + 'WebJob', + 'WebJobCollection', + 'WebSiteInstanceStatus', + 'WorkerPool', + 'WorkerPoolCollection', + 'WorkerPoolResource', + 'AccessControlEntryAction', + 'AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem', + 'AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem', + 'AppServicePlanRestrictions', + 'AutoHealActionType', + 'AzureResourceType', + 'AzureStorageState', + 'AzureStorageType', + 'BackupItemStatus', + 'BackupRestoreOperationType', + 'BuildStatus', + 'BuiltInAuthenticationProvider', + 'CertificateOrderActionType', + 'CertificateOrderStatus', + 'CertificateProductType', + 'Channels', + 'CheckNameResourceTypes', + 'ClientCertMode', + 'CloneAbilityResult', + 'ComputeModeOptions', + 'ConnectionStringType', + 'ContinuousWebJobStatus', + 'CookieExpirationConvention', + 'CreatedByType', + 'CustomHostNameDnsRecordType', + 'DatabaseType', + 'DnsType', + 'DnsVerificationTestResult', + 'DomainPatchResourcePropertiesDomainNotRenewableReasonsItem', + 'DomainPropertiesDomainNotRenewableReasonsItem', + 'DomainStatus', + 'DomainType', + 'Enum5', + 'Enum6', + 'ForwardProxyConvention', + 'FrequencyUnit', + 'FtpsState', + 'HostNameType', + 'HostType', + 'HostingEnvironmentStatus', + 'InAvailabilityReasonType', + 'IpFilterTag', + 'IssueType', + 'KeyVaultSecretStatus', + 'LoadBalancingMode', + 'LogLevel', + 'MSDeployLogEntryType', + 'MSDeployProvisioningState', + 'ManagedPipelineMode', + 'ManagedServiceIdentityType', + 'MySqlMigrationType', + 'NotificationLevel', + 'OperationStatus', + 'ProvisioningState', + 'PublicCertificateLocation', + 'PublishingProfileFormat', + 'RedundancyMode', + 'RenderingType', + 'ResourceScopeType', + 'RouteType', + 'ScmType', + 'SiteAvailabilityState', + 'SiteExtensionType', + 'SiteLoadBalancing', + 'SiteRuntimeState', + 'SkuName', + 'SolutionType', + 'SslState', + 'StatusOptions', + 'SupportedTlsVersions', + 'TriggerTypes', + 'TriggeredWebJobStatus', + 'UnauthenticatedClientAction', + 'UnauthenticatedClientActionV2', + 'UsageState', + 'ValidateResourceTypes', + 'WebJobType', + 'WorkerSizeOptions', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models.py new file mode 100644 index 000000000000..a9139c30ec2f --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models.py @@ -0,0 +1,17635 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + + +class AbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period identified in diagnosis. + + :param start_time: Start time of the downtime. + :type start_time: ~datetime.datetime + :param end_time: End time of the downtime. + :type end_time: ~datetime.datetime + :param events: List of Possible Cause of downtime. + :type events: list[~azure.mgmt.web.v2020_09_01.models.DetectorAbnormalTimePeriod] + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_09_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'events': {'key': 'events', 'type': '[DetectorAbnormalTimePeriod]'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + **kwargs + ): + super(AbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.events = kwargs.get('events', None) + self.solutions = kwargs.get('solutions', None) + + +class Address(msrest.serialization.Model): + """Address information for domain registration. + + All required parameters must be populated in order to send to Azure. + + :param address1: Required. First line of an Address. + :type address1: str + :param address2: The second line of the Address. Optional. + :type address2: str + :param city: Required. The city for the address. + :type city: str + :param country: Required. The country for the address. + :type country: str + :param postal_code: Required. The postal code for the address. + :type postal_code: str + :param state: Required. The state or province for the address. + :type state: str + """ + + _validation = { + 'address1': {'required': True}, + 'city': {'required': True}, + 'country': {'required': True}, + 'postal_code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'address1': {'key': 'address1', 'type': 'str'}, + 'address2': {'key': 'address2', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + 'country': {'key': 'country', 'type': 'str'}, + 'postal_code': {'key': 'postalCode', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Address, self).__init__(**kwargs) + self.address1 = kwargs['address1'] + self.address2 = kwargs.get('address2', None) + self.city = kwargs['city'] + self.country = kwargs['country'] + self.postal_code = kwargs['postal_code'] + self.state = kwargs['state'] + + +class ProxyOnlyResource(msrest.serialization.Model): + """Azure proxy only resource. This resource is not tracked by Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + **kwargs + ): + super(ProxyOnlyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kwargs.get('kind', None) + self.type = None + self.system_data = None + + +class AddressResponse(ProxyOnlyResource): + """Describes main public IP address and any extra virtual IPs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param service_ip_address: Main public virtual IP. + :type service_ip_address: str + :param internal_ip_address: Virtual Network internal IP address of the App Service Environment + if it is in internal load-balancing mode. + :type internal_ip_address: str + :param outbound_ip_addresses: IP addresses appearing on outbound connections. + :type outbound_ip_addresses: list[str] + :param vip_mappings: Additional virtual IPs. + :type vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'service_ip_address': {'key': 'properties.serviceIpAddress', 'type': 'str'}, + 'internal_ip_address': {'key': 'properties.internalIpAddress', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': '[str]'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + } + + def __init__( + self, + **kwargs + ): + super(AddressResponse, self).__init__(**kwargs) + self.service_ip_address = kwargs.get('service_ip_address', None) + self.internal_ip_address = kwargs.get('internal_ip_address', None) + self.outbound_ip_addresses = kwargs.get('outbound_ip_addresses', None) + self.vip_mappings = kwargs.get('vip_mappings', None) + + +class AllowedAudiencesValidation(ProxyOnlyResource): + """AllowedAudiencesValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AllowedAudiencesValidation, self).__init__(**kwargs) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + + +class AnalysisData(msrest.serialization.Model): + """Class Representing Detector Evidence used for analysis. + + :param source: Name of the Detector. + :type source: str + :param detector_definition: Detector Definition. + :type detector_definition: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :param metrics: Source Metrics. + :type metrics: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSet] + :param data: Additional Source Data. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param detector_meta_data: Detector Meta Data. + :type detector_meta_data: ~azure.mgmt.web.v2020_09_01.models.ResponseMetaData + """ + + _attribute_map = { + 'source': {'key': 'source', 'type': 'str'}, + 'detector_definition': {'key': 'detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'metrics', 'type': '[DiagnosticMetricSet]'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'detector_meta_data': {'key': 'detectorMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + **kwargs + ): + super(AnalysisData, self).__init__(**kwargs) + self.source = kwargs.get('source', None) + self.detector_definition = kwargs.get('detector_definition', None) + self.metrics = kwargs.get('metrics', None) + self.data = kwargs.get('data', None) + self.detector_meta_data = kwargs.get('detector_meta_data', None) + + +class AnalysisDefinition(ProxyOnlyResource): + """Definition of Analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Description of the Analysis. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AnalysisDefinition, self).__init__(**kwargs) + self.description = None + + +class ApiDefinitionInfo(msrest.serialization.Model): + """Information about the formal API definition for the app. + + :param url: The URL of the API definition. + :type url: str + """ + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiDefinitionInfo, self).__init__(**kwargs) + self.url = kwargs.get('url', None) + + +class ApiManagementConfig(msrest.serialization.Model): + """Azure API management (APIM) configuration linked to the app. + + :param id: APIM-Api Identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiManagementConfig, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class ApplicationLogsConfig(msrest.serialization.Model): + """Application logs configuration. + + :param file_system: Application logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemApplicationLogsConfig + :param azure_table_storage: Application logs to azure table storage configuration. + :type azure_table_storage: + ~azure.mgmt.web.v2020_09_01.models.AzureTableStorageApplicationLogsConfig + :param azure_blob_storage: Application logs to blob storage configuration. + :type azure_blob_storage: + ~azure.mgmt.web.v2020_09_01.models.AzureBlobStorageApplicationLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemApplicationLogsConfig'}, + 'azure_table_storage': {'key': 'azureTableStorage', 'type': 'AzureTableStorageApplicationLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageApplicationLogsConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationLogsConfig, self).__init__(**kwargs) + self.file_system = kwargs.get('file_system', None) + self.azure_table_storage = kwargs.get('azure_table_storage', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class ApplicationStack(msrest.serialization.Model): + """Application stack. + + :param name: Application stack name. + :type name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStack] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'str'}, + 'dependency': {'key': 'dependency', 'type': 'str'}, + 'major_versions': {'key': 'majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStack, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + self.dependency = kwargs.get('dependency', None) + self.major_versions = kwargs.get('major_versions', None) + self.frameworks = kwargs.get('frameworks', None) + + +class ApplicationStackCollection(msrest.serialization.Model): + """Collection of Application Stacks. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStackResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationStackResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStackCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ApplicationStackResource(ProxyOnlyResource): + """ARM resource for a ApplicationStack. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Application stack name. + :type name_properties_name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStack] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'display': {'key': 'properties.display', 'type': 'str'}, + 'dependency': {'key': 'properties.dependency', 'type': 'str'}, + 'major_versions': {'key': 'properties.majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'properties.frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationStackResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.display = kwargs.get('display', None) + self.dependency = kwargs.get('dependency', None) + self.major_versions = kwargs.get('major_versions', None) + self.frameworks = kwargs.get('frameworks', None) + + +class AppRegistration(ProxyOnlyResource): + """AppRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param app_id: + :type app_id: str + :param app_secret_setting_name: + :type app_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'app_id': {'key': 'properties.appId', 'type': 'str'}, + 'app_secret_setting_name': {'key': 'properties.appSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppRegistration, self).__init__(**kwargs) + self.app_id = kwargs.get('app_id', None) + self.app_secret_setting_name = kwargs.get('app_secret_setting_name', None) + + +class AppServiceCertificate(msrest.serialization.Model): + """Key Vault container for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'key_vault_id': {'key': 'keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificate, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceCertificateCollection(msrest.serialization.Model): + """Collection of certificate order certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Resource(msrest.serialization.Model): + """Azure resource. This resource is tracked in Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kwargs.get('kind', None) + self.location = kwargs['location'] + self.type = None + self.tags = kwargs.get('tags', None) + self.system_data = None + + +class AppServiceCertificateOrder(Resource): + """SSL certificate purchase order. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrder, self).__init__(**kwargs) + self.certificates = kwargs.get('certificates', None) + self.distinguished_name = kwargs.get('distinguished_name', None) + self.domain_verification_token = None + self.validity_in_years = kwargs.get('validity_in_years', 1) + self.key_size = kwargs.get('key_size', 2048) + self.product_type = kwargs.get('product_type', None) + self.auto_renew = kwargs.get('auto_renew', True) + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = kwargs.get('csr', None) + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificateOrderCollection(msrest.serialization.Model): + """Collection of certificate orders. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateOrder]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrderCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServiceCertificateOrderPatchResource(ProxyOnlyResource): + """ARM resource for a certificate order that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateOrderPatchResource, self).__init__(**kwargs) + self.certificates = kwargs.get('certificates', None) + self.distinguished_name = kwargs.get('distinguished_name', None) + self.domain_verification_token = None + self.validity_in_years = kwargs.get('validity_in_years', 1) + self.key_size = kwargs.get('key_size', 2048) + self.product_type = kwargs.get('product_type', None) + self.auto_renew = kwargs.get('auto_renew', True) + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = kwargs.get('csr', None) + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificatePatchResource(ProxyOnlyResource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificatePatchResource, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceCertificateResource(Resource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceCertificateResource, self).__init__(**kwargs) + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.provisioning_state = None + + +class AppServiceEnvironment(msrest.serialization.Model): + """Description of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Name of the App Service Environment. + :type name: str + :param location: Required. Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Required. Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Required. Description of worker pools with worker size IDs, VM sizes, and + number of workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'name': {'required': True}, + 'location': {'required': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'virtual_network': {'required': True}, + 'worker_pools': {'required': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironment, self).__init__(**kwargs) + self.name = kwargs['name'] + self.location = kwargs['location'] + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs['virtual_network'] + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs['worker_pools'] + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppServiceEnvironmentCollection(msrest.serialization.Model): + """Collection of App Service Environments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceEnvironmentResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServiceEnvironmentPatchResource(ProxyOnlyResource): + """ARM resource for a app service environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location: Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentPatchResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.location = kwargs.get('location', None) + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs.get('virtual_network', None) + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs.get('worker_pools', None) + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppServiceEnvironmentResource(Resource): + """App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location_properties_location: Location of the App Service Environment, e.g. "West US". + :type location_properties_location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location_properties_location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServiceEnvironmentResource, self).__init__(**kwargs) + self.name_properties_name = kwargs.get('name_properties_name', None) + self.location_properties_location = kwargs.get('location_properties_location', None) + self.provisioning_state = None + self.status = None + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_resource_group_name = kwargs.get('vnet_resource_group_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + self.virtual_network = kwargs.get('virtual_network', None) + self.internal_load_balancing_mode = kwargs.get('internal_load_balancing_mode', None) + self.multi_size = kwargs.get('multi_size', None) + self.multi_role_count = kwargs.get('multi_role_count', None) + self.worker_pools = kwargs.get('worker_pools', None) + self.ipssl_address_count = kwargs.get('ipssl_address_count', None) + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = kwargs.get('dns_suffix', None) + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = kwargs.get('network_access_control_list', None) + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = kwargs.get('front_end_scale_factor', None) + self.default_front_end_scale_factor = None + self.api_management_account_id = kwargs.get('api_management_account_id', None) + self.suspended = kwargs.get('suspended', None) + self.dynamic_cache_enabled = kwargs.get('dynamic_cache_enabled', None) + self.cluster_settings = kwargs.get('cluster_settings', None) + self.user_whitelisted_ip_ranges = kwargs.get('user_whitelisted_ip_ranges', None) + self.has_linux_workers = kwargs.get('has_linux_workers', None) + self.ssl_cert_key_vault_id = kwargs.get('ssl_cert_key_vault_id', None) + self.ssl_cert_key_vault_secret_name = kwargs.get('ssl_cert_key_vault_secret_name', None) + + +class AppserviceGithubToken(msrest.serialization.Model): + """Github access token for Appservice CLI github integration. + + :param access_token: Github access token for Appservice CLI github integration. + :type access_token: str + :param scope: Scope of the github access token. + :type scope: str + :param token_type: token type. + :type token_type: str + :param got_token: True if valid github token received, False otherwise. + :type got_token: bool + :param error_message: Error message if unable to get token. + :type error_message: str + """ + + _attribute_map = { + 'access_token': {'key': 'accessToken', 'type': 'str'}, + 'scope': {'key': 'scope', 'type': 'str'}, + 'token_type': {'key': 'tokenType', 'type': 'str'}, + 'got_token': {'key': 'gotToken', 'type': 'bool'}, + 'error_message': {'key': 'errorMessage', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppserviceGithubToken, self).__init__(**kwargs) + self.access_token = kwargs.get('access_token', None) + self.scope = kwargs.get('scope', None) + self.token_type = kwargs.get('token_type', None) + self.got_token = kwargs.get('got_token', None) + self.error_message = kwargs.get('error_message', None) + + +class AppserviceGithubTokenRequest(msrest.serialization.Model): + """Appservice Github token request content. + + All required parameters must be populated in order to send to Azure. + + :param code: Required. Code string to exchange for Github Access token. + :type code: str + :param state: Required. State string used for verification. + :type state: str + """ + + _validation = { + 'code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppserviceGithubTokenRequest, self).__init__(**kwargs) + self.code = kwargs['code'] + self.state = kwargs['state'] + + +class AppServicePlan(Resource): + """App Service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: If Linux app service plan :code:`true`, + :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlan, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.worker_tier_name = kwargs.get('worker_tier_name', None) + self.status = None + self.subscription = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = kwargs.get('per_site_scaling', False) + self.maximum_elastic_worker_count = kwargs.get('maximum_elastic_worker_count', None) + self.number_of_sites = None + self.is_spot = kwargs.get('is_spot', None) + self.spot_expiration_time = kwargs.get('spot_expiration_time', None) + self.free_offer_expiration_time = kwargs.get('free_offer_expiration_time', None) + self.resource_group = None + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.target_worker_count = kwargs.get('target_worker_count', None) + self.target_worker_size_id = kwargs.get('target_worker_size_id', None) + self.provisioning_state = None + + +class AppServicePlanCollection(msrest.serialization.Model): + """Collection of App Service plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServicePlan] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServicePlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlanCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class AppServicePlanPatchResource(ProxyOnlyResource): + """ARM resource for a app service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: This needs to set to :code:`true` when creating a Linux App + Service Plan, along with :code:`kind` set to :code:`Linux`. It should + be :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AppServicePlanPatchResource, self).__init__(**kwargs) + self.worker_tier_name = kwargs.get('worker_tier_name', None) + self.status = None + self.subscription = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = kwargs.get('per_site_scaling', False) + self.maximum_elastic_worker_count = kwargs.get('maximum_elastic_worker_count', None) + self.number_of_sites = None + self.is_spot = kwargs.get('is_spot', None) + self.spot_expiration_time = kwargs.get('spot_expiration_time', None) + self.free_offer_expiration_time = kwargs.get('free_offer_expiration_time', None) + self.resource_group = None + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.target_worker_count = kwargs.get('target_worker_count', None) + self.target_worker_size_id = kwargs.get('target_worker_size_id', None) + self.provisioning_state = None + + +class ArmIdWrapper(msrest.serialization.Model): + """A wrapper for an ARM resource id. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ArmIdWrapper, self).__init__(**kwargs) + self.id = None + + +class AuthPlatform(ProxyOnlyResource): + """AuthPlatform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param runtime_version: + :type runtime_version: str + :param config_file_path: + :type config_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'config_file_path': {'key': 'properties.configFilePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AuthPlatform, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.config_file_path = kwargs.get('config_file_path', None) + + +class AutoHealActions(msrest.serialization.Model): + """Actions which to take by the auto-heal module when a rule is triggered. + + :param action_type: Predefined action to be taken. Possible values include: "Recycle", + "LogEvent", "CustomAction". + :type action_type: str or ~azure.mgmt.web.v2020_09_01.models.AutoHealActionType + :param custom_action: Custom action to be taken. + :type custom_action: ~azure.mgmt.web.v2020_09_01.models.AutoHealCustomAction + :param min_process_execution_time: Minimum time the process must execute + before taking the action. + :type min_process_execution_time: str + """ + + _attribute_map = { + 'action_type': {'key': 'actionType', 'type': 'str'}, + 'custom_action': {'key': 'customAction', 'type': 'AutoHealCustomAction'}, + 'min_process_execution_time': {'key': 'minProcessExecutionTime', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealActions, self).__init__(**kwargs) + self.action_type = kwargs.get('action_type', None) + self.custom_action = kwargs.get('custom_action', None) + self.min_process_execution_time = kwargs.get('min_process_execution_time', None) + + +class AutoHealCustomAction(msrest.serialization.Model): + """Custom action to be executed +when an auto heal rule is triggered. + + :param exe: Executable to be run. + :type exe: str + :param parameters: Parameters for the executable. + :type parameters: str + """ + + _attribute_map = { + 'exe': {'key': 'exe', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealCustomAction, self).__init__(**kwargs) + self.exe = kwargs.get('exe', None) + self.parameters = kwargs.get('parameters', None) + + +class AutoHealRules(msrest.serialization.Model): + """Rules that can be defined for auto-heal. + + :param triggers: Conditions that describe when to execute the auto-heal actions. + :type triggers: ~azure.mgmt.web.v2020_09_01.models.AutoHealTriggers + :param actions: Actions to be executed when a rule is triggered. + :type actions: ~azure.mgmt.web.v2020_09_01.models.AutoHealActions + """ + + _attribute_map = { + 'triggers': {'key': 'triggers', 'type': 'AutoHealTriggers'}, + 'actions': {'key': 'actions', 'type': 'AutoHealActions'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealRules, self).__init__(**kwargs) + self.triggers = kwargs.get('triggers', None) + self.actions = kwargs.get('actions', None) + + +class AutoHealTriggers(msrest.serialization.Model): + """Triggers for auto-heal. + + :param requests: A rule based on total requests. + :type requests: ~azure.mgmt.web.v2020_09_01.models.RequestsBasedTrigger + :param private_bytes_in_kb: A rule based on private bytes. + :type private_bytes_in_kb: int + :param status_codes: A rule based on status codes. + :type status_codes: list[~azure.mgmt.web.v2020_09_01.models.StatusCodesBasedTrigger] + :param slow_requests: A rule based on request execution time. + :type slow_requests: ~azure.mgmt.web.v2020_09_01.models.SlowRequestsBasedTrigger + """ + + _attribute_map = { + 'requests': {'key': 'requests', 'type': 'RequestsBasedTrigger'}, + 'private_bytes_in_kb': {'key': 'privateBytesInKB', 'type': 'int'}, + 'status_codes': {'key': 'statusCodes', 'type': '[StatusCodesBasedTrigger]'}, + 'slow_requests': {'key': 'slowRequests', 'type': 'SlowRequestsBasedTrigger'}, + } + + def __init__( + self, + **kwargs + ): + super(AutoHealTriggers, self).__init__(**kwargs) + self.requests = kwargs.get('requests', None) + self.private_bytes_in_kb = kwargs.get('private_bytes_in_kb', None) + self.status_codes = kwargs.get('status_codes', None) + self.slow_requests = kwargs.get('slow_requests', None) + + +class AzureActiveDirectory(ProxyOnlyResource): + """AzureActiveDirectory. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryLogin + :param validation: + :type validation: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryValidation + :param is_auto_provisioned: + :type is_auto_provisioned: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AzureActiveDirectoryRegistration'}, + 'login': {'key': 'properties.login', 'type': 'AzureActiveDirectoryLogin'}, + 'validation': {'key': 'properties.validation', 'type': 'AzureActiveDirectoryValidation'}, + 'is_auto_provisioned': {'key': 'properties.isAutoProvisioned', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + self.validation = kwargs.get('validation', None) + self.is_auto_provisioned = kwargs.get('is_auto_provisioned', None) + + +class AzureActiveDirectoryLogin(ProxyOnlyResource): + """AzureActiveDirectoryLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param disable_www_authenticate: + :type disable_www_authenticate: bool + :param login_parameters: + :type login_parameters: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'disable_www_authenticate': {'key': 'properties.disableWWWAuthenticate', 'type': 'bool'}, + 'login_parameters': {'key': 'properties.loginParameters', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryLogin, self).__init__(**kwargs) + self.disable_www_authenticate = kwargs.get('disable_www_authenticate', None) + self.login_parameters = kwargs.get('login_parameters', None) + + +class AzureActiveDirectoryRegistration(ProxyOnlyResource): + """AzureActiveDirectoryRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param open_id_issuer: + :type open_id_issuer: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: + :type client_secret_certificate_thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'open_id_issuer': {'key': 'properties.openIdIssuer', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryRegistration, self).__init__(**kwargs) + self.open_id_issuer = kwargs.get('open_id_issuer', None) + self.client_id = kwargs.get('client_id', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + self.client_secret_certificate_thumbprint = kwargs.get('client_secret_certificate_thumbprint', None) + + +class AzureActiveDirectoryValidation(ProxyOnlyResource): + """AzureActiveDirectoryValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param jwt_claim_checks: + :type jwt_claim_checks: ~azure.mgmt.web.v2020_09_01.models.JwtClaimChecks + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'jwt_claim_checks': {'key': 'properties.jwtClaimChecks', 'type': 'JwtClaimChecks'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectoryValidation, self).__init__(**kwargs) + self.jwt_claim_checks = kwargs.get('jwt_claim_checks', None) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + + +class AzureBlobStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs azure blob storage configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureBlobStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + self.sas_url = kwargs.get('sas_url', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + + +class AzureBlobStorageHttpLogsConfig(msrest.serialization.Model): + """Http logs to azure blob storage configuration. + + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureBlobStorageHttpLogsConfig, self).__init__(**kwargs) + self.sas_url = kwargs.get('sas_url', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + self.enabled = kwargs.get('enabled', None) + + +class AzureStorageInfoValue(msrest.serialization.Model): + """Azure Files or Blob Storage access information value for dictionary storage. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of storage. Possible values include: "AzureFiles", "AzureBlob". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.AzureStorageType + :param account_name: Name of the storage account. + :type account_name: str + :param share_name: Name of the file share (container name, for Blob storage). + :type share_name: str + :param access_key: Access key for the storage account. + :type access_key: str + :param mount_path: Path to mount the storage within the site's runtime environment. + :type mount_path: str + :ivar state: State of the storage account. Possible values include: "Ok", "InvalidCredentials", + "InvalidShare". + :vartype state: str or ~azure.mgmt.web.v2020_09_01.models.AzureStorageState + """ + + _validation = { + 'state': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'account_name': {'key': 'accountName', 'type': 'str'}, + 'share_name': {'key': 'shareName', 'type': 'str'}, + 'access_key': {'key': 'accessKey', 'type': 'str'}, + 'mount_path': {'key': 'mountPath', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureStorageInfoValue, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.account_name = kwargs.get('account_name', None) + self.share_name = kwargs.get('share_name', None) + self.access_key = kwargs.get('access_key', None) + self.mount_path = kwargs.get('mount_path', None) + self.state = None + + +class AzureStoragePropertyDictionaryResource(ProxyOnlyResource): + """AzureStorageInfo dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Azure storage accounts. + :type properties: dict[str, ~azure.mgmt.web.v2020_09_01.models.AzureStorageInfoValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{AzureStorageInfoValue}'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureStoragePropertyDictionaryResource, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class AzureTableStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs to Azure table storage configuration. + + All required parameters must be populated in order to send to Azure. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + :param sas_url: Required. SAS URL to an Azure table with add/query/delete permissions. + :type sas_url: str + """ + + _validation = { + 'sas_url': {'required': True}, + } + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureTableStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + self.sas_url = kwargs['sas_url'] + + +class BackupItem(ProxyOnlyResource): + """Backup description. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar backup_id: Id of the backup. + :vartype backup_id: int + :ivar storage_account_url: SAS URL for the storage account container which contains this + backup. + :vartype storage_account_url: str + :ivar blob_name: Name of the blob which contains data for this backup. + :vartype blob_name: str + :ivar name_properties_name: Name of this backup. + :vartype name_properties_name: str + :ivar status: Backup status. Possible values include: "InProgress", "Failed", "Succeeded", + "TimedOut", "Created", "Skipped", "PartiallySucceeded", "DeleteInProgress", "DeleteFailed", + "Deleted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.BackupItemStatus + :ivar size_in_bytes: Size of the backup in bytes. + :vartype size_in_bytes: long + :ivar created: Timestamp of the backup creation. + :vartype created: ~datetime.datetime + :ivar log: Details regarding this backup. Might contain an error message. + :vartype log: str + :ivar databases: List of databases included in the backup. + :vartype databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + :ivar scheduled: True if this backup has been created due to a schedule being triggered. + :vartype scheduled: bool + :ivar last_restore_time_stamp: Timestamp of a last restore operation which used this backup. + :vartype last_restore_time_stamp: ~datetime.datetime + :ivar finished_time_stamp: Timestamp when this backup finished. + :vartype finished_time_stamp: ~datetime.datetime + :ivar correlation_id: Unique correlation identifier. Please use this along with the timestamp + while communicating with Azure support. + :vartype correlation_id: str + :ivar website_size_in_bytes: Size of the original web app which has been backed up. + :vartype website_size_in_bytes: long + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'backup_id': {'readonly': True}, + 'storage_account_url': {'readonly': True}, + 'blob_name': {'readonly': True}, + 'name_properties_name': {'readonly': True}, + 'status': {'readonly': True}, + 'size_in_bytes': {'readonly': True}, + 'created': {'readonly': True}, + 'log': {'readonly': True}, + 'databases': {'readonly': True}, + 'scheduled': {'readonly': True}, + 'last_restore_time_stamp': {'readonly': True}, + 'finished_time_stamp': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'website_size_in_bytes': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'backup_id': {'key': 'properties.id', 'type': 'int'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'size_in_bytes': {'key': 'properties.sizeInBytes', 'type': 'long'}, + 'created': {'key': 'properties.created', 'type': 'iso-8601'}, + 'log': {'key': 'properties.log', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'scheduled': {'key': 'properties.scheduled', 'type': 'bool'}, + 'last_restore_time_stamp': {'key': 'properties.lastRestoreTimeStamp', 'type': 'iso-8601'}, + 'finished_time_stamp': {'key': 'properties.finishedTimeStamp', 'type': 'iso-8601'}, + 'correlation_id': {'key': 'properties.correlationId', 'type': 'str'}, + 'website_size_in_bytes': {'key': 'properties.websiteSizeInBytes', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupItem, self).__init__(**kwargs) + self.backup_id = None + self.storage_account_url = None + self.blob_name = None + self.name_properties_name = None + self.status = None + self.size_in_bytes = None + self.created = None + self.log = None + self.databases = None + self.scheduled = None + self.last_restore_time_stamp = None + self.finished_time_stamp = None + self.correlation_id = None + self.website_size_in_bytes = None + + +class BackupItemCollection(msrest.serialization.Model): + """Collection of backup items. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.BackupItem] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackupItem]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupItemCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class BackupRequest(ProxyOnlyResource): + """Description of a backup which will be performed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param backup_name: Name of the backup. + :type backup_name: str + :param enabled: True if the backup schedule is enabled (must be included in that case), false + if the backup schedule should be disabled. + :type enabled: bool + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param backup_schedule: Schedule for the backup if it is executed periodically. + :type backup_schedule: ~azure.mgmt.web.v2020_09_01.models.BackupSchedule + :param databases: Databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'backup_name': {'key': 'properties.backupName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'backup_schedule': {'key': 'properties.backupSchedule', 'type': 'BackupSchedule'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupRequest, self).__init__(**kwargs) + self.backup_name = kwargs.get('backup_name', None) + self.enabled = kwargs.get('enabled', None) + self.storage_account_url = kwargs.get('storage_account_url', None) + self.backup_schedule = kwargs.get('backup_schedule', None) + self.databases = kwargs.get('databases', None) + + +class BackupSchedule(msrest.serialization.Model): + """Description of a backup schedule. Describes how often should be the backup performed and what should be the retention policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param frequency_interval: Required. How often the backup should be executed (e.g. for weekly + backup, this should be set to 7 and FrequencyUnit should be set to Day). + :type frequency_interval: int + :param frequency_unit: Required. The unit of time for how often the backup should be executed + (e.g. for weekly backup, this should be set to Day and FrequencyInterval should be set to 7). + Possible values include: "Day", "Hour". Default value: "Day". + :type frequency_unit: str or ~azure.mgmt.web.v2020_09_01.models.FrequencyUnit + :param keep_at_least_one_backup: Required. True if the retention policy should always keep at + least one backup in the storage account, regardless how old it is; false otherwise. + :type keep_at_least_one_backup: bool + :param retention_period_in_days: Required. After how many days backups should be deleted. + :type retention_period_in_days: int + :param start_time: When the schedule should start working. + :type start_time: ~datetime.datetime + :ivar last_execution_time: Last time when this schedule was triggered. + :vartype last_execution_time: ~datetime.datetime + """ + + _validation = { + 'frequency_interval': {'required': True}, + 'frequency_unit': {'required': True}, + 'keep_at_least_one_backup': {'required': True}, + 'retention_period_in_days': {'required': True}, + 'last_execution_time': {'readonly': True}, + } + + _attribute_map = { + 'frequency_interval': {'key': 'frequencyInterval', 'type': 'int'}, + 'frequency_unit': {'key': 'frequencyUnit', 'type': 'str'}, + 'keep_at_least_one_backup': {'key': 'keepAtLeastOneBackup', 'type': 'bool'}, + 'retention_period_in_days': {'key': 'retentionPeriodInDays', 'type': 'int'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'last_execution_time': {'key': 'lastExecutionTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(BackupSchedule, self).__init__(**kwargs) + self.frequency_interval = kwargs.get('frequency_interval', 7) + self.frequency_unit = kwargs.get('frequency_unit', "Day") + self.keep_at_least_one_backup = kwargs.get('keep_at_least_one_backup', True) + self.retention_period_in_days = kwargs.get('retention_period_in_days', 30) + self.start_time = kwargs.get('start_time', None) + self.last_execution_time = None + + +class BillingMeter(ProxyOnlyResource): + """App Service billing entity that contains information about meter which the Azure billing system utilizes to charge users for services. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param meter_id: Meter GUID onboarded in Commerce. + :type meter_id: str + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param short_name: Short Name from App Service Azure pricing Page. + :type short_name: str + :param friendly_name: Friendly name of the meter. + :type friendly_name: str + :param resource_type: App Service ResourceType meter used for. + :type resource_type: str + :param os_type: App Service OS type meter used for. + :type os_type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'meter_id': {'key': 'properties.meterId', 'type': 'str'}, + 'billing_location': {'key': 'properties.billingLocation', 'type': 'str'}, + 'short_name': {'key': 'properties.shortName', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'os_type': {'key': 'properties.osType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BillingMeter, self).__init__(**kwargs) + self.meter_id = kwargs.get('meter_id', None) + self.billing_location = kwargs.get('billing_location', None) + self.short_name = kwargs.get('short_name', None) + self.friendly_name = kwargs.get('friendly_name', None) + self.resource_type = kwargs.get('resource_type', None) + self.os_type = kwargs.get('os_type', None) + + +class BillingMeterCollection(msrest.serialization.Model): + """Collection of Billing Meters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.BillingMeter] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BillingMeter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BillingMeterCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class BlobStorageTokenStore(ProxyOnlyResource): + """BlobStorageTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sas_url_setting_name: + :type sas_url_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sas_url_setting_name': {'key': 'properties.sasUrlSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BlobStorageTokenStore, self).__init__(**kwargs) + self.sas_url_setting_name = kwargs.get('sas_url_setting_name', None) + + +class Capability(msrest.serialization.Model): + """Describes the capabilities/features allowed for a specific SKU. + + :param name: Name of the SKU capability. + :type name: str + :param value: Value of the SKU capability. + :type value: str + :param reason: Reason of the SKU capability. + :type reason: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + 'reason': {'key': 'reason', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Capability, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + self.reason = kwargs.get('reason', None) + + +class Certificate(Resource): + """SSL certificate for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Certificate, self).__init__(**kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = kwargs.get('host_names', None) + self.pfx_blob = kwargs.get('pfx_blob', None) + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = kwargs.get('password', None) + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.key_vault_secret_status = None + self.server_farm_id = kwargs.get('server_farm_id', None) + self.canonical_name = kwargs.get('canonical_name', None) + + +class CertificateCollection(msrest.serialization.Model): + """Collection of certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Certificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Certificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CertificateDetails(msrest.serialization.Model): + """SSL certificate details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar version: Certificate Version. + :vartype version: int + :ivar serial_number: Certificate Serial Number. + :vartype serial_number: str + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + :ivar subject: Certificate Subject. + :vartype subject: str + :ivar not_before: Date Certificate is valid from. + :vartype not_before: ~datetime.datetime + :ivar not_after: Date Certificate is valid to. + :vartype not_after: ~datetime.datetime + :ivar signature_algorithm: Certificate Signature algorithm. + :vartype signature_algorithm: str + :ivar issuer: Certificate Issuer. + :vartype issuer: str + :ivar raw_data: Raw certificate data. + :vartype raw_data: str + """ + + _validation = { + 'version': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'subject': {'readonly': True}, + 'not_before': {'readonly': True}, + 'not_after': {'readonly': True}, + 'signature_algorithm': {'readonly': True}, + 'issuer': {'readonly': True}, + 'raw_data': {'readonly': True}, + } + + _attribute_map = { + 'version': {'key': 'version', 'type': 'int'}, + 'serial_number': {'key': 'serialNumber', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'subject': {'key': 'subject', 'type': 'str'}, + 'not_before': {'key': 'notBefore', 'type': 'iso-8601'}, + 'not_after': {'key': 'notAfter', 'type': 'iso-8601'}, + 'signature_algorithm': {'key': 'signatureAlgorithm', 'type': 'str'}, + 'issuer': {'key': 'issuer', 'type': 'str'}, + 'raw_data': {'key': 'rawData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateDetails, self).__init__(**kwargs) + self.version = None + self.serial_number = None + self.thumbprint = None + self.subject = None + self.not_before = None + self.not_after = None + self.signature_algorithm = None + self.issuer = None + self.raw_data = None + + +class CertificateEmail(ProxyOnlyResource): + """SSL certificate email. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param email_id: Email id. + :type email_id: str + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'email_id': {'key': 'properties.emailId', 'type': 'str'}, + 'time_stamp': {'key': 'properties.timeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateEmail, self).__init__(**kwargs) + self.email_id = kwargs.get('email_id', None) + self.time_stamp = kwargs.get('time_stamp', None) + + +class CertificateOrderAction(ProxyOnlyResource): + """Certificate order action. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar action_type: Action type. Possible values include: "CertificateIssued", + "CertificateOrderCanceled", "CertificateOrderCreated", "CertificateRevoked", + "DomainValidationComplete", "FraudDetected", "OrgNameChange", "OrgValidationComplete", + "SanDrop", "FraudCleared", "CertificateExpired", "CertificateExpirationWarning", + "FraudDocumentationRequired", "Unknown". + :vartype action_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderActionType + :ivar created_at: Time at which the certificate action was performed. + :vartype created_at: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'action_type': {'readonly': True}, + 'created_at': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'action_type': {'key': 'properties.actionType', 'type': 'str'}, + 'created_at': {'key': 'properties.createdAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateOrderAction, self).__init__(**kwargs) + self.action_type = None + self.created_at = None + + +class CertificatePatchResource(ProxyOnlyResource): + """ARM resource for a certificate. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificatePatchResource, self).__init__(**kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = kwargs.get('host_names', None) + self.pfx_blob = kwargs.get('pfx_blob', None) + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = kwargs.get('password', None) + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = kwargs.get('key_vault_id', None) + self.key_vault_secret_name = kwargs.get('key_vault_secret_name', None) + self.key_vault_secret_status = None + self.server_farm_id = kwargs.get('server_farm_id', None) + self.canonical_name = kwargs.get('canonical_name', None) + + +class ClientRegistration(ProxyOnlyResource): + """ClientRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ClientRegistration, self).__init__(**kwargs) + self.client_id = kwargs.get('client_id', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + + +class CloningInfo(msrest.serialization.Model): + """Information needed for cloning operation. + + All required parameters must be populated in order to send to Azure. + + :param correlation_id: Correlation ID of cloning operation. This ID ties multiple cloning + operations + together to use the same snapshot. + :type correlation_id: str + :param overwrite: :code:`true` to overwrite destination app; otherwise, + :code:`false`. + :type overwrite: bool + :param clone_custom_host_names: :code:`true` to clone custom hostnames from source + app; otherwise, :code:`false`. + :type clone_custom_host_names: bool + :param clone_source_control: :code:`true` to clone source control from source app; + otherwise, :code:`false`. + :type clone_source_control: bool + :param source_web_app_id: Required. ARM resource ID of the source app. App resource ID is of + the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type source_web_app_id: str + :param source_web_app_location: Location of source app ex: West US or North Europe. + :type source_web_app_location: str + :param hosting_environment: App Service Environment. + :type hosting_environment: str + :param app_settings_overrides: Application setting overrides for cloned app. If specified, + these settings override the settings cloned + from source app. Otherwise, application settings from source app are retained. + :type app_settings_overrides: dict[str, str] + :param configure_load_balancing: :code:`true` to configure load balancing for + source and destination app. + :type configure_load_balancing: bool + :param traffic_manager_profile_id: ARM resource ID of the Traffic Manager profile to use, if it + exists. Traffic Manager resource ID is of the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/trafficManagerProfiles/{profileName}. + :type traffic_manager_profile_id: str + :param traffic_manager_profile_name: Name of Traffic Manager profile to create. This is only + needed if Traffic Manager profile does not already exist. + :type traffic_manager_profile_name: str + """ + + _validation = { + 'source_web_app_id': {'required': True}, + } + + _attribute_map = { + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'overwrite': {'key': 'overwrite', 'type': 'bool'}, + 'clone_custom_host_names': {'key': 'cloneCustomHostNames', 'type': 'bool'}, + 'clone_source_control': {'key': 'cloneSourceControl', 'type': 'bool'}, + 'source_web_app_id': {'key': 'sourceWebAppId', 'type': 'str'}, + 'source_web_app_location': {'key': 'sourceWebAppLocation', 'type': 'str'}, + 'hosting_environment': {'key': 'hostingEnvironment', 'type': 'str'}, + 'app_settings_overrides': {'key': 'appSettingsOverrides', 'type': '{str}'}, + 'configure_load_balancing': {'key': 'configureLoadBalancing', 'type': 'bool'}, + 'traffic_manager_profile_id': {'key': 'trafficManagerProfileId', 'type': 'str'}, + 'traffic_manager_profile_name': {'key': 'trafficManagerProfileName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CloningInfo, self).__init__(**kwargs) + self.correlation_id = kwargs.get('correlation_id', None) + self.overwrite = kwargs.get('overwrite', None) + self.clone_custom_host_names = kwargs.get('clone_custom_host_names', None) + self.clone_source_control = kwargs.get('clone_source_control', None) + self.source_web_app_id = kwargs['source_web_app_id'] + self.source_web_app_location = kwargs.get('source_web_app_location', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + self.app_settings_overrides = kwargs.get('app_settings_overrides', None) + self.configure_load_balancing = kwargs.get('configure_load_balancing', None) + self.traffic_manager_profile_id = kwargs.get('traffic_manager_profile_id', None) + self.traffic_manager_profile_name = kwargs.get('traffic_manager_profile_name', None) + + +class Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties(msrest.serialization.Model): + """Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Principal Id of user assigned identity. + :vartype principal_id: str + :ivar client_id: Client Id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionStringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Connection strings. + :type properties: dict[str, ~azure.mgmt.web.v2020_09_01.models.ConnStringValueTypePair] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{ConnStringValueTypePair}'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnectionStringDictionary, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class ConnStringInfo(msrest.serialization.Model): + """Database connection string information. + + :param name: Name of connection string. + :type name: str + :param connection_string: Connection string value. + :type connection_string: str + :param type: Type of database. Possible values include: "MySql", "SQLServer", "SQLAzure", + "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", "RedisCache", + "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ConnectionStringType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnStringInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.connection_string = kwargs.get('connection_string', None) + self.type = kwargs.get('type', None) + + +class ConnStringValueTypePair(msrest.serialization.Model): + """Database connection string value to type pair. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Value of pair. + :type value: str + :param type: Required. Type of database. Possible values include: "MySql", "SQLServer", + "SQLAzure", "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", + "RedisCache", "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ConnectionStringType + """ + + _validation = { + 'value': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ConnStringValueTypePair, self).__init__(**kwargs) + self.value = kwargs['value'] + self.type = kwargs['type'] + + +class Contact(msrest.serialization.Model): + """Contact information for domain registration. If 'Domain Privacy' option is not selected then the contact information is made publicly available through the Whois +directories as per ICANN requirements. + + All required parameters must be populated in order to send to Azure. + + :param address_mailing: Mailing address. + :type address_mailing: ~azure.mgmt.web.v2020_09_01.models.Address + :param email: Required. Email address. + :type email: str + :param fax: Fax number. + :type fax: str + :param job_title: Job title. + :type job_title: str + :param name_first: Required. First name. + :type name_first: str + :param name_last: Required. Last name. + :type name_last: str + :param name_middle: Middle name. + :type name_middle: str + :param organization: Organization contact belongs to. + :type organization: str + :param phone: Required. Phone number. + :type phone: str + """ + + _validation = { + 'email': {'required': True}, + 'name_first': {'required': True}, + 'name_last': {'required': True}, + 'phone': {'required': True}, + } + + _attribute_map = { + 'address_mailing': {'key': 'addressMailing', 'type': 'Address'}, + 'email': {'key': 'email', 'type': 'str'}, + 'fax': {'key': 'fax', 'type': 'str'}, + 'job_title': {'key': 'jobTitle', 'type': 'str'}, + 'name_first': {'key': 'nameFirst', 'type': 'str'}, + 'name_last': {'key': 'nameLast', 'type': 'str'}, + 'name_middle': {'key': 'nameMiddle', 'type': 'str'}, + 'organization': {'key': 'organization', 'type': 'str'}, + 'phone': {'key': 'phone', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Contact, self).__init__(**kwargs) + self.address_mailing = kwargs.get('address_mailing', None) + self.email = kwargs['email'] + self.fax = kwargs.get('fax', None) + self.job_title = kwargs.get('job_title', None) + self.name_first = kwargs['name_first'] + self.name_last = kwargs['name_last'] + self.name_middle = kwargs.get('name_middle', None) + self.organization = kwargs.get('organization', None) + self.phone = kwargs['phone'] + + +class ContainerCpuStatistics(msrest.serialization.Model): + """ContainerCpuStatistics. + + :param cpu_usage: + :type cpu_usage: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuUsage + :param system_cpu_usage: + :type system_cpu_usage: long + :param online_cpu_count: + :type online_cpu_count: int + :param throttling_data: + :type throttling_data: ~azure.mgmt.web.v2020_09_01.models.ContainerThrottlingData + """ + + _attribute_map = { + 'cpu_usage': {'key': 'cpuUsage', 'type': 'ContainerCpuUsage'}, + 'system_cpu_usage': {'key': 'systemCpuUsage', 'type': 'long'}, + 'online_cpu_count': {'key': 'onlineCpuCount', 'type': 'int'}, + 'throttling_data': {'key': 'throttlingData', 'type': 'ContainerThrottlingData'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerCpuStatistics, self).__init__(**kwargs) + self.cpu_usage = kwargs.get('cpu_usage', None) + self.system_cpu_usage = kwargs.get('system_cpu_usage', None) + self.online_cpu_count = kwargs.get('online_cpu_count', None) + self.throttling_data = kwargs.get('throttling_data', None) + + +class ContainerCpuUsage(msrest.serialization.Model): + """ContainerCpuUsage. + + :param total_usage: + :type total_usage: long + :param per_cpu_usage: + :type per_cpu_usage: list[long] + :param kernel_mode_usage: + :type kernel_mode_usage: long + :param user_mode_usage: + :type user_mode_usage: long + """ + + _attribute_map = { + 'total_usage': {'key': 'totalUsage', 'type': 'long'}, + 'per_cpu_usage': {'key': 'perCpuUsage', 'type': '[long]'}, + 'kernel_mode_usage': {'key': 'kernelModeUsage', 'type': 'long'}, + 'user_mode_usage': {'key': 'userModeUsage', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerCpuUsage, self).__init__(**kwargs) + self.total_usage = kwargs.get('total_usage', None) + self.per_cpu_usage = kwargs.get('per_cpu_usage', None) + self.kernel_mode_usage = kwargs.get('kernel_mode_usage', None) + self.user_mode_usage = kwargs.get('user_mode_usage', None) + + +class ContainerInfo(msrest.serialization.Model): + """ContainerInfo. + + :param current_time_stamp: + :type current_time_stamp: ~datetime.datetime + :param previous_time_stamp: + :type previous_time_stamp: ~datetime.datetime + :param current_cpu_stats: + :type current_cpu_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuStatistics + :param previous_cpu_stats: + :type previous_cpu_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuStatistics + :param memory_stats: + :type memory_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerMemoryStatistics + :param name: + :type name: str + :param id: + :type id: str + :param eth0: + :type eth0: ~azure.mgmt.web.v2020_09_01.models.ContainerNetworkInterfaceStatistics + """ + + _attribute_map = { + 'current_time_stamp': {'key': 'currentTimeStamp', 'type': 'iso-8601'}, + 'previous_time_stamp': {'key': 'previousTimeStamp', 'type': 'iso-8601'}, + 'current_cpu_stats': {'key': 'currentCpuStats', 'type': 'ContainerCpuStatistics'}, + 'previous_cpu_stats': {'key': 'previousCpuStats', 'type': 'ContainerCpuStatistics'}, + 'memory_stats': {'key': 'memoryStats', 'type': 'ContainerMemoryStatistics'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'eth0': {'key': 'eth0', 'type': 'ContainerNetworkInterfaceStatistics'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerInfo, self).__init__(**kwargs) + self.current_time_stamp = kwargs.get('current_time_stamp', None) + self.previous_time_stamp = kwargs.get('previous_time_stamp', None) + self.current_cpu_stats = kwargs.get('current_cpu_stats', None) + self.previous_cpu_stats = kwargs.get('previous_cpu_stats', None) + self.memory_stats = kwargs.get('memory_stats', None) + self.name = kwargs.get('name', None) + self.id = kwargs.get('id', None) + self.eth0 = kwargs.get('eth0', None) + + +class ContainerMemoryStatistics(msrest.serialization.Model): + """ContainerMemoryStatistics. + + :param usage: + :type usage: long + :param max_usage: + :type max_usage: long + :param limit: + :type limit: long + """ + + _attribute_map = { + 'usage': {'key': 'usage', 'type': 'long'}, + 'max_usage': {'key': 'maxUsage', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerMemoryStatistics, self).__init__(**kwargs) + self.usage = kwargs.get('usage', None) + self.max_usage = kwargs.get('max_usage', None) + self.limit = kwargs.get('limit', None) + + +class ContainerNetworkInterfaceStatistics(msrest.serialization.Model): + """ContainerNetworkInterfaceStatistics. + + :param rx_bytes: + :type rx_bytes: long + :param rx_packets: + :type rx_packets: long + :param rx_errors: + :type rx_errors: long + :param rx_dropped: + :type rx_dropped: long + :param tx_bytes: + :type tx_bytes: long + :param tx_packets: + :type tx_packets: long + :param tx_errors: + :type tx_errors: long + :param tx_dropped: + :type tx_dropped: long + """ + + _attribute_map = { + 'rx_bytes': {'key': 'rxBytes', 'type': 'long'}, + 'rx_packets': {'key': 'rxPackets', 'type': 'long'}, + 'rx_errors': {'key': 'rxErrors', 'type': 'long'}, + 'rx_dropped': {'key': 'rxDropped', 'type': 'long'}, + 'tx_bytes': {'key': 'txBytes', 'type': 'long'}, + 'tx_packets': {'key': 'txPackets', 'type': 'long'}, + 'tx_errors': {'key': 'txErrors', 'type': 'long'}, + 'tx_dropped': {'key': 'txDropped', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerNetworkInterfaceStatistics, self).__init__(**kwargs) + self.rx_bytes = kwargs.get('rx_bytes', None) + self.rx_packets = kwargs.get('rx_packets', None) + self.rx_errors = kwargs.get('rx_errors', None) + self.rx_dropped = kwargs.get('rx_dropped', None) + self.tx_bytes = kwargs.get('tx_bytes', None) + self.tx_packets = kwargs.get('tx_packets', None) + self.tx_errors = kwargs.get('tx_errors', None) + self.tx_dropped = kwargs.get('tx_dropped', None) + + +class ContainerThrottlingData(msrest.serialization.Model): + """ContainerThrottlingData. + + :param periods: + :type periods: int + :param throttled_periods: + :type throttled_periods: int + :param throttled_time: + :type throttled_time: int + """ + + _attribute_map = { + 'periods': {'key': 'periods', 'type': 'int'}, + 'throttled_periods': {'key': 'throttledPeriods', 'type': 'int'}, + 'throttled_time': {'key': 'throttledTime', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ContainerThrottlingData, self).__init__(**kwargs) + self.periods = kwargs.get('periods', None) + self.throttled_periods = kwargs.get('throttled_periods', None) + self.throttled_time = kwargs.get('throttled_time', None) + + +class ContinuousWebJob(ProxyOnlyResource): + """Continuous Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param status: Job status. Possible values include: "Initializing", "Starting", "Running", + "PendingRestart", "Stopped". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobStatus + :param detailed_status: Detailed status. + :type detailed_status: str + :param log_url: Log URL. + :type log_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'detailed_status': {'key': 'properties.detailed_status', 'type': 'str'}, + 'log_url': {'key': 'properties.log_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(ContinuousWebJob, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.detailed_status = kwargs.get('detailed_status', None) + self.log_url = kwargs.get('log_url', None) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class ContinuousWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ContinuousWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ContinuousWebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CookieExpiration(ProxyOnlyResource): + """CookieExpiration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param convention: Possible values include: "FixedTime", "IdentityProviderDerived". + :type convention: str or ~azure.mgmt.web.v2020_09_01.models.CookieExpirationConvention + :param time_to_expiration: + :type time_to_expiration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'time_to_expiration': {'key': 'properties.timeToExpiration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CookieExpiration, self).__init__(**kwargs) + self.convention = kwargs.get('convention', None) + self.time_to_expiration = kwargs.get('time_to_expiration', None) + + +class CorsSettings(msrest.serialization.Model): + """Cross-Origin Resource Sharing (CORS) settings for the app. + + :param allowed_origins: Gets or sets the list of origins that should be allowed to make cross- + origin + calls (for example: http://example.com:12345). Use "*" to allow all. + :type allowed_origins: list[str] + :param support_credentials: Gets or sets whether CORS requests with credentials are allowed. + See + https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#Requests_with_credentials + for more details. + :type support_credentials: bool + """ + + _attribute_map = { + 'allowed_origins': {'key': 'allowedOrigins', 'type': '[str]'}, + 'support_credentials': {'key': 'supportCredentials', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CorsSettings, self).__init__(**kwargs) + self.allowed_origins = kwargs.get('allowed_origins', None) + self.support_credentials = kwargs.get('support_credentials', None) + + +class CsmCopySlotEntity(msrest.serialization.Model): + """Copy deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during copy operation. + :type target_slot: str + :param site_config: Required. The site object which will be merged with the source slot site + to produce new destination slot site object. + :code:`null` to just copy source slot content. Otherwise a + :code:`Site` + object with properties to override source slot site. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + """ + + _validation = { + 'target_slot': {'required': True}, + 'site_config': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'site_config': {'key': 'siteConfig', 'type': 'SiteConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmCopySlotEntity, self).__init__(**kwargs) + self.target_slot = kwargs['target_slot'] + self.site_config = kwargs['site_config'] + + +class CsmMoveResourceEnvelope(msrest.serialization.Model): + """Object with a list of the resources that need to be moved and the resource group they should be moved to. + + :param target_resource_group: + :type target_resource_group: str + :param resources: + :type resources: list[str] + """ + + _validation = { + 'target_resource_group': {'max_length': 90, 'min_length': 1, 'pattern': r' ^[-\w\._\(\)]+[^\.]$'}, + } + + _attribute_map = { + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'resources': {'key': 'resources', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmMoveResourceEnvelope, self).__init__(**kwargs) + self.target_resource_group = kwargs.get('target_resource_group', None) + self.resources = kwargs.get('resources', None) + + +class CsmOperationCollection(msrest.serialization.Model): + """Collection of Azure resource manager operation metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.CsmOperationDescription] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmOperationDescription]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CsmOperationDescription(msrest.serialization.Model): + """Description of an operation available for Microsoft.Web resource provider. + + :param name: + :type name: str + :param display: Meta data about operation used for display in portal. + :type display: ~azure.mgmt.web.v2020_09_01.models.CsmOperationDisplay + :param origin: + :type origin: str + :param properties: Properties available for a Microsoft.Web resource provider operation. + :type properties: ~azure.mgmt.web.v2020_09_01.models.CsmOperationDescriptionProperties + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'CsmOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'CsmOperationDescriptionProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + self.origin = kwargs.get('origin', None) + self.properties = kwargs.get('properties', None) + + +class CsmOperationDescriptionProperties(msrest.serialization.Model): + """Properties available for a Microsoft.Web resource provider operation. + + :param service_specification: Resource metrics service provided by Microsoft.Insights resource + provider. + :type service_specification: ~azure.mgmt.web.v2020_09_01.models.ServiceSpecification + """ + + _attribute_map = { + 'service_specification': {'key': 'serviceSpecification', 'type': 'ServiceSpecification'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDescriptionProperties, self).__init__(**kwargs) + self.service_specification = kwargs.get('service_specification', None) + + +class CsmOperationDisplay(msrest.serialization.Model): + """Meta data about operation used for display in portal. + + :param provider: + :type provider: str + :param resource: + :type resource: str + :param operation: + :type operation: str + :param description: + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmOperationDisplay, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + self.description = kwargs.get('description', None) + + +class CsmPublishingCredentialsPoliciesCollection(ProxyOnlyResource): + """Publishing Credentials Policies collection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param ftp: Whether FTP is allowed. + :type ftp: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :param scm: Whether Scm Basic Auth is allowed. + :type scm: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'ftp': {'key': 'properties.ftp', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + 'scm': {'key': 'properties.scm', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesCollection, self).__init__(**kwargs) + self.ftp = kwargs.get('ftp', None) + self.scm = kwargs.get('scm', None) + + +class CsmPublishingCredentialsPoliciesEntity(ProxyOnlyResource): + """Publishing Credentials Policies parameters. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allow: :code:`true` to allow access to a publishing method; otherwise, + :code:`false`. + :type allow: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allow': {'key': 'properties.allow', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesEntity, self).__init__(**kwargs) + self.allow = kwargs.get('allow', None) + + +class CsmPublishingProfileOptions(msrest.serialization.Model): + """Publishing options for requested profile. + + :param format: Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp. Possible values include: "FileZilla3", "WebDeploy", "Ftp". + :type format: str or ~azure.mgmt.web.v2020_09_01.models.PublishingProfileFormat + :param include_disaster_recovery_endpoints: Include the DisasterRecover endpoint if true. + :type include_disaster_recovery_endpoints: bool + """ + + _attribute_map = { + 'format': {'key': 'format', 'type': 'str'}, + 'include_disaster_recovery_endpoints': {'key': 'includeDisasterRecoveryEndpoints', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmPublishingProfileOptions, self).__init__(**kwargs) + self.format = kwargs.get('format', None) + self.include_disaster_recovery_endpoints = kwargs.get('include_disaster_recovery_endpoints', None) + + +class CsmSlotEntity(msrest.serialization.Model): + """Deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during swap operation. + :type target_slot: str + :param preserve_vnet: Required. :code:`true` to preserve Virtual Network to the + slot during swap; otherwise, :code:`false`. + :type preserve_vnet: bool + """ + + _validation = { + 'target_slot': {'required': True}, + 'preserve_vnet': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'preserve_vnet': {'key': 'preserveVnet', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmSlotEntity, self).__init__(**kwargs) + self.target_slot = kwargs['target_slot'] + self.preserve_vnet = kwargs['preserve_vnet'] + + +class CsmUsageQuota(msrest.serialization.Model): + """Usage of the quota resource. + + :param unit: Units of measurement for the quota resource. + :type unit: str + :param next_reset_time: Next reset time for the resource counter. + :type next_reset_time: ~datetime.datetime + :param current_value: The current value of the resource counter. + :type current_value: long + :param limit: The resource limit. + :type limit: long + :param name: Quota name. + :type name: ~azure.mgmt.web.v2020_09_01.models.LocalizableString + """ + + _attribute_map = { + 'unit': {'key': 'unit', 'type': 'str'}, + 'next_reset_time': {'key': 'nextResetTime', 'type': 'iso-8601'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'LocalizableString'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmUsageQuota, self).__init__(**kwargs) + self.unit = kwargs.get('unit', None) + self.next_reset_time = kwargs.get('next_reset_time', None) + self.current_value = kwargs.get('current_value', None) + self.limit = kwargs.get('limit', None) + self.name = kwargs.get('name', None) + + +class CsmUsageQuotaCollection(msrest.serialization.Model): + """Collection of CSM usage quotas. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuota] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmUsageQuota]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CsmUsageQuotaCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class CustomHostnameAnalysisResult(ProxyOnlyResource): + """Custom domain analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar is_hostname_already_verified: :code:`true` if hostname is already verified; + otherwise, :code:`false`. + :vartype is_hostname_already_verified: bool + :ivar custom_domain_verification_test: DNS verification test result. Possible values include: + "Passed", "Failed", "Skipped". + :vartype custom_domain_verification_test: str or + ~azure.mgmt.web.v2020_09_01.models.DnsVerificationTestResult + :ivar custom_domain_verification_failure_info: Raw failure information if DNS verification + fails. + :vartype custom_domain_verification_failure_info: + ~azure.mgmt.web.v2020_09_01.models.ErrorEntity + :ivar has_conflict_on_scale_unit: :code:`true` if there is a conflict on a scale + unit; otherwise, :code:`false`. + :vartype has_conflict_on_scale_unit: bool + :ivar has_conflict_across_subscription: :code:`true` if there is a conflict across + subscriptions; otherwise, :code:`false`. + :vartype has_conflict_across_subscription: bool + :ivar conflicting_app_resource_id: Name of the conflicting app on scale unit if it's within the + same subscription. + :vartype conflicting_app_resource_id: str + :param c_name_records: CName records controller can see for this hostname. + :type c_name_records: list[str] + :param txt_records: TXT records controller can see for this hostname. + :type txt_records: list[str] + :param a_records: A records controller can see for this hostname. + :type a_records: list[str] + :param alternate_c_name_records: Alternate CName records controller can see for this hostname. + :type alternate_c_name_records: list[str] + :param alternate_txt_records: Alternate TXT records controller can see for this hostname. + :type alternate_txt_records: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'is_hostname_already_verified': {'readonly': True}, + 'custom_domain_verification_test': {'readonly': True}, + 'custom_domain_verification_failure_info': {'readonly': True}, + 'has_conflict_on_scale_unit': {'readonly': True}, + 'has_conflict_across_subscription': {'readonly': True}, + 'conflicting_app_resource_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_hostname_already_verified': {'key': 'properties.isHostnameAlreadyVerified', 'type': 'bool'}, + 'custom_domain_verification_test': {'key': 'properties.customDomainVerificationTest', 'type': 'str'}, + 'custom_domain_verification_failure_info': {'key': 'properties.customDomainVerificationFailureInfo', 'type': 'ErrorEntity'}, + 'has_conflict_on_scale_unit': {'key': 'properties.hasConflictOnScaleUnit', 'type': 'bool'}, + 'has_conflict_across_subscription': {'key': 'properties.hasConflictAcrossSubscription', 'type': 'bool'}, + 'conflicting_app_resource_id': {'key': 'properties.conflictingAppResourceId', 'type': 'str'}, + 'c_name_records': {'key': 'properties.cNameRecords', 'type': '[str]'}, + 'txt_records': {'key': 'properties.txtRecords', 'type': '[str]'}, + 'a_records': {'key': 'properties.aRecords', 'type': '[str]'}, + 'alternate_c_name_records': {'key': 'properties.alternateCNameRecords', 'type': '[str]'}, + 'alternate_txt_records': {'key': 'properties.alternateTxtRecords', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomHostnameAnalysisResult, self).__init__(**kwargs) + self.is_hostname_already_verified = None + self.custom_domain_verification_test = None + self.custom_domain_verification_failure_info = None + self.has_conflict_on_scale_unit = None + self.has_conflict_across_subscription = None + self.conflicting_app_resource_id = None + self.c_name_records = kwargs.get('c_name_records', None) + self.txt_records = kwargs.get('txt_records', None) + self.a_records = kwargs.get('a_records', None) + self.alternate_c_name_records = kwargs.get('alternate_c_name_records', None) + self.alternate_txt_records = kwargs.get('alternate_txt_records', None) + + +class CustomOpenIdConnectProvider(ProxyOnlyResource): + """CustomOpenIdConnectProvider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectLogin + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'OpenIdConnectRegistration'}, + 'login': {'key': 'properties.login', 'type': 'OpenIdConnectLogin'}, + } + + def __init__( + self, + **kwargs + ): + super(CustomOpenIdConnectProvider, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + + +class DatabaseBackupSetting(msrest.serialization.Model): + """Database backup settings. + + All required parameters must be populated in order to send to Azure. + + :param database_type: Required. Database type (e.g. SqlAzure / MySql). Possible values include: + "SqlAzure", "MySql", "LocalMySql", "PostgreSql". + :type database_type: str or ~azure.mgmt.web.v2020_09_01.models.DatabaseType + :param name: + :type name: str + :param connection_string_name: Contains a connection string name that is linked to the + SiteConfig.ConnectionStrings. + This is used during restore with overwrite connection strings options. + :type connection_string_name: str + :param connection_string: Contains a connection string to a database which is being backed up + or restored. If the restore should happen to a new database, the database name inside is the + new one. + :type connection_string: str + """ + + _validation = { + 'database_type': {'required': True}, + } + + _attribute_map = { + 'database_type': {'key': 'databaseType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string_name': {'key': 'connectionStringName', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DatabaseBackupSetting, self).__init__(**kwargs) + self.database_type = kwargs['database_type'] + self.name = kwargs.get('name', None) + self.connection_string_name = kwargs.get('connection_string_name', None) + self.connection_string = kwargs.get('connection_string', None) + + +class DataSource(msrest.serialization.Model): + """Class representing data source used by the detectors. + + :param instructions: Instructions if any for the data source. + :type instructions: list[str] + :param data_source_uri: Datasource Uri Links. + :type data_source_uri: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + """ + + _attribute_map = { + 'instructions': {'key': 'instructions', 'type': '[str]'}, + 'data_source_uri': {'key': 'dataSourceUri', 'type': '[NameValuePair]'}, + } + + def __init__( + self, + **kwargs + ): + super(DataSource, self).__init__(**kwargs) + self.instructions = kwargs.get('instructions', None) + self.data_source_uri = kwargs.get('data_source_uri', None) + + +class DataTableResponseColumn(msrest.serialization.Model): + """Column definition. + + :param column_name: Name of the column. + :type column_name: str + :param data_type: Data type which looks like 'String' or 'Int32'. + :type data_type: str + :param column_type: Column Type. + :type column_type: str + """ + + _attribute_map = { + 'column_name': {'key': 'columnName', 'type': 'str'}, + 'data_type': {'key': 'dataType', 'type': 'str'}, + 'column_type': {'key': 'columnType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DataTableResponseColumn, self).__init__(**kwargs) + self.column_name = kwargs.get('column_name', None) + self.data_type = kwargs.get('data_type', None) + self.column_type = kwargs.get('column_type', None) + + +class DataTableResponseObject(msrest.serialization.Model): + """Data Table which defines columns and raw row values. + + :param table_name: Name of the table. + :type table_name: str + :param columns: List of columns with data types. + :type columns: list[~azure.mgmt.web.v2020_09_01.models.DataTableResponseColumn] + :param rows: Raw row values. + :type rows: list[list[str]] + """ + + _attribute_map = { + 'table_name': {'key': 'tableName', 'type': 'str'}, + 'columns': {'key': 'columns', 'type': '[DataTableResponseColumn]'}, + 'rows': {'key': 'rows', 'type': '[[str]]'}, + } + + def __init__( + self, + **kwargs + ): + super(DataTableResponseObject, self).__init__(**kwargs) + self.table_name = kwargs.get('table_name', None) + self.columns = kwargs.get('columns', None) + self.rows = kwargs.get('rows', None) + + +class DefaultErrorResponse(msrest.serialization.Model): + """App Service error response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: Error model. + :vartype error: ~azure.mgmt.web.v2020_09_01.models.DefaultErrorResponseError + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'DefaultErrorResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponse, self).__init__(**kwargs) + self.error = None + + +class DefaultErrorResponseError(msrest.serialization.Model): + """Error model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + :param details: + :type details: list[~azure.mgmt.web.v2020_09_01.models.DefaultErrorResponseErrorDetailsItem] + :ivar innererror: More information to debug error. + :vartype innererror: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'innererror': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[DefaultErrorResponseErrorDetailsItem]'}, + 'innererror': {'key': 'innererror', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseError, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = kwargs.get('details', None) + self.innererror = None + + +class DefaultErrorResponseErrorDetailsItem(msrest.serialization.Model): + """Detailed errors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseErrorDetailsItem, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + + +class DeletedAppRestoreRequest(ProxyOnlyResource): + """Details about restoring a deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param deleted_site_id: ARM resource ID of the deleted app. Example: + /subscriptions/{subId}/providers/Microsoft.Web/deletedSites/{deletedSiteId}. + :type deleted_site_id: str + :param recover_configuration: If true, deleted site configuration, in addition to content, will + be restored. + :type recover_configuration: bool + :param snapshot_time: Point in time to restore the deleted app from, formatted as a DateTime + string. + If unspecified, default value is the time that the app was deleted. + :type snapshot_time: str + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'str'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedAppRestoreRequest, self).__init__(**kwargs) + self.deleted_site_id = kwargs.get('deleted_site_id', None) + self.recover_configuration = kwargs.get('recover_configuration', None) + self.snapshot_time = kwargs.get('snapshot_time', None) + self.use_dr_secondary = kwargs.get('use_dr_secondary', None) + + +class DeletedSite(ProxyOnlyResource): + """A deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar deleted_site_id: Numeric id for the deleted site. + :vartype deleted_site_id: int + :ivar deleted_timestamp: Time in UTC when the app was deleted. + :vartype deleted_timestamp: str + :ivar subscription: Subscription containing the deleted site. + :vartype subscription: str + :ivar resource_group: ResourceGroup that contained the deleted site. + :vartype resource_group: str + :ivar deleted_site_name: Name of the deleted site. + :vartype deleted_site_name: str + :ivar slot: Slot of the deleted site. + :vartype slot: str + :ivar kind_properties_kind: Kind of site that was deleted. + :vartype kind_properties_kind: str + :ivar geo_region_name: Geo Region of the deleted site. + :vartype geo_region_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'deleted_site_id': {'readonly': True}, + 'deleted_timestamp': {'readonly': True}, + 'subscription': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'deleted_site_name': {'readonly': True}, + 'slot': {'readonly': True}, + 'kind_properties_kind': {'readonly': True}, + 'geo_region_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'int'}, + 'deleted_timestamp': {'key': 'properties.deletedTimestamp', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'deleted_site_name': {'key': 'properties.deletedSiteName', 'type': 'str'}, + 'slot': {'key': 'properties.slot', 'type': 'str'}, + 'kind_properties_kind': {'key': 'properties.kind', 'type': 'str'}, + 'geo_region_name': {'key': 'properties.geoRegionName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedSite, self).__init__(**kwargs) + self.deleted_site_id = None + self.deleted_timestamp = None + self.subscription = None + self.resource_group = None + self.deleted_site_name = None + self.slot = None + self.kind_properties_kind = None + self.geo_region_name = None + + +class DeletedWebAppCollection(msrest.serialization.Model): + """Collection of deleted apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DeletedSite] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeletedSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeletedWebAppCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Deployment(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param status: Deployment status. + :type status: int + :param message: Details about deployment status. + :type message: str + :param author: Who authored the deployment. + :type author: str + :param deployer: Who performed the deployment. + :type deployer: str + :param author_email: Author email. + :type author_email: str + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param active: True if deployment is currently active, false if completed and null if not + started. + :type active: bool + :param details: Details on deployment. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'status': {'key': 'properties.status', 'type': 'int'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'author': {'key': 'properties.author', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'author_email': {'key': 'properties.author_email', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'active': {'key': 'properties.active', 'type': 'bool'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Deployment, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.message = kwargs.get('message', None) + self.author = kwargs.get('author', None) + self.deployer = kwargs.get('deployer', None) + self.author_email = kwargs.get('author_email', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.active = kwargs.get('active', None) + self.details = kwargs.get('details', None) + + +class DeploymentCollection(msrest.serialization.Model): + """Collection of app deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Deployment] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Deployment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DeploymentLocations(msrest.serialization.Model): + """List of available locations (regions or App Service Environments) for +deployment of App Service resources. + + :param locations: Available regions. + :type locations: list[~azure.mgmt.web.v2020_09_01.models.GeoRegion] + :param hosting_environments: Available App Service Environments with full descriptions of the + environments. + :type hosting_environments: list[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironment] + :param hosting_environment_deployment_infos: Available App Service Environments with basic + information. + :type hosting_environment_deployment_infos: + list[~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDeploymentInfo] + """ + + _attribute_map = { + 'locations': {'key': 'locations', 'type': '[GeoRegion]'}, + 'hosting_environments': {'key': 'hostingEnvironments', 'type': '[AppServiceEnvironment]'}, + 'hosting_environment_deployment_infos': {'key': 'hostingEnvironmentDeploymentInfos', 'type': '[HostingEnvironmentDeploymentInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentLocations, self).__init__(**kwargs) + self.locations = kwargs.get('locations', None) + self.hosting_environments = kwargs.get('hosting_environments', None) + self.hosting_environment_deployment_infos = kwargs.get('hosting_environment_deployment_infos', None) + + +class DetectorAbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period detected. + + :param start_time: Start time of the correlated event. + :type start_time: ~datetime.datetime + :param end_time: End time of the correlated event. + :type end_time: ~datetime.datetime + :param message: Message describing the event. + :type message: str + :param source: Represents the name of the Detector. + :type source: str + :param priority: Represents the rank of the Detector. + :type priority: float + :param meta_data: Downtime metadata. + :type meta_data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param type: Represents the type of the Detector. Possible values include: "ServiceIncident", + "AppDeployment", "AppCrash", "RuntimeIssueDetected", "AseDeployment", "UserIssue", + "PlatformIssue", "Other". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.IssueType + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_09_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'message': {'key': 'message', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'float'}, + 'meta_data': {'key': 'metaData', 'type': '[[NameValuePair]]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorAbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.message = kwargs.get('message', None) + self.source = kwargs.get('source', None) + self.priority = kwargs.get('priority', None) + self.meta_data = kwargs.get('meta_data', None) + self.type = kwargs.get('type', None) + self.solutions = kwargs.get('solutions', None) + + +class DetectorDefinition(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar display_name: Display name of the detector. + :vartype display_name: str + :ivar description: Description of the detector. + :vartype description: str + :ivar rank: Detector Rank. + :vartype rank: float + :ivar is_enabled: Flag representing whether detector is enabled or not. + :vartype is_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'display_name': {'readonly': True}, + 'description': {'readonly': True}, + 'rank': {'readonly': True}, + 'is_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'rank': {'key': 'properties.rank', 'type': 'float'}, + 'is_enabled': {'key': 'properties.isEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorDefinition, self).__init__(**kwargs) + self.display_name = None + self.description = None + self.rank = None + self.is_enabled = None + + +class DetectorInfo(msrest.serialization.Model): + """Definition of Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Short description of the detector and its purpose. + :vartype description: str + :ivar category: Support Category. + :vartype category: str + :ivar sub_category: Support Sub Category. + :vartype sub_category: str + :ivar support_topic_id: Support Topic Id. + :vartype support_topic_id: str + """ + + _validation = { + 'description': {'readonly': True}, + 'category': {'readonly': True}, + 'sub_category': {'readonly': True}, + 'support_topic_id': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'sub_category': {'key': 'subCategory', 'type': 'str'}, + 'support_topic_id': {'key': 'supportTopicId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorInfo, self).__init__(**kwargs) + self.description = None + self.category = None + self.sub_category = None + self.support_topic_id = None + + +class DetectorResponse(ProxyOnlyResource): + """Class representing Response from Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param metadata: metadata for the detector. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.DetectorInfo + :param dataset: Data Set. + :type dataset: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticData] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'metadata': {'key': 'properties.metadata', 'type': 'DetectorInfo'}, + 'dataset': {'key': 'properties.dataset', 'type': '[DiagnosticData]'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorResponse, self).__init__(**kwargs) + self.metadata = kwargs.get('metadata', None) + self.dataset = kwargs.get('dataset', None) + + +class DetectorResponseCollection(msrest.serialization.Model): + """Collection of detector responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DetectorResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorResponseCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticAnalysis(ProxyOnlyResource): + """Class representing a diagnostic analysis done on an application. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param abnormal_time_periods: List of time periods. + :type abnormal_time_periods: list[~azure.mgmt.web.v2020_09_01.models.AbnormalTimePeriod] + :param payload: Data by each detector. + :type payload: list[~azure.mgmt.web.v2020_09_01.models.AnalysisData] + :param non_correlated_detectors: Data by each detector for detectors that did not corelate. + :type non_correlated_detectors: list[~azure.mgmt.web.v2020_09_01.models.DetectorDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[AbnormalTimePeriod]'}, + 'payload': {'key': 'properties.payload', 'type': '[AnalysisData]'}, + 'non_correlated_detectors': {'key': 'properties.nonCorrelatedDetectors', 'type': '[DetectorDefinition]'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticAnalysis, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.abnormal_time_periods = kwargs.get('abnormal_time_periods', None) + self.payload = kwargs.get('payload', None) + self.non_correlated_detectors = kwargs.get('non_correlated_detectors', None) + + +class DiagnosticAnalysisCollection(msrest.serialization.Model): + """Collection of Diagnostic Analyses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AnalysisDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticAnalysisCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticCategory(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Description of the diagnostic category. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticCategory, self).__init__(**kwargs) + self.description = None + + +class DiagnosticCategoryCollection(msrest.serialization.Model): + """Collection of Diagnostic Categories. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DiagnosticCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticCategoryCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticData(msrest.serialization.Model): + """Set of data with rendering instructions. + + :param table: Data in table form. + :type table: ~azure.mgmt.web.v2020_09_01.models.DataTableResponseObject + :param rendering_properties: Properties that describe how the table should be rendered. + :type rendering_properties: ~azure.mgmt.web.v2020_09_01.models.Rendering + """ + + _attribute_map = { + 'table': {'key': 'table', 'type': 'DataTableResponseObject'}, + 'rendering_properties': {'key': 'renderingProperties', 'type': 'Rendering'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticData, self).__init__(**kwargs) + self.table = kwargs.get('table', None) + self.rendering_properties = kwargs.get('rendering_properties', None) + + +class DiagnosticDetectorCollection(msrest.serialization.Model): + """Collection of Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DetectorDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticDetectorCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DiagnosticDetectorResponse(ProxyOnlyResource): + """Class representing Response from Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param issue_detected: Flag representing Issue was detected. + :type issue_detected: bool + :param detector_definition: Detector's definition. + :type detector_definition: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :param metrics: Metrics provided by the detector. + :type metrics: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSet] + :param abnormal_time_periods: List of Correlated events found by the detector. + :type abnormal_time_periods: + list[~azure.mgmt.web.v2020_09_01.models.DetectorAbnormalTimePeriod] + :param data: Additional Data that detector wants to send. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param response_meta_data: Meta Data. + :type response_meta_data: ~azure.mgmt.web.v2020_09_01.models.ResponseMetaData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'issue_detected': {'key': 'properties.issueDetected', 'type': 'bool'}, + 'detector_definition': {'key': 'properties.detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'properties.metrics', 'type': '[DiagnosticMetricSet]'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[DetectorAbnormalTimePeriod]'}, + 'data': {'key': 'properties.data', 'type': '[[NameValuePair]]'}, + 'response_meta_data': {'key': 'properties.responseMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticDetectorResponse, self).__init__(**kwargs) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.issue_detected = kwargs.get('issue_detected', None) + self.detector_definition = kwargs.get('detector_definition', None) + self.metrics = kwargs.get('metrics', None) + self.abnormal_time_periods = kwargs.get('abnormal_time_periods', None) + self.data = kwargs.get('data', None) + self.response_meta_data = kwargs.get('response_meta_data', None) + + +class DiagnosticMetricSample(msrest.serialization.Model): + """Class representing Diagnostic Metric. + + :param timestamp: Time at which metric is measured. + :type timestamp: ~datetime.datetime + :param role_instance: Role Instance. Null if this counter is not per instance + This is returned and should be whichever instance name we desire to be returned + i.e. CPU and Memory return RDWORKERNAME (LargeDed..._IN_0) + where RDWORKERNAME is Machine name below and RoleInstance name in parenthesis. + :type role_instance: str + :param total: Total value of the metric. If multiple measurements are made this will have sum + of all. + :type total: float + :param maximum: Maximum of the metric sampled during the time period. + :type maximum: float + :param minimum: Minimum of the metric sampled during the time period. + :type minimum: float + :param is_aggregated: Whether the values are aggregates across all workers or not. + :type is_aggregated: bool + """ + + _attribute_map = { + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'role_instance': {'key': 'roleInstance', 'type': 'str'}, + 'total': {'key': 'total', 'type': 'float'}, + 'maximum': {'key': 'maximum', 'type': 'float'}, + 'minimum': {'key': 'minimum', 'type': 'float'}, + 'is_aggregated': {'key': 'isAggregated', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticMetricSample, self).__init__(**kwargs) + self.timestamp = kwargs.get('timestamp', None) + self.role_instance = kwargs.get('role_instance', None) + self.total = kwargs.get('total', None) + self.maximum = kwargs.get('maximum', None) + self.minimum = kwargs.get('minimum', None) + self.is_aggregated = kwargs.get('is_aggregated', None) + + +class DiagnosticMetricSet(msrest.serialization.Model): + """Class representing Diagnostic Metric information. + + :param name: Name of the metric. + :type name: str + :param unit: Metric's unit. + :type unit: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. Supported grains at the moment are PT1M, PT1H, P1D. + :type time_grain: str + :param values: Collection of metric values for the selected period based on the + {Microsoft.Web.Hosting.Administration.DiagnosticMetricSet.TimeGrain}. + :type values: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[DiagnosticMetricSample]'}, + } + + def __init__( + self, + **kwargs + ): + super(DiagnosticMetricSet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.unit = kwargs.get('unit', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.time_grain = kwargs.get('time_grain', None) + self.values = kwargs.get('values', None) + + +class Dimension(msrest.serialization.Model): + """Dimension of a resource metric. For e.g. instance specific HTTP requests for a web app, +where instance name is dimension of the metric HTTP request. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param internal_name: + :type internal_name: str + :param to_be_exported_for_shoebox: + :type to_be_exported_for_shoebox: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + 'to_be_exported_for_shoebox': {'key': 'toBeExportedForShoebox', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(Dimension, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.internal_name = kwargs.get('internal_name', None) + self.to_be_exported_for_shoebox = kwargs.get('to_be_exported_for_shoebox', None) + + +class Domain(Resource): + """Information about a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_09_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_09_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_09_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_09_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.DomainPropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Domain, self).__init__(**kwargs) + self.contact_admin = kwargs.get('contact_admin', None) + self.contact_billing = kwargs.get('contact_billing', None) + self.contact_registrant = kwargs.get('contact_registrant', None) + self.contact_tech = kwargs.get('contact_tech', None) + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = kwargs.get('privacy', None) + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = kwargs.get('auto_renew', True) + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = kwargs.get('consent', None) + self.domain_not_renewable_reasons = None + self.dns_type = kwargs.get('dns_type', None) + self.dns_zone_id = kwargs.get('dns_zone_id', None) + self.target_dns_type = kwargs.get('target_dns_type', None) + self.auth_code = kwargs.get('auth_code', None) + + +class DomainAvailabilityCheckResult(msrest.serialization.Model): + """Domain availability check result. + + :param name: Name of the domain. + :type name: str + :param available: :code:`true` if domain can be purchased using CreateDomain API; + otherwise, :code:`false`. + :type available: bool + :param domain_type: Valid values are Regular domain: Azure will charge the full price of domain + registration, SoftDeleted: Purchasing this domain will simply restore it and this operation + will not cost anything. Possible values include: "Regular", "SoftDeleted". + :type domain_type: str or ~azure.mgmt.web.v2020_09_01.models.DomainType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available': {'key': 'available', 'type': 'bool'}, + 'domain_type': {'key': 'domainType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainAvailabilityCheckResult, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.available = kwargs.get('available', None) + self.domain_type = kwargs.get('domain_type', None) + + +class DomainCollection(msrest.serialization.Model): + """Collection of domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Domain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Domain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DomainControlCenterSsoRequest(msrest.serialization.Model): + """Single sign-on request information for domain management. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar url: URL where the single sign-on request is to be made. + :vartype url: str + :ivar post_parameter_key: Post parameter key. + :vartype post_parameter_key: str + :ivar post_parameter_value: Post parameter value. Client should use 'application/x-www-form- + urlencoded' encoding for this value. + :vartype post_parameter_value: str + """ + + _validation = { + 'url': {'readonly': True}, + 'post_parameter_key': {'readonly': True}, + 'post_parameter_value': {'readonly': True}, + } + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + 'post_parameter_key': {'key': 'postParameterKey', 'type': 'str'}, + 'post_parameter_value': {'key': 'postParameterValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainControlCenterSsoRequest, self).__init__(**kwargs) + self.url = None + self.post_parameter_key = None + self.post_parameter_value = None + + +class DomainOwnershipIdentifier(ProxyOnlyResource): + """Domain ownership Identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param ownership_id: Ownership Id. + :type ownership_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'ownership_id': {'key': 'properties.ownershipId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainOwnershipIdentifier, self).__init__(**kwargs) + self.ownership_id = kwargs.get('ownership_id', None) + + +class DomainOwnershipIdentifierCollection(msrest.serialization.Model): + """Collection of domain ownership identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DomainOwnershipIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainOwnershipIdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class DomainPatchResource(ProxyOnlyResource): + """ARM resource for a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_09_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_09_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_09_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_09_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.DomainPatchResourcePropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainPatchResource, self).__init__(**kwargs) + self.contact_admin = kwargs.get('contact_admin', None) + self.contact_billing = kwargs.get('contact_billing', None) + self.contact_registrant = kwargs.get('contact_registrant', None) + self.contact_tech = kwargs.get('contact_tech', None) + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = kwargs.get('privacy', None) + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = kwargs.get('auto_renew', True) + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = kwargs.get('consent', None) + self.domain_not_renewable_reasons = None + self.dns_type = kwargs.get('dns_type', None) + self.dns_zone_id = kwargs.get('dns_zone_id', None) + self.target_dns_type = kwargs.get('target_dns_type', None) + self.auth_code = kwargs.get('auth_code', None) + + +class DomainPurchaseConsent(msrest.serialization.Model): + """Domain purchase consent object, representing acceptance of applicable legal agreements. + + :param agreement_keys: List of applicable legal agreement keys. This list can be retrieved + using ListLegalAgreements API under :code:`TopLevelDomain` resource. + :type agreement_keys: list[str] + :param agreed_by: Client IP address. + :type agreed_by: str + :param agreed_at: Timestamp when the agreements were accepted. + :type agreed_at: ~datetime.datetime + """ + + _attribute_map = { + 'agreement_keys': {'key': 'agreementKeys', 'type': '[str]'}, + 'agreed_by': {'key': 'agreedBy', 'type': 'str'}, + 'agreed_at': {'key': 'agreedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainPurchaseConsent, self).__init__(**kwargs) + self.agreement_keys = kwargs.get('agreement_keys', None) + self.agreed_by = kwargs.get('agreed_by', None) + self.agreed_at = kwargs.get('agreed_at', None) + + +class DomainRecommendationSearchParameters(msrest.serialization.Model): + """Domain recommendation search parameters. + + :param keywords: Keywords to be used for generating domain recommendations. + :type keywords: str + :param max_domain_recommendations: Maximum number of recommendations. + :type max_domain_recommendations: int + """ + + _attribute_map = { + 'keywords': {'key': 'keywords', 'type': 'str'}, + 'max_domain_recommendations': {'key': 'maxDomainRecommendations', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainRecommendationSearchParameters, self).__init__(**kwargs) + self.keywords = kwargs.get('keywords', None) + self.max_domain_recommendations = kwargs.get('max_domain_recommendations', None) + + +class EnabledConfig(msrest.serialization.Model): + """Enabled configuration. + + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(EnabledConfig, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + + +class EndpointDependency(msrest.serialization.Model): + """A domain name that a service is reached at, including details of the current connection status. + + :param domain_name: The domain name of the dependency. + :type domain_name: str + :param endpoint_details: The IP Addresses and Ports used when connecting to DomainName. + :type endpoint_details: list[~azure.mgmt.web.v2020_09_01.models.EndpointDetail] + """ + + _attribute_map = { + 'domain_name': {'key': 'domainName', 'type': 'str'}, + 'endpoint_details': {'key': 'endpointDetails', 'type': '[EndpointDetail]'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointDependency, self).__init__(**kwargs) + self.domain_name = kwargs.get('domain_name', None) + self.endpoint_details = kwargs.get('endpoint_details', None) + + +class EndpointDetail(msrest.serialization.Model): + """Current TCP connectivity information from the App Service Environment to a single endpoint. + + :param ip_address: An IP Address that Domain Name currently resolves to. + :type ip_address: str + :param port: The port an endpoint is connected to. + :type port: int + :param latency: The time in milliseconds it takes for a TCP connection to be created from the + App Service Environment to this IpAddress at this Port. + :type latency: float + :param is_accessible: Whether it is possible to create a TCP connection from the App Service + Environment to this IpAddress at this Port. + :type is_accessible: bool + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + 'latency': {'key': 'latency', 'type': 'float'}, + 'is_accessible': {'key': 'isAccessible', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointDetail, self).__init__(**kwargs) + self.ip_address = kwargs.get('ip_address', None) + self.port = kwargs.get('port', None) + self.latency = kwargs.get('latency', None) + self.is_accessible = kwargs.get('is_accessible', None) + + +class ErrorEntity(msrest.serialization.Model): + """Body of the error response returned from the API. + + :param extended_code: Type of error. + :type extended_code: str + :param message_template: Message template. + :type message_template: str + :param parameters: Parameters for the template. + :type parameters: list[str] + :param inner_errors: Inner errors. + :type inner_errors: list[~azure.mgmt.web.v2020_09_01.models.ErrorEntity] + :param code: Basic error code. + :type code: str + :param message: Any details of the error. + :type message: str + """ + + _attribute_map = { + 'extended_code': {'key': 'extendedCode', 'type': 'str'}, + 'message_template': {'key': 'messageTemplate', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[str]'}, + 'inner_errors': {'key': 'innerErrors', 'type': '[ErrorEntity]'}, + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorEntity, self).__init__(**kwargs) + self.extended_code = kwargs.get('extended_code', None) + self.message_template = kwargs.get('message_template', None) + self.parameters = kwargs.get('parameters', None) + self.inner_errors = kwargs.get('inner_errors', None) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + + +class Experiments(msrest.serialization.Model): + """Routing rules in production experiments. + + :param ramp_up_rules: List of ramp-up rules. + :type ramp_up_rules: list[~azure.mgmt.web.v2020_09_01.models.RampUpRule] + """ + + _attribute_map = { + 'ramp_up_rules': {'key': 'rampUpRules', 'type': '[RampUpRule]'}, + } + + def __init__( + self, + **kwargs + ): + super(Experiments, self).__init__(**kwargs) + self.ramp_up_rules = kwargs.get('ramp_up_rules', None) + + +class Facebook(ProxyOnlyResource): + """Facebook. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.AppRegistration + :param graph_api_version: + :type graph_api_version: str + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AppRegistration'}, + 'graph_api_version': {'key': 'properties.graphApiVersion', 'type': 'str'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + **kwargs + ): + super(Facebook, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.graph_api_version = kwargs.get('graph_api_version', None) + self.login = kwargs.get('login', None) + + +class FileSystemApplicationLogsConfig(msrest.serialization.Model): + """Application logs to file system configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemApplicationLogsConfig, self).__init__(**kwargs) + self.level = kwargs.get('level', None) + + +class FileSystemHttpLogsConfig(msrest.serialization.Model): + """Http logs to file system configuration. + + :param retention_in_mb: Maximum size in megabytes that http log files can use. + When reached old log files will be removed to make space for new ones. + Value can range between 25 and 100. + :type retention_in_mb: int + :param retention_in_days: Retention in days. + Remove files older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _validation = { + 'retention_in_mb': {'maximum': 100, 'minimum': 25}, + } + + _attribute_map = { + 'retention_in_mb': {'key': 'retentionInMb', 'type': 'int'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemHttpLogsConfig, self).__init__(**kwargs) + self.retention_in_mb = kwargs.get('retention_in_mb', None) + self.retention_in_days = kwargs.get('retention_in_days', None) + self.enabled = kwargs.get('enabled', None) + + +class FileSystemTokenStore(ProxyOnlyResource): + """FileSystemTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param directory: + :type directory: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'directory': {'key': 'properties.directory', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FileSystemTokenStore, self).__init__(**kwargs) + self.directory = kwargs.get('directory', None) + + +class ForwardProxy(ProxyOnlyResource): + """ForwardProxy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param convention: Possible values include: "NoProxy", "Standard", "Custom". + :type convention: str or ~azure.mgmt.web.v2020_09_01.models.ForwardProxyConvention + :param custom_host_header_name: + :type custom_host_header_name: str + :param custom_proto_header_name: + :type custom_proto_header_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'custom_host_header_name': {'key': 'properties.customHostHeaderName', 'type': 'str'}, + 'custom_proto_header_name': {'key': 'properties.customProtoHeaderName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ForwardProxy, self).__init__(**kwargs) + self.convention = kwargs.get('convention', None) + self.custom_host_header_name = kwargs.get('custom_host_header_name', None) + self.custom_proto_header_name = kwargs.get('custom_proto_header_name', None) + + +class FunctionEnvelope(ProxyOnlyResource): + """Function information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param function_app_id: Function App ID. + :type function_app_id: str + :param script_root_path_href: Script root path URI. + :type script_root_path_href: str + :param script_href: Script URI. + :type script_href: str + :param config_href: Config URI. + :type config_href: str + :param test_data_href: Test data URI. + :type test_data_href: str + :param secrets_file_href: Secrets file URI. + :type secrets_file_href: str + :param href: Function URI. + :type href: str + :param config: Config information. + :type config: object + :param files: File list. + :type files: dict[str, str] + :param test_data: Test data used when testing via the Azure Portal. + :type test_data: str + :param invoke_url_template: The invocation URL. + :type invoke_url_template: str + :param language: The function language. + :type language: str + :param is_disabled: Gets or sets a value indicating whether the function is disabled. + :type is_disabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'function_app_id': {'key': 'properties.function_app_id', 'type': 'str'}, + 'script_root_path_href': {'key': 'properties.script_root_path_href', 'type': 'str'}, + 'script_href': {'key': 'properties.script_href', 'type': 'str'}, + 'config_href': {'key': 'properties.config_href', 'type': 'str'}, + 'test_data_href': {'key': 'properties.test_data_href', 'type': 'str'}, + 'secrets_file_href': {'key': 'properties.secrets_file_href', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'config': {'key': 'properties.config', 'type': 'object'}, + 'files': {'key': 'properties.files', 'type': '{str}'}, + 'test_data': {'key': 'properties.test_data', 'type': 'str'}, + 'invoke_url_template': {'key': 'properties.invoke_url_template', 'type': 'str'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + 'is_disabled': {'key': 'properties.isDisabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionEnvelope, self).__init__(**kwargs) + self.function_app_id = kwargs.get('function_app_id', None) + self.script_root_path_href = kwargs.get('script_root_path_href', None) + self.script_href = kwargs.get('script_href', None) + self.config_href = kwargs.get('config_href', None) + self.test_data_href = kwargs.get('test_data_href', None) + self.secrets_file_href = kwargs.get('secrets_file_href', None) + self.href = kwargs.get('href', None) + self.config = kwargs.get('config', None) + self.files = kwargs.get('files', None) + self.test_data = kwargs.get('test_data', None) + self.invoke_url_template = kwargs.get('invoke_url_template', None) + self.language = kwargs.get('language', None) + self.is_disabled = kwargs.get('is_disabled', None) + + +class FunctionEnvelopeCollection(msrest.serialization.Model): + """Collection of Kudu function information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FunctionEnvelope]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionEnvelopeCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class FunctionSecrets(msrest.serialization.Model): + """Function secrets. + + :param key: Secret key. + :type key: str + :param trigger_url: Trigger URL. + :type trigger_url: str + """ + + _attribute_map = { + 'key': {'key': 'key', 'type': 'str'}, + 'trigger_url': {'key': 'trigger_url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(FunctionSecrets, self).__init__(**kwargs) + self.key = kwargs.get('key', None) + self.trigger_url = kwargs.get('trigger_url', None) + + +class GeoRegion(ProxyOnlyResource): + """Geographical region. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Region description. + :vartype description: str + :ivar display_name: Display name for region. + :vartype display_name: str + :ivar org_domain: Display name for region. + :vartype org_domain: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + 'display_name': {'readonly': True}, + 'org_domain': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'org_domain': {'key': 'properties.orgDomain', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GeoRegion, self).__init__(**kwargs) + self.description = None + self.display_name = None + self.org_domain = None + + +class GeoRegionCollection(msrest.serialization.Model): + """Collection of geographical regions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.GeoRegion] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GeoRegion]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GeoRegionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class GitHub(ProxyOnlyResource): + """GitHub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + **kwargs + ): + super(GitHub, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + + +class GlobalCsmSkuDescription(msrest.serialization.Model): + """A Global SKU Description. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service Tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_09_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + **kwargs + ): + super(GlobalCsmSkuDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.size = kwargs.get('size', None) + self.family = kwargs.get('family', None) + self.capacity = kwargs.get('capacity', None) + self.locations = kwargs.get('locations', None) + self.capabilities = kwargs.get('capabilities', None) + + +class GlobalValidation(ProxyOnlyResource): + """GlobalValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param require_authentication: + :type require_authentication: bool + :param unauthenticated_client_action: Possible values include: "RedirectToLoginPage", + "AllowAnonymous", "Return401", "Return403". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_09_01.models.UnauthenticatedClientActionV2 + :param redirect_to_provider: + :type redirect_to_provider: str + :param excluded_paths: + :type excluded_paths: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'require_authentication': {'key': 'properties.requireAuthentication', 'type': 'bool'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'redirect_to_provider': {'key': 'properties.redirectToProvider', 'type': 'str'}, + 'excluded_paths': {'key': 'properties.excludedPaths', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(GlobalValidation, self).__init__(**kwargs) + self.require_authentication = kwargs.get('require_authentication', None) + self.unauthenticated_client_action = kwargs.get('unauthenticated_client_action', None) + self.redirect_to_provider = kwargs.get('redirect_to_provider', None) + self.excluded_paths = kwargs.get('excluded_paths', None) + + +class Google(ProxyOnlyResource): + """Google. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + :param validation: + :type validation: ~azure.mgmt.web.v2020_09_01.models.AllowedAudiencesValidation + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + 'validation': {'key': 'properties.validation', 'type': 'AllowedAudiencesValidation'}, + } + + def __init__( + self, + **kwargs + ): + super(Google, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + self.login = kwargs.get('login', None) + self.validation = kwargs.get('validation', None) + + +class HandlerMapping(msrest.serialization.Model): + """The IIS handler mappings used to define which handler processes HTTP requests with certain extension. +For example, it is used to configure php-cgi.exe process to handle all HTTP requests with *.php extension. + + :param extension: Requests with this extension will be handled using the specified FastCGI + application. + :type extension: str + :param script_processor: The absolute path to the FastCGI application. + :type script_processor: str + :param arguments: Command-line arguments to be passed to the script processor. + :type arguments: str + """ + + _attribute_map = { + 'extension': {'key': 'extension', 'type': 'str'}, + 'script_processor': {'key': 'scriptProcessor', 'type': 'str'}, + 'arguments': {'key': 'arguments', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HandlerMapping, self).__init__(**kwargs) + self.extension = kwargs.get('extension', None) + self.script_processor = kwargs.get('script_processor', None) + self.arguments = kwargs.get('arguments', None) + + +class HostingEnvironmentDeploymentInfo(msrest.serialization.Model): + """Information needed to create resources on an App Service Environment. + + :param name: Name of the App Service Environment. + :type name: str + :param location: Location of the App Service Environment. + :type location: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentDeploymentInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.location = kwargs.get('location', None) + + +class HostingEnvironmentDiagnostics(msrest.serialization.Model): + """Diagnostics for an App Service Environment. + + :param name: Name/identifier of the diagnostics. + :type name: str + :param diagnostics_output: Diagnostics output. + :type diagnostics_output: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'diagnostics_output': {'key': 'diagnosticsOutput', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentDiagnostics, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.diagnostics_output = kwargs.get('diagnostics_output', None) + + +class HostingEnvironmentProfile(msrest.serialization.Model): + """Specification for an App Service Environment to use for this resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID of the App Service Environment. + :type id: str + :ivar name: Name of the App Service Environment. + :vartype name: str + :ivar type: Resource type of the App Service Environment. + :vartype type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostingEnvironmentProfile, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = None + self.type = None + + +class HostKeys(msrest.serialization.Model): + """Functions host level keys. + + :param master_key: Secret key. + :type master_key: str + :param function_keys: Host level function keys. + :type function_keys: dict[str, str] + :param system_keys: System keys. + :type system_keys: dict[str, str] + """ + + _attribute_map = { + 'master_key': {'key': 'masterKey', 'type': 'str'}, + 'function_keys': {'key': 'functionKeys', 'type': '{str}'}, + 'system_keys': {'key': 'systemKeys', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(HostKeys, self).__init__(**kwargs) + self.master_key = kwargs.get('master_key', None) + self.function_keys = kwargs.get('function_keys', None) + self.system_keys = kwargs.get('system_keys', None) + + +class HostName(msrest.serialization.Model): + """Details of a hostname derived from a domain. + + :param name: Name of the hostname. + :type name: str + :param site_names: List of apps the hostname is assigned to. This list will have more than one + app only if the hostname is pointing to a Traffic Manager. + :type site_names: list[str] + :param azure_resource_name: Name of the Azure resource the hostname is assigned to. If it is + assigned to a Traffic Manager then it will be the Traffic Manager name otherwise it will be the + app name. + :type azure_resource_name: str + :param azure_resource_type: Type of the Azure resource the hostname is assigned to. Possible + values include: "Website", "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_09_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Type of the DNS record. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_09_01.models.CustomHostNameDnsRecordType + :param host_name_type: Type of the hostname. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_09_01.models.HostNameType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'site_names': {'key': 'siteNames', 'type': '[str]'}, + 'azure_resource_name': {'key': 'azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'hostNameType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostName, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.site_names = kwargs.get('site_names', None) + self.azure_resource_name = kwargs.get('azure_resource_name', None) + self.azure_resource_type = kwargs.get('azure_resource_type', None) + self.custom_host_name_dns_record_type = kwargs.get('custom_host_name_dns_record_type', None) + self.host_name_type = kwargs.get('host_name_type', None) + + +class HostNameBinding(ProxyOnlyResource): + """A hostname binding object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param site_name: App Service app name. + :type site_name: str + :param domain_id: Fully qualified ARM domain resource URI. + :type domain_id: str + :param azure_resource_name: Azure resource name. + :type azure_resource_name: str + :param azure_resource_type: Azure resource type. Possible values include: "Website", + "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_09_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Custom DNS record type. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_09_01.models.CustomHostNameDnsRecordType + :param host_name_type: Hostname type. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_09_01.models.HostNameType + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_09_01.models.SslState + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :ivar virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :vartype virtual_ip: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'virtual_ip': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'domain_id': {'key': 'properties.domainId', 'type': 'str'}, + 'azure_resource_name': {'key': 'properties.azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'properties.azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'properties.customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'properties.hostNameType', 'type': 'str'}, + 'ssl_state': {'key': 'properties.sslState', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'virtual_ip': {'key': 'properties.virtualIP', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameBinding, self).__init__(**kwargs) + self.site_name = kwargs.get('site_name', None) + self.domain_id = kwargs.get('domain_id', None) + self.azure_resource_name = kwargs.get('azure_resource_name', None) + self.azure_resource_type = kwargs.get('azure_resource_type', None) + self.custom_host_name_dns_record_type = kwargs.get('custom_host_name_dns_record_type', None) + self.host_name_type = kwargs.get('host_name_type', None) + self.ssl_state = kwargs.get('ssl_state', None) + self.thumbprint = kwargs.get('thumbprint', None) + self.virtual_ip = None + + +class HostNameBindingCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.HostNameBinding] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HostNameBinding]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameBindingCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class HostNameSslState(msrest.serialization.Model): + """SSL-enabled hostname. + + :param name: Hostname. + :type name: str + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_09_01.models.SslState + :param virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :type virtual_ip: str + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :param to_update: Set to :code:`true` to update existing hostname. + :type to_update: bool + :param host_type: Indicates whether the hostname is a standard or repository hostname. Possible + values include: "Standard", "Repository". + :type host_type: str or ~azure.mgmt.web.v2020_09_01.models.HostType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'ssl_state': {'key': 'sslState', 'type': 'str'}, + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'to_update': {'key': 'toUpdate', 'type': 'bool'}, + 'host_type': {'key': 'hostType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HostNameSslState, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.ssl_state = kwargs.get('ssl_state', None) + self.virtual_ip = kwargs.get('virtual_ip', None) + self.thumbprint = kwargs.get('thumbprint', None) + self.to_update = kwargs.get('to_update', None) + self.host_type = kwargs.get('host_type', None) + + +class HttpLogsConfig(msrest.serialization.Model): + """Http logs configuration. + + :param file_system: Http logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemHttpLogsConfig + :param azure_blob_storage: Http logs to azure blob storage configuration. + :type azure_blob_storage: ~azure.mgmt.web.v2020_09_01.models.AzureBlobStorageHttpLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemHttpLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageHttpLogsConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpLogsConfig, self).__init__(**kwargs) + self.file_system = kwargs.get('file_system', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class HttpSettings(ProxyOnlyResource): + """HttpSettings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param require_https: + :type require_https: bool + :param routes: + :type routes: ~azure.mgmt.web.v2020_09_01.models.HttpSettingsRoutes + :param forward_proxy: + :type forward_proxy: ~azure.mgmt.web.v2020_09_01.models.ForwardProxy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'require_https': {'key': 'properties.requireHttps', 'type': 'bool'}, + 'routes': {'key': 'properties.routes', 'type': 'HttpSettingsRoutes'}, + 'forward_proxy': {'key': 'properties.forwardProxy', 'type': 'ForwardProxy'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpSettings, self).__init__(**kwargs) + self.require_https = kwargs.get('require_https', None) + self.routes = kwargs.get('routes', None) + self.forward_proxy = kwargs.get('forward_proxy', None) + + +class HttpSettingsRoutes(ProxyOnlyResource): + """HttpSettingsRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param api_prefix: + :type api_prefix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'api_prefix': {'key': 'properties.apiPrefix', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpSettingsRoutes, self).__init__(**kwargs) + self.api_prefix = kwargs.get('api_prefix', None) + + +class HybridConnection(ProxyOnlyResource): + """Hybrid Connection contract. This is used to configure a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param service_bus_namespace: The name of the Service Bus namespace. + :type service_bus_namespace: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :param relay_arm_uri: The ARM URI to the Service Bus relay. + :type relay_arm_uri: str + :param hostname: The hostname of the endpoint. + :type hostname: str + :param port: The port of the endpoint. + :type port: int + :param send_key_name: The name of the Service Bus key which has Send permissions. This is used + to authenticate to Service Bus. + :type send_key_name: str + :param send_key_value: The value of the Service Bus key. This is used to authenticate to + Service Bus. In ARM this key will not be returned + normally, use the POST /listKeys API instead. + :type send_key_value: str + :param service_bus_suffix: The suffix for the service bus endpoint. By default this is + .servicebus.windows.net. + :type service_bus_suffix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'service_bus_namespace': {'key': 'properties.serviceBusNamespace', 'type': 'str'}, + 'relay_name': {'key': 'properties.relayName', 'type': 'str'}, + 'relay_arm_uri': {'key': 'properties.relayArmUri', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + 'service_bus_suffix': {'key': 'properties.serviceBusSuffix', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnection, self).__init__(**kwargs) + self.service_bus_namespace = kwargs.get('service_bus_namespace', None) + self.relay_name = kwargs.get('relay_name', None) + self.relay_arm_uri = kwargs.get('relay_arm_uri', None) + self.hostname = kwargs.get('hostname', None) + self.port = kwargs.get('port', None) + self.send_key_name = kwargs.get('send_key_name', None) + self.send_key_value = kwargs.get('send_key_value', None) + self.service_bus_suffix = kwargs.get('service_bus_suffix', None) + + +class HybridConnectionCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.HybridConnection] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HybridConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class HybridConnectionKey(ProxyOnlyResource): + """Hybrid Connection key contract. This has the send key name and value for a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar send_key_name: The name of the send key. + :vartype send_key_name: str + :ivar send_key_value: The value of the send key. + :vartype send_key_value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'send_key_name': {'readonly': True}, + 'send_key_value': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionKey, self).__init__(**kwargs) + self.send_key_name = None + self.send_key_value = None + + +class HybridConnectionLimits(ProxyOnlyResource): + """Hybrid Connection limits contract. This is used to return the plan limits of Hybrid Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar current: The current number of Hybrid Connections. + :vartype current: int + :ivar maximum: The maximum number of Hybrid Connections allowed. + :vartype maximum: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'current': {'readonly': True}, + 'maximum': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'current': {'key': 'properties.current', 'type': 'int'}, + 'maximum': {'key': 'properties.maximum', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(HybridConnectionLimits, self).__init__(**kwargs) + self.current = None + self.maximum = None + + +class Identifier(ProxyOnlyResource): + """A domain specific resource identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param value: String representation of the identity. + :type value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'value': {'key': 'properties.id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Identifier, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class IdentifierCollection(msrest.serialization.Model): + """Collection of identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Identifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Identifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class IdentityProviders(ProxyOnlyResource): + """IdentityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param azure_active_directory: + :type azure_active_directory: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectory + :param facebook: + :type facebook: ~azure.mgmt.web.v2020_09_01.models.Facebook + :param git_hub: + :type git_hub: ~azure.mgmt.web.v2020_09_01.models.GitHub + :param google: + :type google: ~azure.mgmt.web.v2020_09_01.models.Google + :param twitter: + :type twitter: ~azure.mgmt.web.v2020_09_01.models.Twitter + :param custom_open_id_connect_providers: Dictionary of :code:``. + :type custom_open_id_connect_providers: dict[str, + ~azure.mgmt.web.v2020_09_01.models.CustomOpenIdConnectProvider] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'facebook': {'key': 'properties.facebook', 'type': 'Facebook'}, + 'git_hub': {'key': 'properties.gitHub', 'type': 'GitHub'}, + 'google': {'key': 'properties.google', 'type': 'Google'}, + 'twitter': {'key': 'properties.twitter', 'type': 'Twitter'}, + 'custom_open_id_connect_providers': {'key': 'properties.customOpenIdConnectProviders', 'type': '{CustomOpenIdConnectProvider}'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentityProviders, self).__init__(**kwargs) + self.azure_active_directory = kwargs.get('azure_active_directory', None) + self.facebook = kwargs.get('facebook', None) + self.git_hub = kwargs.get('git_hub', None) + self.google = kwargs.get('google', None) + self.twitter = kwargs.get('twitter', None) + self.custom_open_id_connect_providers = kwargs.get('custom_open_id_connect_providers', None) + + +class InboundEnvironmentEndpoint(msrest.serialization.Model): + """The IP Addresses and Ports that require inbound network access to and within the subnet of the App Service Environment. + + :param description: Short text describing the purpose of the network traffic. + :type description: str + :param endpoints: The IP addresses that network traffic will originate from in cidr notation. + :type endpoints: list[str] + :param ports: The ports that network traffic will arrive to the App Service Environment at. + :type ports: list[str] + """ + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[str]'}, + 'ports': {'key': 'ports', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundEnvironmentEndpoint, self).__init__(**kwargs) + self.description = kwargs.get('description', None) + self.endpoints = kwargs.get('endpoints', None) + self.ports = kwargs.get('ports', None) + + +class InboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Inbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.InboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(InboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class IpSecurityRestriction(msrest.serialization.Model): + """IP security restriction on an app. + + :param ip_address: IP address the security restriction is valid for. + It can be in form of pure ipv4 address (required SubnetMask property) or + CIDR notation such as ipv4/mask (leading bit match). For CIDR, + SubnetMask property must not be specified. + :type ip_address: str + :param subnet_mask: Subnet mask for the range of IP addresses the restriction is valid for. + :type subnet_mask: str + :param vnet_subnet_resource_id: Virtual network resource id. + :type vnet_subnet_resource_id: str + :param vnet_traffic_tag: (internal) Vnet traffic tag. + :type vnet_traffic_tag: int + :param subnet_traffic_tag: (internal) Subnet traffic tag. + :type subnet_traffic_tag: int + :param action: Allow or Deny access for this IP range. + :type action: str + :param tag: Defines what this IP filter will be used for. This is to support IP filtering on + proxies. Possible values include: "Default", "XffProxy", "ServiceTag". + :type tag: str or ~azure.mgmt.web.v2020_09_01.models.IpFilterTag + :param priority: Priority of IP restriction rule. + :type priority: int + :param name: IP restriction rule name. + :type name: str + :param description: IP restriction rule description. + :type description: str + :param headers: IP restriction rule headers. + X-Forwarded-Host (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + Host#Examples). + The matching logic is .. + + + * If the property is null or empty (default), all hosts(or lack of) are allowed. + * A value is compared using ordinal-ignore-case (excluding port number). + * Subdomain wildcards are permitted but don't match the root domain. For example, + *.contoso.com matches the subdomain foo.contoso.com + but not the root domain contoso.com or multi-level foo.bar.contoso.com + * Unicode host names are allowed but are converted to Punycode for matching. + + X-Forwarded-For (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + For#Examples). + The matching logic is .. + + + * If the property is null or empty (default), any forwarded-for chains (or lack of) are + allowed. + * If any address (excluding port number) in the chain (comma separated) matches the CIDR + defined by the property. + + X-Azure-FDID and X-FD-HealthProbe. + The matching logic is exact match. + :type headers: dict[str, list[str]] + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'subnet_mask': {'key': 'subnetMask', 'type': 'str'}, + 'vnet_subnet_resource_id': {'key': 'vnetSubnetResourceId', 'type': 'str'}, + 'vnet_traffic_tag': {'key': 'vnetTrafficTag', 'type': 'int'}, + 'subnet_traffic_tag': {'key': 'subnetTrafficTag', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '{[str]}'}, + } + + def __init__( + self, + **kwargs + ): + super(IpSecurityRestriction, self).__init__(**kwargs) + self.ip_address = kwargs.get('ip_address', None) + self.subnet_mask = kwargs.get('subnet_mask', None) + self.vnet_subnet_resource_id = kwargs.get('vnet_subnet_resource_id', None) + self.vnet_traffic_tag = kwargs.get('vnet_traffic_tag', None) + self.subnet_traffic_tag = kwargs.get('subnet_traffic_tag', None) + self.action = kwargs.get('action', None) + self.tag = kwargs.get('tag', None) + self.priority = kwargs.get('priority', None) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + self.headers = kwargs.get('headers', None) + + +class JwtClaimChecks(ProxyOnlyResource): + """JwtClaimChecks. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allowed_groups: + :type allowed_groups: list[str] + :param allowed_client_applications: + :type allowed_client_applications: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allowed_groups': {'key': 'properties.allowedGroups', 'type': '[str]'}, + 'allowed_client_applications': {'key': 'properties.allowedClientApplications', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(JwtClaimChecks, self).__init__(**kwargs) + self.allowed_groups = kwargs.get('allowed_groups', None) + self.allowed_client_applications = kwargs.get('allowed_client_applications', None) + + +class KeyInfo(msrest.serialization.Model): + """Function key info. + + :param name: Key name. + :type name: str + :param value: Key value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(KeyInfo, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + + +class LocalizableString(msrest.serialization.Model): + """Localizable string object containing the name and a localized value. + + :param value: Non-localized name. + :type value: str + :param localized_value: Localized name. + :type localized_value: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LocalizableString, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.localized_value = kwargs.get('localized_value', None) + + +class Login(ProxyOnlyResource): + """Login. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param routes: + :type routes: ~azure.mgmt.web.v2020_09_01.models.LoginRoutes + :param token_store: + :type token_store: ~azure.mgmt.web.v2020_09_01.models.TokenStore + :param preserve_url_fragments_for_logins: + :type preserve_url_fragments_for_logins: bool + :param allowed_external_redirect_urls: + :type allowed_external_redirect_urls: list[str] + :param cookie_expiration: + :type cookie_expiration: ~azure.mgmt.web.v2020_09_01.models.CookieExpiration + :param nonce: + :type nonce: ~azure.mgmt.web.v2020_09_01.models.Nonce + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'routes': {'key': 'properties.routes', 'type': 'LoginRoutes'}, + 'token_store': {'key': 'properties.tokenStore', 'type': 'TokenStore'}, + 'preserve_url_fragments_for_logins': {'key': 'properties.preserveUrlFragmentsForLogins', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'cookie_expiration': {'key': 'properties.cookieExpiration', 'type': 'CookieExpiration'}, + 'nonce': {'key': 'properties.nonce', 'type': 'Nonce'}, + } + + def __init__( + self, + **kwargs + ): + super(Login, self).__init__(**kwargs) + self.routes = kwargs.get('routes', None) + self.token_store = kwargs.get('token_store', None) + self.preserve_url_fragments_for_logins = kwargs.get('preserve_url_fragments_for_logins', None) + self.allowed_external_redirect_urls = kwargs.get('allowed_external_redirect_urls', None) + self.cookie_expiration = kwargs.get('cookie_expiration', None) + self.nonce = kwargs.get('nonce', None) + + +class LoginRoutes(ProxyOnlyResource): + """LoginRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param logout_endpoint: + :type logout_endpoint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'logout_endpoint': {'key': 'properties.logoutEndpoint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoginRoutes, self).__init__(**kwargs) + self.logout_endpoint = kwargs.get('logout_endpoint', None) + + +class LoginScopes(ProxyOnlyResource): + """LoginScopes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(LoginScopes, self).__init__(**kwargs) + self.scopes = kwargs.get('scopes', None) + + +class LogSpecification(msrest.serialization.Model): + """Log Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param blob_duration: + :type blob_duration: str + :param log_filter_pattern: + :type log_filter_pattern: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + 'log_filter_pattern': {'key': 'logFilterPattern', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LogSpecification, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.blob_duration = kwargs.get('blob_duration', None) + self.log_filter_pattern = kwargs.get('log_filter_pattern', None) + + +class ManagedServiceIdentity(msrest.serialization.Model): + """Managed service identity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of managed service identity. Possible values include: "SystemAssigned", + "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentityType + :ivar tenant_id: Tenant of managed service identity. + :vartype tenant_id: str + :ivar principal_id: Principal Id of managed service identity. + :vartype principal_id: str + :param user_assigned_identities: The list of user assigned identities associated with the + resource. The user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. + :type user_assigned_identities: dict[str, + ~azure.mgmt.web.v2020_09_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _validation = { + 'tenant_id': {'readonly': True}, + 'principal_id': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedServiceIdentity, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.tenant_id = None + self.principal_id = None + self.user_assigned_identities = kwargs.get('user_assigned_identities', None) + + +class MetricAvailability(msrest.serialization.Model): + """Retention policy of a resource metric. + + :param time_grain: + :type time_grain: str + :param blob_duration: + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MetricAvailability, self).__init__(**kwargs) + self.time_grain = kwargs.get('time_grain', None) + self.blob_duration = kwargs.get('blob_duration', None) + + +class MetricSpecification(msrest.serialization.Model): + """Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param display_description: + :type display_description: str + :param unit: + :type unit: str + :param aggregation_type: + :type aggregation_type: str + :param supports_instance_level_aggregation: + :type supports_instance_level_aggregation: bool + :param enable_regional_mdm_account: + :type enable_regional_mdm_account: bool + :param source_mdm_account: + :type source_mdm_account: str + :param source_mdm_namespace: + :type source_mdm_namespace: str + :param metric_filter_pattern: + :type metric_filter_pattern: str + :param fill_gap_with_zero: + :type fill_gap_with_zero: bool + :param is_internal: + :type is_internal: bool + :param dimensions: + :type dimensions: list[~azure.mgmt.web.v2020_09_01.models.Dimension] + :param category: + :type category: str + :param availabilities: + :type availabilities: list[~azure.mgmt.web.v2020_09_01.models.MetricAvailability] + :param supported_time_grain_types: + :type supported_time_grain_types: list[str] + :param supported_aggregation_types: + :type supported_aggregation_types: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'display_description': {'key': 'displayDescription', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'aggregation_type': {'key': 'aggregationType', 'type': 'str'}, + 'supports_instance_level_aggregation': {'key': 'supportsInstanceLevelAggregation', 'type': 'bool'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'category': {'key': 'category', 'type': 'str'}, + 'availabilities': {'key': 'availabilities', 'type': '[MetricAvailability]'}, + 'supported_time_grain_types': {'key': 'supportedTimeGrainTypes', 'type': '[str]'}, + 'supported_aggregation_types': {'key': 'supportedAggregationTypes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(MetricSpecification, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display_name = kwargs.get('display_name', None) + self.display_description = kwargs.get('display_description', None) + self.unit = kwargs.get('unit', None) + self.aggregation_type = kwargs.get('aggregation_type', None) + self.supports_instance_level_aggregation = kwargs.get('supports_instance_level_aggregation', None) + self.enable_regional_mdm_account = kwargs.get('enable_regional_mdm_account', None) + self.source_mdm_account = kwargs.get('source_mdm_account', None) + self.source_mdm_namespace = kwargs.get('source_mdm_namespace', None) + self.metric_filter_pattern = kwargs.get('metric_filter_pattern', None) + self.fill_gap_with_zero = kwargs.get('fill_gap_with_zero', None) + self.is_internal = kwargs.get('is_internal', None) + self.dimensions = kwargs.get('dimensions', None) + self.category = kwargs.get('category', None) + self.availabilities = kwargs.get('availabilities', None) + self.supported_time_grain_types = kwargs.get('supported_time_grain_types', None) + self.supported_aggregation_types = kwargs.get('supported_aggregation_types', None) + + +class MigrateMySqlRequest(ProxyOnlyResource): + """MySQL migration request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param connection_string: Connection string to the remote MySQL database. + :type connection_string: str + :param migration_type: The type of migration operation to be done. Possible values include: + "LocalToRemote", "RemoteToLocal". + :type migration_type: str or ~azure.mgmt.web.v2020_09_01.models.MySqlMigrationType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'migration_type': {'key': 'properties.migrationType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MigrateMySqlRequest, self).__init__(**kwargs) + self.connection_string = kwargs.get('connection_string', None) + self.migration_type = kwargs.get('migration_type', None) + + +class MigrateMySqlStatus(ProxyOnlyResource): + """MySQL migration status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar migration_operation_status: Status of the migration task. Possible values include: + "InProgress", "Failed", "Succeeded", "TimedOut", "Created". + :vartype migration_operation_status: str or ~azure.mgmt.web.v2020_09_01.models.OperationStatus + :ivar operation_id: Operation ID for the migration task. + :vartype operation_id: str + :ivar local_my_sql_enabled: True if the web app has in app MySql enabled. + :vartype local_my_sql_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'migration_operation_status': {'readonly': True}, + 'operation_id': {'readonly': True}, + 'local_my_sql_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'migration_operation_status': {'key': 'properties.migrationOperationStatus', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MigrateMySqlStatus, self).__init__(**kwargs) + self.migration_operation_status = None + self.operation_id = None + self.local_my_sql_enabled = None + + +class MSDeploy(ProxyOnlyResource): + """MSDeploy ARM PUT information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param package_uri: Package URI. + :type package_uri: str + :param connection_string: SQL Connection String. + :type connection_string: str + :param db_type: Database Type. + :type db_type: str + :param set_parameters_xml_file_uri: URI of MSDeploy Parameters file. Must not be set if + SetParameters is used. + :type set_parameters_xml_file_uri: str + :param set_parameters: MSDeploy Parameters. Must not be set if SetParametersXmlFileUri is used. + :type set_parameters: dict[str, str] + :param skip_app_data: Controls whether the MSDeploy operation skips the App_Data directory. + If set to :code:`true`, the existing App_Data directory on the destination + will not be deleted, and any App_Data directory in the source will be ignored. + Setting is :code:`false` by default. + :type skip_app_data: bool + :param app_offline: Sets the AppOffline rule while the MSDeploy operation executes. + Setting is :code:`false` by default. + :type app_offline: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'package_uri': {'key': 'properties.packageUri', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'db_type': {'key': 'properties.dbType', 'type': 'str'}, + 'set_parameters_xml_file_uri': {'key': 'properties.setParametersXmlFileUri', 'type': 'str'}, + 'set_parameters': {'key': 'properties.setParameters', 'type': '{str}'}, + 'skip_app_data': {'key': 'properties.skipAppData', 'type': 'bool'}, + 'app_offline': {'key': 'properties.appOffline', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeploy, self).__init__(**kwargs) + self.package_uri = kwargs.get('package_uri', None) + self.connection_string = kwargs.get('connection_string', None) + self.db_type = kwargs.get('db_type', None) + self.set_parameters_xml_file_uri = kwargs.get('set_parameters_xml_file_uri', None) + self.set_parameters = kwargs.get('set_parameters', None) + self.skip_app_data = kwargs.get('skip_app_data', None) + self.app_offline = kwargs.get('app_offline', None) + + +class MSDeployLog(ProxyOnlyResource): + """MSDeploy log. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar entries: List of log entry messages. + :vartype entries: list[~azure.mgmt.web.v2020_09_01.models.MSDeployLogEntry] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'entries': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'entries': {'key': 'properties.entries', 'type': '[MSDeployLogEntry]'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLog, self).__init__(**kwargs) + self.entries = None + + +class MSDeployLogEntry(msrest.serialization.Model): + """MSDeploy log entry. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time: Timestamp of log entry. + :vartype time: ~datetime.datetime + :ivar type: Log entry type. Possible values include: "Message", "Warning", "Error". + :vartype type: str or ~azure.mgmt.web.v2020_09_01.models.MSDeployLogEntryType + :ivar message: Log entry message. + :vartype message: str + """ + + _validation = { + 'time': {'readonly': True}, + 'type': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'type': {'key': 'type', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLogEntry, self).__init__(**kwargs) + self.time = None + self.type = None + self.message = None + + +class MSDeployStatus(ProxyOnlyResource): + """MSDeploy ARM response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar deployer: Username of deployer. + :vartype deployer: str + :ivar provisioning_state: Provisioning state. Possible values include: "accepted", "running", + "succeeded", "failed", "canceled". + :vartype provisioning_state: str or + ~azure.mgmt.web.v2020_09_01.models.MSDeployProvisioningState + :ivar start_time: Start time of deploy operation. + :vartype start_time: ~datetime.datetime + :ivar end_time: End time of deploy operation. + :vartype end_time: ~datetime.datetime + :ivar complete: Whether the deployment operation has completed. + :vartype complete: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'deployer': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'end_time': {'readonly': True}, + 'complete': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'complete': {'key': 'properties.complete', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployStatus, self).__init__(**kwargs) + self.deployer = None + self.provisioning_state = None + self.start_time = None + self.end_time = None + self.complete = None + + +class NameIdentifier(msrest.serialization.Model): + """Identifies an object. + + :param name: Name of the object. + :type name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameIdentifier, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + + +class NameIdentifierCollection(msrest.serialization.Model): + """Collection of domain name identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.NameIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NameIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameIdentifierCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class NameValuePair(msrest.serialization.Model): + """Name value pair. + + :param name: Pair name. + :type name: str + :param value: Pair value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NameValuePair, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.value = kwargs.get('value', None) + + +class NetworkAccessControlEntry(msrest.serialization.Model): + """Network access control entry. + + :param action: Action object. Possible values include: "Permit", "Deny". + :type action: str or ~azure.mgmt.web.v2020_09_01.models.AccessControlEntryAction + :param description: Description of network access control entry. + :type description: str + :param order: Order of precedence. + :type order: int + :param remote_subnet: Remote subnet. + :type remote_subnet: str + """ + + _attribute_map = { + 'action': {'key': 'action', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'int'}, + 'remote_subnet': {'key': 'remoteSubnet', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkAccessControlEntry, self).__init__(**kwargs) + self.action = kwargs.get('action', None) + self.description = kwargs.get('description', None) + self.order = kwargs.get('order', None) + self.remote_subnet = kwargs.get('remote_subnet', None) + + +class NetworkFeatures(ProxyOnlyResource): + """Full view of network features for an app (presently VNET integration and Hybrid Connections). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar virtual_network_name: The Virtual Network name. + :vartype virtual_network_name: str + :ivar virtual_network_connection: The Virtual Network summary view. + :vartype virtual_network_connection: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :ivar hybrid_connections: The Hybrid Connections summary view. + :vartype hybrid_connections: + list[~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity] + :ivar hybrid_connections_v2: The Hybrid Connection V2 (Service Bus) view. + :vartype hybrid_connections_v2: list[~azure.mgmt.web.v2020_09_01.models.HybridConnection] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'virtual_network_name': {'readonly': True}, + 'virtual_network_connection': {'readonly': True}, + 'hybrid_connections': {'readonly': True}, + 'hybrid_connections_v2': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'virtual_network_name': {'key': 'properties.virtualNetworkName', 'type': 'str'}, + 'virtual_network_connection': {'key': 'properties.virtualNetworkConnection', 'type': 'VnetInfo'}, + 'hybrid_connections': {'key': 'properties.hybridConnections', 'type': '[RelayServiceConnectionEntity]'}, + 'hybrid_connections_v2': {'key': 'properties.hybridConnectionsV2', 'type': '[HybridConnection]'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkFeatures, self).__init__(**kwargs) + self.virtual_network_name = None + self.virtual_network_connection = None + self.hybrid_connections = None + self.hybrid_connections_v2 = None + + +class NetworkTrace(msrest.serialization.Model): + """Network trace. + + :param path: Local file path for the captured network trace file. + :type path: str + :param status: Current status of the network trace operation, same as Operation.Status + (InProgress/Succeeded/Failed). + :type status: str + :param message: Detailed message of a network trace operation, e.g. error message in case of + failure. + :type message: str + """ + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkTrace, self).__init__(**kwargs) + self.path = kwargs.get('path', None) + self.status = kwargs.get('status', None) + self.message = kwargs.get('message', None) + + +class Nonce(ProxyOnlyResource): + """Nonce. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param validate_nonce: + :type validate_nonce: bool + :param nonce_expiration_interval: + :type nonce_expiration_interval: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'validate_nonce': {'key': 'properties.validateNonce', 'type': 'bool'}, + 'nonce_expiration_interval': {'key': 'properties.nonceExpirationInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Nonce, self).__init__(**kwargs) + self.validate_nonce = kwargs.get('validate_nonce', None) + self.nonce_expiration_interval = kwargs.get('nonce_expiration_interval', None) + + +class OpenIdConnectClientCredential(ProxyOnlyResource): + """OpenIdConnectClientCredential. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar method: Default value: "ClientSecretPost". + :vartype method: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'method': {'constant': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'method': {'key': 'properties.method', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + method = "ClientSecretPost" + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectClientCredential, self).__init__(**kwargs) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + + +class OpenIdConnectConfig(ProxyOnlyResource): + """OpenIdConnectConfig. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param authorization_endpoint: + :type authorization_endpoint: str + :param token_endpoint: + :type token_endpoint: str + :param issuer: + :type issuer: str + :param certification_uri: + :type certification_uri: str + :param well_known_open_id_configuration: + :type well_known_open_id_configuration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'authorization_endpoint': {'key': 'properties.authorizationEndpoint', 'type': 'str'}, + 'token_endpoint': {'key': 'properties.tokenEndpoint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'certification_uri': {'key': 'properties.certificationUri', 'type': 'str'}, + 'well_known_open_id_configuration': {'key': 'properties.wellKnownOpenIdConfiguration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectConfig, self).__init__(**kwargs) + self.authorization_endpoint = kwargs.get('authorization_endpoint', None) + self.token_endpoint = kwargs.get('token_endpoint', None) + self.issuer = kwargs.get('issuer', None) + self.certification_uri = kwargs.get('certification_uri', None) + self.well_known_open_id_configuration = kwargs.get('well_known_open_id_configuration', None) + + +class OpenIdConnectLogin(ProxyOnlyResource): + """OpenIdConnectLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_claim_type: + :type name_claim_type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_claim_type': {'key': 'properties.nameClaimType', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectLogin, self).__init__(**kwargs) + self.name_claim_type = kwargs.get('name_claim_type', None) + self.scopes = kwargs.get('scopes', None) + + +class OpenIdConnectRegistration(ProxyOnlyResource): + """OpenIdConnectRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param client_id: + :type client_id: str + :param client_credential: + :type client_credential: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectClientCredential + :param open_id_connect_configuration: + :type open_id_connect_configuration: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_credential': {'key': 'properties.clientCredential', 'type': 'OpenIdConnectClientCredential'}, + 'open_id_connect_configuration': {'key': 'properties.openIdConnectConfiguration', 'type': 'OpenIdConnectConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(OpenIdConnectRegistration, self).__init__(**kwargs) + self.client_id = kwargs.get('client_id', None) + self.client_credential = kwargs.get('client_credential', None) + self.open_id_connect_configuration = kwargs.get('open_id_connect_configuration', None) + + +class Operation(msrest.serialization.Model): + """An operation on a resource. + + :param id: Operation ID. + :type id: str + :param name: Operation name. + :type name: str + :param status: The current status of the operation. Possible values include: "InProgress", + "Failed", "Succeeded", "TimedOut", "Created". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.OperationStatus + :param errors: Any errors associate with the operation. + :type errors: list[~azure.mgmt.web.v2020_09_01.models.ErrorEntity] + :param created_time: Time when operation has started. + :type created_time: ~datetime.datetime + :param modified_time: Time when operation has been updated. + :type modified_time: ~datetime.datetime + :param expiration_time: Time when operation will expire. + :type expiration_time: ~datetime.datetime + :param geo_master_operation_id: Applicable only for stamp operation ids. + :type geo_master_operation_id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'errors': {'key': 'errors', 'type': '[ErrorEntity]'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'modified_time': {'key': 'modifiedTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'expirationTime', 'type': 'iso-8601'}, + 'geo_master_operation_id': {'key': 'geoMasterOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = kwargs.get('name', None) + self.status = kwargs.get('status', None) + self.errors = kwargs.get('errors', None) + self.created_time = kwargs.get('created_time', None) + self.modified_time = kwargs.get('modified_time', None) + self.expiration_time = kwargs.get('expiration_time', None) + self.geo_master_operation_id = kwargs.get('geo_master_operation_id', None) + + +class OutboundEnvironmentEndpoint(msrest.serialization.Model): + """Endpoints accessed for a common purpose that the App Service Environment requires outbound network access to. + + :param category: The type of service accessed by the App Service Environment, e.g., Azure + Storage, Azure SQL Database, and Azure Active Directory. + :type category: str + :param endpoints: The endpoints that the App Service Environment reaches the service at. + :type endpoints: list[~azure.mgmt.web.v2020_09_01.models.EndpointDependency] + """ + + _attribute_map = { + 'category': {'key': 'category', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[EndpointDependency]'}, + } + + def __init__( + self, + **kwargs + ): + super(OutboundEnvironmentEndpoint, self).__init__(**kwargs) + self.category = kwargs.get('category', None) + self.endpoints = kwargs.get('endpoints', None) + + +class OutboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Outbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.OutboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OutboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PerfMonCounterCollection(msrest.serialization.Model): + """Collection of performance monitor counters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PerfMonResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PerfMonResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonCounterCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PerfMonResponse(msrest.serialization.Model): + """Performance monitor API response. + + :param code: The response code. + :type code: str + :param message: The message. + :type message: str + :param data: The performance monitor counters. + :type data: ~azure.mgmt.web.v2020_09_01.models.PerfMonSet + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'data': {'key': 'data', 'type': 'PerfMonSet'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonResponse, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + self.data = kwargs.get('data', None) + + +class PerfMonSample(msrest.serialization.Model): + """Performance monitor sample in a set. + + :param time: Point in time for which counter was measured. + :type time: ~datetime.datetime + :param instance_name: Name of the server on which the measurement is made. + :type instance_name: str + :param value: Value of counter at a certain time. + :type value: float + """ + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'instance_name': {'key': 'instanceName', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'float'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonSample, self).__init__(**kwargs) + self.time = kwargs.get('time', None) + self.instance_name = kwargs.get('instance_name', None) + self.value = kwargs.get('value', None) + + +class PerfMonSet(msrest.serialization.Model): + """Metric information. + + :param name: Unique key name of the counter. + :type name: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. + :type time_grain: str + :param values: Collection of workers that are active during this time. + :type values: list[~azure.mgmt.web.v2020_09_01.models.PerfMonSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[PerfMonSample]'}, + } + + def __init__( + self, + **kwargs + ): + super(PerfMonSet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.time_grain = kwargs.get('time_grain', None) + self.values = kwargs.get('values', None) + + +class PremierAddOn(Resource): + """Premier add-on. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOn, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PremierAddOnOffer(ProxyOnlyResource): + """Premier add-on offer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on offer Product. + :type product: str + :param vendor: Premier add on offer Vendor. + :type vendor: str + :param promo_code_required: :code:`true` if promotion code is required; otherwise, + :code:`false`. + :type promo_code_required: bool + :param quota: Premier add on offer Quota. + :type quota: int + :param web_hosting_plan_restrictions: App Service plans this offer is restricted to. Possible + values include: "None", "Free", "Shared", "Basic", "Standard", "Premium". + :type web_hosting_plan_restrictions: str or + ~azure.mgmt.web.v2020_09_01.models.AppServicePlanRestrictions + :param privacy_policy_url: Privacy policy URL. + :type privacy_policy_url: str + :param legal_terms_url: Legal terms URL. + :type legal_terms_url: str + :param marketplace_publisher: Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'promo_code_required': {'key': 'properties.promoCodeRequired', 'type': 'bool'}, + 'quota': {'key': 'properties.quota', 'type': 'int'}, + 'web_hosting_plan_restrictions': {'key': 'properties.webHostingPlanRestrictions', 'type': 'str'}, + 'privacy_policy_url': {'key': 'properties.privacyPolicyUrl', 'type': 'str'}, + 'legal_terms_url': {'key': 'properties.legalTermsUrl', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnOffer, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.promo_code_required = kwargs.get('promo_code_required', None) + self.quota = kwargs.get('quota', None) + self.web_hosting_plan_restrictions = kwargs.get('web_hosting_plan_restrictions', None) + self.privacy_policy_url = kwargs.get('privacy_policy_url', None) + self.legal_terms_url = kwargs.get('legal_terms_url', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PremierAddOnOfferCollection(msrest.serialization.Model): + """Collection of premier add-on offers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOffer] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PremierAddOnOffer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnOfferCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PremierAddOnPatchResource(ProxyOnlyResource): + """ARM resource for a PremierAddOn. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PremierAddOnPatchResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.product = kwargs.get('product', None) + self.vendor = kwargs.get('vendor', None) + self.marketplace_publisher = kwargs.get('marketplace_publisher', None) + self.marketplace_offer = kwargs.get('marketplace_offer', None) + + +class PrivateAccess(ProxyOnlyResource): + """Description of the parameters of Private Access for a Web Site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: Whether private access is enabled or not. + :type enabled: bool + :param virtual_networks: The Virtual Networks (and subnets) allowed to access the site + privately. + :type virtual_networks: list[~azure.mgmt.web.v2020_09_01.models.PrivateAccessVirtualNetwork] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[PrivateAccessVirtualNetwork]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccess, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.virtual_networks = kwargs.get('virtual_networks', None) + + +class PrivateAccessSubnet(msrest.serialization.Model): + """Description of a Virtual Network subnet that is useable for private site access. + + :param name: The name of the subnet. + :type name: str + :param key: The key (ID) of the subnet. + :type key: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccessSubnet, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.key = kwargs.get('key', None) + + +class PrivateAccessVirtualNetwork(msrest.serialization.Model): + """Description of a Virtual Network that is useable for private site access. + + :param name: The name of the Virtual Network. + :type name: str + :param key: The key (ID) of the Virtual Network. + :type key: int + :param resource_id: The ARM uri of the Virtual Network. + :type resource_id: str + :param subnets: A List of subnets that access is allowed to on this Virtual Network. An empty + array (but not null) is interpreted to mean that all subnets are allowed within this Virtual + Network. + :type subnets: list[~azure.mgmt.web.v2020_09_01.models.PrivateAccessSubnet] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'subnets': {'key': 'subnets', 'type': '[PrivateAccessSubnet]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateAccessVirtualNetwork, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.key = kwargs.get('key', None) + self.resource_id = kwargs.get('resource_id', None) + self.subnets = kwargs.get('subnets', None) + + +class PrivateEndpointConnectionResource(ProxyOnlyResource): + """Private Endpoint Connection ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar provisioning_state: + :vartype provisioning_state: str + :param private_endpoint: PrivateEndpoint of a remote private endpoint connection. + :type private_endpoint: ~azure.mgmt.web.v2020_09_01.models.ArmIdWrapper + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'ArmIdWrapper'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateEndpointConnectionResource, self).__init__(**kwargs) + self.provisioning_state = None + self.private_endpoint = kwargs.get('private_endpoint', None) + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + + +class PrivateLinkConnectionApprovalRequestResource(ProxyOnlyResource): + """Private Endpoint Connection Approval ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkConnectionApprovalRequestResource, self).__init__(**kwargs) + self.private_link_service_connection_state = kwargs.get('private_link_service_connection_state', None) + + +class PrivateLinkConnectionState(msrest.serialization.Model): + """The state of a private link connection. + + :param status: Status of a private link connection. + :type status: str + :param description: Description of a private link connection. + :type description: str + :param actions_required: ActionsRequired for a private link connection. + :type actions_required: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'actions_required': {'key': 'actionsRequired', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkConnectionState, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.description = kwargs.get('description', None) + self.actions_required = kwargs.get('actions_required', None) + + +class PrivateLinkResource(msrest.serialization.Model): + """A private link resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. + :type id: str + :param name: Required. Name of a private link resource. + :type name: str + :param type: Required. + :type type: str + :param properties: Required. Properties of a private link resource. + :type properties: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkResourceProperties + """ + + _validation = { + 'id': {'required': True}, + 'name': {'required': True}, + 'type': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'PrivateLinkResourceProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResource, self).__init__(**kwargs) + self.id = kwargs['id'] + self.name = kwargs['name'] + self.type = kwargs['type'] + self.properties = kwargs['properties'] + + +class PrivateLinkResourceProperties(msrest.serialization.Model): + """Properties of a private link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: GroupId of a private link resource. + :vartype group_id: str + :ivar required_members: RequiredMembers of a private link resource. + :vartype required_members: list[str] + :ivar required_zone_names: RequiredZoneNames of a private link resource. + :vartype required_zone_names: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + 'required_zone_names': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_members': {'key': 'requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourceProperties, self).__init__(**kwargs) + self.group_id = None + self.required_members = None + self.required_zone_names = None + + +class PrivateLinkResourcesWrapper(msrest.serialization.Model): + """Wrapper for a collection of private link resources. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PrivateLinkResource] + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkResource]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourcesWrapper, self).__init__(**kwargs) + self.value = kwargs['value'] + + +class ProcessInfo(ProxyOnlyResource): + """Process Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar identifier: ARM Identifier for deployment. + :vartype identifier: int + :param deployment_name: Deployment name. + :type deployment_name: str + :param href: HRef URI. + :type href: str + :param minidump: Minidump URI. + :type minidump: str + :param is_profile_running: Is profile running?. + :type is_profile_running: bool + :param is_iis_profile_running: Is the IIS Profile running?. + :type is_iis_profile_running: bool + :param iis_profile_timeout_in_seconds: IIS Profile timeout (seconds). + :type iis_profile_timeout_in_seconds: float + :param parent: Parent process. + :type parent: str + :param children: Child process list. + :type children: list[str] + :param threads: Thread list. + :type threads: list[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfo] + :param open_file_handles: List of open files. + :type open_file_handles: list[str] + :param modules: List of modules. + :type modules: list[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo] + :param file_name: File name of this process. + :type file_name: str + :param command_line: Command line. + :type command_line: str + :param user_name: User name. + :type user_name: str + :param handle_count: Handle count. + :type handle_count: int + :param module_count: Module count. + :type module_count: int + :param thread_count: Thread count. + :type thread_count: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_cpu_time: Total CPU time. + :type total_cpu_time: str + :param user_cpu_time: User CPU time. + :type user_cpu_time: str + :param privileged_cpu_time: Privileged CPU time. + :type privileged_cpu_time: str + :param working_set: Working set. + :type working_set: long + :param peak_working_set: Peak working set. + :type peak_working_set: long + :param private_memory: Private memory size. + :type private_memory: long + :param virtual_memory: Virtual memory size. + :type virtual_memory: long + :param peak_virtual_memory: Peak virtual memory usage. + :type peak_virtual_memory: long + :param paged_system_memory: Paged system memory. + :type paged_system_memory: long + :param non_paged_system_memory: Non-paged system memory. + :type non_paged_system_memory: long + :param paged_memory: Paged memory. + :type paged_memory: long + :param peak_paged_memory: Peak paged memory. + :type peak_paged_memory: long + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + :param environment_variables: List of environment variables. + :type environment_variables: dict[str, str] + :param is_scm_site: Is this the SCM site?. + :type is_scm_site: bool + :param is_webjob: Is this a Web Job?. + :type is_webjob: bool + :param description: Description of process. + :type description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'deployment_name': {'key': 'properties.deployment_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'minidump': {'key': 'properties.minidump', 'type': 'str'}, + 'is_profile_running': {'key': 'properties.is_profile_running', 'type': 'bool'}, + 'is_iis_profile_running': {'key': 'properties.is_iis_profile_running', 'type': 'bool'}, + 'iis_profile_timeout_in_seconds': {'key': 'properties.iis_profile_timeout_in_seconds', 'type': 'float'}, + 'parent': {'key': 'properties.parent', 'type': 'str'}, + 'children': {'key': 'properties.children', 'type': '[str]'}, + 'threads': {'key': 'properties.threads', 'type': '[ProcessThreadInfo]'}, + 'open_file_handles': {'key': 'properties.open_file_handles', 'type': '[str]'}, + 'modules': {'key': 'properties.modules', 'type': '[ProcessModuleInfo]'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'command_line': {'key': 'properties.command_line', 'type': 'str'}, + 'user_name': {'key': 'properties.user_name', 'type': 'str'}, + 'handle_count': {'key': 'properties.handle_count', 'type': 'int'}, + 'module_count': {'key': 'properties.module_count', 'type': 'int'}, + 'thread_count': {'key': 'properties.thread_count', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_cpu_time': {'key': 'properties.total_cpu_time', 'type': 'str'}, + 'user_cpu_time': {'key': 'properties.user_cpu_time', 'type': 'str'}, + 'privileged_cpu_time': {'key': 'properties.privileged_cpu_time', 'type': 'str'}, + 'working_set': {'key': 'properties.working_set', 'type': 'long'}, + 'peak_working_set': {'key': 'properties.peak_working_set', 'type': 'long'}, + 'private_memory': {'key': 'properties.private_memory', 'type': 'long'}, + 'virtual_memory': {'key': 'properties.virtual_memory', 'type': 'long'}, + 'peak_virtual_memory': {'key': 'properties.peak_virtual_memory', 'type': 'long'}, + 'paged_system_memory': {'key': 'properties.paged_system_memory', 'type': 'long'}, + 'non_paged_system_memory': {'key': 'properties.non_paged_system_memory', 'type': 'long'}, + 'paged_memory': {'key': 'properties.paged_memory', 'type': 'long'}, + 'peak_paged_memory': {'key': 'properties.peak_paged_memory', 'type': 'long'}, + 'time_stamp': {'key': 'properties.time_stamp', 'type': 'iso-8601'}, + 'environment_variables': {'key': 'properties.environment_variables', 'type': '{str}'}, + 'is_scm_site': {'key': 'properties.is_scm_site', 'type': 'bool'}, + 'is_webjob': {'key': 'properties.is_webjob', 'type': 'bool'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessInfo, self).__init__(**kwargs) + self.identifier = None + self.deployment_name = kwargs.get('deployment_name', None) + self.href = kwargs.get('href', None) + self.minidump = kwargs.get('minidump', None) + self.is_profile_running = kwargs.get('is_profile_running', None) + self.is_iis_profile_running = kwargs.get('is_iis_profile_running', None) + self.iis_profile_timeout_in_seconds = kwargs.get('iis_profile_timeout_in_seconds', None) + self.parent = kwargs.get('parent', None) + self.children = kwargs.get('children', None) + self.threads = kwargs.get('threads', None) + self.open_file_handles = kwargs.get('open_file_handles', None) + self.modules = kwargs.get('modules', None) + self.file_name = kwargs.get('file_name', None) + self.command_line = kwargs.get('command_line', None) + self.user_name = kwargs.get('user_name', None) + self.handle_count = kwargs.get('handle_count', None) + self.module_count = kwargs.get('module_count', None) + self.thread_count = kwargs.get('thread_count', None) + self.start_time = kwargs.get('start_time', None) + self.total_cpu_time = kwargs.get('total_cpu_time', None) + self.user_cpu_time = kwargs.get('user_cpu_time', None) + self.privileged_cpu_time = kwargs.get('privileged_cpu_time', None) + self.working_set = kwargs.get('working_set', None) + self.peak_working_set = kwargs.get('peak_working_set', None) + self.private_memory = kwargs.get('private_memory', None) + self.virtual_memory = kwargs.get('virtual_memory', None) + self.peak_virtual_memory = kwargs.get('peak_virtual_memory', None) + self.paged_system_memory = kwargs.get('paged_system_memory', None) + self.non_paged_system_memory = kwargs.get('non_paged_system_memory', None) + self.paged_memory = kwargs.get('paged_memory', None) + self.peak_paged_memory = kwargs.get('peak_paged_memory', None) + self.time_stamp = kwargs.get('time_stamp', None) + self.environment_variables = kwargs.get('environment_variables', None) + self.is_scm_site = kwargs.get('is_scm_site', None) + self.is_webjob = kwargs.get('is_webjob', None) + self.description = kwargs.get('description', None) + + +class ProcessInfoCollection(msrest.serialization.Model): + """Collection of Kudu process information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ProcessModuleInfo(ProxyOnlyResource): + """Process Module Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param base_address: Base address. Used as module identifier in ARM resource URI. + :type base_address: str + :param file_name: File name. + :type file_name: str + :param href: HRef URI. + :type href: str + :param file_path: File path. + :type file_path: str + :param module_memory_size: Module memory size. + :type module_memory_size: int + :param file_version: File version. + :type file_version: str + :param file_description: File description. + :type file_description: str + :param product: Product name. + :type product: str + :param product_version: Product version. + :type product_version: str + :param is_debug: Is debug?. + :type is_debug: bool + :param language: Module language (locale). + :type language: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'base_address': {'key': 'properties.base_address', 'type': 'str'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'file_path': {'key': 'properties.file_path', 'type': 'str'}, + 'module_memory_size': {'key': 'properties.module_memory_size', 'type': 'int'}, + 'file_version': {'key': 'properties.file_version', 'type': 'str'}, + 'file_description': {'key': 'properties.file_description', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'product_version': {'key': 'properties.product_version', 'type': 'str'}, + 'is_debug': {'key': 'properties.is_debug', 'type': 'bool'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessModuleInfo, self).__init__(**kwargs) + self.base_address = kwargs.get('base_address', None) + self.file_name = kwargs.get('file_name', None) + self.href = kwargs.get('href', None) + self.file_path = kwargs.get('file_path', None) + self.module_memory_size = kwargs.get('module_memory_size', None) + self.file_version = kwargs.get('file_version', None) + self.file_description = kwargs.get('file_description', None) + self.product = kwargs.get('product', None) + self.product_version = kwargs.get('product_version', None) + self.is_debug = kwargs.get('is_debug', None) + self.language = kwargs.get('language', None) + + +class ProcessModuleInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessModuleInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessModuleInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ProcessThreadInfo(ProxyOnlyResource): + """Process Thread Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar identifier: Site extension ID. + :vartype identifier: int + :param href: HRef URI. + :type href: str + :param process: Process URI. + :type process: str + :param start_address: Start address. + :type start_address: str + :param current_priority: Current thread priority. + :type current_priority: int + :param priority_level: Thread priority level. + :type priority_level: str + :param base_priority: Base priority. + :type base_priority: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_processor_time: Total processor time. + :type total_processor_time: str + :param user_processor_time: User processor time. + :type user_processor_time: str + :param state: Thread state. + :type state: str + :param wait_reason: Wait reason. + :type wait_reason: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'process': {'key': 'properties.process', 'type': 'str'}, + 'start_address': {'key': 'properties.start_address', 'type': 'str'}, + 'current_priority': {'key': 'properties.current_priority', 'type': 'int'}, + 'priority_level': {'key': 'properties.priority_level', 'type': 'str'}, + 'base_priority': {'key': 'properties.base_priority', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_processor_time': {'key': 'properties.total_processor_time', 'type': 'str'}, + 'user_processor_time': {'key': 'properties.user_processor_time', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'wait_reason': {'key': 'properties.wait_reason', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessThreadInfo, self).__init__(**kwargs) + self.identifier = None + self.href = kwargs.get('href', None) + self.process = kwargs.get('process', None) + self.start_address = kwargs.get('start_address', None) + self.current_priority = kwargs.get('current_priority', None) + self.priority_level = kwargs.get('priority_level', None) + self.base_priority = kwargs.get('base_priority', None) + self.start_time = kwargs.get('start_time', None) + self.total_processor_time = kwargs.get('total_processor_time', None) + self.user_processor_time = kwargs.get('user_processor_time', None) + self.state = kwargs.get('state', None) + self.wait_reason = kwargs.get('wait_reason', None) + + +class ProcessThreadInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessThreadInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProcessThreadInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PublicCertificate(ProxyOnlyResource): + """Public certificate object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param blob: Public Certificate byte array. + :type blob: bytearray + :param public_certificate_location: Public Certificate Location. Possible values include: + "CurrentUserMy", "LocalMachineMy", "Unknown". + :type public_certificate_location: str or + ~azure.mgmt.web.v2020_09_01.models.PublicCertificateLocation + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'thumbprint': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'blob': {'key': 'properties.blob', 'type': 'bytearray'}, + 'public_certificate_location': {'key': 'properties.publicCertificateLocation', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicCertificate, self).__init__(**kwargs) + self.blob = kwargs.get('blob', None) + self.public_certificate_location = kwargs.get('public_certificate_location', None) + self.thumbprint = None + + +class PublicCertificateCollection(msrest.serialization.Model): + """Collection of public certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PublicCertificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicCertificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PublicCertificateCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class PushSettings(ProxyOnlyResource): + """Push settings for the App. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param is_push_enabled: Gets or sets a flag indicating whether the Push endpoint is enabled. + :type is_push_enabled: bool + :param tag_whitelist_json: Gets or sets a JSON string containing a list of tags that are + whitelisted for use by the push registration endpoint. + :type tag_whitelist_json: str + :param tags_requiring_auth: Gets or sets a JSON string containing a list of tags that require + user authentication to be used in the push registration endpoint. + Tags can consist of alphanumeric characters and the following: + '_', '@', '#', '.', ':', '-'. + Validation should be performed at the PushRequestHandler. + :type tags_requiring_auth: str + :param dynamic_tags_json: Gets or sets a JSON string containing a list of dynamic tags that + will be evaluated from user claims in the push registration endpoint. + :type dynamic_tags_json: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_push_enabled': {'key': 'properties.isPushEnabled', 'type': 'bool'}, + 'tag_whitelist_json': {'key': 'properties.tagWhitelistJson', 'type': 'str'}, + 'tags_requiring_auth': {'key': 'properties.tagsRequiringAuth', 'type': 'str'}, + 'dynamic_tags_json': {'key': 'properties.dynamicTagsJson', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PushSettings, self).__init__(**kwargs) + self.is_push_enabled = kwargs.get('is_push_enabled', None) + self.tag_whitelist_json = kwargs.get('tag_whitelist_json', None) + self.tags_requiring_auth = kwargs.get('tags_requiring_auth', None) + self.dynamic_tags_json = kwargs.get('dynamic_tags_json', None) + + +class RampUpRule(msrest.serialization.Model): + """Routing rules for ramp up testing. This rule allows to redirect static traffic % to a slot or to gradually change routing % based on performance. + + :param action_host_name: Hostname of a slot to which the traffic will be redirected if decided + to. E.g. myapp-stage.azurewebsites.net. + :type action_host_name: str + :param reroute_percentage: Percentage of the traffic which will be redirected to + :code:`ActionHostName`. + :type reroute_percentage: float + :param change_step: In auto ramp up scenario this is the step to add/remove from + :code:`ReroutePercentage` until it reaches + \n:code:`MinReroutePercentage` or + :code:`MaxReroutePercentage`. Site metrics are checked every N minutes specified + in :code:`ChangeIntervalInMinutes`.\nCustom decision algorithm + can be provided in TiPCallback site extension which URL can be specified in + :code:`ChangeDecisionCallbackUrl`. + :type change_step: float + :param change_interval_in_minutes: Specifies interval in minutes to reevaluate + ReroutePercentage. + :type change_interval_in_minutes: int + :param min_reroute_percentage: Specifies lower boundary above which ReroutePercentage will + stay. + :type min_reroute_percentage: float + :param max_reroute_percentage: Specifies upper boundary below which ReroutePercentage will + stay. + :type max_reroute_percentage: float + :param change_decision_callback_url: Custom decision algorithm can be provided in TiPCallback + site extension which URL can be specified. See TiPCallback site extension for the scaffold and + contracts. + https://www.siteextensions.net/packages/TiPCallback/. + :type change_decision_callback_url: str + :param name: Name of the routing rule. The recommended name would be to point to the slot which + will receive the traffic in the experiment. + :type name: str + """ + + _attribute_map = { + 'action_host_name': {'key': 'actionHostName', 'type': 'str'}, + 'reroute_percentage': {'key': 'reroutePercentage', 'type': 'float'}, + 'change_step': {'key': 'changeStep', 'type': 'float'}, + 'change_interval_in_minutes': {'key': 'changeIntervalInMinutes', 'type': 'int'}, + 'min_reroute_percentage': {'key': 'minReroutePercentage', 'type': 'float'}, + 'max_reroute_percentage': {'key': 'maxReroutePercentage', 'type': 'float'}, + 'change_decision_callback_url': {'key': 'changeDecisionCallbackUrl', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RampUpRule, self).__init__(**kwargs) + self.action_host_name = kwargs.get('action_host_name', None) + self.reroute_percentage = kwargs.get('reroute_percentage', None) + self.change_step = kwargs.get('change_step', None) + self.change_interval_in_minutes = kwargs.get('change_interval_in_minutes', None) + self.min_reroute_percentage = kwargs.get('min_reroute_percentage', None) + self.max_reroute_percentage = kwargs.get('max_reroute_percentage', None) + self.change_decision_callback_url = kwargs.get('change_decision_callback_url', None) + self.name = kwargs.get('name', None) + + +class Recommendation(ProxyOnlyResource): + """Represents a recommendation result generated by the recommendation engine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param creation_time: Timestamp when this instance was created. + :type creation_time: ~datetime.datetime + :param recommendation_id: A GUID value that each recommendation object is associated with. + :type recommendation_id: str + :param resource_id: Full ARM resource ID string that this recommendation object is associated + with. + :type resource_id: str + :param resource_scope: Name of a resource type this recommendation applies, e.g. Subscription, + ServerFarm, Site. Possible values include: "ServerFarm", "Subscription", "WebSite". + :type resource_scope: str or ~azure.mgmt.web.v2020_09_01.models.ResourceScopeType + :param rule_name: Unique name of the rule. + :type rule_name: str + :param display_name: UI friendly name of the rule (may not be unique). + :type display_name: str + :param message: Recommendation text. + :type message: str + :param level: Level indicating how critical this recommendation can impact. Possible values + include: "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.NotificationLevel + :param channels: List of channels that this recommendation can apply. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_09_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation belongs to. + :vartype category_tags: list[str] + :param action_name: Name of action recommended by this object. + :type action_name: str + :param enabled: True if this recommendation is still valid (i.e. "actionable"). False if it is + invalid. + :type enabled: int + :param states: The list of states of this recommendation. If it's null then it should be + considered "Active". + :type states: list[str] + :param start_time: The beginning time in UTC of a range that the recommendation refers to. + :type start_time: ~datetime.datetime + :param end_time: The end time in UTC of a range that the recommendation refers to. + :type end_time: ~datetime.datetime + :param next_notification_time: When to notify this recommendation next in UTC. Null means that + this will never be notified anymore. + :type next_notification_time: ~datetime.datetime + :param notification_expiration_time: Date and time in UTC when this notification expires. + :type notification_expiration_time: ~datetime.datetime + :param notified_time: Last timestamp in UTC this instance was actually notified. Null means + that this recommendation hasn't been notified yet. + :type notified_time: ~datetime.datetime + :param score: A metric value measured by the rule. + :type score: float + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'creation_time': {'key': 'properties.creationTime', 'type': 'iso-8601'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'resource_id': {'key': 'properties.resourceId', 'type': 'str'}, + 'resource_scope': {'key': 'properties.resourceScope', 'type': 'str'}, + 'rule_name': {'key': 'properties.ruleName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'int'}, + 'states': {'key': 'properties.states', 'type': '[str]'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'next_notification_time': {'key': 'properties.nextNotificationTime', 'type': 'iso-8601'}, + 'notification_expiration_time': {'key': 'properties.notificationExpirationTime', 'type': 'iso-8601'}, + 'notified_time': {'key': 'properties.notifiedTime', 'type': 'iso-8601'}, + 'score': {'key': 'properties.score', 'type': 'float'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Recommendation, self).__init__(**kwargs) + self.creation_time = kwargs.get('creation_time', None) + self.recommendation_id = kwargs.get('recommendation_id', None) + self.resource_id = kwargs.get('resource_id', None) + self.resource_scope = kwargs.get('resource_scope', None) + self.rule_name = kwargs.get('rule_name', None) + self.display_name = kwargs.get('display_name', None) + self.message = kwargs.get('message', None) + self.level = kwargs.get('level', None) + self.channels = kwargs.get('channels', None) + self.category_tags = None + self.action_name = kwargs.get('action_name', None) + self.enabled = kwargs.get('enabled', None) + self.states = kwargs.get('states', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.next_notification_time = kwargs.get('next_notification_time', None) + self.notification_expiration_time = kwargs.get('notification_expiration_time', None) + self.notified_time = kwargs.get('notified_time', None) + self.score = kwargs.get('score', None) + self.is_dynamic = kwargs.get('is_dynamic', None) + self.extension_name = kwargs.get('extension_name', None) + self.blade_name = kwargs.get('blade_name', None) + self.forward_link = kwargs.get('forward_link', None) + + +class RecommendationCollection(msrest.serialization.Model): + """Collection of recommendations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Recommendation] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Recommendation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RecommendationCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class RecommendationRule(ProxyOnlyResource): + """Represents a recommendation rule that the recommendation engine can perform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param recommendation_name: Unique name of the rule. + :type recommendation_name: str + :param display_name: UI friendly name of the rule. + :type display_name: str + :param message: Localized name of the rule (Good for UI). + :type message: str + :param recommendation_id: Recommendation ID of an associated recommendation object tied to the + rule, if exists. + If such an object doesn't exist, it is set to null. + :type recommendation_id: str + :param description: Localized detailed description of the rule. + :type description: str + :param action_name: Name of action that is recommended by this rule in string. + :type action_name: str + :param level: Level of impact indicating how critical this rule is. Possible values include: + "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.NotificationLevel + :param channels: List of available channels that this rule applies. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_09_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation rule belongs to. + :vartype category_tags: list[str] + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. Applicable to dynamic rule only. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. Applicable to dynamic rule only. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. Applicable + to dynamic rule only. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'recommendation_name': {'key': 'properties.recommendationName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RecommendationRule, self).__init__(**kwargs) + self.recommendation_name = kwargs.get('recommendation_name', None) + self.display_name = kwargs.get('display_name', None) + self.message = kwargs.get('message', None) + self.recommendation_id = kwargs.get('recommendation_id', None) + self.description = kwargs.get('description', None) + self.action_name = kwargs.get('action_name', None) + self.level = kwargs.get('level', None) + self.channels = kwargs.get('channels', None) + self.category_tags = None + self.is_dynamic = kwargs.get('is_dynamic', None) + self.extension_name = kwargs.get('extension_name', None) + self.blade_name = kwargs.get('blade_name', None) + self.forward_link = kwargs.get('forward_link', None) + + +class ReissueCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate reissue request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_size: Certificate Key Size. + :type key_size: int + :param delay_existing_revoke_in_hours: Delay in hours to revoke existing certificate after the + new certificate is issued. + :type delay_existing_revoke_in_hours: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'delay_existing_revoke_in_hours': {'key': 'properties.delayExistingRevokeInHours', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ReissueCertificateOrderRequest, self).__init__(**kwargs) + self.key_size = kwargs.get('key_size', None) + self.delay_existing_revoke_in_hours = kwargs.get('delay_existing_revoke_in_hours', None) + self.csr = kwargs.get('csr', None) + self.is_private_key_external = kwargs.get('is_private_key_external', None) + + +class RelayServiceConnectionEntity(ProxyOnlyResource): + """Hybrid Connection for an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param entity_name: + :type entity_name: str + :param entity_connection_string: + :type entity_connection_string: str + :param resource_type: + :type resource_type: str + :param resource_connection_string: + :type resource_connection_string: str + :param hostname: + :type hostname: str + :param port: + :type port: int + :param biztalk_uri: + :type biztalk_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'entity_name': {'key': 'properties.entityName', 'type': 'str'}, + 'entity_connection_string': {'key': 'properties.entityConnectionString', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'resource_connection_string': {'key': 'properties.resourceConnectionString', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'biztalk_uri': {'key': 'properties.biztalkUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RelayServiceConnectionEntity, self).__init__(**kwargs) + self.entity_name = kwargs.get('entity_name', None) + self.entity_connection_string = kwargs.get('entity_connection_string', None) + self.resource_type = kwargs.get('resource_type', None) + self.resource_connection_string = kwargs.get('resource_connection_string', None) + self.hostname = kwargs.get('hostname', None) + self.port = kwargs.get('port', None) + self.biztalk_uri = kwargs.get('biztalk_uri', None) + + +class Rendering(msrest.serialization.Model): + """Instructions for rendering the data. + + :param type: Rendering Type. Possible values include: "NoGraph", "Table", "TimeSeries", + "TimeSeriesPerInstance". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.RenderingType + :param title: Title of data. + :type title: str + :param description: Description of the data that will help it be interpreted. + :type description: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Rendering, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.title = kwargs.get('title', None) + self.description = kwargs.get('description', None) + + +class RenewCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate renew request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_size: Certificate Key Size. + :type key_size: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(RenewCertificateOrderRequest, self).__init__(**kwargs) + self.key_size = kwargs.get('key_size', None) + self.csr = kwargs.get('csr', None) + self.is_private_key_external = kwargs.get('is_private_key_external', None) + + +class RequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on total requests. + + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RequestsBasedTrigger, self).__init__(**kwargs) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class ResourceCollection(msrest.serialization.Model): + """Collection of resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[str] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[str]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceHealthMetadata(ProxyOnlyResource): + """Used for getting ResourceHealthCheck settings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param category: The category that the resource matches in the RHC Policy File. + :type category: str + :param signal_availability: Is there a health signal for the resource. + :type signal_availability: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'category': {'key': 'properties.category', 'type': 'str'}, + 'signal_availability': {'key': 'properties.signalAvailability', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceHealthMetadata, self).__init__(**kwargs) + self.category = kwargs.get('category', None) + self.signal_availability = kwargs.get('signal_availability', None) + + +class ResourceHealthMetadataCollection(msrest.serialization.Model): + """Collection of resource health metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceHealthMetadata]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceHealthMetadataCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceMetricAvailability(msrest.serialization.Model): + """Metrics availability and retention. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time_grain: Time grain . + :vartype time_grain: str + :ivar retention: Retention period for the current time grain. + :vartype retention: str + """ + + _validation = { + 'time_grain': {'readonly': True}, + 'retention': {'readonly': True}, + } + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricAvailability, self).__init__(**kwargs) + self.time_grain = None + self.retention = None + + +class ResourceMetricDefinition(ProxyOnlyResource): + """Metadata for the metrics. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar unit: Unit of the metric. + :vartype unit: str + :ivar primary_aggregation_type: Primary aggregation type. + :vartype primary_aggregation_type: str + :ivar metric_availabilities: List of time grains supported for the metric together with + retention period. + :vartype metric_availabilities: + list[~azure.mgmt.web.v2020_09_01.models.ResourceMetricAvailability] + :ivar resource_uri: Resource URI. + :vartype resource_uri: str + :ivar properties: Resource metric definition properties. + :vartype properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'unit': {'readonly': True}, + 'primary_aggregation_type': {'readonly': True}, + 'metric_availabilities': {'readonly': True}, + 'resource_uri': {'readonly': True}, + 'properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'primary_aggregation_type': {'key': 'properties.primaryAggregationType', 'type': 'str'}, + 'metric_availabilities': {'key': 'properties.metricAvailabilities', 'type': '[ResourceMetricAvailability]'}, + 'resource_uri': {'key': 'properties.resourceUri', 'type': 'str'}, + 'properties': {'key': 'properties.properties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricDefinition, self).__init__(**kwargs) + self.unit = None + self.primary_aggregation_type = None + self.metric_availabilities = None + self.resource_uri = None + self.properties = None + + +class ResourceMetricDefinitionCollection(msrest.serialization.Model): + """Collection of metric definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceMetricDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricDefinitionCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class ResourceNameAvailability(msrest.serialization.Model): + """Information regarding availability of a resource name. + + :param name_available: :code:`true` indicates name is valid and available. + :code:`false` indicates the name is invalid, unavailable, or both. + :type name_available: bool + :param reason: :code:`Invalid` indicates the name provided does not match Azure + App Service naming requirements. :code:`AlreadyExists` indicates that the name is + already in use and is therefore unavailable. Possible values include: "Invalid", + "AlreadyExists". + :type reason: str or ~azure.mgmt.web.v2020_09_01.models.InAvailabilityReasonType + :param message: If reason == invalid, provide the user with the reason why the given name is + invalid, and provide the resource naming requirements so that the user can select a valid name. + If reason == AlreadyExists, explain that resource name is already in use, and direct them to + select a different name. + :type message: str + """ + + _attribute_map = { + 'name_available': {'key': 'nameAvailable', 'type': 'bool'}, + 'reason': {'key': 'reason', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNameAvailability, self).__init__(**kwargs) + self.name_available = kwargs.get('name_available', None) + self.reason = kwargs.get('reason', None) + self.message = kwargs.get('message', None) + + +class ResourceNameAvailabilityRequest(msrest.serialization.Model): + """Resource name availability request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: "Site", + "Slot", "HostingEnvironment", "PublishingUser", "Microsoft.Web/sites", + "Microsoft.Web/sites/slots", "Microsoft.Web/hostingEnvironments", + "Microsoft.Web/publishingUsers". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_fqdn': {'key': 'isFqdn', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceNameAvailabilityRequest, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs['type'] + self.is_fqdn = kwargs.get('is_fqdn', None) + + +class ResponseMetaData(msrest.serialization.Model): + """ResponseMetaData. + + :param data_source: Source of the Data. + :type data_source: ~azure.mgmt.web.v2020_09_01.models.DataSource + """ + + _attribute_map = { + 'data_source': {'key': 'dataSource', 'type': 'DataSource'}, + } + + def __init__( + self, + **kwargs + ): + super(ResponseMetaData, self).__init__(**kwargs) + self.data_source = kwargs.get('data_source', None) + + +class RestoreRequest(ProxyOnlyResource): + """Description of a restore request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param blob_name: Name of a blob which contains the backup. + :type blob_name: str + :param overwrite: :code:`true` if the restore operation can overwrite target app; + otherwise, :code:`false`. :code:`true` is needed if trying to restore + over an existing app. + :type overwrite: bool + :param site_name: Name of an app. + :type site_name: str + :param databases: Collection of databases which should be restored. This list has to match the + list of databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + :param ignore_conflicting_host_names: Changes a logic when restoring an app with custom + domains. :code:`true` to remove custom domains automatically. If + :code:`false`, custom domains are added to + the app's object when it is being restored, but that might fail due to conflicts during the + operation. + :type ignore_conflicting_host_names: bool + :param ignore_databases: Ignore the databases and only restore the site content. + :type ignore_databases: bool + :param app_service_plan: Specify app service plan that will own restored site. + :type app_service_plan: str + :param operation_type: Operation type. Possible values include: "Default", "Clone", + "Relocation", "Snapshot", "CloudFS". Default value: "Default". + :type operation_type: str or ~azure.mgmt.web.v2020_09_01.models.BackupRestoreOperationType + :param adjust_connection_strings: :code:`true` if SiteConfig.ConnectionStrings + should be set in new app; otherwise, :code:`false`. + :type adjust_connection_strings: bool + :param hosting_environment: App Service Environment name, if needed (only when restoring an app + to an App Service Environment). + :type hosting_environment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'ignore_databases': {'key': 'properties.ignoreDatabases', 'type': 'bool'}, + 'app_service_plan': {'key': 'properties.appServicePlan', 'type': 'str'}, + 'operation_type': {'key': 'properties.operationType', 'type': 'str'}, + 'adjust_connection_strings': {'key': 'properties.adjustConnectionStrings', 'type': 'bool'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RestoreRequest, self).__init__(**kwargs) + self.storage_account_url = kwargs.get('storage_account_url', None) + self.blob_name = kwargs.get('blob_name', None) + self.overwrite = kwargs.get('overwrite', None) + self.site_name = kwargs.get('site_name', None) + self.databases = kwargs.get('databases', None) + self.ignore_conflicting_host_names = kwargs.get('ignore_conflicting_host_names', False) + self.ignore_databases = kwargs.get('ignore_databases', False) + self.app_service_plan = kwargs.get('app_service_plan', None) + self.operation_type = kwargs.get('operation_type', "Default") + self.adjust_connection_strings = kwargs.get('adjust_connection_strings', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + + +class ServiceSpecification(msrest.serialization.Model): + """Resource metrics service provided by Microsoft.Insights resource provider. + + :param metric_specifications: + :type metric_specifications: list[~azure.mgmt.web.v2020_09_01.models.MetricSpecification] + :param log_specifications: + :type log_specifications: list[~azure.mgmt.web.v2020_09_01.models.LogSpecification] + """ + + _attribute_map = { + 'metric_specifications': {'key': 'metricSpecifications', 'type': '[MetricSpecification]'}, + 'log_specifications': {'key': 'logSpecifications', 'type': '[LogSpecification]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = kwargs.get('metric_specifications', None) + self.log_specifications = kwargs.get('log_specifications', None) + + +class Site(Resource): + """A web app, a mobile app backend, or an API app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_09_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_09_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_09_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_09_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_09_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_09_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_09_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Site, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = kwargs.get('enabled', None) + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = kwargs.get('host_name_ssl_states', None) + self.server_farm_id = kwargs.get('server_farm_id', None) + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.last_modified_time_utc = None + self.site_config = kwargs.get('site_config', None) + self.traffic_manager_host_names = None + self.scm_site_also_stopped = kwargs.get('scm_site_also_stopped', False) + self.target_swap_slot = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.client_affinity_enabled = kwargs.get('client_affinity_enabled', None) + self.client_cert_enabled = kwargs.get('client_cert_enabled', None) + self.client_cert_mode = kwargs.get('client_cert_mode', None) + self.client_cert_exclusion_paths = kwargs.get('client_cert_exclusion_paths', None) + self.host_names_disabled = kwargs.get('host_names_disabled', None) + self.custom_domain_verification_id = kwargs.get('custom_domain_verification_id', None) + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = kwargs.get('container_size', None) + self.daily_memory_time_quota = kwargs.get('daily_memory_time_quota', None) + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = kwargs.get('cloning_info', None) + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = kwargs.get('https_only', None) + self.redundancy_mode = kwargs.get('redundancy_mode', None) + self.in_progress_operation_id = None + + +class SiteAuthSettings(ProxyOnlyResource): + """Configuration settings for the Azure App Service Authentication / Authorization feature. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: :code:`true` if the Authentication / Authorization feature is + enabled for the current app; otherwise, :code:`false`. + :type enabled: bool + :param runtime_version: The RuntimeVersion of the Authentication / Authorization feature in use + for the current app. + The setting in this value can control the behavior of certain features in the Authentication / + Authorization module. + :type runtime_version: str + :param unauthenticated_client_action: The action to take when an unauthenticated client + attempts to access the app. Possible values include: "RedirectToLoginPage", "AllowAnonymous". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_09_01.models.UnauthenticatedClientAction + :param token_store_enabled: :code:`true` to durably store platform-specific + security tokens that are obtained during login flows; otherwise, :code:`false`. + The default is :code:`false`. + :type token_store_enabled: bool + :param allowed_external_redirect_urls: External URLs that can be redirected to as part of + logging in or logging out of the app. Note that the query string part of the URL is ignored. + This is an advanced setting typically only needed by Windows Store application backends. + Note that URLs within the current domain are always implicitly allowed. + :type allowed_external_redirect_urls: list[str] + :param default_provider: The default authentication provider to use when multiple providers are + configured. + This setting is only needed if multiple providers are configured and the unauthenticated + client + action is set to "RedirectToLoginPage". Possible values include: "AzureActiveDirectory", + "Facebook", "Google", "MicrosoftAccount", "Twitter", "Github". + :type default_provider: str or ~azure.mgmt.web.v2020_09_01.models.BuiltInAuthenticationProvider + :param token_refresh_extension_hours: The number of hours after session token expiration that a + session token can be used to + call the token refresh API. The default is 72 hours. + :type token_refresh_extension_hours: float + :param client_id: The Client ID of this relying party application, known as the client_id. + This setting is required for enabling OpenID Connection authentication with Azure Active + Directory or + other 3rd party OpenID Connect providers. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_id: str + :param client_secret: The Client Secret of this relying party application (in Azure Active + Directory, this is also referred to as the Key). + This setting is optional. If no client secret is configured, the OpenID Connect implicit auth + flow is used to authenticate end users. + Otherwise, the OpenID Connect Authorization Code Flow is used to authenticate end users. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_secret: str + :param client_secret_setting_name: The app setting name that contains the client secret of the + relying party application. + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: An alternative to the client secret, that is the + thumbprint of a certificate used for signing purposes. This property acts as + a replacement for the Client Secret. It is also optional. + :type client_secret_certificate_thumbprint: str + :param issuer: The OpenID Connect Issuer URI that represents the entity which issues access + tokens for this application. + When using Azure Active Directory, this value is the URI of the directory tenant, e.g. + https://sts.windows.net/{tenant-guid}/. + This URI is a case-sensitive identifier for the token issuer. + More information on OpenID Connect Discovery: http://openid.net/specs/openid-connect- + discovery-1_0.html. + :type issuer: str + :param validate_issuer: Gets a value indicating whether the issuer should be a valid HTTPS url + and be validated as such. + :type validate_issuer: bool + :param allowed_audiences: Allowed audience values to consider when validating JWTs issued by + Azure Active Directory. Note that the :code:`ClientID` value is always considered + an + allowed audience, regardless of this setting. + :type allowed_audiences: list[str] + :param additional_login_params: Login parameters to send to the OpenID Connect authorization + endpoint when + a user logs in. Each parameter must be in the form "key=value". + :type additional_login_params: list[str] + :param aad_claims_authorization: Gets a JSON string containing the Azure AD Acl settings. + :type aad_claims_authorization: str + :param google_client_id: The OpenID Connect Client ID for the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_id: str + :param google_client_secret: The client secret associated with the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_secret: str + :param google_client_secret_setting_name: The app setting name that contains the client secret + associated with + the Google web application. + :type google_client_secret_setting_name: str + :param google_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Google + Sign-In authentication. + This setting is optional. If not specified, "openid", "profile", and "email" are used as + default scopes. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_o_auth_scopes: list[str] + :param facebook_app_id: The App ID of the Facebook app used for login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_id: str + :param facebook_app_secret: The App Secret of the Facebook app used for Facebook Login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_secret: str + :param facebook_app_secret_setting_name: The app setting name that contains the app secret used + for Facebook Login. + :type facebook_app_secret_setting_name: str + :param facebook_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Facebook + Login authentication. + This setting is optional. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_o_auth_scopes: list[str] + :param git_hub_client_id: The Client Id of the GitHub app used for login. + This setting is required for enabling Github login. + :type git_hub_client_id: str + :param git_hub_client_secret: The Client Secret of the GitHub app used for Github Login. + This setting is required for enabling Github login. + :type git_hub_client_secret: str + :param git_hub_client_secret_setting_name: The app setting name that contains the client secret + of the Github + app used for GitHub Login. + :type git_hub_client_secret_setting_name: str + :param git_hub_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of GitHub + Login authentication. + This setting is optional. + :type git_hub_o_auth_scopes: list[str] + :param twitter_consumer_key: The OAuth 1.0a consumer key of the Twitter application used for + sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_key: str + :param twitter_consumer_secret: The OAuth 1.0a consumer secret of the Twitter application used + for sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_secret: str + :param twitter_consumer_secret_setting_name: The app setting name that contains the OAuth 1.0a + consumer secret of the Twitter + application used for sign-in. + :type twitter_consumer_secret_setting_name: str + :param microsoft_account_client_id: The OAuth 2.0 client ID that was created for the app used + for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_id: str + :param microsoft_account_client_secret: The OAuth 2.0 client secret that was created for the + app used for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_secret: str + :param microsoft_account_client_secret_setting_name: The app setting name containing the OAuth + 2.0 client secret that was created for the + app used for authentication. + :type microsoft_account_client_secret_setting_name: str + :param microsoft_account_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of + Microsoft Account authentication. + This setting is optional. If not specified, "wl.basic" is used as the default scope. + Microsoft Account Scopes and permissions documentation: https://msdn.microsoft.com/en- + us/library/dn631845.aspx. + :type microsoft_account_o_auth_scopes: list[str] + :param is_auth_from_file: "true" if the auth config settings should be read from a file, + "false" otherwise. + :type is_auth_from_file: str + :param auth_file_path: The path of the config file containing auth settings. + If the path is relative, base will the site's root directory. + :type auth_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'token_store_enabled': {'key': 'properties.tokenStoreEnabled', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'default_provider': {'key': 'properties.defaultProvider', 'type': 'str'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret': {'key': 'properties.clientSecret', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'validate_issuer': {'key': 'properties.validateIssuer', 'type': 'bool'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + 'additional_login_params': {'key': 'properties.additionalLoginParams', 'type': '[str]'}, + 'aad_claims_authorization': {'key': 'properties.aadClaimsAuthorization', 'type': 'str'}, + 'google_client_id': {'key': 'properties.googleClientId', 'type': 'str'}, + 'google_client_secret': {'key': 'properties.googleClientSecret', 'type': 'str'}, + 'google_client_secret_setting_name': {'key': 'properties.googleClientSecretSettingName', 'type': 'str'}, + 'google_o_auth_scopes': {'key': 'properties.googleOAuthScopes', 'type': '[str]'}, + 'facebook_app_id': {'key': 'properties.facebookAppId', 'type': 'str'}, + 'facebook_app_secret': {'key': 'properties.facebookAppSecret', 'type': 'str'}, + 'facebook_app_secret_setting_name': {'key': 'properties.facebookAppSecretSettingName', 'type': 'str'}, + 'facebook_o_auth_scopes': {'key': 'properties.facebookOAuthScopes', 'type': '[str]'}, + 'git_hub_client_id': {'key': 'properties.gitHubClientId', 'type': 'str'}, + 'git_hub_client_secret': {'key': 'properties.gitHubClientSecret', 'type': 'str'}, + 'git_hub_client_secret_setting_name': {'key': 'properties.gitHubClientSecretSettingName', 'type': 'str'}, + 'git_hub_o_auth_scopes': {'key': 'properties.gitHubOAuthScopes', 'type': '[str]'}, + 'twitter_consumer_key': {'key': 'properties.twitterConsumerKey', 'type': 'str'}, + 'twitter_consumer_secret': {'key': 'properties.twitterConsumerSecret', 'type': 'str'}, + 'twitter_consumer_secret_setting_name': {'key': 'properties.twitterConsumerSecretSettingName', 'type': 'str'}, + 'microsoft_account_client_id': {'key': 'properties.microsoftAccountClientId', 'type': 'str'}, + 'microsoft_account_client_secret': {'key': 'properties.microsoftAccountClientSecret', 'type': 'str'}, + 'microsoft_account_client_secret_setting_name': {'key': 'properties.microsoftAccountClientSecretSettingName', 'type': 'str'}, + 'microsoft_account_o_auth_scopes': {'key': 'properties.microsoftAccountOAuthScopes', 'type': '[str]'}, + 'is_auth_from_file': {'key': 'properties.isAuthFromFile', 'type': 'str'}, + 'auth_file_path': {'key': 'properties.authFilePath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteAuthSettings, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.unauthenticated_client_action = kwargs.get('unauthenticated_client_action', None) + self.token_store_enabled = kwargs.get('token_store_enabled', None) + self.allowed_external_redirect_urls = kwargs.get('allowed_external_redirect_urls', None) + self.default_provider = kwargs.get('default_provider', None) + self.token_refresh_extension_hours = kwargs.get('token_refresh_extension_hours', None) + self.client_id = kwargs.get('client_id', None) + self.client_secret = kwargs.get('client_secret', None) + self.client_secret_setting_name = kwargs.get('client_secret_setting_name', None) + self.client_secret_certificate_thumbprint = kwargs.get('client_secret_certificate_thumbprint', None) + self.issuer = kwargs.get('issuer', None) + self.validate_issuer = kwargs.get('validate_issuer', None) + self.allowed_audiences = kwargs.get('allowed_audiences', None) + self.additional_login_params = kwargs.get('additional_login_params', None) + self.aad_claims_authorization = kwargs.get('aad_claims_authorization', None) + self.google_client_id = kwargs.get('google_client_id', None) + self.google_client_secret = kwargs.get('google_client_secret', None) + self.google_client_secret_setting_name = kwargs.get('google_client_secret_setting_name', None) + self.google_o_auth_scopes = kwargs.get('google_o_auth_scopes', None) + self.facebook_app_id = kwargs.get('facebook_app_id', None) + self.facebook_app_secret = kwargs.get('facebook_app_secret', None) + self.facebook_app_secret_setting_name = kwargs.get('facebook_app_secret_setting_name', None) + self.facebook_o_auth_scopes = kwargs.get('facebook_o_auth_scopes', None) + self.git_hub_client_id = kwargs.get('git_hub_client_id', None) + self.git_hub_client_secret = kwargs.get('git_hub_client_secret', None) + self.git_hub_client_secret_setting_name = kwargs.get('git_hub_client_secret_setting_name', None) + self.git_hub_o_auth_scopes = kwargs.get('git_hub_o_auth_scopes', None) + self.twitter_consumer_key = kwargs.get('twitter_consumer_key', None) + self.twitter_consumer_secret = kwargs.get('twitter_consumer_secret', None) + self.twitter_consumer_secret_setting_name = kwargs.get('twitter_consumer_secret_setting_name', None) + self.microsoft_account_client_id = kwargs.get('microsoft_account_client_id', None) + self.microsoft_account_client_secret = kwargs.get('microsoft_account_client_secret', None) + self.microsoft_account_client_secret_setting_name = kwargs.get('microsoft_account_client_secret_setting_name', None) + self.microsoft_account_o_auth_scopes = kwargs.get('microsoft_account_o_auth_scopes', None) + self.is_auth_from_file = kwargs.get('is_auth_from_file', None) + self.auth_file_path = kwargs.get('auth_file_path', None) + + +class SiteAuthSettingsV2(ProxyOnlyResource): + """SiteAuthSettingsV2. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param platform: + :type platform: ~azure.mgmt.web.v2020_09_01.models.AuthPlatform + :param global_validation: + :type global_validation: ~azure.mgmt.web.v2020_09_01.models.GlobalValidation + :param identity_providers: + :type identity_providers: ~azure.mgmt.web.v2020_09_01.models.IdentityProviders + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.Login + :param http_settings: + :type http_settings: ~azure.mgmt.web.v2020_09_01.models.HttpSettings + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'platform': {'key': 'properties.platform', 'type': 'AuthPlatform'}, + 'global_validation': {'key': 'properties.globalValidation', 'type': 'GlobalValidation'}, + 'identity_providers': {'key': 'properties.identityProviders', 'type': 'IdentityProviders'}, + 'login': {'key': 'properties.login', 'type': 'Login'}, + 'http_settings': {'key': 'properties.httpSettings', 'type': 'HttpSettings'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteAuthSettingsV2, self).__init__(**kwargs) + self.platform = kwargs.get('platform', None) + self.global_validation = kwargs.get('global_validation', None) + self.identity_providers = kwargs.get('identity_providers', None) + self.login = kwargs.get('login', None) + self.http_settings = kwargs.get('http_settings', None) + + +class SiteCloneability(msrest.serialization.Model): + """Represents whether or not an app is cloneable. + + :param result: Name of app. Possible values include: "Cloneable", "PartiallyCloneable", + "NotCloneable". + :type result: str or ~azure.mgmt.web.v2020_09_01.models.CloneAbilityResult + :param blocking_features: List of features enabled on app that prevent cloning. + :type blocking_features: list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + :param unsupported_features: List of features enabled on app that are non-blocking but cannot + be cloned. The app can still be cloned + but the features in this list will not be set up on cloned app. + :type unsupported_features: list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + :param blocking_characteristics: List of blocking application characteristics. + :type blocking_characteristics: + list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + """ + + _attribute_map = { + 'result': {'key': 'result', 'type': 'str'}, + 'blocking_features': {'key': 'blockingFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'unsupported_features': {'key': 'unsupportedFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'blocking_characteristics': {'key': 'blockingCharacteristics', 'type': '[SiteCloneabilityCriterion]'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteCloneability, self).__init__(**kwargs) + self.result = kwargs.get('result', None) + self.blocking_features = kwargs.get('blocking_features', None) + self.unsupported_features = kwargs.get('unsupported_features', None) + self.blocking_characteristics = kwargs.get('blocking_characteristics', None) + + +class SiteCloneabilityCriterion(msrest.serialization.Model): + """An app cloneability criterion. + + :param name: Name of criterion. + :type name: str + :param description: Description of criterion. + :type description: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteCloneabilityCriterion, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.description = kwargs.get('description', None) + + +class SiteConfig(msrest.serialization.Model): + """Configuration of an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_09_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_09_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_09_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_09_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_09_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_09_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_09_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_09_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_09_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_09_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_09_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_09_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_09_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_09_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'number_of_workers': {'key': 'numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'phpVersion', 'type': 'str'}, + 'python_version': {'key': 'pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'javaVersion', 'type': 'str'}, + 'java_container': {'key': 'javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'experiments', 'type': 'Experiments'}, + 'limits': {'key': 'limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'cors', 'type': 'CorsSettings'}, + 'push': {'key': 'push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfig, self).__init__(**kwargs) + self.number_of_workers = kwargs.get('number_of_workers', None) + self.default_documents = kwargs.get('default_documents', None) + self.net_framework_version = kwargs.get('net_framework_version', "v4.6") + self.php_version = kwargs.get('php_version', None) + self.python_version = kwargs.get('python_version', None) + self.node_version = kwargs.get('node_version', None) + self.power_shell_version = kwargs.get('power_shell_version', None) + self.linux_fx_version = kwargs.get('linux_fx_version', None) + self.windows_fx_version = kwargs.get('windows_fx_version', None) + self.request_tracing_enabled = kwargs.get('request_tracing_enabled', None) + self.request_tracing_expiration_time = kwargs.get('request_tracing_expiration_time', None) + self.remote_debugging_enabled = kwargs.get('remote_debugging_enabled', None) + self.remote_debugging_version = kwargs.get('remote_debugging_version', None) + self.http_logging_enabled = kwargs.get('http_logging_enabled', None) + self.logs_directory_size_limit = kwargs.get('logs_directory_size_limit', None) + self.detailed_error_logging_enabled = kwargs.get('detailed_error_logging_enabled', None) + self.publishing_username = kwargs.get('publishing_username', None) + self.app_settings = kwargs.get('app_settings', None) + self.connection_strings = kwargs.get('connection_strings', None) + self.machine_key = None + self.handler_mappings = kwargs.get('handler_mappings', None) + self.document_root = kwargs.get('document_root', None) + self.scm_type = kwargs.get('scm_type', None) + self.use32_bit_worker_process = kwargs.get('use32_bit_worker_process', None) + self.web_sockets_enabled = kwargs.get('web_sockets_enabled', None) + self.always_on = kwargs.get('always_on', None) + self.java_version = kwargs.get('java_version', None) + self.java_container = kwargs.get('java_container', None) + self.java_container_version = kwargs.get('java_container_version', None) + self.app_command_line = kwargs.get('app_command_line', None) + self.managed_pipeline_mode = kwargs.get('managed_pipeline_mode', None) + self.virtual_applications = kwargs.get('virtual_applications', None) + self.load_balancing = kwargs.get('load_balancing', None) + self.experiments = kwargs.get('experiments', None) + self.limits = kwargs.get('limits', None) + self.auto_heal_enabled = kwargs.get('auto_heal_enabled', None) + self.auto_heal_rules = kwargs.get('auto_heal_rules', None) + self.tracing_options = kwargs.get('tracing_options', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_route_all_enabled = kwargs.get('vnet_route_all_enabled', None) + self.vnet_private_ports_count = kwargs.get('vnet_private_ports_count', None) + self.cors = kwargs.get('cors', None) + self.push = kwargs.get('push', None) + self.api_definition = kwargs.get('api_definition', None) + self.api_management_config = kwargs.get('api_management_config', None) + self.auto_swap_slot_name = kwargs.get('auto_swap_slot_name', None) + self.local_my_sql_enabled = kwargs.get('local_my_sql_enabled', False) + self.managed_service_identity_id = kwargs.get('managed_service_identity_id', None) + self.x_managed_service_identity_id = kwargs.get('x_managed_service_identity_id', None) + self.ip_security_restrictions = kwargs.get('ip_security_restrictions', None) + self.scm_ip_security_restrictions = kwargs.get('scm_ip_security_restrictions', None) + self.scm_ip_security_restrictions_use_main = kwargs.get('scm_ip_security_restrictions_use_main', None) + self.http20_enabled = kwargs.get('http20_enabled', True) + self.min_tls_version = kwargs.get('min_tls_version', None) + self.scm_min_tls_version = kwargs.get('scm_min_tls_version', None) + self.ftps_state = kwargs.get('ftps_state', None) + self.pre_warmed_instance_count = kwargs.get('pre_warmed_instance_count', None) + self.health_check_path = kwargs.get('health_check_path', None) + + +class SiteConfigResource(ProxyOnlyResource): + """Web app configuration ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_09_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_09_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_09_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_09_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_09_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_09_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_09_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_09_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_09_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_09_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_09_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_09_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_09_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_09_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'number_of_workers': {'key': 'properties.numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'properties.defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'properties.netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'properties.phpVersion', 'type': 'str'}, + 'python_version': {'key': 'properties.pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'properties.nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'properties.powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'properties.linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'properties.windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'properties.requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'properties.requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'properties.remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'properties.remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'properties.httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'properties.logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'properties.detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'properties.publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'properties.appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'properties.connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'properties.machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'properties.handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'properties.documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'properties.scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'properties.use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'properties.webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'properties.alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'properties.javaVersion', 'type': 'str'}, + 'java_container': {'key': 'properties.javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'properties.javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'properties.appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'properties.managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'properties.virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'properties.loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'properties.experiments', 'type': 'Experiments'}, + 'limits': {'key': 'properties.limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'properties.autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'properties.autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'properties.tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'properties.vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'properties.vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'properties.cors', 'type': 'CorsSettings'}, + 'push': {'key': 'properties.push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'properties.apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'properties.apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'properties.autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'properties.managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'properties.xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'properties.ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'properties.scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'properties.scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'properties.http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'properties.minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'properties.scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'properties.ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'properties.preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'properties.healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigResource, self).__init__(**kwargs) + self.number_of_workers = kwargs.get('number_of_workers', None) + self.default_documents = kwargs.get('default_documents', None) + self.net_framework_version = kwargs.get('net_framework_version', "v4.6") + self.php_version = kwargs.get('php_version', None) + self.python_version = kwargs.get('python_version', None) + self.node_version = kwargs.get('node_version', None) + self.power_shell_version = kwargs.get('power_shell_version', None) + self.linux_fx_version = kwargs.get('linux_fx_version', None) + self.windows_fx_version = kwargs.get('windows_fx_version', None) + self.request_tracing_enabled = kwargs.get('request_tracing_enabled', None) + self.request_tracing_expiration_time = kwargs.get('request_tracing_expiration_time', None) + self.remote_debugging_enabled = kwargs.get('remote_debugging_enabled', None) + self.remote_debugging_version = kwargs.get('remote_debugging_version', None) + self.http_logging_enabled = kwargs.get('http_logging_enabled', None) + self.logs_directory_size_limit = kwargs.get('logs_directory_size_limit', None) + self.detailed_error_logging_enabled = kwargs.get('detailed_error_logging_enabled', None) + self.publishing_username = kwargs.get('publishing_username', None) + self.app_settings = kwargs.get('app_settings', None) + self.connection_strings = kwargs.get('connection_strings', None) + self.machine_key = None + self.handler_mappings = kwargs.get('handler_mappings', None) + self.document_root = kwargs.get('document_root', None) + self.scm_type = kwargs.get('scm_type', None) + self.use32_bit_worker_process = kwargs.get('use32_bit_worker_process', None) + self.web_sockets_enabled = kwargs.get('web_sockets_enabled', None) + self.always_on = kwargs.get('always_on', None) + self.java_version = kwargs.get('java_version', None) + self.java_container = kwargs.get('java_container', None) + self.java_container_version = kwargs.get('java_container_version', None) + self.app_command_line = kwargs.get('app_command_line', None) + self.managed_pipeline_mode = kwargs.get('managed_pipeline_mode', None) + self.virtual_applications = kwargs.get('virtual_applications', None) + self.load_balancing = kwargs.get('load_balancing', None) + self.experiments = kwargs.get('experiments', None) + self.limits = kwargs.get('limits', None) + self.auto_heal_enabled = kwargs.get('auto_heal_enabled', None) + self.auto_heal_rules = kwargs.get('auto_heal_rules', None) + self.tracing_options = kwargs.get('tracing_options', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_route_all_enabled = kwargs.get('vnet_route_all_enabled', None) + self.vnet_private_ports_count = kwargs.get('vnet_private_ports_count', None) + self.cors = kwargs.get('cors', None) + self.push = kwargs.get('push', None) + self.api_definition = kwargs.get('api_definition', None) + self.api_management_config = kwargs.get('api_management_config', None) + self.auto_swap_slot_name = kwargs.get('auto_swap_slot_name', None) + self.local_my_sql_enabled = kwargs.get('local_my_sql_enabled', False) + self.managed_service_identity_id = kwargs.get('managed_service_identity_id', None) + self.x_managed_service_identity_id = kwargs.get('x_managed_service_identity_id', None) + self.ip_security_restrictions = kwargs.get('ip_security_restrictions', None) + self.scm_ip_security_restrictions = kwargs.get('scm_ip_security_restrictions', None) + self.scm_ip_security_restrictions_use_main = kwargs.get('scm_ip_security_restrictions_use_main', None) + self.http20_enabled = kwargs.get('http20_enabled', True) + self.min_tls_version = kwargs.get('min_tls_version', None) + self.scm_min_tls_version = kwargs.get('scm_min_tls_version', None) + self.ftps_state = kwargs.get('ftps_state', None) + self.pre_warmed_instance_count = kwargs.get('pre_warmed_instance_count', None) + self.health_check_path = kwargs.get('health_check_path', None) + + +class SiteConfigResourceCollection(msrest.serialization.Model): + """Collection of site configurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteConfigResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigResourceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteConfigurationSnapshotInfo(ProxyOnlyResource): + """A snapshot of a web app configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar time: The time the snapshot was taken. + :vartype time: ~datetime.datetime + :ivar snapshot_id: The id of the snapshot. + :vartype snapshot_id: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'time': {'readonly': True}, + 'snapshot_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'time': {'key': 'properties.time', 'type': 'iso-8601'}, + 'snapshot_id': {'key': 'properties.snapshotId', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigurationSnapshotInfo, self).__init__(**kwargs) + self.time = None + self.snapshot_id = None + + +class SiteConfigurationSnapshotInfoCollection(msrest.serialization.Model): + """Collection of metadata for the app configuration snapshots that can be restored. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigurationSnapshotInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteConfigurationSnapshotInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteExtensionInfo(ProxyOnlyResource): + """Site Extension Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param extension_id: Site extension ID. + :type extension_id: str + :param title: + :type title: str + :param extension_type: Site extension type. Possible values include: "Gallery", "WebRoot". + :type extension_type: str or ~azure.mgmt.web.v2020_09_01.models.SiteExtensionType + :param summary: Summary description. + :type summary: str + :param description: Detailed description. + :type description: str + :param version: Version information. + :type version: str + :param extension_url: Extension URL. + :type extension_url: str + :param project_url: Project URL. + :type project_url: str + :param icon_url: Icon URL. + :type icon_url: str + :param license_url: License URL. + :type license_url: str + :param feed_url: Feed URL. + :type feed_url: str + :param authors: List of authors. + :type authors: list[str] + :param installer_command_line_params: Installer command line parameters. + :type installer_command_line_params: str + :param published_date_time: Published timestamp. + :type published_date_time: ~datetime.datetime + :param download_count: Count of downloads. + :type download_count: int + :param local_is_latest_version: :code:`true` if the local version is the latest + version; :code:`false` otherwise. + :type local_is_latest_version: bool + :param local_path: Local path. + :type local_path: str + :param installed_date_time: Installed timestamp. + :type installed_date_time: ~datetime.datetime + :param provisioning_state: Provisioning state. + :type provisioning_state: str + :param comment: Site Extension comment. + :type comment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'extension_id': {'key': 'properties.extension_id', 'type': 'str'}, + 'title': {'key': 'properties.title', 'type': 'str'}, + 'extension_type': {'key': 'properties.extension_type', 'type': 'str'}, + 'summary': {'key': 'properties.summary', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'extension_url': {'key': 'properties.extension_url', 'type': 'str'}, + 'project_url': {'key': 'properties.project_url', 'type': 'str'}, + 'icon_url': {'key': 'properties.icon_url', 'type': 'str'}, + 'license_url': {'key': 'properties.license_url', 'type': 'str'}, + 'feed_url': {'key': 'properties.feed_url', 'type': 'str'}, + 'authors': {'key': 'properties.authors', 'type': '[str]'}, + 'installer_command_line_params': {'key': 'properties.installer_command_line_params', 'type': 'str'}, + 'published_date_time': {'key': 'properties.published_date_time', 'type': 'iso-8601'}, + 'download_count': {'key': 'properties.download_count', 'type': 'int'}, + 'local_is_latest_version': {'key': 'properties.local_is_latest_version', 'type': 'bool'}, + 'local_path': {'key': 'properties.local_path', 'type': 'str'}, + 'installed_date_time': {'key': 'properties.installed_date_time', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'comment': {'key': 'properties.comment', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteExtensionInfo, self).__init__(**kwargs) + self.extension_id = kwargs.get('extension_id', None) + self.title = kwargs.get('title', None) + self.extension_type = kwargs.get('extension_type', None) + self.summary = kwargs.get('summary', None) + self.description = kwargs.get('description', None) + self.version = kwargs.get('version', None) + self.extension_url = kwargs.get('extension_url', None) + self.project_url = kwargs.get('project_url', None) + self.icon_url = kwargs.get('icon_url', None) + self.license_url = kwargs.get('license_url', None) + self.feed_url = kwargs.get('feed_url', None) + self.authors = kwargs.get('authors', None) + self.installer_command_line_params = kwargs.get('installer_command_line_params', None) + self.published_date_time = kwargs.get('published_date_time', None) + self.download_count = kwargs.get('download_count', None) + self.local_is_latest_version = kwargs.get('local_is_latest_version', None) + self.local_path = kwargs.get('local_path', None) + self.installed_date_time = kwargs.get('installed_date_time', None) + self.provisioning_state = kwargs.get('provisioning_state', None) + self.comment = kwargs.get('comment', None) + + +class SiteExtensionInfoCollection(msrest.serialization.Model): + """Collection of Kudu site extension information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteExtensionInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteExtensionInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SiteLimits(msrest.serialization.Model): + """Metric limits set on an app. + + :param max_percentage_cpu: Maximum allowed CPU usage percentage. + :type max_percentage_cpu: float + :param max_memory_in_mb: Maximum allowed memory usage in MB. + :type max_memory_in_mb: long + :param max_disk_size_in_mb: Maximum allowed disk size usage in MB. + :type max_disk_size_in_mb: long + """ + + _attribute_map = { + 'max_percentage_cpu': {'key': 'maxPercentageCpu', 'type': 'float'}, + 'max_memory_in_mb': {'key': 'maxMemoryInMb', 'type': 'long'}, + 'max_disk_size_in_mb': {'key': 'maxDiskSizeInMb', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteLimits, self).__init__(**kwargs) + self.max_percentage_cpu = kwargs.get('max_percentage_cpu', None) + self.max_memory_in_mb = kwargs.get('max_memory_in_mb', None) + self.max_disk_size_in_mb = kwargs.get('max_disk_size_in_mb', None) + + +class SiteLogsConfig(ProxyOnlyResource): + """Configuration of App Service site logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param application_logs: Application logs configuration. + :type application_logs: ~azure.mgmt.web.v2020_09_01.models.ApplicationLogsConfig + :param http_logs: HTTP logs configuration. + :type http_logs: ~azure.mgmt.web.v2020_09_01.models.HttpLogsConfig + :param failed_requests_tracing: Failed requests tracing configuration. + :type failed_requests_tracing: ~azure.mgmt.web.v2020_09_01.models.EnabledConfig + :param detailed_error_messages: Detailed error messages configuration. + :type detailed_error_messages: ~azure.mgmt.web.v2020_09_01.models.EnabledConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'application_logs': {'key': 'properties.applicationLogs', 'type': 'ApplicationLogsConfig'}, + 'http_logs': {'key': 'properties.httpLogs', 'type': 'HttpLogsConfig'}, + 'failed_requests_tracing': {'key': 'properties.failedRequestsTracing', 'type': 'EnabledConfig'}, + 'detailed_error_messages': {'key': 'properties.detailedErrorMessages', 'type': 'EnabledConfig'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteLogsConfig, self).__init__(**kwargs) + self.application_logs = kwargs.get('application_logs', None) + self.http_logs = kwargs.get('http_logs', None) + self.failed_requests_tracing = kwargs.get('failed_requests_tracing', None) + self.detailed_error_messages = kwargs.get('detailed_error_messages', None) + + +class SiteMachineKey(msrest.serialization.Model): + """MachineKey of an app. + + :param validation: MachineKey validation. + :type validation: str + :param validation_key: Validation key. + :type validation_key: str + :param decryption: Algorithm used for decryption. + :type decryption: str + :param decryption_key: Decryption key. + :type decryption_key: str + """ + + _attribute_map = { + 'validation': {'key': 'validation', 'type': 'str'}, + 'validation_key': {'key': 'validationKey', 'type': 'str'}, + 'decryption': {'key': 'decryption', 'type': 'str'}, + 'decryption_key': {'key': 'decryptionKey', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteMachineKey, self).__init__(**kwargs) + self.validation = kwargs.get('validation', None) + self.validation_key = kwargs.get('validation_key', None) + self.decryption = kwargs.get('decryption', None) + self.decryption_key = kwargs.get('decryption_key', None) + + +class SitePatchResource(ProxyOnlyResource): + """ARM resource for a site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_09_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_09_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_09_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_09_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_09_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_09_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_09_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SitePatchResource, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = kwargs.get('enabled', None) + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = kwargs.get('host_name_ssl_states', None) + self.server_farm_id = kwargs.get('server_farm_id', None) + self.reserved = kwargs.get('reserved', False) + self.is_xenon = kwargs.get('is_xenon', False) + self.hyper_v = kwargs.get('hyper_v', False) + self.last_modified_time_utc = None + self.site_config = kwargs.get('site_config', None) + self.traffic_manager_host_names = None + self.scm_site_also_stopped = kwargs.get('scm_site_also_stopped', False) + self.target_swap_slot = None + self.hosting_environment_profile = kwargs.get('hosting_environment_profile', None) + self.client_affinity_enabled = kwargs.get('client_affinity_enabled', None) + self.client_cert_enabled = kwargs.get('client_cert_enabled', None) + self.client_cert_mode = kwargs.get('client_cert_mode', None) + self.client_cert_exclusion_paths = kwargs.get('client_cert_exclusion_paths', None) + self.host_names_disabled = kwargs.get('host_names_disabled', None) + self.custom_domain_verification_id = kwargs.get('custom_domain_verification_id', None) + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = kwargs.get('container_size', None) + self.daily_memory_time_quota = kwargs.get('daily_memory_time_quota', None) + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = kwargs.get('cloning_info', None) + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = kwargs.get('https_only', None) + self.redundancy_mode = kwargs.get('redundancy_mode', None) + self.in_progress_operation_id = None + + +class SitePhpErrorLogFlag(ProxyOnlyResource): + """Used for getting PHP error logging flag. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param local_log_errors: Local log_errors setting. + :type local_log_errors: str + :param master_log_errors: Master log_errors setting. + :type master_log_errors: str + :param local_log_errors_max_length: Local log_errors_max_len setting. + :type local_log_errors_max_length: str + :param master_log_errors_max_length: Master log_errors_max_len setting. + :type master_log_errors_max_length: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'local_log_errors': {'key': 'properties.localLogErrors', 'type': 'str'}, + 'master_log_errors': {'key': 'properties.masterLogErrors', 'type': 'str'}, + 'local_log_errors_max_length': {'key': 'properties.localLogErrorsMaxLength', 'type': 'str'}, + 'master_log_errors_max_length': {'key': 'properties.masterLogErrorsMaxLength', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SitePhpErrorLogFlag, self).__init__(**kwargs) + self.local_log_errors = kwargs.get('local_log_errors', None) + self.master_log_errors = kwargs.get('master_log_errors', None) + self.local_log_errors_max_length = kwargs.get('local_log_errors_max_length', None) + self.master_log_errors_max_length = kwargs.get('master_log_errors_max_length', None) + + +class SiteSeal(msrest.serialization.Model): + """Site seal. + + All required parameters must be populated in order to send to Azure. + + :param html: Required. HTML snippet. + :type html: str + """ + + _validation = { + 'html': {'required': True}, + } + + _attribute_map = { + 'html': {'key': 'html', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSeal, self).__init__(**kwargs) + self.html = kwargs['html'] + + +class SiteSealRequest(msrest.serialization.Model): + """Site seal request. + + :param light_theme: If :code:`true` use the light color theme for site seal; + otherwise, use the default color theme. + :type light_theme: bool + :param locale: Locale of site seal. + :type locale: str + """ + + _attribute_map = { + 'light_theme': {'key': 'lightTheme', 'type': 'bool'}, + 'locale': {'key': 'locale', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSealRequest, self).__init__(**kwargs) + self.light_theme = kwargs.get('light_theme', None) + self.locale = kwargs.get('locale', None) + + +class SiteSourceControl(ProxyOnlyResource): + """Source control configuration for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repo_url: Repository or source control URL. + :type repo_url: str + :param branch: Name of branch to use for deployment. + :type branch: str + :param is_manual_integration: :code:`true` to limit to manual integration; + :code:`false` to enable continuous integration (which configures webhooks into + online repos like GitHub). + :type is_manual_integration: bool + :param is_git_hub_action: :code:`true` if this is deployed via GitHub action. + :type is_git_hub_action: bool + :param deployment_rollback_enabled: :code:`true` to enable deployment rollback; + otherwise, :code:`false`. + :type deployment_rollback_enabled: bool + :param is_mercurial: :code:`true` for a Mercurial repository; + :code:`false` for a Git repository. + :type is_mercurial: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repo_url': {'key': 'properties.repoUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'is_manual_integration': {'key': 'properties.isManualIntegration', 'type': 'bool'}, + 'is_git_hub_action': {'key': 'properties.isGitHubAction', 'type': 'bool'}, + 'deployment_rollback_enabled': {'key': 'properties.deploymentRollbackEnabled', 'type': 'bool'}, + 'is_mercurial': {'key': 'properties.isMercurial', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SiteSourceControl, self).__init__(**kwargs) + self.repo_url = kwargs.get('repo_url', None) + self.branch = kwargs.get('branch', None) + self.is_manual_integration = kwargs.get('is_manual_integration', None) + self.is_git_hub_action = kwargs.get('is_git_hub_action', None) + self.deployment_rollback_enabled = kwargs.get('deployment_rollback_enabled', None) + self.is_mercurial = kwargs.get('is_mercurial', None) + + +class SkuCapacity(msrest.serialization.Model): + """Description of the App Service plan scale options. + + :param minimum: Minimum number of workers for this App Service plan SKU. + :type minimum: int + :param maximum: Maximum number of workers for this App Service plan SKU. + :type maximum: int + :param default: Default number of workers for this App Service plan SKU. + :type default: int + :param scale_type: Available scale configurations for an App Service plan. + :type scale_type: str + """ + + _attribute_map = { + 'minimum': {'key': 'minimum', 'type': 'int'}, + 'maximum': {'key': 'maximum', 'type': 'int'}, + 'default': {'key': 'default', 'type': 'int'}, + 'scale_type': {'key': 'scaleType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuCapacity, self).__init__(**kwargs) + self.minimum = kwargs.get('minimum', None) + self.maximum = kwargs.get('maximum', None) + self.default = kwargs.get('default', None) + self.scale_type = kwargs.get('scale_type', None) + + +class SkuDescription(msrest.serialization.Model): + """Description of a SKU for a scalable resource. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Current number of instances assigned to the resource. + :type capacity: int + :param sku_capacity: Min, max, and default scale values of the SKU. + :type sku_capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_09_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + 'sku_capacity': {'key': 'skuCapacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuDescription, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.size = kwargs.get('size', None) + self.family = kwargs.get('family', None) + self.capacity = kwargs.get('capacity', None) + self.sku_capacity = kwargs.get('sku_capacity', None) + self.locations = kwargs.get('locations', None) + self.capabilities = kwargs.get('capabilities', None) + + +class SkuInfo(msrest.serialization.Model): + """SKU discovery information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param sku: Name and tier of the SKU. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfo, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.sku = kwargs.get('sku', None) + self.capacity = kwargs.get('capacity', None) + + +class SkuInfoCollection(msrest.serialization.Model): + """Collection of SKU information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SkuInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SkuInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfoCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SkuInfos(msrest.serialization.Model): + """Collection of SKU information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param skus: List of SKUs the subscription is able to use. + :type skus: list[~azure.mgmt.web.v2020_09_01.models.GlobalCsmSkuDescription] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'skus': {'key': 'skus', 'type': '[GlobalCsmSkuDescription]'}, + } + + def __init__( + self, + **kwargs + ): + super(SkuInfos, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.skus = kwargs.get('skus', None) + + +class SlotConfigNamesResource(ProxyOnlyResource): + """Slot Config names azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param connection_string_names: List of connection string names. + :type connection_string_names: list[str] + :param app_setting_names: List of application settings names. + :type app_setting_names: list[str] + :param azure_storage_config_names: List of external Azure storage account identifiers. + :type azure_storage_config_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'connection_string_names': {'key': 'properties.connectionStringNames', 'type': '[str]'}, + 'app_setting_names': {'key': 'properties.appSettingNames', 'type': '[str]'}, + 'azure_storage_config_names': {'key': 'properties.azureStorageConfigNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotConfigNamesResource, self).__init__(**kwargs) + self.connection_string_names = kwargs.get('connection_string_names', None) + self.app_setting_names = kwargs.get('app_setting_names', None) + self.azure_storage_config_names = kwargs.get('azure_storage_config_names', None) + + +class SlotDifference(ProxyOnlyResource): + """A setting difference between two deployment slots of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar level: Level of the difference: Information, Warning or Error. + :vartype level: str + :ivar setting_type: The type of the setting: General, AppSetting or ConnectionString. + :vartype setting_type: str + :ivar diff_rule: Rule that describes how to process the setting difference during a slot swap. + :vartype diff_rule: str + :ivar setting_name: Name of the setting. + :vartype setting_name: str + :ivar value_in_current_slot: Value of the setting in the current slot. + :vartype value_in_current_slot: str + :ivar value_in_target_slot: Value of the setting in the target slot. + :vartype value_in_target_slot: str + :ivar description: Description of the setting difference. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'level': {'readonly': True}, + 'setting_type': {'readonly': True}, + 'diff_rule': {'readonly': True}, + 'setting_name': {'readonly': True}, + 'value_in_current_slot': {'readonly': True}, + 'value_in_target_slot': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'setting_type': {'key': 'properties.settingType', 'type': 'str'}, + 'diff_rule': {'key': 'properties.diffRule', 'type': 'str'}, + 'setting_name': {'key': 'properties.settingName', 'type': 'str'}, + 'value_in_current_slot': {'key': 'properties.valueInCurrentSlot', 'type': 'str'}, + 'value_in_target_slot': {'key': 'properties.valueInTargetSlot', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotDifference, self).__init__(**kwargs) + self.level = None + self.setting_type = None + self.diff_rule = None + self.setting_name = None + self.value_in_current_slot = None + self.value_in_target_slot = None + self.description = None + + +class SlotDifferenceCollection(msrest.serialization.Model): + """Collection of slot differences. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SlotDifference] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SlotDifference]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotDifferenceCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SlotSwapStatus(msrest.serialization.Model): + """The status of the last successful slot swap operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar timestamp_utc: The time the last successful slot swap completed. + :vartype timestamp_utc: ~datetime.datetime + :ivar source_slot_name: The source slot of the last swap operation. + :vartype source_slot_name: str + :ivar destination_slot_name: The destination slot of the last swap operation. + :vartype destination_slot_name: str + """ + + _validation = { + 'timestamp_utc': {'readonly': True}, + 'source_slot_name': {'readonly': True}, + 'destination_slot_name': {'readonly': True}, + } + + _attribute_map = { + 'timestamp_utc': {'key': 'timestampUtc', 'type': 'iso-8601'}, + 'source_slot_name': {'key': 'sourceSlotName', 'type': 'str'}, + 'destination_slot_name': {'key': 'destinationSlotName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotSwapStatus, self).__init__(**kwargs) + self.timestamp_utc = None + self.source_slot_name = None + self.destination_slot_name = None + + +class SlowRequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on request execution time. + + :param time_taken: Time taken. + :type time_taken: str + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'time_taken': {'key': 'timeTaken', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlowRequestsBasedTrigger, self).__init__(**kwargs) + self.time_taken = kwargs.get('time_taken', None) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class Snapshot(ProxyOnlyResource): + """A snapshot of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar time: The time the snapshot was taken. + :vartype time: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'time': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'time': {'key': 'properties.time', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Snapshot, self).__init__(**kwargs) + self.time = None + + +class SnapshotCollection(msrest.serialization.Model): + """Collection of snapshots which can be used to revert an app to a previous time. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Snapshot] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Snapshot]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class SnapshotRecoverySource(msrest.serialization.Model): + """Specifies the web app that snapshot contents will be retrieved from. + + :param location: Geographical location of the source web app, e.g. SouthEastAsia, + SouthCentralUS. + :type location: str + :param id: ARM resource ID of the source app. + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type id: str + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotRecoverySource, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.id = kwargs.get('id', None) + + +class SnapshotRestoreRequest(ProxyOnlyResource): + """Details about app recovery operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param snapshot_time: Point in time in which the app restore should be done, formatted as a + DateTime string. + :type snapshot_time: str + :param recovery_source: Optional. Specifies the web app that snapshot contents will be + retrieved from. + If empty, the targeted web app will be used as the source. + :type recovery_source: ~azure.mgmt.web.v2020_09_01.models.SnapshotRecoverySource + :param overwrite: If :code:`true` the restore operation can overwrite source app; + otherwise, :code:`false`. + :type overwrite: bool + :param recover_configuration: If true, site configuration, in addition to content, will be + reverted. + :type recover_configuration: bool + :param ignore_conflicting_host_names: If true, custom hostname conflicts will be ignored when + recovering to a target web app. + This setting is only necessary when RecoverConfiguration is enabled. + :type ignore_conflicting_host_names: bool + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'recovery_source': {'key': 'properties.recoverySource', 'type': 'SnapshotRecoverySource'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SnapshotRestoreRequest, self).__init__(**kwargs) + self.snapshot_time = kwargs.get('snapshot_time', None) + self.recovery_source = kwargs.get('recovery_source', None) + self.overwrite = kwargs.get('overwrite', None) + self.recover_configuration = kwargs.get('recover_configuration', None) + self.ignore_conflicting_host_names = kwargs.get('ignore_conflicting_host_names', None) + self.use_dr_secondary = kwargs.get('use_dr_secondary', None) + + +class Solution(msrest.serialization.Model): + """Class Representing Solution for problems detected. + + :param id: Solution Id. + :type id: float + :param display_name: Display Name of the solution. + :type display_name: str + :param order: Order of the solution. + :type order: float + :param description: Description of the solution. + :type description: str + :param type: Type of Solution. Possible values include: "QuickSolution", "DeepInvestigation", + "BestPractices". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.SolutionType + :param data: Solution Data. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param metadata: Solution Metadata. + :type metadata: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'float'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'float'}, + 'description': {'key': 'description', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'metadata': {'key': 'metadata', 'type': '[[NameValuePair]]'}, + } + + def __init__( + self, + **kwargs + ): + super(Solution, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.display_name = kwargs.get('display_name', None) + self.order = kwargs.get('order', None) + self.description = kwargs.get('description', None) + self.type = kwargs.get('type', None) + self.data = kwargs.get('data', None) + self.metadata = kwargs.get('metadata', None) + + +class SourceControl(ProxyOnlyResource): + """The source control OAuth token. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param token: OAuth access token. + :type token: str + :param token_secret: OAuth access token secret. + :type token_secret: str + :param refresh_token: OAuth refresh token. + :type refresh_token: str + :param expiration_time: OAuth token expiration. + :type expiration_time: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'token': {'key': 'properties.token', 'type': 'str'}, + 'token_secret': {'key': 'properties.tokenSecret', 'type': 'str'}, + 'refresh_token': {'key': 'properties.refreshToken', 'type': 'str'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(SourceControl, self).__init__(**kwargs) + self.token = kwargs.get('token', None) + self.token_secret = kwargs.get('token_secret', None) + self.refresh_token = kwargs.get('refresh_token', None) + self.expiration_time = kwargs.get('expiration_time', None) + + +class SourceControlCollection(msrest.serialization.Model): + """Collection of source controls. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SourceControl] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SourceControl]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SourceControlCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StackMajorVersion(msrest.serialization.Model): + """Application stack major version. + + :param display_version: Application stack major version (display only). + :type display_version: str + :param runtime_version: Application stack major version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default major version; otherwise, + :code:`false`. + :type is_default: bool + :param minor_versions: Minor versions associated with the major version. + :type minor_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMinorVersion] + :param application_insights: :code:`true` if this supports Application Insights; + otherwise, :code:`false`. + :type application_insights: bool + :param is_preview: :code:`true` if this stack is in Preview, otherwise + :code:`false`. + :type is_preview: bool + :param is_deprecated: :code:`true` if this stack has been deprecated, otherwise + :code:`false`. + :type is_deprecated: bool + :param is_hidden: :code:`true` if this stack should be hidden for new customers on + portal, otherwise :code:`false`. + :type is_hidden: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'minor_versions': {'key': 'minorVersions', 'type': '[StackMinorVersion]'}, + 'application_insights': {'key': 'applicationInsights', 'type': 'bool'}, + 'is_preview': {'key': 'isPreview', 'type': 'bool'}, + 'is_deprecated': {'key': 'isDeprecated', 'type': 'bool'}, + 'is_hidden': {'key': 'isHidden', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StackMajorVersion, self).__init__(**kwargs) + self.display_version = kwargs.get('display_version', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.is_default = kwargs.get('is_default', None) + self.minor_versions = kwargs.get('minor_versions', None) + self.application_insights = kwargs.get('application_insights', None) + self.is_preview = kwargs.get('is_preview', None) + self.is_deprecated = kwargs.get('is_deprecated', None) + self.is_hidden = kwargs.get('is_hidden', None) + + +class StackMinorVersion(msrest.serialization.Model): + """Application stack minor version. + + :param display_version: Application stack minor version (display only). + :type display_version: str + :param runtime_version: Application stack minor version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default minor version; otherwise, + :code:`false`. + :type is_default: bool + :param is_remote_debugging_enabled: :code:`true` if this supports Remote + Debugging, otherwise :code:`false`. + :type is_remote_debugging_enabled: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'is_remote_debugging_enabled': {'key': 'isRemoteDebuggingEnabled', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StackMinorVersion, self).__init__(**kwargs) + self.display_version = kwargs.get('display_version', None) + self.runtime_version = kwargs.get('runtime_version', None) + self.is_default = kwargs.get('is_default', None) + self.is_remote_debugging_enabled = kwargs.get('is_remote_debugging_enabled', None) + + +class StampCapacity(msrest.serialization.Model): + """Stamp capacity information. + + :param name: Name of the stamp. + :type name: str + :param available_capacity: Available capacity (# of machines, bytes of storage etc...). + :type available_capacity: long + :param total_capacity: Total capacity (# of machines, bytes of storage etc...). + :type total_capacity: long + :param unit: Name of the unit. + :type unit: str + :param compute_mode: Shared/dedicated workers. Possible values include: "Shared", "Dedicated", + "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: Size of the machines. Possible values include: "Small", "Medium", "Large", + "D1", "D2", "D3", "NestedSmall", "Default". + :type worker_size: str or ~azure.mgmt.web.v2020_09_01.models.WorkerSizeOptions + :param worker_size_id: Size ID of machines: + 0 - Small + 1 - Medium + 2 - Large. + :type worker_size_id: int + :param exclude_from_capacity_allocation: If :code:`true`, it includes basic apps. + Basic apps are not used for capacity allocation. + :type exclude_from_capacity_allocation: bool + :param is_applicable_for_all_compute_modes: :code:`true` if capacity is applicable + for all apps; otherwise, :code:`false`. + :type is_applicable_for_all_compute_modes: bool + :param site_mode: Shared or Dedicated. + :type site_mode: str + :param is_linux: Is this a linux stamp capacity. + :type is_linux: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available_capacity': {'key': 'availableCapacity', 'type': 'long'}, + 'total_capacity': {'key': 'totalCapacity', 'type': 'long'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'exclude_from_capacity_allocation': {'key': 'excludeFromCapacityAllocation', 'type': 'bool'}, + 'is_applicable_for_all_compute_modes': {'key': 'isApplicableForAllComputeModes', 'type': 'bool'}, + 'site_mode': {'key': 'siteMode', 'type': 'str'}, + 'is_linux': {'key': 'isLinux', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StampCapacity, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.available_capacity = kwargs.get('available_capacity', None) + self.total_capacity = kwargs.get('total_capacity', None) + self.unit = kwargs.get('unit', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.exclude_from_capacity_allocation = kwargs.get('exclude_from_capacity_allocation', None) + self.is_applicable_for_all_compute_modes = kwargs.get('is_applicable_for_all_compute_modes', None) + self.site_mode = kwargs.get('site_mode', None) + self.is_linux = kwargs.get('is_linux', None) + + +class StampCapacityCollection(msrest.serialization.Model): + """Collection of stamp capacities. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StampCapacity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StampCapacityCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteARMResource(Resource): + """Static Site ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteARMResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.default_hostname = None + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.custom_domains = None + self.repository_token = kwargs.get('repository_token', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteBuildARMResource(ProxyOnlyResource): + """Static Site Build ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar build_id: An identifier for the static site build. + :vartype build_id: str + :ivar source_branch: The source branch. + :vartype source_branch: str + :ivar pull_request_title: The title of a pull request that a static site build is related to. + :vartype pull_request_title: str + :ivar hostname: The hostname for a static site build. + :vartype hostname: str + :ivar created_time_utc: When this build was created. + :vartype created_time_utc: ~datetime.datetime + :ivar last_updated_on: When this build was updated. + :vartype last_updated_on: ~datetime.datetime + :ivar status: The status of the static site build. Possible values include: + "WaitingForDeployment", "Uploading", "Deploying", "Ready", "Failed", "Deleting", "Detached". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.BuildStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'build_id': {'readonly': True}, + 'source_branch': {'readonly': True}, + 'pull_request_title': {'readonly': True}, + 'hostname': {'readonly': True}, + 'created_time_utc': {'readonly': True}, + 'last_updated_on': {'readonly': True}, + 'status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'build_id': {'key': 'properties.buildId', 'type': 'str'}, + 'source_branch': {'key': 'properties.sourceBranch', 'type': 'str'}, + 'pull_request_title': {'key': 'properties.pullRequestTitle', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'created_time_utc': {'key': 'properties.createdTimeUtc', 'type': 'iso-8601'}, + 'last_updated_on': {'key': 'properties.lastUpdatedOn', 'type': 'iso-8601'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildARMResource, self).__init__(**kwargs) + self.build_id = None + self.source_branch = None + self.pull_request_title = None + self.hostname = None + self.created_time_utc = None + self.last_updated_on = None + self.status = None + + +class StaticSiteBuildCollection(msrest.serialization.Model): + """Collection of static site builds. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteBuildARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteBuildProperties(msrest.serialization.Model): + """Build properties for the static site. + + :param app_location: The path to the app code within the repository. + :type app_location: str + :param api_location: The path to the api code within the repository. + :type api_location: str + :param app_artifact_location: The path of the app artifacts after building. + :type app_artifact_location: str + """ + + _attribute_map = { + 'app_location': {'key': 'appLocation', 'type': 'str'}, + 'api_location': {'key': 'apiLocation', 'type': 'str'}, + 'app_artifact_location': {'key': 'appArtifactLocation', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteBuildProperties, self).__init__(**kwargs) + self.app_location = kwargs.get('app_location', None) + self.api_location = kwargs.get('api_location', None) + self.app_artifact_location = kwargs.get('app_artifact_location', None) + + +class StaticSiteCollection(msrest.serialization.Model): + """Collection of static sites. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteCustomDomainOverviewARMResource(ProxyOnlyResource): + """Static Site Custom Domain Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar domain_name: The domain name for the static site custom domain. + :vartype domain_name: str + :ivar created_on: The date and time on which the custom domain was created for the static site. + :vartype created_on: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_name': {'readonly': True}, + 'created_on': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'domain_name': {'key': 'properties.domainName', 'type': 'str'}, + 'created_on': {'key': 'properties.createdOn', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCustomDomainOverviewARMResource, self).__init__(**kwargs) + self.domain_name = None + self.created_on = None + + +class StaticSiteCustomDomainOverviewCollection(msrest.serialization.Model): + """Collection of static site custom domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteCustomDomainOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteCustomDomainOverviewCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteFunctionOverviewARMResource(ProxyOnlyResource): + """Static Site Function Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar function_name: The name for the function. + :vartype function_name: str + :ivar trigger_type: The trigger type of the function. Possible values include: "HttpTrigger", + "Unknown". + :vartype trigger_type: str or ~azure.mgmt.web.v2020_09_01.models.TriggerTypes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'function_name': {'readonly': True}, + 'trigger_type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'function_name': {'key': 'properties.functionName', 'type': 'str'}, + 'trigger_type': {'key': 'properties.triggerType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteFunctionOverviewARMResource, self).__init__(**kwargs) + self.function_name = None + self.trigger_type = None + + +class StaticSiteFunctionOverviewCollection(msrest.serialization.Model): + """Collection of static site functions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteFunctionOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteFunctionOverviewCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSitePatchResource(ProxyOnlyResource): + """ARM resource for a static site when patching. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitePatchResource, self).__init__(**kwargs) + self.default_hostname = None + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.custom_domains = None + self.repository_token = kwargs.get('repository_token', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteResetPropertiesARMResource(ProxyOnlyResource): + """Static Site Reset Properties ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repository_token: The token which proves admin privileges to the repository. + :type repository_token: str + :param should_update_repository: Determines whether the repository should be updated with the + new properties. + :type should_update_repository: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'should_update_repository': {'key': 'properties.shouldUpdateRepository', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteResetPropertiesARMResource, self).__init__(**kwargs) + self.repository_token = kwargs.get('repository_token', None) + self.should_update_repository = kwargs.get('should_update_repository', None) + + +class StaticSitesWorkflowPreview(ProxyOnlyResource): + """Preview for the Static Site Workflow to be generated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar path: The path for the workflow file to be generated. + :vartype path: str + :ivar contents: The contents for the workflow file to be generated. + :vartype contents: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'path': {'readonly': True}, + 'contents': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'contents': {'key': 'properties.contents', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitesWorkflowPreview, self).__init__(**kwargs) + self.path = None + self.contents = None + + +class StaticSitesWorkflowPreviewRequest(ProxyOnlyResource): + """Request entity for previewing the Static Site workflow. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSitesWorkflowPreviewRequest, self).__init__(**kwargs) + self.repository_url = kwargs.get('repository_url', None) + self.branch = kwargs.get('branch', None) + self.build_properties = kwargs.get('build_properties', None) + + +class StaticSiteUserARMResource(ProxyOnlyResource): + """Static Site User ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar provider: The identity provider for the static site user. + :vartype provider: str + :ivar user_id: The user id for the static site user. + :vartype user_id: str + :ivar display_name: The display name for the static site user. + :vartype display_name: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provider': {'readonly': True}, + 'user_id': {'readonly': True}, + 'display_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_id': {'key': 'properties.userId', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserARMResource, self).__init__(**kwargs) + self.provider = None + self.user_id = None + self.display_name = None + self.roles = kwargs.get('roles', None) + + +class StaticSiteUserCollection(msrest.serialization.Model): + """Collection of static site custom users. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteUserARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class StaticSiteUserInvitationRequestResource(ProxyOnlyResource): + """Static sites user roles invitation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param domain: The domain name for the static site custom domain. + :type domain: str + :param provider: The identity provider for the static site user. + :type provider: str + :param user_details: The user id for the static site user. + :type user_details: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + :param num_hours_to_expiration: The number of hours the sas token stays valid. + :type num_hours_to_expiration: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'domain': {'key': 'properties.domain', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_details': {'key': 'properties.userDetails', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + 'num_hours_to_expiration': {'key': 'properties.numHoursToExpiration', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserInvitationRequestResource, self).__init__(**kwargs) + self.domain = kwargs.get('domain', None) + self.provider = kwargs.get('provider', None) + self.user_details = kwargs.get('user_details', None) + self.roles = kwargs.get('roles', None) + self.num_hours_to_expiration = kwargs.get('num_hours_to_expiration', None) + + +class StaticSiteUserInvitationResponseResource(ProxyOnlyResource): + """Static sites user roles invitation link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar expires_on: The expiration time of the invitation. + :vartype expires_on: ~datetime.datetime + :ivar invitation_url: The url for the invitation link. + :vartype invitation_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'expires_on': {'readonly': True}, + 'invitation_url': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'invitation_url': {'key': 'properties.invitationUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StaticSiteUserInvitationResponseResource, self).__init__(**kwargs) + self.expires_on = None + self.invitation_url = None + + +class StatusCodesBasedTrigger(msrest.serialization.Model): + """Trigger based on status code. + + :param status: HTTP status code. + :type status: int + :param sub_status: Request Sub Status. + :type sub_status: int + :param win32_status: Win32 error code. + :type win32_status: int + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'int'}, + 'sub_status': {'key': 'subStatus', 'type': 'int'}, + 'win32_status': {'key': 'win32Status', 'type': 'int'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StatusCodesBasedTrigger, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.sub_status = kwargs.get('sub_status', None) + self.win32_status = kwargs.get('win32_status', None) + self.count = kwargs.get('count', None) + self.time_interval = kwargs.get('time_interval', None) + + +class StorageMigrationOptions(ProxyOnlyResource): + """Options for app content migration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param azurefiles_connection_string: AzureFiles connection string. + :type azurefiles_connection_string: str + :param azurefiles_share: AzureFiles share. + :type azurefiles_share: str + :param switch_site_after_migration: :code:`true`if the app should be switched + over; otherwise, :code:`false`. + :type switch_site_after_migration: bool + :param block_write_access_to_site: :code:`true` if the app should be read only + during copy operation; otherwise, :code:`false`. + :type block_write_access_to_site: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'azurefiles_connection_string': {'key': 'properties.azurefilesConnectionString', 'type': 'str'}, + 'azurefiles_share': {'key': 'properties.azurefilesShare', 'type': 'str'}, + 'switch_site_after_migration': {'key': 'properties.switchSiteAfterMigration', 'type': 'bool'}, + 'block_write_access_to_site': {'key': 'properties.blockWriteAccessToSite', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StorageMigrationOptions, self).__init__(**kwargs) + self.azurefiles_connection_string = kwargs.get('azurefiles_connection_string', None) + self.azurefiles_share = kwargs.get('azurefiles_share', None) + self.switch_site_after_migration = kwargs.get('switch_site_after_migration', False) + self.block_write_access_to_site = kwargs.get('block_write_access_to_site', False) + + +class StorageMigrationResponse(ProxyOnlyResource): + """Response for a migration of app content request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar operation_id: When server starts the migration process, it will return an operation ID + identifying that particular migration operation. + :vartype operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StorageMigrationResponse, self).__init__(**kwargs) + self.operation_id = None + + +class StringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Settings. + :type properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(StringDictionary, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class SwiftVirtualNetwork(ProxyOnlyResource): + """Swift Virtual Network Contract. This is used to enable the new Swift way of doing virtual network integration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param subnet_resource_id: The Virtual Network subnet's resource ID. This is the subnet that + this Web App will join. This subnet must have a delegation to Microsoft.Web/serverFarms defined + first. + :type subnet_resource_id: str + :param swift_supported: A flag that specifies if the scale unit this Web App is on supports + Swift integration. + :type swift_supported: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'subnet_resource_id': {'key': 'properties.subnetResourceId', 'type': 'str'}, + 'swift_supported': {'key': 'properties.swiftSupported', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(SwiftVirtualNetwork, self).__init__(**kwargs) + self.subnet_resource_id = kwargs.get('subnet_resource_id', None) + self.swift_supported = kwargs.get('swift_supported', None) + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. Possible values + include: "User", "Application", "ManagedIdentity", "Key". + :type created_by_type: str or ~azure.mgmt.web.v2020_09_01.models.CreatedByType + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. Possible + values include: "User", "Application", "ManagedIdentity", "Key". + :type last_modified_by_type: str or ~azure.mgmt.web.v2020_09_01.models.CreatedByType + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = kwargs.get('created_by', None) + self.created_by_type = kwargs.get('created_by_type', None) + self.created_at = kwargs.get('created_at', None) + self.last_modified_by = kwargs.get('last_modified_by', None) + self.last_modified_by_type = kwargs.get('last_modified_by_type', None) + self.last_modified_at = kwargs.get('last_modified_at', None) + + +class TldLegalAgreement(msrest.serialization.Model): + """Legal agreement for a top level domain. + + All required parameters must be populated in order to send to Azure. + + :param agreement_key: Required. Unique identifier for the agreement. + :type agreement_key: str + :param title: Required. Agreement title. + :type title: str + :param content: Required. Agreement details. + :type content: str + :param url: URL where a copy of the agreement details is hosted. + :type url: str + """ + + _validation = { + 'agreement_key': {'required': True}, + 'title': {'required': True}, + 'content': {'required': True}, + } + + _attribute_map = { + 'agreement_key': {'key': 'agreementKey', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'content': {'key': 'content', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TldLegalAgreement, self).__init__(**kwargs) + self.agreement_key = kwargs['agreement_key'] + self.title = kwargs['title'] + self.content = kwargs['content'] + self.url = kwargs.get('url', None) + + +class TldLegalAgreementCollection(msrest.serialization.Model): + """Collection of top-level domain legal agreements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TldLegalAgreement] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TldLegalAgreement]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TldLegalAgreementCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TokenStore(ProxyOnlyResource): + """TokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param token_refresh_extension_hours: + :type token_refresh_extension_hours: float + :param file_system: + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemTokenStore + :param azure_blob_storage: + :type azure_blob_storage: ~azure.mgmt.web.v2020_09_01.models.BlobStorageTokenStore + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'file_system': {'key': 'properties.fileSystem', 'type': 'FileSystemTokenStore'}, + 'azure_blob_storage': {'key': 'properties.azureBlobStorage', 'type': 'BlobStorageTokenStore'}, + } + + def __init__( + self, + **kwargs + ): + super(TokenStore, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.token_refresh_extension_hours = kwargs.get('token_refresh_extension_hours', None) + self.file_system = kwargs.get('file_system', None) + self.azure_blob_storage = kwargs.get('azure_blob_storage', None) + + +class TopLevelDomain(ProxyOnlyResource): + """A top level domain object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param privacy: If :code:`true`, then the top level domain supports domain + privacy; otherwise, :code:`false`. + :type privacy: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomain, self).__init__(**kwargs) + self.privacy = kwargs.get('privacy', None) + + +class TopLevelDomainAgreementOption(msrest.serialization.Model): + """Options for retrieving the list of top level domain legal agreements. + + :param include_privacy: If :code:`true`, then the list of agreements will include + agreements for domain privacy as well; otherwise, :code:`false`. + :type include_privacy: bool + :param for_transfer: If :code:`true`, then the list of agreements will include + agreements for domain transfer as well; otherwise, :code:`false`. + :type for_transfer: bool + """ + + _attribute_map = { + 'include_privacy': {'key': 'includePrivacy', 'type': 'bool'}, + 'for_transfer': {'key': 'forTransfer', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomainAgreementOption, self).__init__(**kwargs) + self.include_privacy = kwargs.get('include_privacy', None) + self.for_transfer = kwargs.get('for_transfer', None) + + +class TopLevelDomainCollection(msrest.serialization.Model): + """Collection of Top-level domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TopLevelDomain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TopLevelDomain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TopLevelDomainCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TriggeredJobHistory(ProxyOnlyResource): + """Triggered Web Job History. List of Triggered Web Job Run Information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param runs: List of triggered web job runs. + :type runs: list[~azure.mgmt.web.v2020_09_01.models.TriggeredJobRun] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'runs': {'key': 'properties.runs', 'type': '[TriggeredJobRun]'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobHistory, self).__init__(**kwargs) + self.runs = kwargs.get('runs', None) + + +class TriggeredJobHistoryCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredJobHistory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobHistoryCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class TriggeredJobRun(ProxyOnlyResource): + """Triggered Web Job Run Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param web_job_id: Job ID. + :type web_job_id: str + :param web_job_name: Job name. + :type web_job_name: str + :param status: Job status. Possible values include: "Success", "Failed", "Error". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobStatus + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param duration: Job duration. + :type duration: str + :param output_url: Output URL. + :type output_url: str + :param error_url: Error URL. + :type error_url: str + :param url: Job URL. + :type url: str + :param job_name: Job name. + :type job_name: str + :param trigger: Job trigger. + :type trigger: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'web_job_id': {'key': 'properties.web_job_id', 'type': 'str'}, + 'web_job_name': {'key': 'properties.web_job_name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'duration': {'key': 'properties.duration', 'type': 'str'}, + 'output_url': {'key': 'properties.output_url', 'type': 'str'}, + 'error_url': {'key': 'properties.error_url', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'job_name': {'key': 'properties.job_name', 'type': 'str'}, + 'trigger': {'key': 'properties.trigger', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredJobRun, self).__init__(**kwargs) + self.web_job_id = kwargs.get('web_job_id', None) + self.web_job_name = kwargs.get('web_job_name', None) + self.status = kwargs.get('status', None) + self.start_time = kwargs.get('start_time', None) + self.end_time = kwargs.get('end_time', None) + self.duration = kwargs.get('duration', None) + self.output_url = kwargs.get('output_url', None) + self.error_url = kwargs.get('error_url', None) + self.url = kwargs.get('url', None) + self.job_name = kwargs.get('job_name', None) + self.trigger = kwargs.get('trigger', None) + + +class TriggeredWebJob(ProxyOnlyResource): + """Triggered Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param latest_run: Latest job run information. + :type latest_run: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobRun + :param history_url: History URL. + :type history_url: str + :param scheduler_logs_url: Scheduler Logs URL. + :type scheduler_logs_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'latest_run': {'key': 'properties.latest_run', 'type': 'TriggeredJobRun'}, + 'history_url': {'key': 'properties.history_url', 'type': 'str'}, + 'scheduler_logs_url': {'key': 'properties.scheduler_logs_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredWebJob, self).__init__(**kwargs) + self.latest_run = kwargs.get('latest_run', None) + self.history_url = kwargs.get('history_url', None) + self.scheduler_logs_url = kwargs.get('scheduler_logs_url', None) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class TriggeredWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TriggeredWebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class Twitter(ProxyOnlyResource): + """Twitter. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.TwitterRegistration + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'TwitterRegistration'}, + } + + def __init__( + self, + **kwargs + ): + super(Twitter, self).__init__(**kwargs) + self.enabled = kwargs.get('enabled', None) + self.registration = kwargs.get('registration', None) + + +class TwitterRegistration(ProxyOnlyResource): + """TwitterRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param consumer_key: + :type consumer_key: str + :param consumer_secret_setting_name: + :type consumer_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'consumer_key': {'key': 'properties.consumerKey', 'type': 'str'}, + 'consumer_secret_setting_name': {'key': 'properties.consumerSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TwitterRegistration, self).__init__(**kwargs) + self.consumer_key = kwargs.get('consumer_key', None) + self.consumer_secret_setting_name = kwargs.get('consumer_secret_setting_name', None) + + +class Usage(ProxyOnlyResource): + """Usage of the quota resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar display_name: Friendly name shown in the UI. + :vartype display_name: str + :ivar resource_name: Name of the quota resource. + :vartype resource_name: str + :ivar unit: Units of measurement for the quota resource. + :vartype unit: str + :ivar current_value: The current value of the resource counter. + :vartype current_value: long + :ivar limit: The resource limit. + :vartype limit: long + :ivar next_reset_time: Next reset time for the resource counter. + :vartype next_reset_time: ~datetime.datetime + :ivar compute_mode: Compute mode used for this usage. Possible values include: "Shared", + "Dedicated", "Dynamic". + :vartype compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :ivar site_mode: Site mode used for this usage. + :vartype site_mode: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'display_name': {'readonly': True}, + 'resource_name': {'readonly': True}, + 'unit': {'readonly': True}, + 'current_value': {'readonly': True}, + 'limit': {'readonly': True}, + 'next_reset_time': {'readonly': True}, + 'compute_mode': {'readonly': True}, + 'site_mode': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'resource_name': {'key': 'properties.resourceName', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'current_value': {'key': 'properties.currentValue', 'type': 'long'}, + 'limit': {'key': 'properties.limit', 'type': 'long'}, + 'next_reset_time': {'key': 'properties.nextResetTime', 'type': 'iso-8601'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'site_mode': {'key': 'properties.siteMode', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Usage, self).__init__(**kwargs) + self.display_name = None + self.resource_name = None + self.unit = None + self.current_value = None + self.limit = None + self.next_reset_time = None + self.compute_mode = None + self.site_mode = None + + +class UsageCollection(msrest.serialization.Model): + """Collection of usages. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Usage] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UsageCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class User(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param publishing_user_name: Username used for publishing. + :type publishing_user_name: str + :param publishing_password: Password used for publishing. + :type publishing_password: str + :param publishing_password_hash: Password hash used for publishing. + :type publishing_password_hash: str + :param publishing_password_hash_salt: Password hash salt used for publishing. + :type publishing_password_hash_salt: str + :param scm_uri: Url of SCM site. + :type scm_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'publishing_user_name': {'key': 'properties.publishingUserName', 'type': 'str'}, + 'publishing_password': {'key': 'properties.publishingPassword', 'type': 'str'}, + 'publishing_password_hash': {'key': 'properties.publishingPasswordHash', 'type': 'str'}, + 'publishing_password_hash_salt': {'key': 'properties.publishingPasswordHashSalt', 'type': 'str'}, + 'scm_uri': {'key': 'properties.scmUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(User, self).__init__(**kwargs) + self.publishing_user_name = kwargs.get('publishing_user_name', None) + self.publishing_password = kwargs.get('publishing_password', None) + self.publishing_password_hash = kwargs.get('publishing_password_hash', None) + self.publishing_password_hash_salt = kwargs.get('publishing_password_hash_salt', None) + self.scm_uri = kwargs.get('scm_uri', None) + + +class ValidateRequest(msrest.serialization.Model): + """Resource validation request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: + "ServerFarm", "Site". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ValidateResourceTypes + :param location: Required. Expected location of the resource. + :type location: str + :param server_farm_id: ARM resource ID of an App Service plan that would host the app. + :type server_farm_id: str + :param sku_name: Name of the target SKU for the App Service plan. + :type sku_name: str + :param need_linux_workers: :code:`true` if App Service plan is for Linux workers; + otherwise, :code:`false`. + :type need_linux_workers: bool + :param is_spot: :code:`true` if App Service plan is for Spot instances; otherwise, + :code:`false`. + :type is_spot: bool + :param capacity: Target capacity of the App Service plan (number of VMs). + :type capacity: int + :param hosting_environment: Name of App Service Environment where app or App Service plan + should be created. + :type hosting_environment: str + :param is_xenon: :code:`true` if App Service plan is running as a windows + container. + :type is_xenon: bool + :param container_registry_base_url: Base URL of the container registry. + :type container_registry_base_url: str + :param container_registry_username: Username for to access the container registry. + :type container_registry_username: str + :param container_registry_password: Password for to access the container registry. + :type container_registry_password: str + :param container_image_repository: Repository name (image name). + :type container_image_repository: str + :param container_image_tag: Image tag. + :type container_image_tag: str + :param container_image_platform: Platform (windows or linux). + :type container_image_platform: str + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + 'location': {'required': True}, + 'capacity': {'minimum': 1}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'sku_name': {'key': 'properties.skuName', 'type': 'str'}, + 'need_linux_workers': {'key': 'properties.needLinuxWorkers', 'type': 'bool'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'capacity': {'key': 'properties.capacity', 'type': 'int'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'container_registry_base_url': {'key': 'properties.containerRegistryBaseUrl', 'type': 'str'}, + 'container_registry_username': {'key': 'properties.containerRegistryUsername', 'type': 'str'}, + 'container_registry_password': {'key': 'properties.containerRegistryPassword', 'type': 'str'}, + 'container_image_repository': {'key': 'properties.containerImageRepository', 'type': 'str'}, + 'container_image_tag': {'key': 'properties.containerImageTag', 'type': 'str'}, + 'container_image_platform': {'key': 'properties.containerImagePlatform', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateRequest, self).__init__(**kwargs) + self.name = kwargs['name'] + self.type = kwargs['type'] + self.location = kwargs['location'] + self.server_farm_id = kwargs.get('server_farm_id', None) + self.sku_name = kwargs.get('sku_name', None) + self.need_linux_workers = kwargs.get('need_linux_workers', None) + self.is_spot = kwargs.get('is_spot', None) + self.capacity = kwargs.get('capacity', None) + self.hosting_environment = kwargs.get('hosting_environment', None) + self.is_xenon = kwargs.get('is_xenon', None) + self.container_registry_base_url = kwargs.get('container_registry_base_url', None) + self.container_registry_username = kwargs.get('container_registry_username', None) + self.container_registry_password = kwargs.get('container_registry_password', None) + self.container_image_repository = kwargs.get('container_image_repository', None) + self.container_image_tag = kwargs.get('container_image_tag', None) + self.container_image_platform = kwargs.get('container_image_platform', None) + + +class ValidateResponse(msrest.serialization.Model): + """Describes the result of resource validation. + + :param status: Result of validation. + :type status: str + :param error: Error details for the case when validation fails. + :type error: ~azure.mgmt.web.v2020_09_01.models.ValidateResponseError + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ValidateResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateResponse, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.error = kwargs.get('error', None) + + +class ValidateResponseError(msrest.serialization.Model): + """Error details for when validation fails. + + :param code: Validation error code. + :type code: str + :param message: Validation error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ValidateResponseError, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + + +class VirtualApplication(msrest.serialization.Model): + """Virtual application in an app. + + :param virtual_path: Virtual path. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + :param preload_enabled: :code:`true` if preloading is enabled; otherwise, + :code:`false`. + :type preload_enabled: bool + :param virtual_directories: Virtual directories for virtual application. + :type virtual_directories: list[~azure.mgmt.web.v2020_09_01.models.VirtualDirectory] + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + 'preload_enabled': {'key': 'preloadEnabled', 'type': 'bool'}, + 'virtual_directories': {'key': 'virtualDirectories', 'type': '[VirtualDirectory]'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualApplication, self).__init__(**kwargs) + self.virtual_path = kwargs.get('virtual_path', None) + self.physical_path = kwargs.get('physical_path', None) + self.preload_enabled = kwargs.get('preload_enabled', None) + self.virtual_directories = kwargs.get('virtual_directories', None) + + +class VirtualDirectory(msrest.serialization.Model): + """Directory for virtual application. + + :param virtual_path: Path to virtual application. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualDirectory, self).__init__(**kwargs) + self.virtual_path = kwargs.get('virtual_path', None) + self.physical_path = kwargs.get('physical_path', None) + + +class VirtualIPMapping(msrest.serialization.Model): + """Virtual IP mapping. + + :param virtual_ip: Virtual IP address. + :type virtual_ip: str + :param internal_http_port: Internal HTTP port. + :type internal_http_port: int + :param internal_https_port: Internal HTTPS port. + :type internal_https_port: int + :param in_use: Is virtual IP mapping in use. + :type in_use: bool + :param service_name: name of the service that virtual IP is assigned to. + :type service_name: str + """ + + _attribute_map = { + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'internal_http_port': {'key': 'internalHttpPort', 'type': 'int'}, + 'internal_https_port': {'key': 'internalHttpsPort', 'type': 'int'}, + 'in_use': {'key': 'inUse', 'type': 'bool'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualIPMapping, self).__init__(**kwargs) + self.virtual_ip = kwargs.get('virtual_ip', None) + self.internal_http_port = kwargs.get('internal_http_port', None) + self.internal_https_port = kwargs.get('internal_https_port', None) + self.in_use = kwargs.get('in_use', None) + self.service_name = kwargs.get('service_name', None) + + +class VirtualNetworkProfile(msrest.serialization.Model): + """Specification for using a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource id of the Virtual Network. + :type id: str + :ivar name: Name of the Virtual Network (read-only). + :vartype name: str + :ivar type: Resource type of the Virtual Network (read-only). + :vartype type: str + :param subnet: Subnet within the Virtual Network. + :type subnet: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'subnet', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VirtualNetworkProfile, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.name = None + self.type = None + self.subnet = kwargs.get('subnet', None) + + +class VnetGateway(ProxyOnlyResource): + """The Virtual Network gateway contract. This is used to give the Virtual Network gateway access to the VPN package. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_name: The Virtual Network name. + :type vnet_name: str + :param vpn_package_uri: The URI where the VPN package can be downloaded. + :type vpn_package_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vpn_package_uri': {'key': 'properties.vpnPackageUri', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetGateway, self).__init__(**kwargs) + self.vnet_name = kwargs.get('vnet_name', None) + self.vpn_package_uri = kwargs.get('vpn_package_uri', None) + + +class VnetInfo(ProxyOnlyResource): + """Virtual Network information contract. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_resource_id: The Virtual Network's resource ID. + :type vnet_resource_id: str + :ivar cert_thumbprint: The client certificate thumbprint. + :vartype cert_thumbprint: str + :param cert_blob: A certificate file (.cer) blob containing the public key of the private key + used to authenticate a + Point-To-Site VPN connection. + :type cert_blob: str + :ivar routes: The routes that this Virtual Network connection uses. + :vartype routes: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] + :ivar resync_required: :code:`true` if a resync is required; otherwise, + :code:`false`. + :vartype resync_required: bool + :param dns_servers: DNS servers to be used by this Virtual Network. This should be a comma- + separated list of IP addresses. + :type dns_servers: str + :param is_swift: Flag that is used to denote if this is VNET injection. + :type is_swift: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'cert_thumbprint': {'readonly': True}, + 'routes': {'readonly': True}, + 'resync_required': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_resource_id': {'key': 'properties.vnetResourceId', 'type': 'str'}, + 'cert_thumbprint': {'key': 'properties.certThumbprint', 'type': 'str'}, + 'cert_blob': {'key': 'properties.certBlob', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VnetRoute]'}, + 'resync_required': {'key': 'properties.resyncRequired', 'type': 'bool'}, + 'dns_servers': {'key': 'properties.dnsServers', 'type': 'str'}, + 'is_swift': {'key': 'properties.isSwift', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetInfo, self).__init__(**kwargs) + self.vnet_resource_id = kwargs.get('vnet_resource_id', None) + self.cert_thumbprint = None + self.cert_blob = kwargs.get('cert_blob', None) + self.routes = None + self.resync_required = None + self.dns_servers = kwargs.get('dns_servers', None) + self.is_swift = kwargs.get('is_swift', None) + + +class VnetParameters(ProxyOnlyResource): + """The required set of inputs to validate a VNET. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_resource_group: The Resource Group of the VNET to be validated. + :type vnet_resource_group: str + :param vnet_name: The name of the VNET to be validated. + :type vnet_name: str + :param vnet_subnet_name: The subnet name to be validated. + :type vnet_subnet_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_resource_group': {'key': 'properties.vnetResourceGroup', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetParameters, self).__init__(**kwargs) + self.vnet_resource_group = kwargs.get('vnet_resource_group', None) + self.vnet_name = kwargs.get('vnet_name', None) + self.vnet_subnet_name = kwargs.get('vnet_subnet_name', None) + + +class VnetRoute(ProxyOnlyResource): + """Virtual Network route contract used to pass routing information for a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_address: The starting address for this route. This may also include a CIDR + notation, in which case the end address must not be specified. + :type start_address: str + :param end_address: The ending address for this route. If the start address is specified in + CIDR notation, this must be omitted. + :type end_address: str + :param route_type: The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + Possible values include: "DEFAULT", "INHERITED", "STATIC". + :type route_type: str or ~azure.mgmt.web.v2020_09_01.models.RouteType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_address': {'key': 'properties.startAddress', 'type': 'str'}, + 'end_address': {'key': 'properties.endAddress', 'type': 'str'}, + 'route_type': {'key': 'properties.routeType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetRoute, self).__init__(**kwargs) + self.start_address = kwargs.get('start_address', None) + self.end_address = kwargs.get('end_address', None) + self.route_type = kwargs.get('route_type', None) + + +class VnetValidationFailureDetails(ProxyOnlyResource): + """A class that describes the reason for a validation failure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param failed: A flag describing whether or not validation failed. + :type failed: bool + :param failed_tests: A list of tests that failed in the validation. + :type failed_tests: list[~azure.mgmt.web.v2020_09_01.models.VnetValidationTestFailure] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'failed': {'key': 'properties.failed', 'type': 'bool'}, + 'failed_tests': {'key': 'properties.failedTests', 'type': '[VnetValidationTestFailure]'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetValidationFailureDetails, self).__init__(**kwargs) + self.failed = kwargs.get('failed', None) + self.failed_tests = kwargs.get('failed_tests', None) + + +class VnetValidationTestFailure(ProxyOnlyResource): + """A class that describes a test that failed during NSG and UDR validation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param test_name: The name of the test that failed. + :type test_name: str + :param details: The details of what caused the failure, e.g. the blocking rule name, etc. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'test_name': {'key': 'properties.testName', 'type': 'str'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VnetValidationTestFailure, self).__init__(**kwargs) + self.test_name = kwargs.get('test_name', None) + self.details = kwargs.get('details', None) + + +class WebAppCollection(msrest.serialization.Model): + """Collection of App Service apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Site] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Site]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebAppCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebAppInstanceStatusCollection(msrest.serialization.Model): + """Collection of app instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebSiteInstanceStatus]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebAppInstanceStatusCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebJob(ProxyOnlyResource): + """Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + **kwargs + ): + super(WebJob, self).__init__(**kwargs) + self.run_command = kwargs.get('run_command', None) + self.url = kwargs.get('url', None) + self.extra_info_url = kwargs.get('extra_info_url', None) + self.web_job_type = kwargs.get('web_job_type', None) + self.error = kwargs.get('error', None) + self.using_sdk = kwargs.get('using_sdk', None) + self.settings = kwargs.get('settings', None) + + +class WebJobCollection(msrest.serialization.Model): + """Collection of Kudu web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WebJobCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WebSiteInstanceStatus(ProxyOnlyResource): + """WebSiteInstanceStatus. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param state: Possible values include: "READY", "STOPPED", "UNKNOWN". + :type state: str or ~azure.mgmt.web.v2020_09_01.models.SiteRuntimeState + :param status_url: Link to the GetStatusApi in Kudu. + :type status_url: str + :param detector_url: Link to the Diagnose and Solve Portal. + :type detector_url: str + :param console_url: Link to the console to web app instance. + :type console_url: str + :param health_check_url: Link to the console to web app instance. + :type health_check_url: str + :param containers: Dictionary of :code:``. + :type containers: dict[str, ~azure.mgmt.web.v2020_09_01.models.ContainerInfo] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'status_url': {'key': 'properties.statusUrl', 'type': 'str'}, + 'detector_url': {'key': 'properties.detectorUrl', 'type': 'str'}, + 'console_url': {'key': 'properties.consoleUrl', 'type': 'str'}, + 'health_check_url': {'key': 'properties.healthCheckUrl', 'type': 'str'}, + 'containers': {'key': 'properties.containers', 'type': '{ContainerInfo}'}, + } + + def __init__( + self, + **kwargs + ): + super(WebSiteInstanceStatus, self).__init__(**kwargs) + self.state = kwargs.get('state', None) + self.status_url = kwargs.get('status_url', None) + self.detector_url = kwargs.get('detector_url', None) + self.console_url = kwargs.get('console_url', None) + self.health_check_url = kwargs.get('health_check_url', None) + self.containers = kwargs.get('containers', None) + + +class WorkerPool(msrest.serialization.Model): + """Worker pool of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_count': {'key': 'workerCount', 'type': 'int'}, + 'instance_names': {'key': 'instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPool, self).__init__(**kwargs) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_count = kwargs.get('worker_count', None) + self.instance_names = None + + +class WorkerPoolCollection(msrest.serialization.Model): + """Collection of worker pools. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WorkerPoolResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPoolCollection, self).__init__(**kwargs) + self.value = kwargs['value'] + self.next_link = None + + +class WorkerPoolResource(ProxyOnlyResource): + """Worker pool of an App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_size_id': {'key': 'properties.workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'worker_size': {'key': 'properties.workerSize', 'type': 'str'}, + 'worker_count': {'key': 'properties.workerCount', 'type': 'int'}, + 'instance_names': {'key': 'properties.instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(WorkerPoolResource, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.worker_size_id = kwargs.get('worker_size_id', None) + self.compute_mode = kwargs.get('compute_mode', None) + self.worker_size = kwargs.get('worker_size', None) + self.worker_count = kwargs.get('worker_count', None) + self.instance_names = None diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models_py3.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models_py3.py new file mode 100644 index 000000000000..658df7ac9206 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_models_py3.py @@ -0,0 +1,19507 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import datetime +from typing import Dict, List, Optional, Union + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + +from ._web_site_management_client_enums import * + + +class AbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period identified in diagnosis. + + :param start_time: Start time of the downtime. + :type start_time: ~datetime.datetime + :param end_time: End time of the downtime. + :type end_time: ~datetime.datetime + :param events: List of Possible Cause of downtime. + :type events: list[~azure.mgmt.web.v2020_09_01.models.DetectorAbnormalTimePeriod] + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_09_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'events': {'key': 'events', 'type': '[DetectorAbnormalTimePeriod]'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + *, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + events: Optional[List["DetectorAbnormalTimePeriod"]] = None, + solutions: Optional[List["Solution"]] = None, + **kwargs + ): + super(AbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = start_time + self.end_time = end_time + self.events = events + self.solutions = solutions + + +class Address(msrest.serialization.Model): + """Address information for domain registration. + + All required parameters must be populated in order to send to Azure. + + :param address1: Required. First line of an Address. + :type address1: str + :param address2: The second line of the Address. Optional. + :type address2: str + :param city: Required. The city for the address. + :type city: str + :param country: Required. The country for the address. + :type country: str + :param postal_code: Required. The postal code for the address. + :type postal_code: str + :param state: Required. The state or province for the address. + :type state: str + """ + + _validation = { + 'address1': {'required': True}, + 'city': {'required': True}, + 'country': {'required': True}, + 'postal_code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'address1': {'key': 'address1', 'type': 'str'}, + 'address2': {'key': 'address2', 'type': 'str'}, + 'city': {'key': 'city', 'type': 'str'}, + 'country': {'key': 'country', 'type': 'str'}, + 'postal_code': {'key': 'postalCode', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + address1: str, + city: str, + country: str, + postal_code: str, + state: str, + address2: Optional[str] = None, + **kwargs + ): + super(Address, self).__init__(**kwargs) + self.address1 = address1 + self.address2 = address2 + self.city = city + self.country = country + self.postal_code = postal_code + self.state = state + + +class ProxyOnlyResource(msrest.serialization.Model): + """Azure proxy only resource. This resource is not tracked by Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(ProxyOnlyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kind + self.type = None + self.system_data = None + + +class AddressResponse(ProxyOnlyResource): + """Describes main public IP address and any extra virtual IPs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param service_ip_address: Main public virtual IP. + :type service_ip_address: str + :param internal_ip_address: Virtual Network internal IP address of the App Service Environment + if it is in internal load-balancing mode. + :type internal_ip_address: str + :param outbound_ip_addresses: IP addresses appearing on outbound connections. + :type outbound_ip_addresses: list[str] + :param vip_mappings: Additional virtual IPs. + :type vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'service_ip_address': {'key': 'properties.serviceIpAddress', 'type': 'str'}, + 'internal_ip_address': {'key': 'properties.internalIpAddress', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': '[str]'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + service_ip_address: Optional[str] = None, + internal_ip_address: Optional[str] = None, + outbound_ip_addresses: Optional[List[str]] = None, + vip_mappings: Optional[List["VirtualIPMapping"]] = None, + **kwargs + ): + super(AddressResponse, self).__init__(kind=kind, **kwargs) + self.service_ip_address = service_ip_address + self.internal_ip_address = internal_ip_address + self.outbound_ip_addresses = outbound_ip_addresses + self.vip_mappings = vip_mappings + + +class AllowedAudiencesValidation(ProxyOnlyResource): + """AllowedAudiencesValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allowed_audiences: Optional[List[str]] = None, + **kwargs + ): + super(AllowedAudiencesValidation, self).__init__(kind=kind, **kwargs) + self.allowed_audiences = allowed_audiences + + +class AnalysisData(msrest.serialization.Model): + """Class Representing Detector Evidence used for analysis. + + :param source: Name of the Detector. + :type source: str + :param detector_definition: Detector Definition. + :type detector_definition: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :param metrics: Source Metrics. + :type metrics: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSet] + :param data: Additional Source Data. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param detector_meta_data: Detector Meta Data. + :type detector_meta_data: ~azure.mgmt.web.v2020_09_01.models.ResponseMetaData + """ + + _attribute_map = { + 'source': {'key': 'source', 'type': 'str'}, + 'detector_definition': {'key': 'detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'metrics', 'type': '[DiagnosticMetricSet]'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'detector_meta_data': {'key': 'detectorMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + *, + source: Optional[str] = None, + detector_definition: Optional["DetectorDefinition"] = None, + metrics: Optional[List["DiagnosticMetricSet"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + detector_meta_data: Optional["ResponseMetaData"] = None, + **kwargs + ): + super(AnalysisData, self).__init__(**kwargs) + self.source = source + self.detector_definition = detector_definition + self.metrics = metrics + self.data = data + self.detector_meta_data = detector_meta_data + + +class AnalysisDefinition(ProxyOnlyResource): + """Definition of Analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Description of the Analysis. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(AnalysisDefinition, self).__init__(kind=kind, **kwargs) + self.description = None + + +class ApiDefinitionInfo(msrest.serialization.Model): + """Information about the formal API definition for the app. + + :param url: The URL of the API definition. + :type url: str + """ + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + *, + url: Optional[str] = None, + **kwargs + ): + super(ApiDefinitionInfo, self).__init__(**kwargs) + self.url = url + + +class ApiManagementConfig(msrest.serialization.Model): + """Azure API management (APIM) configuration linked to the app. + + :param id: APIM-Api Identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(ApiManagementConfig, self).__init__(**kwargs) + self.id = id + + +class ApplicationLogsConfig(msrest.serialization.Model): + """Application logs configuration. + + :param file_system: Application logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemApplicationLogsConfig + :param azure_table_storage: Application logs to azure table storage configuration. + :type azure_table_storage: + ~azure.mgmt.web.v2020_09_01.models.AzureTableStorageApplicationLogsConfig + :param azure_blob_storage: Application logs to blob storage configuration. + :type azure_blob_storage: + ~azure.mgmt.web.v2020_09_01.models.AzureBlobStorageApplicationLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemApplicationLogsConfig'}, + 'azure_table_storage': {'key': 'azureTableStorage', 'type': 'AzureTableStorageApplicationLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageApplicationLogsConfig'}, + } + + def __init__( + self, + *, + file_system: Optional["FileSystemApplicationLogsConfig"] = None, + azure_table_storage: Optional["AzureTableStorageApplicationLogsConfig"] = None, + azure_blob_storage: Optional["AzureBlobStorageApplicationLogsConfig"] = None, + **kwargs + ): + super(ApplicationLogsConfig, self).__init__(**kwargs) + self.file_system = file_system + self.azure_table_storage = azure_table_storage + self.azure_blob_storage = azure_blob_storage + + +class ApplicationStack(msrest.serialization.Model): + """Application stack. + + :param name: Application stack name. + :type name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStack] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'str'}, + 'dependency': {'key': 'dependency', 'type': 'str'}, + 'major_versions': {'key': 'majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional[str] = None, + dependency: Optional[str] = None, + major_versions: Optional[List["StackMajorVersion"]] = None, + frameworks: Optional[List["ApplicationStack"]] = None, + **kwargs + ): + super(ApplicationStack, self).__init__(**kwargs) + self.name = name + self.display = display + self.dependency = dependency + self.major_versions = major_versions + self.frameworks = frameworks + + +class ApplicationStackCollection(msrest.serialization.Model): + """Collection of Application Stacks. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStackResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationStackResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ApplicationStackResource"], + **kwargs + ): + super(ApplicationStackCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ApplicationStackResource(ProxyOnlyResource): + """ARM resource for a ApplicationStack. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Application stack name. + :type name_properties_name: str + :param display: Application stack display name. + :type display: str + :param dependency: Application stack dependency. + :type dependency: str + :param major_versions: List of major versions available. + :type major_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMajorVersion] + :param frameworks: List of frameworks associated with application stack. + :type frameworks: list[~azure.mgmt.web.v2020_09_01.models.ApplicationStack] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'display': {'key': 'properties.display', 'type': 'str'}, + 'dependency': {'key': 'properties.dependency', 'type': 'str'}, + 'major_versions': {'key': 'properties.majorVersions', 'type': '[StackMajorVersion]'}, + 'frameworks': {'key': 'properties.frameworks', 'type': '[ApplicationStack]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_properties_name: Optional[str] = None, + display: Optional[str] = None, + dependency: Optional[str] = None, + major_versions: Optional[List["StackMajorVersion"]] = None, + frameworks: Optional[List["ApplicationStack"]] = None, + **kwargs + ): + super(ApplicationStackResource, self).__init__(kind=kind, **kwargs) + self.name_properties_name = name_properties_name + self.display = display + self.dependency = dependency + self.major_versions = major_versions + self.frameworks = frameworks + + +class AppRegistration(ProxyOnlyResource): + """AppRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param app_id: + :type app_id: str + :param app_secret_setting_name: + :type app_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'app_id': {'key': 'properties.appId', 'type': 'str'}, + 'app_secret_setting_name': {'key': 'properties.appSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + app_id: Optional[str] = None, + app_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(AppRegistration, self).__init__(kind=kind, **kwargs) + self.app_id = app_id + self.app_secret_setting_name = app_secret_setting_name + + +class AppServiceCertificate(msrest.serialization.Model): + """Key Vault container for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'key_vault_id': {'key': 'keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificate, self).__init__(**kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceCertificateCollection(msrest.serialization.Model): + """Collection of certificate order certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceCertificateResource"], + **kwargs + ): + super(AppServiceCertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Resource(msrest.serialization.Model): + """Azure resource. This resource is tracked in Azure Resource Manager. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.kind = kind + self.location = location + self.type = None + self.tags = tags + self.system_data = None + + +class AppServiceCertificateOrder(Resource): + """SSL certificate purchase order. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + certificates: Optional[Dict[str, "AppServiceCertificate"]] = None, + distinguished_name: Optional[str] = None, + validity_in_years: Optional[int] = 1, + key_size: Optional[int] = 2048, + product_type: Optional[Union[str, "CertificateProductType"]] = None, + auto_renew: Optional[bool] = True, + csr: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateOrder, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.certificates = certificates + self.distinguished_name = distinguished_name + self.domain_verification_token = None + self.validity_in_years = validity_in_years + self.key_size = key_size + self.product_type = product_type + self.auto_renew = auto_renew + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = csr + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificateOrderCollection(msrest.serialization.Model): + """Collection of certificate orders. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceCertificateOrder]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceCertificateOrder"], + **kwargs + ): + super(AppServiceCertificateOrderCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServiceCertificateOrderPatchResource(ProxyOnlyResource): + """ARM resource for a certificate order that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param certificates: State of the Key Vault secret. + :type certificates: dict[str, ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificate] + :param distinguished_name: Certificate distinguished name. + :type distinguished_name: str + :ivar domain_verification_token: Domain verification token. + :vartype domain_verification_token: str + :param validity_in_years: Duration in years (must be between 1 and 3). + :type validity_in_years: int + :param key_size: Certificate key size. + :type key_size: int + :param product_type: Certificate product type. Possible values include: + "StandardDomainValidatedSsl", "StandardDomainValidatedWildCardSsl". + :type product_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateProductType + :param auto_renew: :code:`true` if the certificate should be automatically renewed + when it expires; otherwise, :code:`false`. + :type auto_renew: bool + :ivar provisioning_state: Status of certificate order. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current order status. Possible values include: "Pendingissuance", "Issued", + "Revoked", "Canceled", "Denied", "Pendingrevocation", "PendingRekey", "Unused", "Expired", + "NotSubmitted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderStatus + :ivar signed_certificate: Signed certificate. + :vartype signed_certificate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :param csr: Last CSR that was created for this order. + :type csr: str + :ivar intermediate: Intermediate certificate. + :vartype intermediate: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar root: Root certificate. + :vartype root: ~azure.mgmt.web.v2020_09_01.models.CertificateDetails + :ivar serial_number: Current serial number of the certificate. + :vartype serial_number: str + :ivar last_certificate_issuance_time: Certificate last issuance time. + :vartype last_certificate_issuance_time: ~datetime.datetime + :ivar expiration_time: Certificate expiration time. + :vartype expiration_time: ~datetime.datetime + :ivar is_private_key_external: :code:`true` if private key is external; otherwise, + :code:`false`. + :vartype is_private_key_external: bool + :ivar app_service_certificate_not_renewable_reasons: Reasons why App Service Certificate is not + renewable at the current moment. + :vartype app_service_certificate_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem] + :ivar next_auto_renewal_time_stamp: Time stamp when the certificate would be auto renewed next. + :vartype next_auto_renewal_time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_verification_token': {'readonly': True}, + 'validity_in_years': {'maximum': 3, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'signed_certificate': {'readonly': True}, + 'intermediate': {'readonly': True}, + 'root': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'last_certificate_issuance_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'is_private_key_external': {'readonly': True}, + 'app_service_certificate_not_renewable_reasons': {'readonly': True}, + 'next_auto_renewal_time_stamp': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'certificates': {'key': 'properties.certificates', 'type': '{AppServiceCertificate}'}, + 'distinguished_name': {'key': 'properties.distinguishedName', 'type': 'str'}, + 'domain_verification_token': {'key': 'properties.domainVerificationToken', 'type': 'str'}, + 'validity_in_years': {'key': 'properties.validityInYears', 'type': 'int'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'product_type': {'key': 'properties.productType', 'type': 'str'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'signed_certificate': {'key': 'properties.signedCertificate', 'type': 'CertificateDetails'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'intermediate': {'key': 'properties.intermediate', 'type': 'CertificateDetails'}, + 'root': {'key': 'properties.root', 'type': 'CertificateDetails'}, + 'serial_number': {'key': 'properties.serialNumber', 'type': 'str'}, + 'last_certificate_issuance_time': {'key': 'properties.lastCertificateIssuanceTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + 'app_service_certificate_not_renewable_reasons': {'key': 'properties.appServiceCertificateNotRenewableReasons', 'type': '[str]'}, + 'next_auto_renewal_time_stamp': {'key': 'properties.nextAutoRenewalTimeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + certificates: Optional[Dict[str, "AppServiceCertificate"]] = None, + distinguished_name: Optional[str] = None, + validity_in_years: Optional[int] = 1, + key_size: Optional[int] = 2048, + product_type: Optional[Union[str, "CertificateProductType"]] = None, + auto_renew: Optional[bool] = True, + csr: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateOrderPatchResource, self).__init__(kind=kind, **kwargs) + self.certificates = certificates + self.distinguished_name = distinguished_name + self.domain_verification_token = None + self.validity_in_years = validity_in_years + self.key_size = key_size + self.product_type = product_type + self.auto_renew = auto_renew + self.provisioning_state = None + self.status = None + self.signed_certificate = None + self.csr = csr + self.intermediate = None + self.root = None + self.serial_number = None + self.last_certificate_issuance_time = None + self.expiration_time = None + self.is_private_key_external = None + self.app_service_certificate_not_renewable_reasons = None + self.next_auto_renewal_time_stamp = None + + +class AppServiceCertificatePatchResource(ProxyOnlyResource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificatePatchResource, self).__init__(kind=kind, **kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceCertificateResource(Resource): + """Key Vault container ARM resource for a certificate that is purchased through Azure. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_vault_id: Key Vault resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar provisioning_state: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceCertificateResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.provisioning_state = None + + +class AppServiceEnvironment(msrest.serialization.Model): + """Description of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Name of the App Service Environment. + :type name: str + :param location: Required. Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Required. Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Required. Description of worker pools with worker size IDs, VM sizes, and + number of workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'name': {'required': True}, + 'location': {'required': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'virtual_network': {'required': True}, + 'worker_pools': {'required': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + location: str, + virtual_network: "VirtualNetworkProfile", + worker_pools: List["WorkerPool"], + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironment, self).__init__(**kwargs) + self.name = name + self.location = location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppServiceEnvironmentCollection(msrest.serialization.Model): + """Collection of App Service Environments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServiceEnvironmentResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServiceEnvironmentResource"], + **kwargs + ): + super(AppServiceEnvironmentCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServiceEnvironmentPatchResource(ProxyOnlyResource): + """ARM resource for a app service environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location: Location of the App Service Environment, e.g. "West US". + :type location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_properties_name: Optional[str] = None, + location: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + virtual_network: Optional["VirtualNetworkProfile"] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + worker_pools: Optional[List["WorkerPool"]] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironmentPatchResource, self).__init__(kind=kind, **kwargs) + self.name_properties_name = name_properties_name + self.location = location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppServiceEnvironmentResource(Resource): + """App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_properties_name: Name of the App Service Environment. + :type name_properties_name: str + :param location_properties_location: Location of the App Service Environment, e.g. "West US". + :type location_properties_location: str + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar status: Current status of the App Service Environment. Possible values include: + "Preparing", "Ready", "Scaling", "Deleting". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentStatus + :param vnet_name: Name of the Virtual Network for the App Service Environment. + :type vnet_name: str + :param vnet_resource_group_name: Resource group of the Virtual Network. + :type vnet_resource_group_name: str + :param vnet_subnet_name: Subnet of the Virtual Network. + :type vnet_subnet_name: str + :param virtual_network: Description of the Virtual Network. + :type virtual_network: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :param internal_load_balancing_mode: Specifies which endpoints to serve internally in the + Virtual Network for the App Service Environment. Possible values include: "None", "Web", + "Publishing", "Web,Publishing". + :type internal_load_balancing_mode: str or ~azure.mgmt.web.v2020_09_01.models.LoadBalancingMode + :param multi_size: Front-end VM size, e.g. "Medium", "Large". + :type multi_size: str + :param multi_role_count: Number of front-end instances. + :type multi_role_count: int + :param worker_pools: Description of worker pools with worker size IDs, VM sizes, and number of + workers in each pool. + :type worker_pools: list[~azure.mgmt.web.v2020_09_01.models.WorkerPool] + :param ipssl_address_count: Number of IP SSL addresses reserved for the App Service + Environment. + :type ipssl_address_count: int + :ivar database_edition: Edition of the metadata database for the App Service Environment, e.g. + "Standard". + :vartype database_edition: str + :ivar database_service_objective: Service objective of the metadata database for the App + Service Environment, e.g. "S0". + :vartype database_service_objective: str + :ivar upgrade_domains: Number of upgrade domains of the App Service Environment. + :vartype upgrade_domains: int + :ivar subscription_id: Subscription of the App Service Environment. + :vartype subscription_id: str + :param dns_suffix: DNS suffix of the App Service Environment. + :type dns_suffix: str + :ivar last_action: Last deployment action on the App Service Environment. + :vartype last_action: str + :ivar last_action_result: Result of the last deployment action on the App Service Environment. + :vartype last_action_result: str + :ivar allowed_multi_sizes: List of comma separated strings describing which VM sizes are + allowed for front-ends. + :vartype allowed_multi_sizes: str + :ivar allowed_worker_sizes: List of comma separated strings describing which VM sizes are + allowed for workers. + :vartype allowed_worker_sizes: str + :ivar maximum_number_of_machines: Maximum number of VMs in the App Service Environment. + :vartype maximum_number_of_machines: int + :ivar vip_mappings: Description of IP SSL mapping for the App Service Environment. + :vartype vip_mappings: list[~azure.mgmt.web.v2020_09_01.models.VirtualIPMapping] + :ivar environment_capacities: Current total, used, and available worker capacities. + :vartype environment_capacities: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :param network_access_control_list: Access control list for controlling traffic to the App + Service Environment. + :type network_access_control_list: + list[~azure.mgmt.web.v2020_09_01.models.NetworkAccessControlEntry] + :ivar environment_is_healthy: True/false indicating whether the App Service Environment is + healthy. + :vartype environment_is_healthy: bool + :ivar environment_status: Detailed message about with results of the last check of the App + Service Environment. + :vartype environment_status: str + :ivar resource_group: Resource group of the App Service Environment. + :vartype resource_group: str + :param front_end_scale_factor: Scale factor for front-ends. + :type front_end_scale_factor: int + :ivar default_front_end_scale_factor: Default Scale Factor for FrontEnds. + :vartype default_front_end_scale_factor: int + :param api_management_account_id: API Management Account associated with the App Service + Environment. + :type api_management_account_id: str + :param suspended: :code:`true` if the App Service Environment is suspended; + otherwise, :code:`false`. The environment can be suspended, e.g. when the + management endpoint is no longer available + (most likely because NSG blocked the incoming traffic). + :type suspended: bool + :param dynamic_cache_enabled: True/false indicating whether the App Service Environment is + suspended. The environment can be suspended e.g. when the management endpoint is no longer + available + (most likely because NSG blocked the incoming traffic). + :type dynamic_cache_enabled: bool + :param cluster_settings: Custom settings for changing the behavior of the App Service + Environment. + :type cluster_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param user_whitelisted_ip_ranges: User added ip ranges to whitelist on ASE db. + :type user_whitelisted_ip_ranges: list[str] + :param has_linux_workers: Flag that displays whether an ASE has linux workers or not. + :type has_linux_workers: bool + :param ssl_cert_key_vault_id: Key Vault ID for ILB App Service Environment default SSL + certificate. + :type ssl_cert_key_vault_id: str + :param ssl_cert_key_vault_secret_name: Key Vault Secret Name for ILB App Service Environment + default SSL certificate. + :type ssl_cert_key_vault_secret_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'status': {'readonly': True}, + 'database_edition': {'readonly': True}, + 'database_service_objective': {'readonly': True}, + 'upgrade_domains': {'readonly': True}, + 'subscription_id': {'readonly': True}, + 'last_action': {'readonly': True}, + 'last_action_result': {'readonly': True}, + 'allowed_multi_sizes': {'readonly': True}, + 'allowed_worker_sizes': {'readonly': True}, + 'maximum_number_of_machines': {'readonly': True}, + 'vip_mappings': {'readonly': True}, + 'environment_capacities': {'readonly': True}, + 'environment_is_healthy': {'readonly': True}, + 'environment_status': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'default_front_end_scale_factor': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'location_properties_location': {'key': 'properties.location', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_resource_group_name': {'key': 'properties.vnetResourceGroupName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + 'virtual_network': {'key': 'properties.virtualNetwork', 'type': 'VirtualNetworkProfile'}, + 'internal_load_balancing_mode': {'key': 'properties.internalLoadBalancingMode', 'type': 'str'}, + 'multi_size': {'key': 'properties.multiSize', 'type': 'str'}, + 'multi_role_count': {'key': 'properties.multiRoleCount', 'type': 'int'}, + 'worker_pools': {'key': 'properties.workerPools', 'type': '[WorkerPool]'}, + 'ipssl_address_count': {'key': 'properties.ipsslAddressCount', 'type': 'int'}, + 'database_edition': {'key': 'properties.databaseEdition', 'type': 'str'}, + 'database_service_objective': {'key': 'properties.databaseServiceObjective', 'type': 'str'}, + 'upgrade_domains': {'key': 'properties.upgradeDomains', 'type': 'int'}, + 'subscription_id': {'key': 'properties.subscriptionId', 'type': 'str'}, + 'dns_suffix': {'key': 'properties.dnsSuffix', 'type': 'str'}, + 'last_action': {'key': 'properties.lastAction', 'type': 'str'}, + 'last_action_result': {'key': 'properties.lastActionResult', 'type': 'str'}, + 'allowed_multi_sizes': {'key': 'properties.allowedMultiSizes', 'type': 'str'}, + 'allowed_worker_sizes': {'key': 'properties.allowedWorkerSizes', 'type': 'str'}, + 'maximum_number_of_machines': {'key': 'properties.maximumNumberOfMachines', 'type': 'int'}, + 'vip_mappings': {'key': 'properties.vipMappings', 'type': '[VirtualIPMapping]'}, + 'environment_capacities': {'key': 'properties.environmentCapacities', 'type': '[StampCapacity]'}, + 'network_access_control_list': {'key': 'properties.networkAccessControlList', 'type': '[NetworkAccessControlEntry]'}, + 'environment_is_healthy': {'key': 'properties.environmentIsHealthy', 'type': 'bool'}, + 'environment_status': {'key': 'properties.environmentStatus', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'front_end_scale_factor': {'key': 'properties.frontEndScaleFactor', 'type': 'int'}, + 'default_front_end_scale_factor': {'key': 'properties.defaultFrontEndScaleFactor', 'type': 'int'}, + 'api_management_account_id': {'key': 'properties.apiManagementAccountId', 'type': 'str'}, + 'suspended': {'key': 'properties.suspended', 'type': 'bool'}, + 'dynamic_cache_enabled': {'key': 'properties.dynamicCacheEnabled', 'type': 'bool'}, + 'cluster_settings': {'key': 'properties.clusterSettings', 'type': '[NameValuePair]'}, + 'user_whitelisted_ip_ranges': {'key': 'properties.userWhitelistedIpRanges', 'type': '[str]'}, + 'has_linux_workers': {'key': 'properties.hasLinuxWorkers', 'type': 'bool'}, + 'ssl_cert_key_vault_id': {'key': 'properties.sslCertKeyVaultId', 'type': 'str'}, + 'ssl_cert_key_vault_secret_name': {'key': 'properties.sslCertKeyVaultSecretName', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + name_properties_name: Optional[str] = None, + location_properties_location: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_resource_group_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + virtual_network: Optional["VirtualNetworkProfile"] = None, + internal_load_balancing_mode: Optional[Union[str, "LoadBalancingMode"]] = None, + multi_size: Optional[str] = None, + multi_role_count: Optional[int] = None, + worker_pools: Optional[List["WorkerPool"]] = None, + ipssl_address_count: Optional[int] = None, + dns_suffix: Optional[str] = None, + network_access_control_list: Optional[List["NetworkAccessControlEntry"]] = None, + front_end_scale_factor: Optional[int] = None, + api_management_account_id: Optional[str] = None, + suspended: Optional[bool] = None, + dynamic_cache_enabled: Optional[bool] = None, + cluster_settings: Optional[List["NameValuePair"]] = None, + user_whitelisted_ip_ranges: Optional[List[str]] = None, + has_linux_workers: Optional[bool] = None, + ssl_cert_key_vault_id: Optional[str] = None, + ssl_cert_key_vault_secret_name: Optional[str] = None, + **kwargs + ): + super(AppServiceEnvironmentResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.name_properties_name = name_properties_name + self.location_properties_location = location_properties_location + self.provisioning_state = None + self.status = None + self.vnet_name = vnet_name + self.vnet_resource_group_name = vnet_resource_group_name + self.vnet_subnet_name = vnet_subnet_name + self.virtual_network = virtual_network + self.internal_load_balancing_mode = internal_load_balancing_mode + self.multi_size = multi_size + self.multi_role_count = multi_role_count + self.worker_pools = worker_pools + self.ipssl_address_count = ipssl_address_count + self.database_edition = None + self.database_service_objective = None + self.upgrade_domains = None + self.subscription_id = None + self.dns_suffix = dns_suffix + self.last_action = None + self.last_action_result = None + self.allowed_multi_sizes = None + self.allowed_worker_sizes = None + self.maximum_number_of_machines = None + self.vip_mappings = None + self.environment_capacities = None + self.network_access_control_list = network_access_control_list + self.environment_is_healthy = None + self.environment_status = None + self.resource_group = None + self.front_end_scale_factor = front_end_scale_factor + self.default_front_end_scale_factor = None + self.api_management_account_id = api_management_account_id + self.suspended = suspended + self.dynamic_cache_enabled = dynamic_cache_enabled + self.cluster_settings = cluster_settings + self.user_whitelisted_ip_ranges = user_whitelisted_ip_ranges + self.has_linux_workers = has_linux_workers + self.ssl_cert_key_vault_id = ssl_cert_key_vault_id + self.ssl_cert_key_vault_secret_name = ssl_cert_key_vault_secret_name + + +class AppserviceGithubToken(msrest.serialization.Model): + """Github access token for Appservice CLI github integration. + + :param access_token: Github access token for Appservice CLI github integration. + :type access_token: str + :param scope: Scope of the github access token. + :type scope: str + :param token_type: token type. + :type token_type: str + :param got_token: True if valid github token received, False otherwise. + :type got_token: bool + :param error_message: Error message if unable to get token. + :type error_message: str + """ + + _attribute_map = { + 'access_token': {'key': 'accessToken', 'type': 'str'}, + 'scope': {'key': 'scope', 'type': 'str'}, + 'token_type': {'key': 'tokenType', 'type': 'str'}, + 'got_token': {'key': 'gotToken', 'type': 'bool'}, + 'error_message': {'key': 'errorMessage', 'type': 'str'}, + } + + def __init__( + self, + *, + access_token: Optional[str] = None, + scope: Optional[str] = None, + token_type: Optional[str] = None, + got_token: Optional[bool] = None, + error_message: Optional[str] = None, + **kwargs + ): + super(AppserviceGithubToken, self).__init__(**kwargs) + self.access_token = access_token + self.scope = scope + self.token_type = token_type + self.got_token = got_token + self.error_message = error_message + + +class AppserviceGithubTokenRequest(msrest.serialization.Model): + """Appservice Github token request content. + + All required parameters must be populated in order to send to Azure. + + :param code: Required. Code string to exchange for Github Access token. + :type code: str + :param state: Required. State string used for verification. + :type state: str + """ + + _validation = { + 'code': {'required': True}, + 'state': {'required': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + code: str, + state: str, + **kwargs + ): + super(AppserviceGithubTokenRequest, self).__init__(**kwargs) + self.code = code + self.state = state + + +class AppServicePlan(Resource): + """App Service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: If Linux app service plan :code:`true`, + :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["SkuDescription"] = None, + worker_tier_name: Optional[str] = None, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + per_site_scaling: Optional[bool] = False, + maximum_elastic_worker_count: Optional[int] = None, + is_spot: Optional[bool] = None, + spot_expiration_time: Optional[datetime.datetime] = None, + free_offer_expiration_time: Optional[datetime.datetime] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + target_worker_count: Optional[int] = None, + target_worker_size_id: Optional[int] = None, + **kwargs + ): + super(AppServicePlan, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.worker_tier_name = worker_tier_name + self.status = None + self.subscription = None + self.hosting_environment_profile = hosting_environment_profile + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = per_site_scaling + self.maximum_elastic_worker_count = maximum_elastic_worker_count + self.number_of_sites = None + self.is_spot = is_spot + self.spot_expiration_time = spot_expiration_time + self.free_offer_expiration_time = free_offer_expiration_time + self.resource_group = None + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.target_worker_count = target_worker_count + self.target_worker_size_id = target_worker_size_id + self.provisioning_state = None + + +class AppServicePlanCollection(msrest.serialization.Model): + """Collection of App Service plans. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AppServicePlan] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AppServicePlan]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AppServicePlan"], + **kwargs + ): + super(AppServicePlanCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class AppServicePlanPatchResource(ProxyOnlyResource): + """ARM resource for a app service plan. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param worker_tier_name: Target worker tier assigned to the App Service plan. + :type worker_tier_name: str + :ivar status: App Service plan status. Possible values include: "Ready", "Pending", "Creating". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.StatusOptions + :ivar subscription: App Service plan subscription. + :vartype subscription: str + :param hosting_environment_profile: Specification for the App Service Environment to use for + the App Service plan. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :ivar maximum_number_of_workers: Maximum number of instances that can be assigned to this App + Service plan. + :vartype maximum_number_of_workers: int + :ivar geo_region: Geographical location for the App Service plan. + :vartype geo_region: str + :param per_site_scaling: If :code:`true`, apps assigned to this App Service plan + can be scaled independently. + If :code:`false`, apps assigned to this App Service plan will scale to all + instances of the plan. + :type per_site_scaling: bool + :param maximum_elastic_worker_count: Maximum number of total workers allowed for this + ElasticScaleEnabled App Service Plan. + :type maximum_elastic_worker_count: int + :ivar number_of_sites: Number of apps assigned to this App Service plan. + :vartype number_of_sites: int + :param is_spot: If :code:`true`, this App Service Plan owns spot instances. + :type is_spot: bool + :param spot_expiration_time: The time when the server farm expires. Valid only if it is a spot + server farm. + :type spot_expiration_time: ~datetime.datetime + :param free_offer_expiration_time: The time when the server farm free offer expires. + :type free_offer_expiration_time: ~datetime.datetime + :ivar resource_group: Resource group of the App Service plan. + :vartype resource_group: str + :param reserved: This needs to set to :code:`true` when creating a Linux App + Service Plan, along with :code:`kind` set to :code:`Linux`. It should + be :code:`false` otherwise. + :type reserved: bool + :param is_xenon: Obsolete: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type is_xenon: bool + :param hyper_v: If Hyper-V container app service plan :code:`true`, + :code:`false` otherwise. + :type hyper_v: bool + :param target_worker_count: Scaling worker count. + :type target_worker_count: int + :param target_worker_size_id: Scaling worker size ID. + :type target_worker_size_id: int + :ivar provisioning_state: Provisioning state of the App Service Environment. Possible values + include: "Succeeded", "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'status': {'readonly': True}, + 'subscription': {'readonly': True}, + 'maximum_number_of_workers': {'readonly': True}, + 'geo_region': {'readonly': True}, + 'number_of_sites': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'worker_tier_name': {'key': 'properties.workerTierName', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'maximum_number_of_workers': {'key': 'properties.maximumNumberOfWorkers', 'type': 'int'}, + 'geo_region': {'key': 'properties.geoRegion', 'type': 'str'}, + 'per_site_scaling': {'key': 'properties.perSiteScaling', 'type': 'bool'}, + 'maximum_elastic_worker_count': {'key': 'properties.maximumElasticWorkerCount', 'type': 'int'}, + 'number_of_sites': {'key': 'properties.numberOfSites', 'type': 'int'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'spot_expiration_time': {'key': 'properties.spotExpirationTime', 'type': 'iso-8601'}, + 'free_offer_expiration_time': {'key': 'properties.freeOfferExpirationTime', 'type': 'iso-8601'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'target_worker_count': {'key': 'properties.targetWorkerCount', 'type': 'int'}, + 'target_worker_size_id': {'key': 'properties.targetWorkerSizeId', 'type': 'int'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + worker_tier_name: Optional[str] = None, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + per_site_scaling: Optional[bool] = False, + maximum_elastic_worker_count: Optional[int] = None, + is_spot: Optional[bool] = None, + spot_expiration_time: Optional[datetime.datetime] = None, + free_offer_expiration_time: Optional[datetime.datetime] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + target_worker_count: Optional[int] = None, + target_worker_size_id: Optional[int] = None, + **kwargs + ): + super(AppServicePlanPatchResource, self).__init__(kind=kind, **kwargs) + self.worker_tier_name = worker_tier_name + self.status = None + self.subscription = None + self.hosting_environment_profile = hosting_environment_profile + self.maximum_number_of_workers = None + self.geo_region = None + self.per_site_scaling = per_site_scaling + self.maximum_elastic_worker_count = maximum_elastic_worker_count + self.number_of_sites = None + self.is_spot = is_spot + self.spot_expiration_time = spot_expiration_time + self.free_offer_expiration_time = free_offer_expiration_time + self.resource_group = None + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.target_worker_count = target_worker_count + self.target_worker_size_id = target_worker_size_id + self.provisioning_state = None + + +class ArmIdWrapper(msrest.serialization.Model): + """A wrapper for an ARM resource id. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ArmIdWrapper, self).__init__(**kwargs) + self.id = None + + +class AuthPlatform(ProxyOnlyResource): + """AuthPlatform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param runtime_version: + :type runtime_version: str + :param config_file_path: + :type config_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'config_file_path': {'key': 'properties.configFilePath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + runtime_version: Optional[str] = None, + config_file_path: Optional[str] = None, + **kwargs + ): + super(AuthPlatform, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.runtime_version = runtime_version + self.config_file_path = config_file_path + + +class AutoHealActions(msrest.serialization.Model): + """Actions which to take by the auto-heal module when a rule is triggered. + + :param action_type: Predefined action to be taken. Possible values include: "Recycle", + "LogEvent", "CustomAction". + :type action_type: str or ~azure.mgmt.web.v2020_09_01.models.AutoHealActionType + :param custom_action: Custom action to be taken. + :type custom_action: ~azure.mgmt.web.v2020_09_01.models.AutoHealCustomAction + :param min_process_execution_time: Minimum time the process must execute + before taking the action. + :type min_process_execution_time: str + """ + + _attribute_map = { + 'action_type': {'key': 'actionType', 'type': 'str'}, + 'custom_action': {'key': 'customAction', 'type': 'AutoHealCustomAction'}, + 'min_process_execution_time': {'key': 'minProcessExecutionTime', 'type': 'str'}, + } + + def __init__( + self, + *, + action_type: Optional[Union[str, "AutoHealActionType"]] = None, + custom_action: Optional["AutoHealCustomAction"] = None, + min_process_execution_time: Optional[str] = None, + **kwargs + ): + super(AutoHealActions, self).__init__(**kwargs) + self.action_type = action_type + self.custom_action = custom_action + self.min_process_execution_time = min_process_execution_time + + +class AutoHealCustomAction(msrest.serialization.Model): + """Custom action to be executed +when an auto heal rule is triggered. + + :param exe: Executable to be run. + :type exe: str + :param parameters: Parameters for the executable. + :type parameters: str + """ + + _attribute_map = { + 'exe': {'key': 'exe', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': 'str'}, + } + + def __init__( + self, + *, + exe: Optional[str] = None, + parameters: Optional[str] = None, + **kwargs + ): + super(AutoHealCustomAction, self).__init__(**kwargs) + self.exe = exe + self.parameters = parameters + + +class AutoHealRules(msrest.serialization.Model): + """Rules that can be defined for auto-heal. + + :param triggers: Conditions that describe when to execute the auto-heal actions. + :type triggers: ~azure.mgmt.web.v2020_09_01.models.AutoHealTriggers + :param actions: Actions to be executed when a rule is triggered. + :type actions: ~azure.mgmt.web.v2020_09_01.models.AutoHealActions + """ + + _attribute_map = { + 'triggers': {'key': 'triggers', 'type': 'AutoHealTriggers'}, + 'actions': {'key': 'actions', 'type': 'AutoHealActions'}, + } + + def __init__( + self, + *, + triggers: Optional["AutoHealTriggers"] = None, + actions: Optional["AutoHealActions"] = None, + **kwargs + ): + super(AutoHealRules, self).__init__(**kwargs) + self.triggers = triggers + self.actions = actions + + +class AutoHealTriggers(msrest.serialization.Model): + """Triggers for auto-heal. + + :param requests: A rule based on total requests. + :type requests: ~azure.mgmt.web.v2020_09_01.models.RequestsBasedTrigger + :param private_bytes_in_kb: A rule based on private bytes. + :type private_bytes_in_kb: int + :param status_codes: A rule based on status codes. + :type status_codes: list[~azure.mgmt.web.v2020_09_01.models.StatusCodesBasedTrigger] + :param slow_requests: A rule based on request execution time. + :type slow_requests: ~azure.mgmt.web.v2020_09_01.models.SlowRequestsBasedTrigger + """ + + _attribute_map = { + 'requests': {'key': 'requests', 'type': 'RequestsBasedTrigger'}, + 'private_bytes_in_kb': {'key': 'privateBytesInKB', 'type': 'int'}, + 'status_codes': {'key': 'statusCodes', 'type': '[StatusCodesBasedTrigger]'}, + 'slow_requests': {'key': 'slowRequests', 'type': 'SlowRequestsBasedTrigger'}, + } + + def __init__( + self, + *, + requests: Optional["RequestsBasedTrigger"] = None, + private_bytes_in_kb: Optional[int] = None, + status_codes: Optional[List["StatusCodesBasedTrigger"]] = None, + slow_requests: Optional["SlowRequestsBasedTrigger"] = None, + **kwargs + ): + super(AutoHealTriggers, self).__init__(**kwargs) + self.requests = requests + self.private_bytes_in_kb = private_bytes_in_kb + self.status_codes = status_codes + self.slow_requests = slow_requests + + +class AzureActiveDirectory(ProxyOnlyResource): + """AzureActiveDirectory. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryLogin + :param validation: + :type validation: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectoryValidation + :param is_auto_provisioned: + :type is_auto_provisioned: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AzureActiveDirectoryRegistration'}, + 'login': {'key': 'properties.login', 'type': 'AzureActiveDirectoryLogin'}, + 'validation': {'key': 'properties.validation', 'type': 'AzureActiveDirectoryValidation'}, + 'is_auto_provisioned': {'key': 'properties.isAutoProvisioned', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["AzureActiveDirectoryRegistration"] = None, + login: Optional["AzureActiveDirectoryLogin"] = None, + validation: Optional["AzureActiveDirectoryValidation"] = None, + is_auto_provisioned: Optional[bool] = None, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + self.validation = validation + self.is_auto_provisioned = is_auto_provisioned + + +class AzureActiveDirectoryLogin(ProxyOnlyResource): + """AzureActiveDirectoryLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param disable_www_authenticate: + :type disable_www_authenticate: bool + :param login_parameters: + :type login_parameters: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'disable_www_authenticate': {'key': 'properties.disableWWWAuthenticate', 'type': 'bool'}, + 'login_parameters': {'key': 'properties.loginParameters', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + disable_www_authenticate: Optional[bool] = None, + login_parameters: Optional[List[str]] = None, + **kwargs + ): + super(AzureActiveDirectoryLogin, self).__init__(kind=kind, **kwargs) + self.disable_www_authenticate = disable_www_authenticate + self.login_parameters = login_parameters + + +class AzureActiveDirectoryRegistration(ProxyOnlyResource): + """AzureActiveDirectoryRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param open_id_issuer: + :type open_id_issuer: str + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: + :type client_secret_certificate_thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'open_id_issuer': {'key': 'properties.openIdIssuer', 'type': 'str'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + open_id_issuer: Optional[str] = None, + client_id: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + client_secret_certificate_thumbprint: Optional[str] = None, + **kwargs + ): + super(AzureActiveDirectoryRegistration, self).__init__(kind=kind, **kwargs) + self.open_id_issuer = open_id_issuer + self.client_id = client_id + self.client_secret_setting_name = client_secret_setting_name + self.client_secret_certificate_thumbprint = client_secret_certificate_thumbprint + + +class AzureActiveDirectoryValidation(ProxyOnlyResource): + """AzureActiveDirectoryValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param jwt_claim_checks: + :type jwt_claim_checks: ~azure.mgmt.web.v2020_09_01.models.JwtClaimChecks + :param allowed_audiences: + :type allowed_audiences: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'jwt_claim_checks': {'key': 'properties.jwtClaimChecks', 'type': 'JwtClaimChecks'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + jwt_claim_checks: Optional["JwtClaimChecks"] = None, + allowed_audiences: Optional[List[str]] = None, + **kwargs + ): + super(AzureActiveDirectoryValidation, self).__init__(kind=kind, **kwargs) + self.jwt_claim_checks = jwt_claim_checks + self.allowed_audiences = allowed_audiences + + +class AzureBlobStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs azure blob storage configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + } + + def __init__( + self, + *, + level: Optional[Union[str, "LogLevel"]] = None, + sas_url: Optional[str] = None, + retention_in_days: Optional[int] = None, + **kwargs + ): + super(AzureBlobStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + self.sas_url = sas_url + self.retention_in_days = retention_in_days + + +class AzureBlobStorageHttpLogsConfig(msrest.serialization.Model): + """Http logs to azure blob storage configuration. + + :param sas_url: SAS url to a azure blob container with read/write/list/delete permissions. + :type sas_url: str + :param retention_in_days: Retention in days. + Remove blobs older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + sas_url: Optional[str] = None, + retention_in_days: Optional[int] = None, + enabled: Optional[bool] = None, + **kwargs + ): + super(AzureBlobStorageHttpLogsConfig, self).__init__(**kwargs) + self.sas_url = sas_url + self.retention_in_days = retention_in_days + self.enabled = enabled + + +class AzureStorageInfoValue(msrest.serialization.Model): + """Azure Files or Blob Storage access information value for dictionary storage. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of storage. Possible values include: "AzureFiles", "AzureBlob". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.AzureStorageType + :param account_name: Name of the storage account. + :type account_name: str + :param share_name: Name of the file share (container name, for Blob storage). + :type share_name: str + :param access_key: Access key for the storage account. + :type access_key: str + :param mount_path: Path to mount the storage within the site's runtime environment. + :type mount_path: str + :ivar state: State of the storage account. Possible values include: "Ok", "InvalidCredentials", + "InvalidShare". + :vartype state: str or ~azure.mgmt.web.v2020_09_01.models.AzureStorageState + """ + + _validation = { + 'state': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'account_name': {'key': 'accountName', 'type': 'str'}, + 'share_name': {'key': 'shareName', 'type': 'str'}, + 'access_key': {'key': 'accessKey', 'type': 'str'}, + 'mount_path': {'key': 'mountPath', 'type': 'str'}, + 'state': {'key': 'state', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "AzureStorageType"]] = None, + account_name: Optional[str] = None, + share_name: Optional[str] = None, + access_key: Optional[str] = None, + mount_path: Optional[str] = None, + **kwargs + ): + super(AzureStorageInfoValue, self).__init__(**kwargs) + self.type = type + self.account_name = account_name + self.share_name = share_name + self.access_key = access_key + self.mount_path = mount_path + self.state = None + + +class AzureStoragePropertyDictionaryResource(ProxyOnlyResource): + """AzureStorageInfo dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Azure storage accounts. + :type properties: dict[str, ~azure.mgmt.web.v2020_09_01.models.AzureStorageInfoValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{AzureStorageInfoValue}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, "AzureStorageInfoValue"]] = None, + **kwargs + ): + super(AzureStoragePropertyDictionaryResource, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class AzureTableStorageApplicationLogsConfig(msrest.serialization.Model): + """Application logs to Azure table storage configuration. + + All required parameters must be populated in order to send to Azure. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + :param sas_url: Required. SAS URL to an Azure table with add/query/delete permissions. + :type sas_url: str + """ + + _validation = { + 'sas_url': {'required': True}, + } + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + 'sas_url': {'key': 'sasUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + sas_url: str, + level: Optional[Union[str, "LogLevel"]] = None, + **kwargs + ): + super(AzureTableStorageApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + self.sas_url = sas_url + + +class BackupItem(ProxyOnlyResource): + """Backup description. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar backup_id: Id of the backup. + :vartype backup_id: int + :ivar storage_account_url: SAS URL for the storage account container which contains this + backup. + :vartype storage_account_url: str + :ivar blob_name: Name of the blob which contains data for this backup. + :vartype blob_name: str + :ivar name_properties_name: Name of this backup. + :vartype name_properties_name: str + :ivar status: Backup status. Possible values include: "InProgress", "Failed", "Succeeded", + "TimedOut", "Created", "Skipped", "PartiallySucceeded", "DeleteInProgress", "DeleteFailed", + "Deleted". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.BackupItemStatus + :ivar size_in_bytes: Size of the backup in bytes. + :vartype size_in_bytes: long + :ivar created: Timestamp of the backup creation. + :vartype created: ~datetime.datetime + :ivar log: Details regarding this backup. Might contain an error message. + :vartype log: str + :ivar databases: List of databases included in the backup. + :vartype databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + :ivar scheduled: True if this backup has been created due to a schedule being triggered. + :vartype scheduled: bool + :ivar last_restore_time_stamp: Timestamp of a last restore operation which used this backup. + :vartype last_restore_time_stamp: ~datetime.datetime + :ivar finished_time_stamp: Timestamp when this backup finished. + :vartype finished_time_stamp: ~datetime.datetime + :ivar correlation_id: Unique correlation identifier. Please use this along with the timestamp + while communicating with Azure support. + :vartype correlation_id: str + :ivar website_size_in_bytes: Size of the original web app which has been backed up. + :vartype website_size_in_bytes: long + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'backup_id': {'readonly': True}, + 'storage_account_url': {'readonly': True}, + 'blob_name': {'readonly': True}, + 'name_properties_name': {'readonly': True}, + 'status': {'readonly': True}, + 'size_in_bytes': {'readonly': True}, + 'created': {'readonly': True}, + 'log': {'readonly': True}, + 'databases': {'readonly': True}, + 'scheduled': {'readonly': True}, + 'last_restore_time_stamp': {'readonly': True}, + 'finished_time_stamp': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'website_size_in_bytes': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'backup_id': {'key': 'properties.id', 'type': 'int'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'name_properties_name': {'key': 'properties.name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'size_in_bytes': {'key': 'properties.sizeInBytes', 'type': 'long'}, + 'created': {'key': 'properties.created', 'type': 'iso-8601'}, + 'log': {'key': 'properties.log', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'scheduled': {'key': 'properties.scheduled', 'type': 'bool'}, + 'last_restore_time_stamp': {'key': 'properties.lastRestoreTimeStamp', 'type': 'iso-8601'}, + 'finished_time_stamp': {'key': 'properties.finishedTimeStamp', 'type': 'iso-8601'}, + 'correlation_id': {'key': 'properties.correlationId', 'type': 'str'}, + 'website_size_in_bytes': {'key': 'properties.websiteSizeInBytes', 'type': 'long'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(BackupItem, self).__init__(kind=kind, **kwargs) + self.backup_id = None + self.storage_account_url = None + self.blob_name = None + self.name_properties_name = None + self.status = None + self.size_in_bytes = None + self.created = None + self.log = None + self.databases = None + self.scheduled = None + self.last_restore_time_stamp = None + self.finished_time_stamp = None + self.correlation_id = None + self.website_size_in_bytes = None + + +class BackupItemCollection(msrest.serialization.Model): + """Collection of backup items. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.BackupItem] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BackupItem]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["BackupItem"], + **kwargs + ): + super(BackupItemCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class BackupRequest(ProxyOnlyResource): + """Description of a backup which will be performed. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param backup_name: Name of the backup. + :type backup_name: str + :param enabled: True if the backup schedule is enabled (must be included in that case), false + if the backup schedule should be disabled. + :type enabled: bool + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param backup_schedule: Schedule for the backup if it is executed periodically. + :type backup_schedule: ~azure.mgmt.web.v2020_09_01.models.BackupSchedule + :param databases: Databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'backup_name': {'key': 'properties.backupName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'backup_schedule': {'key': 'properties.backupSchedule', 'type': 'BackupSchedule'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + backup_name: Optional[str] = None, + enabled: Optional[bool] = None, + storage_account_url: Optional[str] = None, + backup_schedule: Optional["BackupSchedule"] = None, + databases: Optional[List["DatabaseBackupSetting"]] = None, + **kwargs + ): + super(BackupRequest, self).__init__(kind=kind, **kwargs) + self.backup_name = backup_name + self.enabled = enabled + self.storage_account_url = storage_account_url + self.backup_schedule = backup_schedule + self.databases = databases + + +class BackupSchedule(msrest.serialization.Model): + """Description of a backup schedule. Describes how often should be the backup performed and what should be the retention policy. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param frequency_interval: Required. How often the backup should be executed (e.g. for weekly + backup, this should be set to 7 and FrequencyUnit should be set to Day). + :type frequency_interval: int + :param frequency_unit: Required. The unit of time for how often the backup should be executed + (e.g. for weekly backup, this should be set to Day and FrequencyInterval should be set to 7). + Possible values include: "Day", "Hour". Default value: "Day". + :type frequency_unit: str or ~azure.mgmt.web.v2020_09_01.models.FrequencyUnit + :param keep_at_least_one_backup: Required. True if the retention policy should always keep at + least one backup in the storage account, regardless how old it is; false otherwise. + :type keep_at_least_one_backup: bool + :param retention_period_in_days: Required. After how many days backups should be deleted. + :type retention_period_in_days: int + :param start_time: When the schedule should start working. + :type start_time: ~datetime.datetime + :ivar last_execution_time: Last time when this schedule was triggered. + :vartype last_execution_time: ~datetime.datetime + """ + + _validation = { + 'frequency_interval': {'required': True}, + 'frequency_unit': {'required': True}, + 'keep_at_least_one_backup': {'required': True}, + 'retention_period_in_days': {'required': True}, + 'last_execution_time': {'readonly': True}, + } + + _attribute_map = { + 'frequency_interval': {'key': 'frequencyInterval', 'type': 'int'}, + 'frequency_unit': {'key': 'frequencyUnit', 'type': 'str'}, + 'keep_at_least_one_backup': {'key': 'keepAtLeastOneBackup', 'type': 'bool'}, + 'retention_period_in_days': {'key': 'retentionPeriodInDays', 'type': 'int'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'last_execution_time': {'key': 'lastExecutionTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + frequency_interval: int = 7, + frequency_unit: Union[str, "FrequencyUnit"] = "Day", + keep_at_least_one_backup: bool = True, + retention_period_in_days: int = 30, + start_time: Optional[datetime.datetime] = None, + **kwargs + ): + super(BackupSchedule, self).__init__(**kwargs) + self.frequency_interval = frequency_interval + self.frequency_unit = frequency_unit + self.keep_at_least_one_backup = keep_at_least_one_backup + self.retention_period_in_days = retention_period_in_days + self.start_time = start_time + self.last_execution_time = None + + +class BillingMeter(ProxyOnlyResource): + """App Service billing entity that contains information about meter which the Azure billing system utilizes to charge users for services. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param meter_id: Meter GUID onboarded in Commerce. + :type meter_id: str + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param short_name: Short Name from App Service Azure pricing Page. + :type short_name: str + :param friendly_name: Friendly name of the meter. + :type friendly_name: str + :param resource_type: App Service ResourceType meter used for. + :type resource_type: str + :param os_type: App Service OS type meter used for. + :type os_type: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'meter_id': {'key': 'properties.meterId', 'type': 'str'}, + 'billing_location': {'key': 'properties.billingLocation', 'type': 'str'}, + 'short_name': {'key': 'properties.shortName', 'type': 'str'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'os_type': {'key': 'properties.osType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + meter_id: Optional[str] = None, + billing_location: Optional[str] = None, + short_name: Optional[str] = None, + friendly_name: Optional[str] = None, + resource_type: Optional[str] = None, + os_type: Optional[str] = None, + **kwargs + ): + super(BillingMeter, self).__init__(kind=kind, **kwargs) + self.meter_id = meter_id + self.billing_location = billing_location + self.short_name = short_name + self.friendly_name = friendly_name + self.resource_type = resource_type + self.os_type = os_type + + +class BillingMeterCollection(msrest.serialization.Model): + """Collection of Billing Meters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.BillingMeter] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[BillingMeter]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["BillingMeter"], + **kwargs + ): + super(BillingMeterCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class BlobStorageTokenStore(ProxyOnlyResource): + """BlobStorageTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sas_url_setting_name: + :type sas_url_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sas_url_setting_name': {'key': 'properties.sasUrlSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sas_url_setting_name: Optional[str] = None, + **kwargs + ): + super(BlobStorageTokenStore, self).__init__(kind=kind, **kwargs) + self.sas_url_setting_name = sas_url_setting_name + + +class Capability(msrest.serialization.Model): + """Describes the capabilities/features allowed for a specific SKU. + + :param name: Name of the SKU capability. + :type name: str + :param value: Value of the SKU capability. + :type value: str + :param reason: Reason of the SKU capability. + :type reason: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + 'reason': {'key': 'reason', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + reason: Optional[str] = None, + **kwargs + ): + super(Capability, self).__init__(**kwargs) + self.name = name + self.value = value + self.reason = reason + + +class Certificate(Resource): + """SSL certificate for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + host_names: Optional[List[str]] = None, + pfx_blob: Optional[bytearray] = None, + password: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + server_farm_id: Optional[str] = None, + canonical_name: Optional[str] = None, + **kwargs + ): + super(Certificate, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = host_names + self.pfx_blob = pfx_blob + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = password + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.key_vault_secret_status = None + self.server_farm_id = server_farm_id + self.canonical_name = canonical_name + + +class CertificateCollection(msrest.serialization.Model): + """Collection of certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Certificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Certificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Certificate"], + **kwargs + ): + super(CertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CertificateDetails(msrest.serialization.Model): + """SSL certificate details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar version: Certificate Version. + :vartype version: int + :ivar serial_number: Certificate Serial Number. + :vartype serial_number: str + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + :ivar subject: Certificate Subject. + :vartype subject: str + :ivar not_before: Date Certificate is valid from. + :vartype not_before: ~datetime.datetime + :ivar not_after: Date Certificate is valid to. + :vartype not_after: ~datetime.datetime + :ivar signature_algorithm: Certificate Signature algorithm. + :vartype signature_algorithm: str + :ivar issuer: Certificate Issuer. + :vartype issuer: str + :ivar raw_data: Raw certificate data. + :vartype raw_data: str + """ + + _validation = { + 'version': {'readonly': True}, + 'serial_number': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'subject': {'readonly': True}, + 'not_before': {'readonly': True}, + 'not_after': {'readonly': True}, + 'signature_algorithm': {'readonly': True}, + 'issuer': {'readonly': True}, + 'raw_data': {'readonly': True}, + } + + _attribute_map = { + 'version': {'key': 'version', 'type': 'int'}, + 'serial_number': {'key': 'serialNumber', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'subject': {'key': 'subject', 'type': 'str'}, + 'not_before': {'key': 'notBefore', 'type': 'iso-8601'}, + 'not_after': {'key': 'notAfter', 'type': 'iso-8601'}, + 'signature_algorithm': {'key': 'signatureAlgorithm', 'type': 'str'}, + 'issuer': {'key': 'issuer', 'type': 'str'}, + 'raw_data': {'key': 'rawData', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(CertificateDetails, self).__init__(**kwargs) + self.version = None + self.serial_number = None + self.thumbprint = None + self.subject = None + self.not_before = None + self.not_after = None + self.signature_algorithm = None + self.issuer = None + self.raw_data = None + + +class CertificateEmail(ProxyOnlyResource): + """SSL certificate email. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param email_id: Email id. + :type email_id: str + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'email_id': {'key': 'properties.emailId', 'type': 'str'}, + 'time_stamp': {'key': 'properties.timeStamp', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + email_id: Optional[str] = None, + time_stamp: Optional[datetime.datetime] = None, + **kwargs + ): + super(CertificateEmail, self).__init__(kind=kind, **kwargs) + self.email_id = email_id + self.time_stamp = time_stamp + + +class CertificateOrderAction(ProxyOnlyResource): + """Certificate order action. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar action_type: Action type. Possible values include: "CertificateIssued", + "CertificateOrderCanceled", "CertificateOrderCreated", "CertificateRevoked", + "DomainValidationComplete", "FraudDetected", "OrgNameChange", "OrgValidationComplete", + "SanDrop", "FraudCleared", "CertificateExpired", "CertificateExpirationWarning", + "FraudDocumentationRequired", "Unknown". + :vartype action_type: str or ~azure.mgmt.web.v2020_09_01.models.CertificateOrderActionType + :ivar created_at: Time at which the certificate action was performed. + :vartype created_at: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'action_type': {'readonly': True}, + 'created_at': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'action_type': {'key': 'properties.actionType', 'type': 'str'}, + 'created_at': {'key': 'properties.createdAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(CertificateOrderAction, self).__init__(kind=kind, **kwargs) + self.action_type = None + self.created_at = None + + +class CertificatePatchResource(ProxyOnlyResource): + """ARM resource for a certificate. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar friendly_name: Friendly name of the certificate. + :vartype friendly_name: str + :ivar subject_name: Subject name of the certificate. + :vartype subject_name: str + :param host_names: Host names the certificate applies to. + :type host_names: list[str] + :param pfx_blob: Pfx blob. + :type pfx_blob: bytearray + :ivar site_name: App name. + :vartype site_name: str + :ivar self_link: Self link. + :vartype self_link: str + :ivar issuer: Certificate issuer. + :vartype issuer: str + :ivar issue_date: Certificate issue Date. + :vartype issue_date: ~datetime.datetime + :ivar expiration_date: Certificate expiration date. + :vartype expiration_date: ~datetime.datetime + :param password: Certificate password. + :type password: str + :ivar thumbprint: Certificate thumbprint. + :vartype thumbprint: str + :ivar valid: Is the certificate valid?. + :vartype valid: bool + :ivar cer_blob: Raw bytes of .cer file. + :vartype cer_blob: bytearray + :ivar public_key_hash: Public key hash. + :vartype public_key_hash: str + :ivar hosting_environment_profile: Specification for the App Service Environment to use for the + certificate. + :vartype hosting_environment_profile: + ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param key_vault_id: Key Vault Csm resource Id. + :type key_vault_id: str + :param key_vault_secret_name: Key Vault secret name. + :type key_vault_secret_name: str + :ivar key_vault_secret_status: Status of the Key Vault secret. Possible values include: + "Initialized", "WaitingOnCertificateOrder", "Succeeded", "CertificateOrderFailed", + "OperationNotPermittedOnKeyVault", "AzureServiceUnauthorizedToAccessKeyVault", + "KeyVaultDoesNotExist", "KeyVaultSecretDoesNotExist", "UnknownError", "ExternalPrivateKey", + "Unknown". + :vartype key_vault_secret_status: str or + ~azure.mgmt.web.v2020_09_01.models.KeyVaultSecretStatus + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param canonical_name: CNAME of the certificate to be issued via free certificate. + :type canonical_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'friendly_name': {'readonly': True}, + 'subject_name': {'readonly': True}, + 'site_name': {'readonly': True}, + 'self_link': {'readonly': True}, + 'issuer': {'readonly': True}, + 'issue_date': {'readonly': True}, + 'expiration_date': {'readonly': True}, + 'thumbprint': {'readonly': True}, + 'valid': {'readonly': True}, + 'cer_blob': {'readonly': True}, + 'public_key_hash': {'readonly': True}, + 'hosting_environment_profile': {'readonly': True}, + 'key_vault_secret_status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'friendly_name': {'key': 'properties.friendlyName', 'type': 'str'}, + 'subject_name': {'key': 'properties.subjectName', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'pfx_blob': {'key': 'properties.pfxBlob', 'type': 'bytearray'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'self_link': {'key': 'properties.selfLink', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'issue_date': {'key': 'properties.issueDate', 'type': 'iso-8601'}, + 'expiration_date': {'key': 'properties.expirationDate', 'type': 'iso-8601'}, + 'password': {'key': 'properties.password', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'valid': {'key': 'properties.valid', 'type': 'bool'}, + 'cer_blob': {'key': 'properties.cerBlob', 'type': 'bytearray'}, + 'public_key_hash': {'key': 'properties.publicKeyHash', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'key_vault_id': {'key': 'properties.keyVaultId', 'type': 'str'}, + 'key_vault_secret_name': {'key': 'properties.keyVaultSecretName', 'type': 'str'}, + 'key_vault_secret_status': {'key': 'properties.keyVaultSecretStatus', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'canonical_name': {'key': 'properties.canonicalName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + host_names: Optional[List[str]] = None, + pfx_blob: Optional[bytearray] = None, + password: Optional[str] = None, + key_vault_id: Optional[str] = None, + key_vault_secret_name: Optional[str] = None, + server_farm_id: Optional[str] = None, + canonical_name: Optional[str] = None, + **kwargs + ): + super(CertificatePatchResource, self).__init__(kind=kind, **kwargs) + self.friendly_name = None + self.subject_name = None + self.host_names = host_names + self.pfx_blob = pfx_blob + self.site_name = None + self.self_link = None + self.issuer = None + self.issue_date = None + self.expiration_date = None + self.password = password + self.thumbprint = None + self.valid = None + self.cer_blob = None + self.public_key_hash = None + self.hosting_environment_profile = None + self.key_vault_id = key_vault_id + self.key_vault_secret_name = key_vault_secret_name + self.key_vault_secret_status = None + self.server_farm_id = server_farm_id + self.canonical_name = canonical_name + + +class ClientRegistration(ProxyOnlyResource): + """ClientRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param client_id: + :type client_id: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + client_id: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(ClientRegistration, self).__init__(kind=kind, **kwargs) + self.client_id = client_id + self.client_secret_setting_name = client_secret_setting_name + + +class CloningInfo(msrest.serialization.Model): + """Information needed for cloning operation. + + All required parameters must be populated in order to send to Azure. + + :param correlation_id: Correlation ID of cloning operation. This ID ties multiple cloning + operations + together to use the same snapshot. + :type correlation_id: str + :param overwrite: :code:`true` to overwrite destination app; otherwise, + :code:`false`. + :type overwrite: bool + :param clone_custom_host_names: :code:`true` to clone custom hostnames from source + app; otherwise, :code:`false`. + :type clone_custom_host_names: bool + :param clone_source_control: :code:`true` to clone source control from source app; + otherwise, :code:`false`. + :type clone_source_control: bool + :param source_web_app_id: Required. ARM resource ID of the source app. App resource ID is of + the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type source_web_app_id: str + :param source_web_app_location: Location of source app ex: West US or North Europe. + :type source_web_app_location: str + :param hosting_environment: App Service Environment. + :type hosting_environment: str + :param app_settings_overrides: Application setting overrides for cloned app. If specified, + these settings override the settings cloned + from source app. Otherwise, application settings from source app are retained. + :type app_settings_overrides: dict[str, str] + :param configure_load_balancing: :code:`true` to configure load balancing for + source and destination app. + :type configure_load_balancing: bool + :param traffic_manager_profile_id: ARM resource ID of the Traffic Manager profile to use, if it + exists. Traffic Manager resource ID is of the form + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/trafficManagerProfiles/{profileName}. + :type traffic_manager_profile_id: str + :param traffic_manager_profile_name: Name of Traffic Manager profile to create. This is only + needed if Traffic Manager profile does not already exist. + :type traffic_manager_profile_name: str + """ + + _validation = { + 'source_web_app_id': {'required': True}, + } + + _attribute_map = { + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'overwrite': {'key': 'overwrite', 'type': 'bool'}, + 'clone_custom_host_names': {'key': 'cloneCustomHostNames', 'type': 'bool'}, + 'clone_source_control': {'key': 'cloneSourceControl', 'type': 'bool'}, + 'source_web_app_id': {'key': 'sourceWebAppId', 'type': 'str'}, + 'source_web_app_location': {'key': 'sourceWebAppLocation', 'type': 'str'}, + 'hosting_environment': {'key': 'hostingEnvironment', 'type': 'str'}, + 'app_settings_overrides': {'key': 'appSettingsOverrides', 'type': '{str}'}, + 'configure_load_balancing': {'key': 'configureLoadBalancing', 'type': 'bool'}, + 'traffic_manager_profile_id': {'key': 'trafficManagerProfileId', 'type': 'str'}, + 'traffic_manager_profile_name': {'key': 'trafficManagerProfileName', 'type': 'str'}, + } + + def __init__( + self, + *, + source_web_app_id: str, + correlation_id: Optional[str] = None, + overwrite: Optional[bool] = None, + clone_custom_host_names: Optional[bool] = None, + clone_source_control: Optional[bool] = None, + source_web_app_location: Optional[str] = None, + hosting_environment: Optional[str] = None, + app_settings_overrides: Optional[Dict[str, str]] = None, + configure_load_balancing: Optional[bool] = None, + traffic_manager_profile_id: Optional[str] = None, + traffic_manager_profile_name: Optional[str] = None, + **kwargs + ): + super(CloningInfo, self).__init__(**kwargs) + self.correlation_id = correlation_id + self.overwrite = overwrite + self.clone_custom_host_names = clone_custom_host_names + self.clone_source_control = clone_source_control + self.source_web_app_id = source_web_app_id + self.source_web_app_location = source_web_app_location + self.hosting_environment = hosting_environment + self.app_settings_overrides = app_settings_overrides + self.configure_load_balancing = configure_load_balancing + self.traffic_manager_profile_id = traffic_manager_profile_id + self.traffic_manager_profile_name = traffic_manager_profile_name + + +class Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties(msrest.serialization.Model): + """Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Principal Id of user assigned identity. + :vartype principal_id: str + :ivar client_id: Client Id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class ConnectionStringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Connection strings. + :type properties: dict[str, ~azure.mgmt.web.v2020_09_01.models.ConnStringValueTypePair] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{ConnStringValueTypePair}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, "ConnStringValueTypePair"]] = None, + **kwargs + ): + super(ConnectionStringDictionary, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class ConnStringInfo(msrest.serialization.Model): + """Database connection string information. + + :param name: Name of connection string. + :type name: str + :param connection_string: Connection string value. + :type connection_string: str + :param type: Type of database. Possible values include: "MySql", "SQLServer", "SQLAzure", + "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", "RedisCache", + "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ConnectionStringType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + connection_string: Optional[str] = None, + type: Optional[Union[str, "ConnectionStringType"]] = None, + **kwargs + ): + super(ConnStringInfo, self).__init__(**kwargs) + self.name = name + self.connection_string = connection_string + self.type = type + + +class ConnStringValueTypePair(msrest.serialization.Model): + """Database connection string value to type pair. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Value of pair. + :type value: str + :param type: Required. Type of database. Possible values include: "MySql", "SQLServer", + "SQLAzure", "Custom", "NotificationHub", "ServiceBus", "EventHub", "ApiHub", "DocDb", + "RedisCache", "PostgreSQL". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ConnectionStringType + """ + + _validation = { + 'value': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + value: str, + type: Union[str, "ConnectionStringType"], + **kwargs + ): + super(ConnStringValueTypePair, self).__init__(**kwargs) + self.value = value + self.type = type + + +class Contact(msrest.serialization.Model): + """Contact information for domain registration. If 'Domain Privacy' option is not selected then the contact information is made publicly available through the Whois +directories as per ICANN requirements. + + All required parameters must be populated in order to send to Azure. + + :param address_mailing: Mailing address. + :type address_mailing: ~azure.mgmt.web.v2020_09_01.models.Address + :param email: Required. Email address. + :type email: str + :param fax: Fax number. + :type fax: str + :param job_title: Job title. + :type job_title: str + :param name_first: Required. First name. + :type name_first: str + :param name_last: Required. Last name. + :type name_last: str + :param name_middle: Middle name. + :type name_middle: str + :param organization: Organization contact belongs to. + :type organization: str + :param phone: Required. Phone number. + :type phone: str + """ + + _validation = { + 'email': {'required': True}, + 'name_first': {'required': True}, + 'name_last': {'required': True}, + 'phone': {'required': True}, + } + + _attribute_map = { + 'address_mailing': {'key': 'addressMailing', 'type': 'Address'}, + 'email': {'key': 'email', 'type': 'str'}, + 'fax': {'key': 'fax', 'type': 'str'}, + 'job_title': {'key': 'jobTitle', 'type': 'str'}, + 'name_first': {'key': 'nameFirst', 'type': 'str'}, + 'name_last': {'key': 'nameLast', 'type': 'str'}, + 'name_middle': {'key': 'nameMiddle', 'type': 'str'}, + 'organization': {'key': 'organization', 'type': 'str'}, + 'phone': {'key': 'phone', 'type': 'str'}, + } + + def __init__( + self, + *, + email: str, + name_first: str, + name_last: str, + phone: str, + address_mailing: Optional["Address"] = None, + fax: Optional[str] = None, + job_title: Optional[str] = None, + name_middle: Optional[str] = None, + organization: Optional[str] = None, + **kwargs + ): + super(Contact, self).__init__(**kwargs) + self.address_mailing = address_mailing + self.email = email + self.fax = fax + self.job_title = job_title + self.name_first = name_first + self.name_last = name_last + self.name_middle = name_middle + self.organization = organization + self.phone = phone + + +class ContainerCpuStatistics(msrest.serialization.Model): + """ContainerCpuStatistics. + + :param cpu_usage: + :type cpu_usage: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuUsage + :param system_cpu_usage: + :type system_cpu_usage: long + :param online_cpu_count: + :type online_cpu_count: int + :param throttling_data: + :type throttling_data: ~azure.mgmt.web.v2020_09_01.models.ContainerThrottlingData + """ + + _attribute_map = { + 'cpu_usage': {'key': 'cpuUsage', 'type': 'ContainerCpuUsage'}, + 'system_cpu_usage': {'key': 'systemCpuUsage', 'type': 'long'}, + 'online_cpu_count': {'key': 'onlineCpuCount', 'type': 'int'}, + 'throttling_data': {'key': 'throttlingData', 'type': 'ContainerThrottlingData'}, + } + + def __init__( + self, + *, + cpu_usage: Optional["ContainerCpuUsage"] = None, + system_cpu_usage: Optional[int] = None, + online_cpu_count: Optional[int] = None, + throttling_data: Optional["ContainerThrottlingData"] = None, + **kwargs + ): + super(ContainerCpuStatistics, self).__init__(**kwargs) + self.cpu_usage = cpu_usage + self.system_cpu_usage = system_cpu_usage + self.online_cpu_count = online_cpu_count + self.throttling_data = throttling_data + + +class ContainerCpuUsage(msrest.serialization.Model): + """ContainerCpuUsage. + + :param total_usage: + :type total_usage: long + :param per_cpu_usage: + :type per_cpu_usage: list[long] + :param kernel_mode_usage: + :type kernel_mode_usage: long + :param user_mode_usage: + :type user_mode_usage: long + """ + + _attribute_map = { + 'total_usage': {'key': 'totalUsage', 'type': 'long'}, + 'per_cpu_usage': {'key': 'perCpuUsage', 'type': '[long]'}, + 'kernel_mode_usage': {'key': 'kernelModeUsage', 'type': 'long'}, + 'user_mode_usage': {'key': 'userModeUsage', 'type': 'long'}, + } + + def __init__( + self, + *, + total_usage: Optional[int] = None, + per_cpu_usage: Optional[List[int]] = None, + kernel_mode_usage: Optional[int] = None, + user_mode_usage: Optional[int] = None, + **kwargs + ): + super(ContainerCpuUsage, self).__init__(**kwargs) + self.total_usage = total_usage + self.per_cpu_usage = per_cpu_usage + self.kernel_mode_usage = kernel_mode_usage + self.user_mode_usage = user_mode_usage + + +class ContainerInfo(msrest.serialization.Model): + """ContainerInfo. + + :param current_time_stamp: + :type current_time_stamp: ~datetime.datetime + :param previous_time_stamp: + :type previous_time_stamp: ~datetime.datetime + :param current_cpu_stats: + :type current_cpu_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuStatistics + :param previous_cpu_stats: + :type previous_cpu_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerCpuStatistics + :param memory_stats: + :type memory_stats: ~azure.mgmt.web.v2020_09_01.models.ContainerMemoryStatistics + :param name: + :type name: str + :param id: + :type id: str + :param eth0: + :type eth0: ~azure.mgmt.web.v2020_09_01.models.ContainerNetworkInterfaceStatistics + """ + + _attribute_map = { + 'current_time_stamp': {'key': 'currentTimeStamp', 'type': 'iso-8601'}, + 'previous_time_stamp': {'key': 'previousTimeStamp', 'type': 'iso-8601'}, + 'current_cpu_stats': {'key': 'currentCpuStats', 'type': 'ContainerCpuStatistics'}, + 'previous_cpu_stats': {'key': 'previousCpuStats', 'type': 'ContainerCpuStatistics'}, + 'memory_stats': {'key': 'memoryStats', 'type': 'ContainerMemoryStatistics'}, + 'name': {'key': 'name', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'eth0': {'key': 'eth0', 'type': 'ContainerNetworkInterfaceStatistics'}, + } + + def __init__( + self, + *, + current_time_stamp: Optional[datetime.datetime] = None, + previous_time_stamp: Optional[datetime.datetime] = None, + current_cpu_stats: Optional["ContainerCpuStatistics"] = None, + previous_cpu_stats: Optional["ContainerCpuStatistics"] = None, + memory_stats: Optional["ContainerMemoryStatistics"] = None, + name: Optional[str] = None, + id: Optional[str] = None, + eth0: Optional["ContainerNetworkInterfaceStatistics"] = None, + **kwargs + ): + super(ContainerInfo, self).__init__(**kwargs) + self.current_time_stamp = current_time_stamp + self.previous_time_stamp = previous_time_stamp + self.current_cpu_stats = current_cpu_stats + self.previous_cpu_stats = previous_cpu_stats + self.memory_stats = memory_stats + self.name = name + self.id = id + self.eth0 = eth0 + + +class ContainerMemoryStatistics(msrest.serialization.Model): + """ContainerMemoryStatistics. + + :param usage: + :type usage: long + :param max_usage: + :type max_usage: long + :param limit: + :type limit: long + """ + + _attribute_map = { + 'usage': {'key': 'usage', 'type': 'long'}, + 'max_usage': {'key': 'maxUsage', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + } + + def __init__( + self, + *, + usage: Optional[int] = None, + max_usage: Optional[int] = None, + limit: Optional[int] = None, + **kwargs + ): + super(ContainerMemoryStatistics, self).__init__(**kwargs) + self.usage = usage + self.max_usage = max_usage + self.limit = limit + + +class ContainerNetworkInterfaceStatistics(msrest.serialization.Model): + """ContainerNetworkInterfaceStatistics. + + :param rx_bytes: + :type rx_bytes: long + :param rx_packets: + :type rx_packets: long + :param rx_errors: + :type rx_errors: long + :param rx_dropped: + :type rx_dropped: long + :param tx_bytes: + :type tx_bytes: long + :param tx_packets: + :type tx_packets: long + :param tx_errors: + :type tx_errors: long + :param tx_dropped: + :type tx_dropped: long + """ + + _attribute_map = { + 'rx_bytes': {'key': 'rxBytes', 'type': 'long'}, + 'rx_packets': {'key': 'rxPackets', 'type': 'long'}, + 'rx_errors': {'key': 'rxErrors', 'type': 'long'}, + 'rx_dropped': {'key': 'rxDropped', 'type': 'long'}, + 'tx_bytes': {'key': 'txBytes', 'type': 'long'}, + 'tx_packets': {'key': 'txPackets', 'type': 'long'}, + 'tx_errors': {'key': 'txErrors', 'type': 'long'}, + 'tx_dropped': {'key': 'txDropped', 'type': 'long'}, + } + + def __init__( + self, + *, + rx_bytes: Optional[int] = None, + rx_packets: Optional[int] = None, + rx_errors: Optional[int] = None, + rx_dropped: Optional[int] = None, + tx_bytes: Optional[int] = None, + tx_packets: Optional[int] = None, + tx_errors: Optional[int] = None, + tx_dropped: Optional[int] = None, + **kwargs + ): + super(ContainerNetworkInterfaceStatistics, self).__init__(**kwargs) + self.rx_bytes = rx_bytes + self.rx_packets = rx_packets + self.rx_errors = rx_errors + self.rx_dropped = rx_dropped + self.tx_bytes = tx_bytes + self.tx_packets = tx_packets + self.tx_errors = tx_errors + self.tx_dropped = tx_dropped + + +class ContainerThrottlingData(msrest.serialization.Model): + """ContainerThrottlingData. + + :param periods: + :type periods: int + :param throttled_periods: + :type throttled_periods: int + :param throttled_time: + :type throttled_time: int + """ + + _attribute_map = { + 'periods': {'key': 'periods', 'type': 'int'}, + 'throttled_periods': {'key': 'throttledPeriods', 'type': 'int'}, + 'throttled_time': {'key': 'throttledTime', 'type': 'int'}, + } + + def __init__( + self, + *, + periods: Optional[int] = None, + throttled_periods: Optional[int] = None, + throttled_time: Optional[int] = None, + **kwargs + ): + super(ContainerThrottlingData, self).__init__(**kwargs) + self.periods = periods + self.throttled_periods = throttled_periods + self.throttled_time = throttled_time + + +class ContinuousWebJob(ProxyOnlyResource): + """Continuous Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param status: Job status. Possible values include: "Initializing", "Starting", "Running", + "PendingRestart", "Stopped". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobStatus + :param detailed_status: Detailed status. + :type detailed_status: str + :param log_url: Log URL. + :type log_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'detailed_status': {'key': 'properties.detailed_status', 'type': 'str'}, + 'log_url': {'key': 'properties.log_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + status: Optional[Union[str, "ContinuousWebJobStatus"]] = None, + detailed_status: Optional[str] = None, + log_url: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(ContinuousWebJob, self).__init__(kind=kind, **kwargs) + self.status = status + self.detailed_status = detailed_status + self.log_url = log_url + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class ContinuousWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ContinuousWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ContinuousWebJob"], + **kwargs + ): + super(ContinuousWebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CookieExpiration(ProxyOnlyResource): + """CookieExpiration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param convention: Possible values include: "FixedTime", "IdentityProviderDerived". + :type convention: str or ~azure.mgmt.web.v2020_09_01.models.CookieExpirationConvention + :param time_to_expiration: + :type time_to_expiration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'time_to_expiration': {'key': 'properties.timeToExpiration', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + convention: Optional[Union[str, "CookieExpirationConvention"]] = None, + time_to_expiration: Optional[str] = None, + **kwargs + ): + super(CookieExpiration, self).__init__(kind=kind, **kwargs) + self.convention = convention + self.time_to_expiration = time_to_expiration + + +class CorsSettings(msrest.serialization.Model): + """Cross-Origin Resource Sharing (CORS) settings for the app. + + :param allowed_origins: Gets or sets the list of origins that should be allowed to make cross- + origin + calls (for example: http://example.com:12345). Use "*" to allow all. + :type allowed_origins: list[str] + :param support_credentials: Gets or sets whether CORS requests with credentials are allowed. + See + https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#Requests_with_credentials + for more details. + :type support_credentials: bool + """ + + _attribute_map = { + 'allowed_origins': {'key': 'allowedOrigins', 'type': '[str]'}, + 'support_credentials': {'key': 'supportCredentials', 'type': 'bool'}, + } + + def __init__( + self, + *, + allowed_origins: Optional[List[str]] = None, + support_credentials: Optional[bool] = None, + **kwargs + ): + super(CorsSettings, self).__init__(**kwargs) + self.allowed_origins = allowed_origins + self.support_credentials = support_credentials + + +class CsmCopySlotEntity(msrest.serialization.Model): + """Copy deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during copy operation. + :type target_slot: str + :param site_config: Required. The site object which will be merged with the source slot site + to produce new destination slot site object. + :code:`null` to just copy source slot content. Otherwise a + :code:`Site` + object with properties to override source slot site. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + """ + + _validation = { + 'target_slot': {'required': True}, + 'site_config': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'site_config': {'key': 'siteConfig', 'type': 'SiteConfig'}, + } + + def __init__( + self, + *, + target_slot: str, + site_config: "SiteConfig", + **kwargs + ): + super(CsmCopySlotEntity, self).__init__(**kwargs) + self.target_slot = target_slot + self.site_config = site_config + + +class CsmMoveResourceEnvelope(msrest.serialization.Model): + """Object with a list of the resources that need to be moved and the resource group they should be moved to. + + :param target_resource_group: + :type target_resource_group: str + :param resources: + :type resources: list[str] + """ + + _validation = { + 'target_resource_group': {'max_length': 90, 'min_length': 1, 'pattern': r' ^[-\w\._\(\)]+[^\.]$'}, + } + + _attribute_map = { + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + 'resources': {'key': 'resources', 'type': '[str]'}, + } + + def __init__( + self, + *, + target_resource_group: Optional[str] = None, + resources: Optional[List[str]] = None, + **kwargs + ): + super(CsmMoveResourceEnvelope, self).__init__(**kwargs) + self.target_resource_group = target_resource_group + self.resources = resources + + +class CsmOperationCollection(msrest.serialization.Model): + """Collection of Azure resource manager operation metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.CsmOperationDescription] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmOperationDescription]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["CsmOperationDescription"], + **kwargs + ): + super(CsmOperationCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CsmOperationDescription(msrest.serialization.Model): + """Description of an operation available for Microsoft.Web resource provider. + + :param name: + :type name: str + :param display: Meta data about operation used for display in portal. + :type display: ~azure.mgmt.web.v2020_09_01.models.CsmOperationDisplay + :param origin: + :type origin: str + :param properties: Properties available for a Microsoft.Web resource provider operation. + :type properties: ~azure.mgmt.web.v2020_09_01.models.CsmOperationDescriptionProperties + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'CsmOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'CsmOperationDescriptionProperties'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional["CsmOperationDisplay"] = None, + origin: Optional[str] = None, + properties: Optional["CsmOperationDescriptionProperties"] = None, + **kwargs + ): + super(CsmOperationDescription, self).__init__(**kwargs) + self.name = name + self.display = display + self.origin = origin + self.properties = properties + + +class CsmOperationDescriptionProperties(msrest.serialization.Model): + """Properties available for a Microsoft.Web resource provider operation. + + :param service_specification: Resource metrics service provided by Microsoft.Insights resource + provider. + :type service_specification: ~azure.mgmt.web.v2020_09_01.models.ServiceSpecification + """ + + _attribute_map = { + 'service_specification': {'key': 'serviceSpecification', 'type': 'ServiceSpecification'}, + } + + def __init__( + self, + *, + service_specification: Optional["ServiceSpecification"] = None, + **kwargs + ): + super(CsmOperationDescriptionProperties, self).__init__(**kwargs) + self.service_specification = service_specification + + +class CsmOperationDisplay(msrest.serialization.Model): + """Meta data about operation used for display in portal. + + :param provider: + :type provider: str + :param resource: + :type resource: str + :param operation: + :type operation: str + :param description: + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(CsmOperationDisplay, self).__init__(**kwargs) + self.provider = provider + self.resource = resource + self.operation = operation + self.description = description + + +class CsmPublishingCredentialsPoliciesCollection(ProxyOnlyResource): + """Publishing Credentials Policies collection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param ftp: Whether FTP is allowed. + :type ftp: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :param scm: Whether Scm Basic Auth is allowed. + :type scm: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'ftp': {'key': 'properties.ftp', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + 'scm': {'key': 'properties.scm', 'type': 'CsmPublishingCredentialsPoliciesEntity'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + ftp: Optional["CsmPublishingCredentialsPoliciesEntity"] = None, + scm: Optional["CsmPublishingCredentialsPoliciesEntity"] = None, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesCollection, self).__init__(kind=kind, **kwargs) + self.ftp = ftp + self.scm = scm + + +class CsmPublishingCredentialsPoliciesEntity(ProxyOnlyResource): + """Publishing Credentials Policies parameters. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allow: :code:`true` to allow access to a publishing method; otherwise, + :code:`false`. + :type allow: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allow': {'key': 'properties.allow', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allow: Optional[bool] = None, + **kwargs + ): + super(CsmPublishingCredentialsPoliciesEntity, self).__init__(kind=kind, **kwargs) + self.allow = allow + + +class CsmPublishingProfileOptions(msrest.serialization.Model): + """Publishing options for requested profile. + + :param format: Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp. Possible values include: "FileZilla3", "WebDeploy", "Ftp". + :type format: str or ~azure.mgmt.web.v2020_09_01.models.PublishingProfileFormat + :param include_disaster_recovery_endpoints: Include the DisasterRecover endpoint if true. + :type include_disaster_recovery_endpoints: bool + """ + + _attribute_map = { + 'format': {'key': 'format', 'type': 'str'}, + 'include_disaster_recovery_endpoints': {'key': 'includeDisasterRecoveryEndpoints', 'type': 'bool'}, + } + + def __init__( + self, + *, + format: Optional[Union[str, "PublishingProfileFormat"]] = None, + include_disaster_recovery_endpoints: Optional[bool] = None, + **kwargs + ): + super(CsmPublishingProfileOptions, self).__init__(**kwargs) + self.format = format + self.include_disaster_recovery_endpoints = include_disaster_recovery_endpoints + + +class CsmSlotEntity(msrest.serialization.Model): + """Deployment slot parameters. + + All required parameters must be populated in order to send to Azure. + + :param target_slot: Required. Destination deployment slot during swap operation. + :type target_slot: str + :param preserve_vnet: Required. :code:`true` to preserve Virtual Network to the + slot during swap; otherwise, :code:`false`. + :type preserve_vnet: bool + """ + + _validation = { + 'target_slot': {'required': True}, + 'preserve_vnet': {'required': True}, + } + + _attribute_map = { + 'target_slot': {'key': 'targetSlot', 'type': 'str'}, + 'preserve_vnet': {'key': 'preserveVnet', 'type': 'bool'}, + } + + def __init__( + self, + *, + target_slot: str, + preserve_vnet: bool, + **kwargs + ): + super(CsmSlotEntity, self).__init__(**kwargs) + self.target_slot = target_slot + self.preserve_vnet = preserve_vnet + + +class CsmUsageQuota(msrest.serialization.Model): + """Usage of the quota resource. + + :param unit: Units of measurement for the quota resource. + :type unit: str + :param next_reset_time: Next reset time for the resource counter. + :type next_reset_time: ~datetime.datetime + :param current_value: The current value of the resource counter. + :type current_value: long + :param limit: The resource limit. + :type limit: long + :param name: Quota name. + :type name: ~azure.mgmt.web.v2020_09_01.models.LocalizableString + """ + + _attribute_map = { + 'unit': {'key': 'unit', 'type': 'str'}, + 'next_reset_time': {'key': 'nextResetTime', 'type': 'iso-8601'}, + 'current_value': {'key': 'currentValue', 'type': 'long'}, + 'limit': {'key': 'limit', 'type': 'long'}, + 'name': {'key': 'name', 'type': 'LocalizableString'}, + } + + def __init__( + self, + *, + unit: Optional[str] = None, + next_reset_time: Optional[datetime.datetime] = None, + current_value: Optional[int] = None, + limit: Optional[int] = None, + name: Optional["LocalizableString"] = None, + **kwargs + ): + super(CsmUsageQuota, self).__init__(**kwargs) + self.unit = unit + self.next_reset_time = next_reset_time + self.current_value = current_value + self.limit = limit + self.name = name + + +class CsmUsageQuotaCollection(msrest.serialization.Model): + """Collection of CSM usage quotas. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuota] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[CsmUsageQuota]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["CsmUsageQuota"], + **kwargs + ): + super(CsmUsageQuotaCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class CustomHostnameAnalysisResult(ProxyOnlyResource): + """Custom domain analysis. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar is_hostname_already_verified: :code:`true` if hostname is already verified; + otherwise, :code:`false`. + :vartype is_hostname_already_verified: bool + :ivar custom_domain_verification_test: DNS verification test result. Possible values include: + "Passed", "Failed", "Skipped". + :vartype custom_domain_verification_test: str or + ~azure.mgmt.web.v2020_09_01.models.DnsVerificationTestResult + :ivar custom_domain_verification_failure_info: Raw failure information if DNS verification + fails. + :vartype custom_domain_verification_failure_info: + ~azure.mgmt.web.v2020_09_01.models.ErrorEntity + :ivar has_conflict_on_scale_unit: :code:`true` if there is a conflict on a scale + unit; otherwise, :code:`false`. + :vartype has_conflict_on_scale_unit: bool + :ivar has_conflict_across_subscription: :code:`true` if there is a conflict across + subscriptions; otherwise, :code:`false`. + :vartype has_conflict_across_subscription: bool + :ivar conflicting_app_resource_id: Name of the conflicting app on scale unit if it's within the + same subscription. + :vartype conflicting_app_resource_id: str + :param c_name_records: CName records controller can see for this hostname. + :type c_name_records: list[str] + :param txt_records: TXT records controller can see for this hostname. + :type txt_records: list[str] + :param a_records: A records controller can see for this hostname. + :type a_records: list[str] + :param alternate_c_name_records: Alternate CName records controller can see for this hostname. + :type alternate_c_name_records: list[str] + :param alternate_txt_records: Alternate TXT records controller can see for this hostname. + :type alternate_txt_records: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'is_hostname_already_verified': {'readonly': True}, + 'custom_domain_verification_test': {'readonly': True}, + 'custom_domain_verification_failure_info': {'readonly': True}, + 'has_conflict_on_scale_unit': {'readonly': True}, + 'has_conflict_across_subscription': {'readonly': True}, + 'conflicting_app_resource_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_hostname_already_verified': {'key': 'properties.isHostnameAlreadyVerified', 'type': 'bool'}, + 'custom_domain_verification_test': {'key': 'properties.customDomainVerificationTest', 'type': 'str'}, + 'custom_domain_verification_failure_info': {'key': 'properties.customDomainVerificationFailureInfo', 'type': 'ErrorEntity'}, + 'has_conflict_on_scale_unit': {'key': 'properties.hasConflictOnScaleUnit', 'type': 'bool'}, + 'has_conflict_across_subscription': {'key': 'properties.hasConflictAcrossSubscription', 'type': 'bool'}, + 'conflicting_app_resource_id': {'key': 'properties.conflictingAppResourceId', 'type': 'str'}, + 'c_name_records': {'key': 'properties.cNameRecords', 'type': '[str]'}, + 'txt_records': {'key': 'properties.txtRecords', 'type': '[str]'}, + 'a_records': {'key': 'properties.aRecords', 'type': '[str]'}, + 'alternate_c_name_records': {'key': 'properties.alternateCNameRecords', 'type': '[str]'}, + 'alternate_txt_records': {'key': 'properties.alternateTxtRecords', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + c_name_records: Optional[List[str]] = None, + txt_records: Optional[List[str]] = None, + a_records: Optional[List[str]] = None, + alternate_c_name_records: Optional[List[str]] = None, + alternate_txt_records: Optional[List[str]] = None, + **kwargs + ): + super(CustomHostnameAnalysisResult, self).__init__(kind=kind, **kwargs) + self.is_hostname_already_verified = None + self.custom_domain_verification_test = None + self.custom_domain_verification_failure_info = None + self.has_conflict_on_scale_unit = None + self.has_conflict_across_subscription = None + self.conflicting_app_resource_id = None + self.c_name_records = c_name_records + self.txt_records = txt_records + self.a_records = a_records + self.alternate_c_name_records = alternate_c_name_records + self.alternate_txt_records = alternate_txt_records + + +class CustomOpenIdConnectProvider(ProxyOnlyResource): + """CustomOpenIdConnectProvider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectLogin + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'OpenIdConnectRegistration'}, + 'login': {'key': 'properties.login', 'type': 'OpenIdConnectLogin'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["OpenIdConnectRegistration"] = None, + login: Optional["OpenIdConnectLogin"] = None, + **kwargs + ): + super(CustomOpenIdConnectProvider, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + + +class DatabaseBackupSetting(msrest.serialization.Model): + """Database backup settings. + + All required parameters must be populated in order to send to Azure. + + :param database_type: Required. Database type (e.g. SqlAzure / MySql). Possible values include: + "SqlAzure", "MySql", "LocalMySql", "PostgreSql". + :type database_type: str or ~azure.mgmt.web.v2020_09_01.models.DatabaseType + :param name: + :type name: str + :param connection_string_name: Contains a connection string name that is linked to the + SiteConfig.ConnectionStrings. + This is used during restore with overwrite connection strings options. + :type connection_string_name: str + :param connection_string: Contains a connection string to a database which is being backed up + or restored. If the restore should happen to a new database, the database name inside is the + new one. + :type connection_string: str + """ + + _validation = { + 'database_type': {'required': True}, + } + + _attribute_map = { + 'database_type': {'key': 'databaseType', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'connection_string_name': {'key': 'connectionStringName', 'type': 'str'}, + 'connection_string': {'key': 'connectionString', 'type': 'str'}, + } + + def __init__( + self, + *, + database_type: Union[str, "DatabaseType"], + name: Optional[str] = None, + connection_string_name: Optional[str] = None, + connection_string: Optional[str] = None, + **kwargs + ): + super(DatabaseBackupSetting, self).__init__(**kwargs) + self.database_type = database_type + self.name = name + self.connection_string_name = connection_string_name + self.connection_string = connection_string + + +class DataSource(msrest.serialization.Model): + """Class representing data source used by the detectors. + + :param instructions: Instructions if any for the data source. + :type instructions: list[str] + :param data_source_uri: Datasource Uri Links. + :type data_source_uri: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + """ + + _attribute_map = { + 'instructions': {'key': 'instructions', 'type': '[str]'}, + 'data_source_uri': {'key': 'dataSourceUri', 'type': '[NameValuePair]'}, + } + + def __init__( + self, + *, + instructions: Optional[List[str]] = None, + data_source_uri: Optional[List["NameValuePair"]] = None, + **kwargs + ): + super(DataSource, self).__init__(**kwargs) + self.instructions = instructions + self.data_source_uri = data_source_uri + + +class DataTableResponseColumn(msrest.serialization.Model): + """Column definition. + + :param column_name: Name of the column. + :type column_name: str + :param data_type: Data type which looks like 'String' or 'Int32'. + :type data_type: str + :param column_type: Column Type. + :type column_type: str + """ + + _attribute_map = { + 'column_name': {'key': 'columnName', 'type': 'str'}, + 'data_type': {'key': 'dataType', 'type': 'str'}, + 'column_type': {'key': 'columnType', 'type': 'str'}, + } + + def __init__( + self, + *, + column_name: Optional[str] = None, + data_type: Optional[str] = None, + column_type: Optional[str] = None, + **kwargs + ): + super(DataTableResponseColumn, self).__init__(**kwargs) + self.column_name = column_name + self.data_type = data_type + self.column_type = column_type + + +class DataTableResponseObject(msrest.serialization.Model): + """Data Table which defines columns and raw row values. + + :param table_name: Name of the table. + :type table_name: str + :param columns: List of columns with data types. + :type columns: list[~azure.mgmt.web.v2020_09_01.models.DataTableResponseColumn] + :param rows: Raw row values. + :type rows: list[list[str]] + """ + + _attribute_map = { + 'table_name': {'key': 'tableName', 'type': 'str'}, + 'columns': {'key': 'columns', 'type': '[DataTableResponseColumn]'}, + 'rows': {'key': 'rows', 'type': '[[str]]'}, + } + + def __init__( + self, + *, + table_name: Optional[str] = None, + columns: Optional[List["DataTableResponseColumn"]] = None, + rows: Optional[List[List[str]]] = None, + **kwargs + ): + super(DataTableResponseObject, self).__init__(**kwargs) + self.table_name = table_name + self.columns = columns + self.rows = rows + + +class DefaultErrorResponse(msrest.serialization.Model): + """App Service error response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: Error model. + :vartype error: ~azure.mgmt.web.v2020_09_01.models.DefaultErrorResponseError + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'DefaultErrorResponseError'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponse, self).__init__(**kwargs) + self.error = None + + +class DefaultErrorResponseError(msrest.serialization.Model): + """Error model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + :param details: + :type details: list[~azure.mgmt.web.v2020_09_01.models.DefaultErrorResponseErrorDetailsItem] + :ivar innererror: More information to debug error. + :vartype innererror: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'innererror': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[DefaultErrorResponseErrorDetailsItem]'}, + 'innererror': {'key': 'innererror', 'type': 'str'}, + } + + def __init__( + self, + *, + details: Optional[List["DefaultErrorResponseErrorDetailsItem"]] = None, + **kwargs + ): + super(DefaultErrorResponseError, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = details + self.innererror = None + + +class DefaultErrorResponseErrorDetailsItem(msrest.serialization.Model): + """Detailed errors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: Standardized string to programmatically identify the error. + :vartype code: str + :ivar message: Detailed error description and debugging information. + :vartype message: str + :ivar target: Detailed error description and debugging information. + :vartype target: str + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DefaultErrorResponseErrorDetailsItem, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + + +class DeletedAppRestoreRequest(ProxyOnlyResource): + """Details about restoring a deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param deleted_site_id: ARM resource ID of the deleted app. Example: + /subscriptions/{subId}/providers/Microsoft.Web/deletedSites/{deletedSiteId}. + :type deleted_site_id: str + :param recover_configuration: If true, deleted site configuration, in addition to content, will + be restored. + :type recover_configuration: bool + :param snapshot_time: Point in time to restore the deleted app from, formatted as a DateTime + string. + If unspecified, default value is the time that the app was deleted. + :type snapshot_time: str + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'str'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + deleted_site_id: Optional[str] = None, + recover_configuration: Optional[bool] = None, + snapshot_time: Optional[str] = None, + use_dr_secondary: Optional[bool] = None, + **kwargs + ): + super(DeletedAppRestoreRequest, self).__init__(kind=kind, **kwargs) + self.deleted_site_id = deleted_site_id + self.recover_configuration = recover_configuration + self.snapshot_time = snapshot_time + self.use_dr_secondary = use_dr_secondary + + +class DeletedSite(ProxyOnlyResource): + """A deleted app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar deleted_site_id: Numeric id for the deleted site. + :vartype deleted_site_id: int + :ivar deleted_timestamp: Time in UTC when the app was deleted. + :vartype deleted_timestamp: str + :ivar subscription: Subscription containing the deleted site. + :vartype subscription: str + :ivar resource_group: ResourceGroup that contained the deleted site. + :vartype resource_group: str + :ivar deleted_site_name: Name of the deleted site. + :vartype deleted_site_name: str + :ivar slot: Slot of the deleted site. + :vartype slot: str + :ivar kind_properties_kind: Kind of site that was deleted. + :vartype kind_properties_kind: str + :ivar geo_region_name: Geo Region of the deleted site. + :vartype geo_region_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'deleted_site_id': {'readonly': True}, + 'deleted_timestamp': {'readonly': True}, + 'subscription': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'deleted_site_name': {'readonly': True}, + 'slot': {'readonly': True}, + 'kind_properties_kind': {'readonly': True}, + 'geo_region_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deleted_site_id': {'key': 'properties.deletedSiteId', 'type': 'int'}, + 'deleted_timestamp': {'key': 'properties.deletedTimestamp', 'type': 'str'}, + 'subscription': {'key': 'properties.subscription', 'type': 'str'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'deleted_site_name': {'key': 'properties.deletedSiteName', 'type': 'str'}, + 'slot': {'key': 'properties.slot', 'type': 'str'}, + 'kind_properties_kind': {'key': 'properties.kind', 'type': 'str'}, + 'geo_region_name': {'key': 'properties.geoRegionName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DeletedSite, self).__init__(kind=kind, **kwargs) + self.deleted_site_id = None + self.deleted_timestamp = None + self.subscription = None + self.resource_group = None + self.deleted_site_name = None + self.slot = None + self.kind_properties_kind = None + self.geo_region_name = None + + +class DeletedWebAppCollection(msrest.serialization.Model): + """Collection of deleted apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DeletedSite] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeletedSite]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DeletedSite"], + **kwargs + ): + super(DeletedWebAppCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Deployment(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param status: Deployment status. + :type status: int + :param message: Details about deployment status. + :type message: str + :param author: Who authored the deployment. + :type author: str + :param deployer: Who performed the deployment. + :type deployer: str + :param author_email: Author email. + :type author_email: str + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param active: True if deployment is currently active, false if completed and null if not + started. + :type active: bool + :param details: Details on deployment. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'status': {'key': 'properties.status', 'type': 'int'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'author': {'key': 'properties.author', 'type': 'str'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'author_email': {'key': 'properties.author_email', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'active': {'key': 'properties.active', 'type': 'bool'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + status: Optional[int] = None, + message: Optional[str] = None, + author: Optional[str] = None, + deployer: Optional[str] = None, + author_email: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + active: Optional[bool] = None, + details: Optional[str] = None, + **kwargs + ): + super(Deployment, self).__init__(kind=kind, **kwargs) + self.status = status + self.message = message + self.author = author + self.deployer = deployer + self.author_email = author_email + self.start_time = start_time + self.end_time = end_time + self.active = active + self.details = details + + +class DeploymentCollection(msrest.serialization.Model): + """Collection of app deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Deployment] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Deployment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Deployment"], + **kwargs + ): + super(DeploymentCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DeploymentLocations(msrest.serialization.Model): + """List of available locations (regions or App Service Environments) for +deployment of App Service resources. + + :param locations: Available regions. + :type locations: list[~azure.mgmt.web.v2020_09_01.models.GeoRegion] + :param hosting_environments: Available App Service Environments with full descriptions of the + environments. + :type hosting_environments: list[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironment] + :param hosting_environment_deployment_infos: Available App Service Environments with basic + information. + :type hosting_environment_deployment_infos: + list[~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDeploymentInfo] + """ + + _attribute_map = { + 'locations': {'key': 'locations', 'type': '[GeoRegion]'}, + 'hosting_environments': {'key': 'hostingEnvironments', 'type': '[AppServiceEnvironment]'}, + 'hosting_environment_deployment_infos': {'key': 'hostingEnvironmentDeploymentInfos', 'type': '[HostingEnvironmentDeploymentInfo]'}, + } + + def __init__( + self, + *, + locations: Optional[List["GeoRegion"]] = None, + hosting_environments: Optional[List["AppServiceEnvironment"]] = None, + hosting_environment_deployment_infos: Optional[List["HostingEnvironmentDeploymentInfo"]] = None, + **kwargs + ): + super(DeploymentLocations, self).__init__(**kwargs) + self.locations = locations + self.hosting_environments = hosting_environments + self.hosting_environment_deployment_infos = hosting_environment_deployment_infos + + +class DetectorAbnormalTimePeriod(msrest.serialization.Model): + """Class representing Abnormal Time Period detected. + + :param start_time: Start time of the correlated event. + :type start_time: ~datetime.datetime + :param end_time: End time of the correlated event. + :type end_time: ~datetime.datetime + :param message: Message describing the event. + :type message: str + :param source: Represents the name of the Detector. + :type source: str + :param priority: Represents the rank of the Detector. + :type priority: float + :param meta_data: Downtime metadata. + :type meta_data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param type: Represents the type of the Detector. Possible values include: "ServiceIncident", + "AppDeployment", "AppCrash", "RuntimeIssueDetected", "AseDeployment", "UserIssue", + "PlatformIssue", "Other". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.IssueType + :param solutions: List of proposed solutions. + :type solutions: list[~azure.mgmt.web.v2020_09_01.models.Solution] + """ + + _attribute_map = { + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'message': {'key': 'message', 'type': 'str'}, + 'source': {'key': 'source', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'float'}, + 'meta_data': {'key': 'metaData', 'type': '[[NameValuePair]]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'solutions': {'key': 'solutions', 'type': '[Solution]'}, + } + + def __init__( + self, + *, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + message: Optional[str] = None, + source: Optional[str] = None, + priority: Optional[float] = None, + meta_data: Optional[List[List["NameValuePair"]]] = None, + type: Optional[Union[str, "IssueType"]] = None, + solutions: Optional[List["Solution"]] = None, + **kwargs + ): + super(DetectorAbnormalTimePeriod, self).__init__(**kwargs) + self.start_time = start_time + self.end_time = end_time + self.message = message + self.source = source + self.priority = priority + self.meta_data = meta_data + self.type = type + self.solutions = solutions + + +class DetectorDefinition(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar display_name: Display name of the detector. + :vartype display_name: str + :ivar description: Description of the detector. + :vartype description: str + :ivar rank: Detector Rank. + :vartype rank: float + :ivar is_enabled: Flag representing whether detector is enabled or not. + :vartype is_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'display_name': {'readonly': True}, + 'description': {'readonly': True}, + 'rank': {'readonly': True}, + 'is_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'rank': {'key': 'properties.rank', 'type': 'float'}, + 'is_enabled': {'key': 'properties.isEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DetectorDefinition, self).__init__(kind=kind, **kwargs) + self.display_name = None + self.description = None + self.rank = None + self.is_enabled = None + + +class DetectorInfo(msrest.serialization.Model): + """Definition of Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Short description of the detector and its purpose. + :vartype description: str + :ivar category: Support Category. + :vartype category: str + :ivar sub_category: Support Sub Category. + :vartype sub_category: str + :ivar support_topic_id: Support Topic Id. + :vartype support_topic_id: str + """ + + _validation = { + 'description': {'readonly': True}, + 'category': {'readonly': True}, + 'sub_category': {'readonly': True}, + 'support_topic_id': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'sub_category': {'key': 'subCategory', 'type': 'str'}, + 'support_topic_id': {'key': 'supportTopicId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DetectorInfo, self).__init__(**kwargs) + self.description = None + self.category = None + self.sub_category = None + self.support_topic_id = None + + +class DetectorResponse(ProxyOnlyResource): + """Class representing Response from Detector. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param metadata: metadata for the detector. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.DetectorInfo + :param dataset: Data Set. + :type dataset: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticData] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'metadata': {'key': 'properties.metadata', 'type': 'DetectorInfo'}, + 'dataset': {'key': 'properties.dataset', 'type': '[DiagnosticData]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + metadata: Optional["DetectorInfo"] = None, + dataset: Optional[List["DiagnosticData"]] = None, + **kwargs + ): + super(DetectorResponse, self).__init__(kind=kind, **kwargs) + self.metadata = metadata + self.dataset = dataset + + +class DetectorResponseCollection(msrest.serialization.Model): + """Collection of detector responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DetectorResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DetectorResponse"], + **kwargs + ): + super(DetectorResponseCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticAnalysis(ProxyOnlyResource): + """Class representing a diagnostic analysis done on an application. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param abnormal_time_periods: List of time periods. + :type abnormal_time_periods: list[~azure.mgmt.web.v2020_09_01.models.AbnormalTimePeriod] + :param payload: Data by each detector. + :type payload: list[~azure.mgmt.web.v2020_09_01.models.AnalysisData] + :param non_correlated_detectors: Data by each detector for detectors that did not corelate. + :type non_correlated_detectors: list[~azure.mgmt.web.v2020_09_01.models.DetectorDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[AbnormalTimePeriod]'}, + 'payload': {'key': 'properties.payload', 'type': '[AnalysisData]'}, + 'non_correlated_detectors': {'key': 'properties.nonCorrelatedDetectors', 'type': '[DetectorDefinition]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + abnormal_time_periods: Optional[List["AbnormalTimePeriod"]] = None, + payload: Optional[List["AnalysisData"]] = None, + non_correlated_detectors: Optional[List["DetectorDefinition"]] = None, + **kwargs + ): + super(DiagnosticAnalysis, self).__init__(kind=kind, **kwargs) + self.start_time = start_time + self.end_time = end_time + self.abnormal_time_periods = abnormal_time_periods + self.payload = payload + self.non_correlated_detectors = non_correlated_detectors + + +class DiagnosticAnalysisCollection(msrest.serialization.Model): + """Collection of Diagnostic Analyses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[AnalysisDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["AnalysisDefinition"], + **kwargs + ): + super(DiagnosticAnalysisCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticCategory(ProxyOnlyResource): + """Class representing detector definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Description of the diagnostic category. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(DiagnosticCategory, self).__init__(kind=kind, **kwargs) + self.description = None + + +class DiagnosticCategoryCollection(msrest.serialization.Model): + """Collection of Diagnostic Categories. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DiagnosticCategory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DiagnosticCategory"], + **kwargs + ): + super(DiagnosticCategoryCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticData(msrest.serialization.Model): + """Set of data with rendering instructions. + + :param table: Data in table form. + :type table: ~azure.mgmt.web.v2020_09_01.models.DataTableResponseObject + :param rendering_properties: Properties that describe how the table should be rendered. + :type rendering_properties: ~azure.mgmt.web.v2020_09_01.models.Rendering + """ + + _attribute_map = { + 'table': {'key': 'table', 'type': 'DataTableResponseObject'}, + 'rendering_properties': {'key': 'renderingProperties', 'type': 'Rendering'}, + } + + def __init__( + self, + *, + table: Optional["DataTableResponseObject"] = None, + rendering_properties: Optional["Rendering"] = None, + **kwargs + ): + super(DiagnosticData, self).__init__(**kwargs) + self.table = table + self.rendering_properties = rendering_properties + + +class DiagnosticDetectorCollection(msrest.serialization.Model): + """Collection of Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DetectorDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DetectorDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DetectorDefinition"], + **kwargs + ): + super(DiagnosticDetectorCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DiagnosticDetectorResponse(ProxyOnlyResource): + """Class representing Response from Diagnostic Detectors. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param issue_detected: Flag representing Issue was detected. + :type issue_detected: bool + :param detector_definition: Detector's definition. + :type detector_definition: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :param metrics: Metrics provided by the detector. + :type metrics: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSet] + :param abnormal_time_periods: List of Correlated events found by the detector. + :type abnormal_time_periods: + list[~azure.mgmt.web.v2020_09_01.models.DetectorAbnormalTimePeriod] + :param data: Additional Data that detector wants to send. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param response_meta_data: Meta Data. + :type response_meta_data: ~azure.mgmt.web.v2020_09_01.models.ResponseMetaData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'issue_detected': {'key': 'properties.issueDetected', 'type': 'bool'}, + 'detector_definition': {'key': 'properties.detectorDefinition', 'type': 'DetectorDefinition'}, + 'metrics': {'key': 'properties.metrics', 'type': '[DiagnosticMetricSet]'}, + 'abnormal_time_periods': {'key': 'properties.abnormalTimePeriods', 'type': '[DetectorAbnormalTimePeriod]'}, + 'data': {'key': 'properties.data', 'type': '[[NameValuePair]]'}, + 'response_meta_data': {'key': 'properties.responseMetaData', 'type': 'ResponseMetaData'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + issue_detected: Optional[bool] = None, + detector_definition: Optional["DetectorDefinition"] = None, + metrics: Optional[List["DiagnosticMetricSet"]] = None, + abnormal_time_periods: Optional[List["DetectorAbnormalTimePeriod"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + response_meta_data: Optional["ResponseMetaData"] = None, + **kwargs + ): + super(DiagnosticDetectorResponse, self).__init__(kind=kind, **kwargs) + self.start_time = start_time + self.end_time = end_time + self.issue_detected = issue_detected + self.detector_definition = detector_definition + self.metrics = metrics + self.abnormal_time_periods = abnormal_time_periods + self.data = data + self.response_meta_data = response_meta_data + + +class DiagnosticMetricSample(msrest.serialization.Model): + """Class representing Diagnostic Metric. + + :param timestamp: Time at which metric is measured. + :type timestamp: ~datetime.datetime + :param role_instance: Role Instance. Null if this counter is not per instance + This is returned and should be whichever instance name we desire to be returned + i.e. CPU and Memory return RDWORKERNAME (LargeDed..._IN_0) + where RDWORKERNAME is Machine name below and RoleInstance name in parenthesis. + :type role_instance: str + :param total: Total value of the metric. If multiple measurements are made this will have sum + of all. + :type total: float + :param maximum: Maximum of the metric sampled during the time period. + :type maximum: float + :param minimum: Minimum of the metric sampled during the time period. + :type minimum: float + :param is_aggregated: Whether the values are aggregates across all workers or not. + :type is_aggregated: bool + """ + + _attribute_map = { + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'role_instance': {'key': 'roleInstance', 'type': 'str'}, + 'total': {'key': 'total', 'type': 'float'}, + 'maximum': {'key': 'maximum', 'type': 'float'}, + 'minimum': {'key': 'minimum', 'type': 'float'}, + 'is_aggregated': {'key': 'isAggregated', 'type': 'bool'}, + } + + def __init__( + self, + *, + timestamp: Optional[datetime.datetime] = None, + role_instance: Optional[str] = None, + total: Optional[float] = None, + maximum: Optional[float] = None, + minimum: Optional[float] = None, + is_aggregated: Optional[bool] = None, + **kwargs + ): + super(DiagnosticMetricSample, self).__init__(**kwargs) + self.timestamp = timestamp + self.role_instance = role_instance + self.total = total + self.maximum = maximum + self.minimum = minimum + self.is_aggregated = is_aggregated + + +class DiagnosticMetricSet(msrest.serialization.Model): + """Class representing Diagnostic Metric information. + + :param name: Name of the metric. + :type name: str + :param unit: Metric's unit. + :type unit: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. Supported grains at the moment are PT1M, PT1H, P1D. + :type time_grain: str + :param values: Collection of metric values for the selected period based on the + {Microsoft.Web.Hosting.Administration.DiagnosticMetricSet.TimeGrain}. + :type values: list[~azure.mgmt.web.v2020_09_01.models.DiagnosticMetricSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[DiagnosticMetricSample]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + unit: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + values: Optional[List["DiagnosticMetricSample"]] = None, + **kwargs + ): + super(DiagnosticMetricSet, self).__init__(**kwargs) + self.name = name + self.unit = unit + self.start_time = start_time + self.end_time = end_time + self.time_grain = time_grain + self.values = values + + +class Dimension(msrest.serialization.Model): + """Dimension of a resource metric. For e.g. instance specific HTTP requests for a web app, +where instance name is dimension of the metric HTTP request. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param internal_name: + :type internal_name: str + :param to_be_exported_for_shoebox: + :type to_be_exported_for_shoebox: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'internal_name': {'key': 'internalName', 'type': 'str'}, + 'to_be_exported_for_shoebox': {'key': 'toBeExportedForShoebox', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + internal_name: Optional[str] = None, + to_be_exported_for_shoebox: Optional[bool] = None, + **kwargs + ): + super(Dimension, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.internal_name = internal_name + self.to_be_exported_for_shoebox = to_be_exported_for_shoebox + + +class Domain(Resource): + """Information about a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_09_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_09_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_09_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_09_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.DomainPropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + contact_admin: Optional["Contact"] = None, + contact_billing: Optional["Contact"] = None, + contact_registrant: Optional["Contact"] = None, + contact_tech: Optional["Contact"] = None, + privacy: Optional[bool] = None, + auto_renew: Optional[bool] = True, + consent: Optional["DomainPurchaseConsent"] = None, + dns_type: Optional[Union[str, "DnsType"]] = None, + dns_zone_id: Optional[str] = None, + target_dns_type: Optional[Union[str, "DnsType"]] = None, + auth_code: Optional[str] = None, + **kwargs + ): + super(Domain, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.contact_admin = contact_admin + self.contact_billing = contact_billing + self.contact_registrant = contact_registrant + self.contact_tech = contact_tech + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = privacy + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = auto_renew + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = consent + self.domain_not_renewable_reasons = None + self.dns_type = dns_type + self.dns_zone_id = dns_zone_id + self.target_dns_type = target_dns_type + self.auth_code = auth_code + + +class DomainAvailabilityCheckResult(msrest.serialization.Model): + """Domain availability check result. + + :param name: Name of the domain. + :type name: str + :param available: :code:`true` if domain can be purchased using CreateDomain API; + otherwise, :code:`false`. + :type available: bool + :param domain_type: Valid values are Regular domain: Azure will charge the full price of domain + registration, SoftDeleted: Purchasing this domain will simply restore it and this operation + will not cost anything. Possible values include: "Regular", "SoftDeleted". + :type domain_type: str or ~azure.mgmt.web.v2020_09_01.models.DomainType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available': {'key': 'available', 'type': 'bool'}, + 'domain_type': {'key': 'domainType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + available: Optional[bool] = None, + domain_type: Optional[Union[str, "DomainType"]] = None, + **kwargs + ): + super(DomainAvailabilityCheckResult, self).__init__(**kwargs) + self.name = name + self.available = available + self.domain_type = domain_type + + +class DomainCollection(msrest.serialization.Model): + """Collection of domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Domain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Domain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Domain"], + **kwargs + ): + super(DomainCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DomainControlCenterSsoRequest(msrest.serialization.Model): + """Single sign-on request information for domain management. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar url: URL where the single sign-on request is to be made. + :vartype url: str + :ivar post_parameter_key: Post parameter key. + :vartype post_parameter_key: str + :ivar post_parameter_value: Post parameter value. Client should use 'application/x-www-form- + urlencoded' encoding for this value. + :vartype post_parameter_value: str + """ + + _validation = { + 'url': {'readonly': True}, + 'post_parameter_key': {'readonly': True}, + 'post_parameter_value': {'readonly': True}, + } + + _attribute_map = { + 'url': {'key': 'url', 'type': 'str'}, + 'post_parameter_key': {'key': 'postParameterKey', 'type': 'str'}, + 'post_parameter_value': {'key': 'postParameterValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DomainControlCenterSsoRequest, self).__init__(**kwargs) + self.url = None + self.post_parameter_key = None + self.post_parameter_value = None + + +class DomainOwnershipIdentifier(ProxyOnlyResource): + """Domain ownership Identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param ownership_id: Ownership Id. + :type ownership_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'ownership_id': {'key': 'properties.ownershipId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + ownership_id: Optional[str] = None, + **kwargs + ): + super(DomainOwnershipIdentifier, self).__init__(kind=kind, **kwargs) + self.ownership_id = ownership_id + + +class DomainOwnershipIdentifierCollection(msrest.serialization.Model): + """Collection of domain ownership identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DomainOwnershipIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["DomainOwnershipIdentifier"], + **kwargs + ): + super(DomainOwnershipIdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DomainPatchResource(ProxyOnlyResource): + """ARM resource for a domain. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param contact_admin: Administrative contact. + :type contact_admin: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_billing: Billing contact. + :type contact_billing: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_registrant: Registrant contact. + :type contact_registrant: ~azure.mgmt.web.v2020_09_01.models.Contact + :param contact_tech: Technical contact. + :type contact_tech: ~azure.mgmt.web.v2020_09_01.models.Contact + :ivar registration_status: Domain registration status. Possible values include: "Active", + "Awaiting", "Cancelled", "Confiscated", "Disabled", "Excluded", "Expired", "Failed", "Held", + "Locked", "Parked", "Pending", "Reserved", "Reverted", "Suspended", "Transferred", "Unknown", + "Unlocked", "Unparked", "Updated", "JsonConverterFailed". + :vartype registration_status: str or ~azure.mgmt.web.v2020_09_01.models.DomainStatus + :ivar provisioning_state: Domain provisioning state. Possible values include: "Succeeded", + "Failed", "Canceled", "InProgress", "Deleting". + :vartype provisioning_state: str or ~azure.mgmt.web.v2020_09_01.models.ProvisioningState + :ivar name_servers: Name servers. + :vartype name_servers: list[str] + :param privacy: :code:`true` if domain privacy is enabled for this domain; + otherwise, :code:`false`. + :type privacy: bool + :ivar created_time: Domain creation timestamp. + :vartype created_time: ~datetime.datetime + :ivar expiration_time: Domain expiration timestamp. + :vartype expiration_time: ~datetime.datetime + :ivar last_renewed_time: Timestamp when the domain was renewed last time. + :vartype last_renewed_time: ~datetime.datetime + :param auto_renew: :code:`true` if the domain should be automatically renewed; + otherwise, :code:`false`. + :type auto_renew: bool + :ivar ready_for_dns_record_management: :code:`true` if Azure can assign this + domain to App Service apps; otherwise, :code:`false`. This value will be + :code:`true` if domain registration status is active and + it is hosted on name servers Azure has programmatic access to. + :vartype ready_for_dns_record_management: bool + :ivar managed_host_names: All hostnames derived from the domain and assigned to Azure + resources. + :vartype managed_host_names: list[~azure.mgmt.web.v2020_09_01.models.HostName] + :param consent: Legal agreement consent. + :type consent: ~azure.mgmt.web.v2020_09_01.models.DomainPurchaseConsent + :ivar domain_not_renewable_reasons: Reasons why domain is not renewable. + :vartype domain_not_renewable_reasons: list[str or + ~azure.mgmt.web.v2020_09_01.models.DomainPatchResourcePropertiesDomainNotRenewableReasonsItem] + :param dns_type: Current DNS type. Possible values include: "AzureDns", + "DefaultDomainRegistrarDns". + :type dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param dns_zone_id: Azure DNS Zone to use. + :type dns_zone_id: str + :param target_dns_type: Target DNS type (would be used for migration). Possible values include: + "AzureDns", "DefaultDomainRegistrarDns". + :type target_dns_type: str or ~azure.mgmt.web.v2020_09_01.models.DnsType + :param auth_code: + :type auth_code: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'registration_status': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'name_servers': {'readonly': True}, + 'created_time': {'readonly': True}, + 'expiration_time': {'readonly': True}, + 'last_renewed_time': {'readonly': True}, + 'ready_for_dns_record_management': {'readonly': True}, + 'managed_host_names': {'readonly': True}, + 'domain_not_renewable_reasons': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'contact_admin': {'key': 'properties.contactAdmin', 'type': 'Contact'}, + 'contact_billing': {'key': 'properties.contactBilling', 'type': 'Contact'}, + 'contact_registrant': {'key': 'properties.contactRegistrant', 'type': 'Contact'}, + 'contact_tech': {'key': 'properties.contactTech', 'type': 'Contact'}, + 'registration_status': {'key': 'properties.registrationStatus', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'name_servers': {'key': 'properties.nameServers', 'type': '[str]'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + 'created_time': {'key': 'properties.createdTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + 'last_renewed_time': {'key': 'properties.lastRenewedTime', 'type': 'iso-8601'}, + 'auto_renew': {'key': 'properties.autoRenew', 'type': 'bool'}, + 'ready_for_dns_record_management': {'key': 'properties.readyForDnsRecordManagement', 'type': 'bool'}, + 'managed_host_names': {'key': 'properties.managedHostNames', 'type': '[HostName]'}, + 'consent': {'key': 'properties.consent', 'type': 'DomainPurchaseConsent'}, + 'domain_not_renewable_reasons': {'key': 'properties.domainNotRenewableReasons', 'type': '[str]'}, + 'dns_type': {'key': 'properties.dnsType', 'type': 'str'}, + 'dns_zone_id': {'key': 'properties.dnsZoneId', 'type': 'str'}, + 'target_dns_type': {'key': 'properties.targetDnsType', 'type': 'str'}, + 'auth_code': {'key': 'properties.authCode', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + contact_admin: Optional["Contact"] = None, + contact_billing: Optional["Contact"] = None, + contact_registrant: Optional["Contact"] = None, + contact_tech: Optional["Contact"] = None, + privacy: Optional[bool] = None, + auto_renew: Optional[bool] = True, + consent: Optional["DomainPurchaseConsent"] = None, + dns_type: Optional[Union[str, "DnsType"]] = None, + dns_zone_id: Optional[str] = None, + target_dns_type: Optional[Union[str, "DnsType"]] = None, + auth_code: Optional[str] = None, + **kwargs + ): + super(DomainPatchResource, self).__init__(kind=kind, **kwargs) + self.contact_admin = contact_admin + self.contact_billing = contact_billing + self.contact_registrant = contact_registrant + self.contact_tech = contact_tech + self.registration_status = None + self.provisioning_state = None + self.name_servers = None + self.privacy = privacy + self.created_time = None + self.expiration_time = None + self.last_renewed_time = None + self.auto_renew = auto_renew + self.ready_for_dns_record_management = None + self.managed_host_names = None + self.consent = consent + self.domain_not_renewable_reasons = None + self.dns_type = dns_type + self.dns_zone_id = dns_zone_id + self.target_dns_type = target_dns_type + self.auth_code = auth_code + + +class DomainPurchaseConsent(msrest.serialization.Model): + """Domain purchase consent object, representing acceptance of applicable legal agreements. + + :param agreement_keys: List of applicable legal agreement keys. This list can be retrieved + using ListLegalAgreements API under :code:`TopLevelDomain` resource. + :type agreement_keys: list[str] + :param agreed_by: Client IP address. + :type agreed_by: str + :param agreed_at: Timestamp when the agreements were accepted. + :type agreed_at: ~datetime.datetime + """ + + _attribute_map = { + 'agreement_keys': {'key': 'agreementKeys', 'type': '[str]'}, + 'agreed_by': {'key': 'agreedBy', 'type': 'str'}, + 'agreed_at': {'key': 'agreedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + agreement_keys: Optional[List[str]] = None, + agreed_by: Optional[str] = None, + agreed_at: Optional[datetime.datetime] = None, + **kwargs + ): + super(DomainPurchaseConsent, self).__init__(**kwargs) + self.agreement_keys = agreement_keys + self.agreed_by = agreed_by + self.agreed_at = agreed_at + + +class DomainRecommendationSearchParameters(msrest.serialization.Model): + """Domain recommendation search parameters. + + :param keywords: Keywords to be used for generating domain recommendations. + :type keywords: str + :param max_domain_recommendations: Maximum number of recommendations. + :type max_domain_recommendations: int + """ + + _attribute_map = { + 'keywords': {'key': 'keywords', 'type': 'str'}, + 'max_domain_recommendations': {'key': 'maxDomainRecommendations', 'type': 'int'}, + } + + def __init__( + self, + *, + keywords: Optional[str] = None, + max_domain_recommendations: Optional[int] = None, + **kwargs + ): + super(DomainRecommendationSearchParameters, self).__init__(**kwargs) + self.keywords = keywords + self.max_domain_recommendations = max_domain_recommendations + + +class EnabledConfig(msrest.serialization.Model): + """Enabled configuration. + + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _attribute_map = { + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + enabled: Optional[bool] = None, + **kwargs + ): + super(EnabledConfig, self).__init__(**kwargs) + self.enabled = enabled + + +class EndpointDependency(msrest.serialization.Model): + """A domain name that a service is reached at, including details of the current connection status. + + :param domain_name: The domain name of the dependency. + :type domain_name: str + :param endpoint_details: The IP Addresses and Ports used when connecting to DomainName. + :type endpoint_details: list[~azure.mgmt.web.v2020_09_01.models.EndpointDetail] + """ + + _attribute_map = { + 'domain_name': {'key': 'domainName', 'type': 'str'}, + 'endpoint_details': {'key': 'endpointDetails', 'type': '[EndpointDetail]'}, + } + + def __init__( + self, + *, + domain_name: Optional[str] = None, + endpoint_details: Optional[List["EndpointDetail"]] = None, + **kwargs + ): + super(EndpointDependency, self).__init__(**kwargs) + self.domain_name = domain_name + self.endpoint_details = endpoint_details + + +class EndpointDetail(msrest.serialization.Model): + """Current TCP connectivity information from the App Service Environment to a single endpoint. + + :param ip_address: An IP Address that Domain Name currently resolves to. + :type ip_address: str + :param port: The port an endpoint is connected to. + :type port: int + :param latency: The time in milliseconds it takes for a TCP connection to be created from the + App Service Environment to this IpAddress at this Port. + :type latency: float + :param is_accessible: Whether it is possible to create a TCP connection from the App Service + Environment to this IpAddress at this Port. + :type is_accessible: bool + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'port': {'key': 'port', 'type': 'int'}, + 'latency': {'key': 'latency', 'type': 'float'}, + 'is_accessible': {'key': 'isAccessible', 'type': 'bool'}, + } + + def __init__( + self, + *, + ip_address: Optional[str] = None, + port: Optional[int] = None, + latency: Optional[float] = None, + is_accessible: Optional[bool] = None, + **kwargs + ): + super(EndpointDetail, self).__init__(**kwargs) + self.ip_address = ip_address + self.port = port + self.latency = latency + self.is_accessible = is_accessible + + +class ErrorEntity(msrest.serialization.Model): + """Body of the error response returned from the API. + + :param extended_code: Type of error. + :type extended_code: str + :param message_template: Message template. + :type message_template: str + :param parameters: Parameters for the template. + :type parameters: list[str] + :param inner_errors: Inner errors. + :type inner_errors: list[~azure.mgmt.web.v2020_09_01.models.ErrorEntity] + :param code: Basic error code. + :type code: str + :param message: Any details of the error. + :type message: str + """ + + _attribute_map = { + 'extended_code': {'key': 'extendedCode', 'type': 'str'}, + 'message_template': {'key': 'messageTemplate', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[str]'}, + 'inner_errors': {'key': 'innerErrors', 'type': '[ErrorEntity]'}, + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + extended_code: Optional[str] = None, + message_template: Optional[str] = None, + parameters: Optional[List[str]] = None, + inner_errors: Optional[List["ErrorEntity"]] = None, + code: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ErrorEntity, self).__init__(**kwargs) + self.extended_code = extended_code + self.message_template = message_template + self.parameters = parameters + self.inner_errors = inner_errors + self.code = code + self.message = message + + +class Experiments(msrest.serialization.Model): + """Routing rules in production experiments. + + :param ramp_up_rules: List of ramp-up rules. + :type ramp_up_rules: list[~azure.mgmt.web.v2020_09_01.models.RampUpRule] + """ + + _attribute_map = { + 'ramp_up_rules': {'key': 'rampUpRules', 'type': '[RampUpRule]'}, + } + + def __init__( + self, + *, + ramp_up_rules: Optional[List["RampUpRule"]] = None, + **kwargs + ): + super(Experiments, self).__init__(**kwargs) + self.ramp_up_rules = ramp_up_rules + + +class Facebook(ProxyOnlyResource): + """Facebook. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.AppRegistration + :param graph_api_version: + :type graph_api_version: str + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'AppRegistration'}, + 'graph_api_version': {'key': 'properties.graphApiVersion', 'type': 'str'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["AppRegistration"] = None, + graph_api_version: Optional[str] = None, + login: Optional["LoginScopes"] = None, + **kwargs + ): + super(Facebook, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.graph_api_version = graph_api_version + self.login = login + + +class FileSystemApplicationLogsConfig(msrest.serialization.Model): + """Application logs to file system configuration. + + :param level: Log level. Possible values include: "Off", "Verbose", "Information", "Warning", + "Error". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.LogLevel + """ + + _attribute_map = { + 'level': {'key': 'level', 'type': 'str'}, + } + + def __init__( + self, + *, + level: Optional[Union[str, "LogLevel"]] = None, + **kwargs + ): + super(FileSystemApplicationLogsConfig, self).__init__(**kwargs) + self.level = level + + +class FileSystemHttpLogsConfig(msrest.serialization.Model): + """Http logs to file system configuration. + + :param retention_in_mb: Maximum size in megabytes that http log files can use. + When reached old log files will be removed to make space for new ones. + Value can range between 25 and 100. + :type retention_in_mb: int + :param retention_in_days: Retention in days. + Remove files older than X days. + 0 or lower means no retention. + :type retention_in_days: int + :param enabled: True if configuration is enabled, false if it is disabled and null if + configuration is not set. + :type enabled: bool + """ + + _validation = { + 'retention_in_mb': {'maximum': 100, 'minimum': 25}, + } + + _attribute_map = { + 'retention_in_mb': {'key': 'retentionInMb', 'type': 'int'}, + 'retention_in_days': {'key': 'retentionInDays', 'type': 'int'}, + 'enabled': {'key': 'enabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + retention_in_mb: Optional[int] = None, + retention_in_days: Optional[int] = None, + enabled: Optional[bool] = None, + **kwargs + ): + super(FileSystemHttpLogsConfig, self).__init__(**kwargs) + self.retention_in_mb = retention_in_mb + self.retention_in_days = retention_in_days + self.enabled = enabled + + +class FileSystemTokenStore(ProxyOnlyResource): + """FileSystemTokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param directory: + :type directory: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'directory': {'key': 'properties.directory', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + directory: Optional[str] = None, + **kwargs + ): + super(FileSystemTokenStore, self).__init__(kind=kind, **kwargs) + self.directory = directory + + +class ForwardProxy(ProxyOnlyResource): + """ForwardProxy. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param convention: Possible values include: "NoProxy", "Standard", "Custom". + :type convention: str or ~azure.mgmt.web.v2020_09_01.models.ForwardProxyConvention + :param custom_host_header_name: + :type custom_host_header_name: str + :param custom_proto_header_name: + :type custom_proto_header_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'convention': {'key': 'properties.convention', 'type': 'str'}, + 'custom_host_header_name': {'key': 'properties.customHostHeaderName', 'type': 'str'}, + 'custom_proto_header_name': {'key': 'properties.customProtoHeaderName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + convention: Optional[Union[str, "ForwardProxyConvention"]] = None, + custom_host_header_name: Optional[str] = None, + custom_proto_header_name: Optional[str] = None, + **kwargs + ): + super(ForwardProxy, self).__init__(kind=kind, **kwargs) + self.convention = convention + self.custom_host_header_name = custom_host_header_name + self.custom_proto_header_name = custom_proto_header_name + + +class FunctionEnvelope(ProxyOnlyResource): + """Function information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param function_app_id: Function App ID. + :type function_app_id: str + :param script_root_path_href: Script root path URI. + :type script_root_path_href: str + :param script_href: Script URI. + :type script_href: str + :param config_href: Config URI. + :type config_href: str + :param test_data_href: Test data URI. + :type test_data_href: str + :param secrets_file_href: Secrets file URI. + :type secrets_file_href: str + :param href: Function URI. + :type href: str + :param config: Config information. + :type config: object + :param files: File list. + :type files: dict[str, str] + :param test_data: Test data used when testing via the Azure Portal. + :type test_data: str + :param invoke_url_template: The invocation URL. + :type invoke_url_template: str + :param language: The function language. + :type language: str + :param is_disabled: Gets or sets a value indicating whether the function is disabled. + :type is_disabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'function_app_id': {'key': 'properties.function_app_id', 'type': 'str'}, + 'script_root_path_href': {'key': 'properties.script_root_path_href', 'type': 'str'}, + 'script_href': {'key': 'properties.script_href', 'type': 'str'}, + 'config_href': {'key': 'properties.config_href', 'type': 'str'}, + 'test_data_href': {'key': 'properties.test_data_href', 'type': 'str'}, + 'secrets_file_href': {'key': 'properties.secrets_file_href', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'config': {'key': 'properties.config', 'type': 'object'}, + 'files': {'key': 'properties.files', 'type': '{str}'}, + 'test_data': {'key': 'properties.test_data', 'type': 'str'}, + 'invoke_url_template': {'key': 'properties.invoke_url_template', 'type': 'str'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + 'is_disabled': {'key': 'properties.isDisabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + function_app_id: Optional[str] = None, + script_root_path_href: Optional[str] = None, + script_href: Optional[str] = None, + config_href: Optional[str] = None, + test_data_href: Optional[str] = None, + secrets_file_href: Optional[str] = None, + href: Optional[str] = None, + config: Optional[object] = None, + files: Optional[Dict[str, str]] = None, + test_data: Optional[str] = None, + invoke_url_template: Optional[str] = None, + language: Optional[str] = None, + is_disabled: Optional[bool] = None, + **kwargs + ): + super(FunctionEnvelope, self).__init__(kind=kind, **kwargs) + self.function_app_id = function_app_id + self.script_root_path_href = script_root_path_href + self.script_href = script_href + self.config_href = config_href + self.test_data_href = test_data_href + self.secrets_file_href = secrets_file_href + self.href = href + self.config = config + self.files = files + self.test_data = test_data + self.invoke_url_template = invoke_url_template + self.language = language + self.is_disabled = is_disabled + + +class FunctionEnvelopeCollection(msrest.serialization.Model): + """Collection of Kudu function information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[FunctionEnvelope]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["FunctionEnvelope"], + **kwargs + ): + super(FunctionEnvelopeCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class FunctionSecrets(msrest.serialization.Model): + """Function secrets. + + :param key: Secret key. + :type key: str + :param trigger_url: Trigger URL. + :type trigger_url: str + """ + + _attribute_map = { + 'key': {'key': 'key', 'type': 'str'}, + 'trigger_url': {'key': 'trigger_url', 'type': 'str'}, + } + + def __init__( + self, + *, + key: Optional[str] = None, + trigger_url: Optional[str] = None, + **kwargs + ): + super(FunctionSecrets, self).__init__(**kwargs) + self.key = key + self.trigger_url = trigger_url + + +class GeoRegion(ProxyOnlyResource): + """Geographical region. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar description: Region description. + :vartype description: str + :ivar display_name: Display name for region. + :vartype display_name: str + :ivar org_domain: Display name for region. + :vartype org_domain: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'description': {'readonly': True}, + 'display_name': {'readonly': True}, + 'org_domain': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'org_domain': {'key': 'properties.orgDomain', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(GeoRegion, self).__init__(kind=kind, **kwargs) + self.description = None + self.display_name = None + self.org_domain = None + + +class GeoRegionCollection(msrest.serialization.Model): + """Collection of geographical regions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.GeoRegion] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GeoRegion]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["GeoRegion"], + **kwargs + ): + super(GeoRegionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class GitHub(ProxyOnlyResource): + """GitHub. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["ClientRegistration"] = None, + login: Optional["LoginScopes"] = None, + **kwargs + ): + super(GitHub, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + + +class GlobalCsmSkuDescription(msrest.serialization.Model): + """A Global SKU Description. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service Tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_09_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[str] = None, + size: Optional[str] = None, + family: Optional[str] = None, + capacity: Optional["SkuCapacity"] = None, + locations: Optional[List[str]] = None, + capabilities: Optional[List["Capability"]] = None, + **kwargs + ): + super(GlobalCsmSkuDescription, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.size = size + self.family = family + self.capacity = capacity + self.locations = locations + self.capabilities = capabilities + + +class GlobalValidation(ProxyOnlyResource): + """GlobalValidation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param require_authentication: + :type require_authentication: bool + :param unauthenticated_client_action: Possible values include: "RedirectToLoginPage", + "AllowAnonymous", "Return401", "Return403". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_09_01.models.UnauthenticatedClientActionV2 + :param redirect_to_provider: + :type redirect_to_provider: str + :param excluded_paths: + :type excluded_paths: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'require_authentication': {'key': 'properties.requireAuthentication', 'type': 'bool'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'redirect_to_provider': {'key': 'properties.redirectToProvider', 'type': 'str'}, + 'excluded_paths': {'key': 'properties.excludedPaths', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + require_authentication: Optional[bool] = None, + unauthenticated_client_action: Optional[Union[str, "UnauthenticatedClientActionV2"]] = None, + redirect_to_provider: Optional[str] = None, + excluded_paths: Optional[List[str]] = None, + **kwargs + ): + super(GlobalValidation, self).__init__(kind=kind, **kwargs) + self.require_authentication = require_authentication + self.unauthenticated_client_action = unauthenticated_client_action + self.redirect_to_provider = redirect_to_provider + self.excluded_paths = excluded_paths + + +class Google(ProxyOnlyResource): + """Google. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.ClientRegistration + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.LoginScopes + :param validation: + :type validation: ~azure.mgmt.web.v2020_09_01.models.AllowedAudiencesValidation + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'ClientRegistration'}, + 'login': {'key': 'properties.login', 'type': 'LoginScopes'}, + 'validation': {'key': 'properties.validation', 'type': 'AllowedAudiencesValidation'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["ClientRegistration"] = None, + login: Optional["LoginScopes"] = None, + validation: Optional["AllowedAudiencesValidation"] = None, + **kwargs + ): + super(Google, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + self.login = login + self.validation = validation + + +class HandlerMapping(msrest.serialization.Model): + """The IIS handler mappings used to define which handler processes HTTP requests with certain extension. +For example, it is used to configure php-cgi.exe process to handle all HTTP requests with *.php extension. + + :param extension: Requests with this extension will be handled using the specified FastCGI + application. + :type extension: str + :param script_processor: The absolute path to the FastCGI application. + :type script_processor: str + :param arguments: Command-line arguments to be passed to the script processor. + :type arguments: str + """ + + _attribute_map = { + 'extension': {'key': 'extension', 'type': 'str'}, + 'script_processor': {'key': 'scriptProcessor', 'type': 'str'}, + 'arguments': {'key': 'arguments', 'type': 'str'}, + } + + def __init__( + self, + *, + extension: Optional[str] = None, + script_processor: Optional[str] = None, + arguments: Optional[str] = None, + **kwargs + ): + super(HandlerMapping, self).__init__(**kwargs) + self.extension = extension + self.script_processor = script_processor + self.arguments = arguments + + +class HostingEnvironmentDeploymentInfo(msrest.serialization.Model): + """Information needed to create resources on an App Service Environment. + + :param name: Name of the App Service Environment. + :type name: str + :param location: Location of the App Service Environment. + :type location: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + location: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentDeploymentInfo, self).__init__(**kwargs) + self.name = name + self.location = location + + +class HostingEnvironmentDiagnostics(msrest.serialization.Model): + """Diagnostics for an App Service Environment. + + :param name: Name/identifier of the diagnostics. + :type name: str + :param diagnostics_output: Diagnostics output. + :type diagnostics_output: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'diagnostics_output': {'key': 'diagnosticsOutput', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + diagnostics_output: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentDiagnostics, self).__init__(**kwargs) + self.name = name + self.diagnostics_output = diagnostics_output + + +class HostingEnvironmentProfile(msrest.serialization.Model): + """Specification for an App Service Environment to use for this resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource ID of the App Service Environment. + :type id: str + :ivar name: Name of the App Service Environment. + :vartype name: str + :ivar type: Resource type of the App Service Environment. + :vartype type: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(HostingEnvironmentProfile, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + + +class HostKeys(msrest.serialization.Model): + """Functions host level keys. + + :param master_key: Secret key. + :type master_key: str + :param function_keys: Host level function keys. + :type function_keys: dict[str, str] + :param system_keys: System keys. + :type system_keys: dict[str, str] + """ + + _attribute_map = { + 'master_key': {'key': 'masterKey', 'type': 'str'}, + 'function_keys': {'key': 'functionKeys', 'type': '{str}'}, + 'system_keys': {'key': 'systemKeys', 'type': '{str}'}, + } + + def __init__( + self, + *, + master_key: Optional[str] = None, + function_keys: Optional[Dict[str, str]] = None, + system_keys: Optional[Dict[str, str]] = None, + **kwargs + ): + super(HostKeys, self).__init__(**kwargs) + self.master_key = master_key + self.function_keys = function_keys + self.system_keys = system_keys + + +class HostName(msrest.serialization.Model): + """Details of a hostname derived from a domain. + + :param name: Name of the hostname. + :type name: str + :param site_names: List of apps the hostname is assigned to. This list will have more than one + app only if the hostname is pointing to a Traffic Manager. + :type site_names: list[str] + :param azure_resource_name: Name of the Azure resource the hostname is assigned to. If it is + assigned to a Traffic Manager then it will be the Traffic Manager name otherwise it will be the + app name. + :type azure_resource_name: str + :param azure_resource_type: Type of the Azure resource the hostname is assigned to. Possible + values include: "Website", "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_09_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Type of the DNS record. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_09_01.models.CustomHostNameDnsRecordType + :param host_name_type: Type of the hostname. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_09_01.models.HostNameType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'site_names': {'key': 'siteNames', 'type': '[str]'}, + 'azure_resource_name': {'key': 'azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'hostNameType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + site_names: Optional[List[str]] = None, + azure_resource_name: Optional[str] = None, + azure_resource_type: Optional[Union[str, "AzureResourceType"]] = None, + custom_host_name_dns_record_type: Optional[Union[str, "CustomHostNameDnsRecordType"]] = None, + host_name_type: Optional[Union[str, "HostNameType"]] = None, + **kwargs + ): + super(HostName, self).__init__(**kwargs) + self.name = name + self.site_names = site_names + self.azure_resource_name = azure_resource_name + self.azure_resource_type = azure_resource_type + self.custom_host_name_dns_record_type = custom_host_name_dns_record_type + self.host_name_type = host_name_type + + +class HostNameBinding(ProxyOnlyResource): + """A hostname binding object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param site_name: App Service app name. + :type site_name: str + :param domain_id: Fully qualified ARM domain resource URI. + :type domain_id: str + :param azure_resource_name: Azure resource name. + :type azure_resource_name: str + :param azure_resource_type: Azure resource type. Possible values include: "Website", + "TrafficManager". + :type azure_resource_type: str or ~azure.mgmt.web.v2020_09_01.models.AzureResourceType + :param custom_host_name_dns_record_type: Custom DNS record type. Possible values include: + "CName", "A". + :type custom_host_name_dns_record_type: str or + ~azure.mgmt.web.v2020_09_01.models.CustomHostNameDnsRecordType + :param host_name_type: Hostname type. Possible values include: "Verified", "Managed". + :type host_name_type: str or ~azure.mgmt.web.v2020_09_01.models.HostNameType + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_09_01.models.SslState + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :ivar virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :vartype virtual_ip: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'virtual_ip': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'domain_id': {'key': 'properties.domainId', 'type': 'str'}, + 'azure_resource_name': {'key': 'properties.azureResourceName', 'type': 'str'}, + 'azure_resource_type': {'key': 'properties.azureResourceType', 'type': 'str'}, + 'custom_host_name_dns_record_type': {'key': 'properties.customHostNameDnsRecordType', 'type': 'str'}, + 'host_name_type': {'key': 'properties.hostNameType', 'type': 'str'}, + 'ssl_state': {'key': 'properties.sslState', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + 'virtual_ip': {'key': 'properties.virtualIP', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + site_name: Optional[str] = None, + domain_id: Optional[str] = None, + azure_resource_name: Optional[str] = None, + azure_resource_type: Optional[Union[str, "AzureResourceType"]] = None, + custom_host_name_dns_record_type: Optional[Union[str, "CustomHostNameDnsRecordType"]] = None, + host_name_type: Optional[Union[str, "HostNameType"]] = None, + ssl_state: Optional[Union[str, "SslState"]] = None, + thumbprint: Optional[str] = None, + **kwargs + ): + super(HostNameBinding, self).__init__(kind=kind, **kwargs) + self.site_name = site_name + self.domain_id = domain_id + self.azure_resource_name = azure_resource_name + self.azure_resource_type = azure_resource_type + self.custom_host_name_dns_record_type = custom_host_name_dns_record_type + self.host_name_type = host_name_type + self.ssl_state = ssl_state + self.thumbprint = thumbprint + self.virtual_ip = None + + +class HostNameBindingCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.HostNameBinding] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HostNameBinding]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["HostNameBinding"], + **kwargs + ): + super(HostNameBindingCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class HostNameSslState(msrest.serialization.Model): + """SSL-enabled hostname. + + :param name: Hostname. + :type name: str + :param ssl_state: SSL type. Possible values include: "Disabled", "SniEnabled", + "IpBasedEnabled". + :type ssl_state: str or ~azure.mgmt.web.v2020_09_01.models.SslState + :param virtual_ip: Virtual IP address assigned to the hostname if IP based SSL is enabled. + :type virtual_ip: str + :param thumbprint: SSL certificate thumbprint. + :type thumbprint: str + :param to_update: Set to :code:`true` to update existing hostname. + :type to_update: bool + :param host_type: Indicates whether the hostname is a standard or repository hostname. Possible + values include: "Standard", "Repository". + :type host_type: str or ~azure.mgmt.web.v2020_09_01.models.HostType + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'ssl_state': {'key': 'sslState', 'type': 'str'}, + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'to_update': {'key': 'toUpdate', 'type': 'bool'}, + 'host_type': {'key': 'hostType', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + ssl_state: Optional[Union[str, "SslState"]] = None, + virtual_ip: Optional[str] = None, + thumbprint: Optional[str] = None, + to_update: Optional[bool] = None, + host_type: Optional[Union[str, "HostType"]] = None, + **kwargs + ): + super(HostNameSslState, self).__init__(**kwargs) + self.name = name + self.ssl_state = ssl_state + self.virtual_ip = virtual_ip + self.thumbprint = thumbprint + self.to_update = to_update + self.host_type = host_type + + +class HttpLogsConfig(msrest.serialization.Model): + """Http logs configuration. + + :param file_system: Http logs to file system configuration. + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemHttpLogsConfig + :param azure_blob_storage: Http logs to azure blob storage configuration. + :type azure_blob_storage: ~azure.mgmt.web.v2020_09_01.models.AzureBlobStorageHttpLogsConfig + """ + + _attribute_map = { + 'file_system': {'key': 'fileSystem', 'type': 'FileSystemHttpLogsConfig'}, + 'azure_blob_storage': {'key': 'azureBlobStorage', 'type': 'AzureBlobStorageHttpLogsConfig'}, + } + + def __init__( + self, + *, + file_system: Optional["FileSystemHttpLogsConfig"] = None, + azure_blob_storage: Optional["AzureBlobStorageHttpLogsConfig"] = None, + **kwargs + ): + super(HttpLogsConfig, self).__init__(**kwargs) + self.file_system = file_system + self.azure_blob_storage = azure_blob_storage + + +class HttpSettings(ProxyOnlyResource): + """HttpSettings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param require_https: + :type require_https: bool + :param routes: + :type routes: ~azure.mgmt.web.v2020_09_01.models.HttpSettingsRoutes + :param forward_proxy: + :type forward_proxy: ~azure.mgmt.web.v2020_09_01.models.ForwardProxy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'require_https': {'key': 'properties.requireHttps', 'type': 'bool'}, + 'routes': {'key': 'properties.routes', 'type': 'HttpSettingsRoutes'}, + 'forward_proxy': {'key': 'properties.forwardProxy', 'type': 'ForwardProxy'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + require_https: Optional[bool] = None, + routes: Optional["HttpSettingsRoutes"] = None, + forward_proxy: Optional["ForwardProxy"] = None, + **kwargs + ): + super(HttpSettings, self).__init__(kind=kind, **kwargs) + self.require_https = require_https + self.routes = routes + self.forward_proxy = forward_proxy + + +class HttpSettingsRoutes(ProxyOnlyResource): + """HttpSettingsRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param api_prefix: + :type api_prefix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'api_prefix': {'key': 'properties.apiPrefix', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + api_prefix: Optional[str] = None, + **kwargs + ): + super(HttpSettingsRoutes, self).__init__(kind=kind, **kwargs) + self.api_prefix = api_prefix + + +class HybridConnection(ProxyOnlyResource): + """Hybrid Connection contract. This is used to configure a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param service_bus_namespace: The name of the Service Bus namespace. + :type service_bus_namespace: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :param relay_arm_uri: The ARM URI to the Service Bus relay. + :type relay_arm_uri: str + :param hostname: The hostname of the endpoint. + :type hostname: str + :param port: The port of the endpoint. + :type port: int + :param send_key_name: The name of the Service Bus key which has Send permissions. This is used + to authenticate to Service Bus. + :type send_key_name: str + :param send_key_value: The value of the Service Bus key. This is used to authenticate to + Service Bus. In ARM this key will not be returned + normally, use the POST /listKeys API instead. + :type send_key_value: str + :param service_bus_suffix: The suffix for the service bus endpoint. By default this is + .servicebus.windows.net. + :type service_bus_suffix: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'service_bus_namespace': {'key': 'properties.serviceBusNamespace', 'type': 'str'}, + 'relay_name': {'key': 'properties.relayName', 'type': 'str'}, + 'relay_arm_uri': {'key': 'properties.relayArmUri', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + 'service_bus_suffix': {'key': 'properties.serviceBusSuffix', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + service_bus_namespace: Optional[str] = None, + relay_name: Optional[str] = None, + relay_arm_uri: Optional[str] = None, + hostname: Optional[str] = None, + port: Optional[int] = None, + send_key_name: Optional[str] = None, + send_key_value: Optional[str] = None, + service_bus_suffix: Optional[str] = None, + **kwargs + ): + super(HybridConnection, self).__init__(kind=kind, **kwargs) + self.service_bus_namespace = service_bus_namespace + self.relay_name = relay_name + self.relay_arm_uri = relay_arm_uri + self.hostname = hostname + self.port = port + self.send_key_name = send_key_name + self.send_key_value = send_key_value + self.service_bus_suffix = service_bus_suffix + + +class HybridConnectionCollection(msrest.serialization.Model): + """Collection of hostname bindings. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.HybridConnection] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[HybridConnection]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["HybridConnection"], + **kwargs + ): + super(HybridConnectionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class HybridConnectionKey(ProxyOnlyResource): + """Hybrid Connection key contract. This has the send key name and value for a Hybrid Connection. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar send_key_name: The name of the send key. + :vartype send_key_name: str + :ivar send_key_value: The value of the send key. + :vartype send_key_value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'send_key_name': {'readonly': True}, + 'send_key_value': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'send_key_name': {'key': 'properties.sendKeyName', 'type': 'str'}, + 'send_key_value': {'key': 'properties.sendKeyValue', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(HybridConnectionKey, self).__init__(kind=kind, **kwargs) + self.send_key_name = None + self.send_key_value = None + + +class HybridConnectionLimits(ProxyOnlyResource): + """Hybrid Connection limits contract. This is used to return the plan limits of Hybrid Connections. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar current: The current number of Hybrid Connections. + :vartype current: int + :ivar maximum: The maximum number of Hybrid Connections allowed. + :vartype maximum: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'current': {'readonly': True}, + 'maximum': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'current': {'key': 'properties.current', 'type': 'int'}, + 'maximum': {'key': 'properties.maximum', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(HybridConnectionLimits, self).__init__(kind=kind, **kwargs) + self.current = None + self.maximum = None + + +class Identifier(ProxyOnlyResource): + """A domain specific resource identifier. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param value: String representation of the identity. + :type value: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'value': {'key': 'properties.id', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(Identifier, self).__init__(kind=kind, **kwargs) + self.value = value + + +class IdentifierCollection(msrest.serialization.Model): + """Collection of identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Identifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Identifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Identifier"], + **kwargs + ): + super(IdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class IdentityProviders(ProxyOnlyResource): + """IdentityProviders. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param azure_active_directory: + :type azure_active_directory: ~azure.mgmt.web.v2020_09_01.models.AzureActiveDirectory + :param facebook: + :type facebook: ~azure.mgmt.web.v2020_09_01.models.Facebook + :param git_hub: + :type git_hub: ~azure.mgmt.web.v2020_09_01.models.GitHub + :param google: + :type google: ~azure.mgmt.web.v2020_09_01.models.Google + :param twitter: + :type twitter: ~azure.mgmt.web.v2020_09_01.models.Twitter + :param custom_open_id_connect_providers: Dictionary of :code:``. + :type custom_open_id_connect_providers: dict[str, + ~azure.mgmt.web.v2020_09_01.models.CustomOpenIdConnectProvider] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'facebook': {'key': 'properties.facebook', 'type': 'Facebook'}, + 'git_hub': {'key': 'properties.gitHub', 'type': 'GitHub'}, + 'google': {'key': 'properties.google', 'type': 'Google'}, + 'twitter': {'key': 'properties.twitter', 'type': 'Twitter'}, + 'custom_open_id_connect_providers': {'key': 'properties.customOpenIdConnectProviders', 'type': '{CustomOpenIdConnectProvider}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + azure_active_directory: Optional["AzureActiveDirectory"] = None, + facebook: Optional["Facebook"] = None, + git_hub: Optional["GitHub"] = None, + google: Optional["Google"] = None, + twitter: Optional["Twitter"] = None, + custom_open_id_connect_providers: Optional[Dict[str, "CustomOpenIdConnectProvider"]] = None, + **kwargs + ): + super(IdentityProviders, self).__init__(kind=kind, **kwargs) + self.azure_active_directory = azure_active_directory + self.facebook = facebook + self.git_hub = git_hub + self.google = google + self.twitter = twitter + self.custom_open_id_connect_providers = custom_open_id_connect_providers + + +class InboundEnvironmentEndpoint(msrest.serialization.Model): + """The IP Addresses and Ports that require inbound network access to and within the subnet of the App Service Environment. + + :param description: Short text describing the purpose of the network traffic. + :type description: str + :param endpoints: The IP addresses that network traffic will originate from in cidr notation. + :type endpoints: list[str] + :param ports: The ports that network traffic will arrive to the App Service Environment at. + :type ports: list[str] + """ + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[str]'}, + 'ports': {'key': 'ports', 'type': '[str]'}, + } + + def __init__( + self, + *, + description: Optional[str] = None, + endpoints: Optional[List[str]] = None, + ports: Optional[List[str]] = None, + **kwargs + ): + super(InboundEnvironmentEndpoint, self).__init__(**kwargs) + self.description = description + self.endpoints = endpoints + self.ports = ports + + +class InboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Inbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.InboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[InboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["InboundEnvironmentEndpoint"], + **kwargs + ): + super(InboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class IpSecurityRestriction(msrest.serialization.Model): + """IP security restriction on an app. + + :param ip_address: IP address the security restriction is valid for. + It can be in form of pure ipv4 address (required SubnetMask property) or + CIDR notation such as ipv4/mask (leading bit match). For CIDR, + SubnetMask property must not be specified. + :type ip_address: str + :param subnet_mask: Subnet mask for the range of IP addresses the restriction is valid for. + :type subnet_mask: str + :param vnet_subnet_resource_id: Virtual network resource id. + :type vnet_subnet_resource_id: str + :param vnet_traffic_tag: (internal) Vnet traffic tag. + :type vnet_traffic_tag: int + :param subnet_traffic_tag: (internal) Subnet traffic tag. + :type subnet_traffic_tag: int + :param action: Allow or Deny access for this IP range. + :type action: str + :param tag: Defines what this IP filter will be used for. This is to support IP filtering on + proxies. Possible values include: "Default", "XffProxy", "ServiceTag". + :type tag: str or ~azure.mgmt.web.v2020_09_01.models.IpFilterTag + :param priority: Priority of IP restriction rule. + :type priority: int + :param name: IP restriction rule name. + :type name: str + :param description: IP restriction rule description. + :type description: str + :param headers: IP restriction rule headers. + X-Forwarded-Host (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + Host#Examples). + The matching logic is .. + + + * If the property is null or empty (default), all hosts(or lack of) are allowed. + * A value is compared using ordinal-ignore-case (excluding port number). + * Subdomain wildcards are permitted but don't match the root domain. For example, + *.contoso.com matches the subdomain foo.contoso.com + but not the root domain contoso.com or multi-level foo.bar.contoso.com + * Unicode host names are allowed but are converted to Punycode for matching. + + X-Forwarded-For (https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded- + For#Examples). + The matching logic is .. + + + * If the property is null or empty (default), any forwarded-for chains (or lack of) are + allowed. + * If any address (excluding port number) in the chain (comma separated) matches the CIDR + defined by the property. + + X-Azure-FDID and X-FD-HealthProbe. + The matching logic is exact match. + :type headers: dict[str, list[str]] + """ + + _attribute_map = { + 'ip_address': {'key': 'ipAddress', 'type': 'str'}, + 'subnet_mask': {'key': 'subnetMask', 'type': 'str'}, + 'vnet_subnet_resource_id': {'key': 'vnetSubnetResourceId', 'type': 'str'}, + 'vnet_traffic_tag': {'key': 'vnetTrafficTag', 'type': 'int'}, + 'subnet_traffic_tag': {'key': 'subnetTrafficTag', 'type': 'int'}, + 'action': {'key': 'action', 'type': 'str'}, + 'tag': {'key': 'tag', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'headers': {'key': 'headers', 'type': '{[str]}'}, + } + + def __init__( + self, + *, + ip_address: Optional[str] = None, + subnet_mask: Optional[str] = None, + vnet_subnet_resource_id: Optional[str] = None, + vnet_traffic_tag: Optional[int] = None, + subnet_traffic_tag: Optional[int] = None, + action: Optional[str] = None, + tag: Optional[Union[str, "IpFilterTag"]] = None, + priority: Optional[int] = None, + name: Optional[str] = None, + description: Optional[str] = None, + headers: Optional[Dict[str, List[str]]] = None, + **kwargs + ): + super(IpSecurityRestriction, self).__init__(**kwargs) + self.ip_address = ip_address + self.subnet_mask = subnet_mask + self.vnet_subnet_resource_id = vnet_subnet_resource_id + self.vnet_traffic_tag = vnet_traffic_tag + self.subnet_traffic_tag = subnet_traffic_tag + self.action = action + self.tag = tag + self.priority = priority + self.name = name + self.description = description + self.headers = headers + + +class JwtClaimChecks(ProxyOnlyResource): + """JwtClaimChecks. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param allowed_groups: + :type allowed_groups: list[str] + :param allowed_client_applications: + :type allowed_client_applications: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'allowed_groups': {'key': 'properties.allowedGroups', 'type': '[str]'}, + 'allowed_client_applications': {'key': 'properties.allowedClientApplications', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + allowed_groups: Optional[List[str]] = None, + allowed_client_applications: Optional[List[str]] = None, + **kwargs + ): + super(JwtClaimChecks, self).__init__(kind=kind, **kwargs) + self.allowed_groups = allowed_groups + self.allowed_client_applications = allowed_client_applications + + +class KeyInfo(msrest.serialization.Model): + """Function key info. + + :param name: Key name. + :type name: str + :param value: Key value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(KeyInfo, self).__init__(**kwargs) + self.name = name + self.value = value + + +class LocalizableString(msrest.serialization.Model): + """Localizable string object containing the name and a localized value. + + :param value: Non-localized name. + :type value: str + :param localized_value: Localized name. + :type localized_value: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'str'}, + 'localized_value': {'key': 'localizedValue', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[str] = None, + localized_value: Optional[str] = None, + **kwargs + ): + super(LocalizableString, self).__init__(**kwargs) + self.value = value + self.localized_value = localized_value + + +class Login(ProxyOnlyResource): + """Login. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param routes: + :type routes: ~azure.mgmt.web.v2020_09_01.models.LoginRoutes + :param token_store: + :type token_store: ~azure.mgmt.web.v2020_09_01.models.TokenStore + :param preserve_url_fragments_for_logins: + :type preserve_url_fragments_for_logins: bool + :param allowed_external_redirect_urls: + :type allowed_external_redirect_urls: list[str] + :param cookie_expiration: + :type cookie_expiration: ~azure.mgmt.web.v2020_09_01.models.CookieExpiration + :param nonce: + :type nonce: ~azure.mgmt.web.v2020_09_01.models.Nonce + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'routes': {'key': 'properties.routes', 'type': 'LoginRoutes'}, + 'token_store': {'key': 'properties.tokenStore', 'type': 'TokenStore'}, + 'preserve_url_fragments_for_logins': {'key': 'properties.preserveUrlFragmentsForLogins', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'cookie_expiration': {'key': 'properties.cookieExpiration', 'type': 'CookieExpiration'}, + 'nonce': {'key': 'properties.nonce', 'type': 'Nonce'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + routes: Optional["LoginRoutes"] = None, + token_store: Optional["TokenStore"] = None, + preserve_url_fragments_for_logins: Optional[bool] = None, + allowed_external_redirect_urls: Optional[List[str]] = None, + cookie_expiration: Optional["CookieExpiration"] = None, + nonce: Optional["Nonce"] = None, + **kwargs + ): + super(Login, self).__init__(kind=kind, **kwargs) + self.routes = routes + self.token_store = token_store + self.preserve_url_fragments_for_logins = preserve_url_fragments_for_logins + self.allowed_external_redirect_urls = allowed_external_redirect_urls + self.cookie_expiration = cookie_expiration + self.nonce = nonce + + +class LoginRoutes(ProxyOnlyResource): + """LoginRoutes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param logout_endpoint: + :type logout_endpoint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'logout_endpoint': {'key': 'properties.logoutEndpoint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + logout_endpoint: Optional[str] = None, + **kwargs + ): + super(LoginRoutes, self).__init__(kind=kind, **kwargs) + self.logout_endpoint = logout_endpoint + + +class LoginScopes(ProxyOnlyResource): + """LoginScopes. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + scopes: Optional[List[str]] = None, + **kwargs + ): + super(LoginScopes, self).__init__(kind=kind, **kwargs) + self.scopes = scopes + + +class LogSpecification(msrest.serialization.Model): + """Log Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param blob_duration: + :type blob_duration: str + :param log_filter_pattern: + :type log_filter_pattern: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + 'log_filter_pattern': {'key': 'logFilterPattern', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + blob_duration: Optional[str] = None, + log_filter_pattern: Optional[str] = None, + **kwargs + ): + super(LogSpecification, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.blob_duration = blob_duration + self.log_filter_pattern = log_filter_pattern + + +class ManagedServiceIdentity(msrest.serialization.Model): + """Managed service identity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param type: Type of managed service identity. Possible values include: "SystemAssigned", + "UserAssigned", "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentityType + :ivar tenant_id: Tenant of managed service identity. + :vartype tenant_id: str + :ivar principal_id: Principal Id of managed service identity. + :vartype principal_id: str + :param user_assigned_identities: The list of user assigned identities associated with the + resource. The user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. + :type user_assigned_identities: dict[str, + ~azure.mgmt.web.v2020_09_01.models.Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties] + """ + + _validation = { + 'tenant_id': {'readonly': True}, + 'principal_id': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties}'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ManagedServiceIdentityType"]] = None, + user_assigned_identities: Optional[Dict[str, "Components1Jq1T4ISchemasManagedserviceidentityPropertiesUserassignedidentitiesAdditionalproperties"]] = None, + **kwargs + ): + super(ManagedServiceIdentity, self).__init__(**kwargs) + self.type = type + self.tenant_id = None + self.principal_id = None + self.user_assigned_identities = user_assigned_identities + + +class MetricAvailability(msrest.serialization.Model): + """Retention policy of a resource metric. + + :param time_grain: + :type time_grain: str + :param blob_duration: + :type blob_duration: str + """ + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'blob_duration': {'key': 'blobDuration', 'type': 'str'}, + } + + def __init__( + self, + *, + time_grain: Optional[str] = None, + blob_duration: Optional[str] = None, + **kwargs + ): + super(MetricAvailability, self).__init__(**kwargs) + self.time_grain = time_grain + self.blob_duration = blob_duration + + +class MetricSpecification(msrest.serialization.Model): + """Definition of a single resource metric. + + :param name: + :type name: str + :param display_name: + :type display_name: str + :param display_description: + :type display_description: str + :param unit: + :type unit: str + :param aggregation_type: + :type aggregation_type: str + :param supports_instance_level_aggregation: + :type supports_instance_level_aggregation: bool + :param enable_regional_mdm_account: + :type enable_regional_mdm_account: bool + :param source_mdm_account: + :type source_mdm_account: str + :param source_mdm_namespace: + :type source_mdm_namespace: str + :param metric_filter_pattern: + :type metric_filter_pattern: str + :param fill_gap_with_zero: + :type fill_gap_with_zero: bool + :param is_internal: + :type is_internal: bool + :param dimensions: + :type dimensions: list[~azure.mgmt.web.v2020_09_01.models.Dimension] + :param category: + :type category: str + :param availabilities: + :type availabilities: list[~azure.mgmt.web.v2020_09_01.models.MetricAvailability] + :param supported_time_grain_types: + :type supported_time_grain_types: list[str] + :param supported_aggregation_types: + :type supported_aggregation_types: list[str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'display_description': {'key': 'displayDescription', 'type': 'str'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'aggregation_type': {'key': 'aggregationType', 'type': 'str'}, + 'supports_instance_level_aggregation': {'key': 'supportsInstanceLevelAggregation', 'type': 'bool'}, + 'enable_regional_mdm_account': {'key': 'enableRegionalMdmAccount', 'type': 'bool'}, + 'source_mdm_account': {'key': 'sourceMdmAccount', 'type': 'str'}, + 'source_mdm_namespace': {'key': 'sourceMdmNamespace', 'type': 'str'}, + 'metric_filter_pattern': {'key': 'metricFilterPattern', 'type': 'str'}, + 'fill_gap_with_zero': {'key': 'fillGapWithZero', 'type': 'bool'}, + 'is_internal': {'key': 'isInternal', 'type': 'bool'}, + 'dimensions': {'key': 'dimensions', 'type': '[Dimension]'}, + 'category': {'key': 'category', 'type': 'str'}, + 'availabilities': {'key': 'availabilities', 'type': '[MetricAvailability]'}, + 'supported_time_grain_types': {'key': 'supportedTimeGrainTypes', 'type': '[str]'}, + 'supported_aggregation_types': {'key': 'supportedAggregationTypes', 'type': '[str]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display_name: Optional[str] = None, + display_description: Optional[str] = None, + unit: Optional[str] = None, + aggregation_type: Optional[str] = None, + supports_instance_level_aggregation: Optional[bool] = None, + enable_regional_mdm_account: Optional[bool] = None, + source_mdm_account: Optional[str] = None, + source_mdm_namespace: Optional[str] = None, + metric_filter_pattern: Optional[str] = None, + fill_gap_with_zero: Optional[bool] = None, + is_internal: Optional[bool] = None, + dimensions: Optional[List["Dimension"]] = None, + category: Optional[str] = None, + availabilities: Optional[List["MetricAvailability"]] = None, + supported_time_grain_types: Optional[List[str]] = None, + supported_aggregation_types: Optional[List[str]] = None, + **kwargs + ): + super(MetricSpecification, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.display_description = display_description + self.unit = unit + self.aggregation_type = aggregation_type + self.supports_instance_level_aggregation = supports_instance_level_aggregation + self.enable_regional_mdm_account = enable_regional_mdm_account + self.source_mdm_account = source_mdm_account + self.source_mdm_namespace = source_mdm_namespace + self.metric_filter_pattern = metric_filter_pattern + self.fill_gap_with_zero = fill_gap_with_zero + self.is_internal = is_internal + self.dimensions = dimensions + self.category = category + self.availabilities = availabilities + self.supported_time_grain_types = supported_time_grain_types + self.supported_aggregation_types = supported_aggregation_types + + +class MigrateMySqlRequest(ProxyOnlyResource): + """MySQL migration request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param connection_string: Connection string to the remote MySQL database. + :type connection_string: str + :param migration_type: The type of migration operation to be done. Possible values include: + "LocalToRemote", "RemoteToLocal". + :type migration_type: str or ~azure.mgmt.web.v2020_09_01.models.MySqlMigrationType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'migration_type': {'key': 'properties.migrationType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + connection_string: Optional[str] = None, + migration_type: Optional[Union[str, "MySqlMigrationType"]] = None, + **kwargs + ): + super(MigrateMySqlRequest, self).__init__(kind=kind, **kwargs) + self.connection_string = connection_string + self.migration_type = migration_type + + +class MigrateMySqlStatus(ProxyOnlyResource): + """MySQL migration status. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar migration_operation_status: Status of the migration task. Possible values include: + "InProgress", "Failed", "Succeeded", "TimedOut", "Created". + :vartype migration_operation_status: str or ~azure.mgmt.web.v2020_09_01.models.OperationStatus + :ivar operation_id: Operation ID for the migration task. + :vartype operation_id: str + :ivar local_my_sql_enabled: True if the web app has in app MySql enabled. + :vartype local_my_sql_enabled: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'migration_operation_status': {'readonly': True}, + 'operation_id': {'readonly': True}, + 'local_my_sql_enabled': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'migration_operation_status': {'key': 'properties.migrationOperationStatus', 'type': 'str'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MigrateMySqlStatus, self).__init__(kind=kind, **kwargs) + self.migration_operation_status = None + self.operation_id = None + self.local_my_sql_enabled = None + + +class MSDeploy(ProxyOnlyResource): + """MSDeploy ARM PUT information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param package_uri: Package URI. + :type package_uri: str + :param connection_string: SQL Connection String. + :type connection_string: str + :param db_type: Database Type. + :type db_type: str + :param set_parameters_xml_file_uri: URI of MSDeploy Parameters file. Must not be set if + SetParameters is used. + :type set_parameters_xml_file_uri: str + :param set_parameters: MSDeploy Parameters. Must not be set if SetParametersXmlFileUri is used. + :type set_parameters: dict[str, str] + :param skip_app_data: Controls whether the MSDeploy operation skips the App_Data directory. + If set to :code:`true`, the existing App_Data directory on the destination + will not be deleted, and any App_Data directory in the source will be ignored. + Setting is :code:`false` by default. + :type skip_app_data: bool + :param app_offline: Sets the AppOffline rule while the MSDeploy operation executes. + Setting is :code:`false` by default. + :type app_offline: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'package_uri': {'key': 'properties.packageUri', 'type': 'str'}, + 'connection_string': {'key': 'properties.connectionString', 'type': 'str'}, + 'db_type': {'key': 'properties.dbType', 'type': 'str'}, + 'set_parameters_xml_file_uri': {'key': 'properties.setParametersXmlFileUri', 'type': 'str'}, + 'set_parameters': {'key': 'properties.setParameters', 'type': '{str}'}, + 'skip_app_data': {'key': 'properties.skipAppData', 'type': 'bool'}, + 'app_offline': {'key': 'properties.appOffline', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + package_uri: Optional[str] = None, + connection_string: Optional[str] = None, + db_type: Optional[str] = None, + set_parameters_xml_file_uri: Optional[str] = None, + set_parameters: Optional[Dict[str, str]] = None, + skip_app_data: Optional[bool] = None, + app_offline: Optional[bool] = None, + **kwargs + ): + super(MSDeploy, self).__init__(kind=kind, **kwargs) + self.package_uri = package_uri + self.connection_string = connection_string + self.db_type = db_type + self.set_parameters_xml_file_uri = set_parameters_xml_file_uri + self.set_parameters = set_parameters + self.skip_app_data = skip_app_data + self.app_offline = app_offline + + +class MSDeployLog(ProxyOnlyResource): + """MSDeploy log. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar entries: List of log entry messages. + :vartype entries: list[~azure.mgmt.web.v2020_09_01.models.MSDeployLogEntry] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'entries': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'entries': {'key': 'properties.entries', 'type': '[MSDeployLogEntry]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MSDeployLog, self).__init__(kind=kind, **kwargs) + self.entries = None + + +class MSDeployLogEntry(msrest.serialization.Model): + """MSDeploy log entry. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time: Timestamp of log entry. + :vartype time: ~datetime.datetime + :ivar type: Log entry type. Possible values include: "Message", "Warning", "Error". + :vartype type: str or ~azure.mgmt.web.v2020_09_01.models.MSDeployLogEntryType + :ivar message: Log entry message. + :vartype message: str + """ + + _validation = { + 'time': {'readonly': True}, + 'type': {'readonly': True}, + 'message': {'readonly': True}, + } + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'type': {'key': 'type', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(MSDeployLogEntry, self).__init__(**kwargs) + self.time = None + self.type = None + self.message = None + + +class MSDeployStatus(ProxyOnlyResource): + """MSDeploy ARM response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar deployer: Username of deployer. + :vartype deployer: str + :ivar provisioning_state: Provisioning state. Possible values include: "accepted", "running", + "succeeded", "failed", "canceled". + :vartype provisioning_state: str or + ~azure.mgmt.web.v2020_09_01.models.MSDeployProvisioningState + :ivar start_time: Start time of deploy operation. + :vartype start_time: ~datetime.datetime + :ivar end_time: End time of deploy operation. + :vartype end_time: ~datetime.datetime + :ivar complete: Whether the deployment operation has completed. + :vartype complete: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'deployer': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'start_time': {'readonly': True}, + 'end_time': {'readonly': True}, + 'complete': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'deployer': {'key': 'properties.deployer', 'type': 'str'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'complete': {'key': 'properties.complete', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(MSDeployStatus, self).__init__(kind=kind, **kwargs) + self.deployer = None + self.provisioning_state = None + self.start_time = None + self.end_time = None + self.complete = None + + +class NameIdentifier(msrest.serialization.Model): + """Identifies an object. + + :param name: Name of the object. + :type name: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + **kwargs + ): + super(NameIdentifier, self).__init__(**kwargs) + self.name = name + + +class NameIdentifierCollection(msrest.serialization.Model): + """Collection of domain name identifiers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.NameIdentifier] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NameIdentifier]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["NameIdentifier"], + **kwargs + ): + super(NameIdentifierCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class NameValuePair(msrest.serialization.Model): + """Name value pair. + + :param name: Pair name. + :type name: str + :param value: Pair value. + :type value: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + value: Optional[str] = None, + **kwargs + ): + super(NameValuePair, self).__init__(**kwargs) + self.name = name + self.value = value + + +class NetworkAccessControlEntry(msrest.serialization.Model): + """Network access control entry. + + :param action: Action object. Possible values include: "Permit", "Deny". + :type action: str or ~azure.mgmt.web.v2020_09_01.models.AccessControlEntryAction + :param description: Description of network access control entry. + :type description: str + :param order: Order of precedence. + :type order: int + :param remote_subnet: Remote subnet. + :type remote_subnet: str + """ + + _attribute_map = { + 'action': {'key': 'action', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'int'}, + 'remote_subnet': {'key': 'remoteSubnet', 'type': 'str'}, + } + + def __init__( + self, + *, + action: Optional[Union[str, "AccessControlEntryAction"]] = None, + description: Optional[str] = None, + order: Optional[int] = None, + remote_subnet: Optional[str] = None, + **kwargs + ): + super(NetworkAccessControlEntry, self).__init__(**kwargs) + self.action = action + self.description = description + self.order = order + self.remote_subnet = remote_subnet + + +class NetworkFeatures(ProxyOnlyResource): + """Full view of network features for an app (presently VNET integration and Hybrid Connections). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar virtual_network_name: The Virtual Network name. + :vartype virtual_network_name: str + :ivar virtual_network_connection: The Virtual Network summary view. + :vartype virtual_network_connection: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :ivar hybrid_connections: The Hybrid Connections summary view. + :vartype hybrid_connections: + list[~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity] + :ivar hybrid_connections_v2: The Hybrid Connection V2 (Service Bus) view. + :vartype hybrid_connections_v2: list[~azure.mgmt.web.v2020_09_01.models.HybridConnection] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'virtual_network_name': {'readonly': True}, + 'virtual_network_connection': {'readonly': True}, + 'hybrid_connections': {'readonly': True}, + 'hybrid_connections_v2': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'virtual_network_name': {'key': 'properties.virtualNetworkName', 'type': 'str'}, + 'virtual_network_connection': {'key': 'properties.virtualNetworkConnection', 'type': 'VnetInfo'}, + 'hybrid_connections': {'key': 'properties.hybridConnections', 'type': '[RelayServiceConnectionEntity]'}, + 'hybrid_connections_v2': {'key': 'properties.hybridConnectionsV2', 'type': '[HybridConnection]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(NetworkFeatures, self).__init__(kind=kind, **kwargs) + self.virtual_network_name = None + self.virtual_network_connection = None + self.hybrid_connections = None + self.hybrid_connections_v2 = None + + +class NetworkTrace(msrest.serialization.Model): + """Network trace. + + :param path: Local file path for the captured network trace file. + :type path: str + :param status: Current status of the network trace operation, same as Operation.Status + (InProgress/Succeeded/Failed). + :type status: str + :param message: Detailed message of a network trace operation, e.g. error message in case of + failure. + :type message: str + """ + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + path: Optional[str] = None, + status: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(NetworkTrace, self).__init__(**kwargs) + self.path = path + self.status = status + self.message = message + + +class Nonce(ProxyOnlyResource): + """Nonce. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param validate_nonce: + :type validate_nonce: bool + :param nonce_expiration_interval: + :type nonce_expiration_interval: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'validate_nonce': {'key': 'properties.validateNonce', 'type': 'bool'}, + 'nonce_expiration_interval': {'key': 'properties.nonceExpirationInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + validate_nonce: Optional[bool] = None, + nonce_expiration_interval: Optional[str] = None, + **kwargs + ): + super(Nonce, self).__init__(kind=kind, **kwargs) + self.validate_nonce = validate_nonce + self.nonce_expiration_interval = nonce_expiration_interval + + +class OpenIdConnectClientCredential(ProxyOnlyResource): + """OpenIdConnectClientCredential. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar method: Default value: "ClientSecretPost". + :vartype method: str + :param client_secret_setting_name: + :type client_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'method': {'constant': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'method': {'key': 'properties.method', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + } + + method = "ClientSecretPost" + + def __init__( + self, + *, + kind: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(OpenIdConnectClientCredential, self).__init__(kind=kind, **kwargs) + self.client_secret_setting_name = client_secret_setting_name + + +class OpenIdConnectConfig(ProxyOnlyResource): + """OpenIdConnectConfig. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param authorization_endpoint: + :type authorization_endpoint: str + :param token_endpoint: + :type token_endpoint: str + :param issuer: + :type issuer: str + :param certification_uri: + :type certification_uri: str + :param well_known_open_id_configuration: + :type well_known_open_id_configuration: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'authorization_endpoint': {'key': 'properties.authorizationEndpoint', 'type': 'str'}, + 'token_endpoint': {'key': 'properties.tokenEndpoint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'certification_uri': {'key': 'properties.certificationUri', 'type': 'str'}, + 'well_known_open_id_configuration': {'key': 'properties.wellKnownOpenIdConfiguration', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + authorization_endpoint: Optional[str] = None, + token_endpoint: Optional[str] = None, + issuer: Optional[str] = None, + certification_uri: Optional[str] = None, + well_known_open_id_configuration: Optional[str] = None, + **kwargs + ): + super(OpenIdConnectConfig, self).__init__(kind=kind, **kwargs) + self.authorization_endpoint = authorization_endpoint + self.token_endpoint = token_endpoint + self.issuer = issuer + self.certification_uri = certification_uri + self.well_known_open_id_configuration = well_known_open_id_configuration + + +class OpenIdConnectLogin(ProxyOnlyResource): + """OpenIdConnectLogin. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param name_claim_type: + :type name_claim_type: str + :param scopes: + :type scopes: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'name_claim_type': {'key': 'properties.nameClaimType', 'type': 'str'}, + 'scopes': {'key': 'properties.scopes', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + name_claim_type: Optional[str] = None, + scopes: Optional[List[str]] = None, + **kwargs + ): + super(OpenIdConnectLogin, self).__init__(kind=kind, **kwargs) + self.name_claim_type = name_claim_type + self.scopes = scopes + + +class OpenIdConnectRegistration(ProxyOnlyResource): + """OpenIdConnectRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param client_id: + :type client_id: str + :param client_credential: + :type client_credential: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectClientCredential + :param open_id_connect_configuration: + :type open_id_connect_configuration: ~azure.mgmt.web.v2020_09_01.models.OpenIdConnectConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_credential': {'key': 'properties.clientCredential', 'type': 'OpenIdConnectClientCredential'}, + 'open_id_connect_configuration': {'key': 'properties.openIdConnectConfiguration', 'type': 'OpenIdConnectConfig'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + client_id: Optional[str] = None, + client_credential: Optional["OpenIdConnectClientCredential"] = None, + open_id_connect_configuration: Optional["OpenIdConnectConfig"] = None, + **kwargs + ): + super(OpenIdConnectRegistration, self).__init__(kind=kind, **kwargs) + self.client_id = client_id + self.client_credential = client_credential + self.open_id_connect_configuration = open_id_connect_configuration + + +class Operation(msrest.serialization.Model): + """An operation on a resource. + + :param id: Operation ID. + :type id: str + :param name: Operation name. + :type name: str + :param status: The current status of the operation. Possible values include: "InProgress", + "Failed", "Succeeded", "TimedOut", "Created". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.OperationStatus + :param errors: Any errors associate with the operation. + :type errors: list[~azure.mgmt.web.v2020_09_01.models.ErrorEntity] + :param created_time: Time when operation has started. + :type created_time: ~datetime.datetime + :param modified_time: Time when operation has been updated. + :type modified_time: ~datetime.datetime + :param expiration_time: Time when operation will expire. + :type expiration_time: ~datetime.datetime + :param geo_master_operation_id: Applicable only for stamp operation ids. + :type geo_master_operation_id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'status': {'key': 'status', 'type': 'str'}, + 'errors': {'key': 'errors', 'type': '[ErrorEntity]'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'modified_time': {'key': 'modifiedTime', 'type': 'iso-8601'}, + 'expiration_time': {'key': 'expirationTime', 'type': 'iso-8601'}, + 'geo_master_operation_id': {'key': 'geoMasterOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + name: Optional[str] = None, + status: Optional[Union[str, "OperationStatus"]] = None, + errors: Optional[List["ErrorEntity"]] = None, + created_time: Optional[datetime.datetime] = None, + modified_time: Optional[datetime.datetime] = None, + expiration_time: Optional[datetime.datetime] = None, + geo_master_operation_id: Optional[str] = None, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.id = id + self.name = name + self.status = status + self.errors = errors + self.created_time = created_time + self.modified_time = modified_time + self.expiration_time = expiration_time + self.geo_master_operation_id = geo_master_operation_id + + +class OutboundEnvironmentEndpoint(msrest.serialization.Model): + """Endpoints accessed for a common purpose that the App Service Environment requires outbound network access to. + + :param category: The type of service accessed by the App Service Environment, e.g., Azure + Storage, Azure SQL Database, and Azure Active Directory. + :type category: str + :param endpoints: The endpoints that the App Service Environment reaches the service at. + :type endpoints: list[~azure.mgmt.web.v2020_09_01.models.EndpointDependency] + """ + + _attribute_map = { + 'category': {'key': 'category', 'type': 'str'}, + 'endpoints': {'key': 'endpoints', 'type': '[EndpointDependency]'}, + } + + def __init__( + self, + *, + category: Optional[str] = None, + endpoints: Optional[List["EndpointDependency"]] = None, + **kwargs + ): + super(OutboundEnvironmentEndpoint, self).__init__(**kwargs) + self.category = category + self.endpoints = endpoints + + +class OutboundEnvironmentEndpointCollection(msrest.serialization.Model): + """Collection of Outbound Environment Endpoints. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.OutboundEnvironmentEndpoint] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OutboundEnvironmentEndpoint]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["OutboundEnvironmentEndpoint"], + **kwargs + ): + super(OutboundEnvironmentEndpointCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PerfMonCounterCollection(msrest.serialization.Model): + """Collection of performance monitor counters. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PerfMonResponse] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PerfMonResponse]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PerfMonResponse"], + **kwargs + ): + super(PerfMonCounterCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PerfMonResponse(msrest.serialization.Model): + """Performance monitor API response. + + :param code: The response code. + :type code: str + :param message: The message. + :type message: str + :param data: The performance monitor counters. + :type data: ~azure.mgmt.web.v2020_09_01.models.PerfMonSet + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'data': {'key': 'data', 'type': 'PerfMonSet'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + data: Optional["PerfMonSet"] = None, + **kwargs + ): + super(PerfMonResponse, self).__init__(**kwargs) + self.code = code + self.message = message + self.data = data + + +class PerfMonSample(msrest.serialization.Model): + """Performance monitor sample in a set. + + :param time: Point in time for which counter was measured. + :type time: ~datetime.datetime + :param instance_name: Name of the server on which the measurement is made. + :type instance_name: str + :param value: Value of counter at a certain time. + :type value: float + """ + + _attribute_map = { + 'time': {'key': 'time', 'type': 'iso-8601'}, + 'instance_name': {'key': 'instanceName', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'float'}, + } + + def __init__( + self, + *, + time: Optional[datetime.datetime] = None, + instance_name: Optional[str] = None, + value: Optional[float] = None, + **kwargs + ): + super(PerfMonSample, self).__init__(**kwargs) + self.time = time + self.instance_name = instance_name + self.value = value + + +class PerfMonSet(msrest.serialization.Model): + """Metric information. + + :param name: Unique key name of the counter. + :type name: str + :param start_time: Start time of the period. + :type start_time: ~datetime.datetime + :param end_time: End time of the period. + :type end_time: ~datetime.datetime + :param time_grain: Presented time grain. + :type time_grain: str + :param values: Collection of workers that are active during this time. + :type values: list[~azure.mgmt.web.v2020_09_01.models.PerfMonSample] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'start_time': {'key': 'startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'endTime', 'type': 'iso-8601'}, + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'values': {'key': 'values', 'type': '[PerfMonSample]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + time_grain: Optional[str] = None, + values: Optional[List["PerfMonSample"]] = None, + **kwargs + ): + super(PerfMonSet, self).__init__(**kwargs) + self.name = name + self.start_time = start_time + self.end_time = end_time + self.time_grain = time_grain + self.values = values + + +class PremierAddOn(Resource): + """Premier add-on. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOn, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PremierAddOnOffer(ProxyOnlyResource): + """Premier add-on offer. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on offer Product. + :type product: str + :param vendor: Premier add on offer Vendor. + :type vendor: str + :param promo_code_required: :code:`true` if promotion code is required; otherwise, + :code:`false`. + :type promo_code_required: bool + :param quota: Premier add on offer Quota. + :type quota: int + :param web_hosting_plan_restrictions: App Service plans this offer is restricted to. Possible + values include: "None", "Free", "Shared", "Basic", "Standard", "Premium". + :type web_hosting_plan_restrictions: str or + ~azure.mgmt.web.v2020_09_01.models.AppServicePlanRestrictions + :param privacy_policy_url: Privacy policy URL. + :type privacy_policy_url: str + :param legal_terms_url: Legal terms URL. + :type legal_terms_url: str + :param marketplace_publisher: Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'promo_code_required': {'key': 'properties.promoCodeRequired', 'type': 'bool'}, + 'quota': {'key': 'properties.quota', 'type': 'int'}, + 'web_hosting_plan_restrictions': {'key': 'properties.webHostingPlanRestrictions', 'type': 'str'}, + 'privacy_policy_url': {'key': 'properties.privacyPolicyUrl', 'type': 'str'}, + 'legal_terms_url': {'key': 'properties.legalTermsUrl', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + promo_code_required: Optional[bool] = None, + quota: Optional[int] = None, + web_hosting_plan_restrictions: Optional[Union[str, "AppServicePlanRestrictions"]] = None, + privacy_policy_url: Optional[str] = None, + legal_terms_url: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOnOffer, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.promo_code_required = promo_code_required + self.quota = quota + self.web_hosting_plan_restrictions = web_hosting_plan_restrictions + self.privacy_policy_url = privacy_policy_url + self.legal_terms_url = legal_terms_url + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PremierAddOnOfferCollection(msrest.serialization.Model): + """Collection of premier add-on offers. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOffer] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PremierAddOnOffer]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PremierAddOnOffer"], + **kwargs + ): + super(PremierAddOnOfferCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PremierAddOnPatchResource(ProxyOnlyResource): + """ARM resource for a PremierAddOn. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Premier add on SKU. + :type sku: str + :param product: Premier add on Product. + :type product: str + :param vendor: Premier add on Vendor. + :type vendor: str + :param marketplace_publisher: Premier add on Marketplace publisher. + :type marketplace_publisher: str + :param marketplace_offer: Premier add on Marketplace offer. + :type marketplace_offer: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'properties.sku', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'vendor': {'key': 'properties.vendor', 'type': 'str'}, + 'marketplace_publisher': {'key': 'properties.marketplacePublisher', 'type': 'str'}, + 'marketplace_offer': {'key': 'properties.marketplaceOffer', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional[str] = None, + product: Optional[str] = None, + vendor: Optional[str] = None, + marketplace_publisher: Optional[str] = None, + marketplace_offer: Optional[str] = None, + **kwargs + ): + super(PremierAddOnPatchResource, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.product = product + self.vendor = vendor + self.marketplace_publisher = marketplace_publisher + self.marketplace_offer = marketplace_offer + + +class PrivateAccess(ProxyOnlyResource): + """Description of the parameters of Private Access for a Web Site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: Whether private access is enabled or not. + :type enabled: bool + :param virtual_networks: The Virtual Networks (and subnets) allowed to access the site + privately. + :type virtual_networks: list[~azure.mgmt.web.v2020_09_01.models.PrivateAccessVirtualNetwork] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'virtual_networks': {'key': 'properties.virtualNetworks', 'type': '[PrivateAccessVirtualNetwork]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + virtual_networks: Optional[List["PrivateAccessVirtualNetwork"]] = None, + **kwargs + ): + super(PrivateAccess, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.virtual_networks = virtual_networks + + +class PrivateAccessSubnet(msrest.serialization.Model): + """Description of a Virtual Network subnet that is useable for private site access. + + :param name: The name of the subnet. + :type name: str + :param key: The key (ID) of the subnet. + :type key: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + key: Optional[int] = None, + **kwargs + ): + super(PrivateAccessSubnet, self).__init__(**kwargs) + self.name = name + self.key = key + + +class PrivateAccessVirtualNetwork(msrest.serialization.Model): + """Description of a Virtual Network that is useable for private site access. + + :param name: The name of the Virtual Network. + :type name: str + :param key: The key (ID) of the Virtual Network. + :type key: int + :param resource_id: The ARM uri of the Virtual Network. + :type resource_id: str + :param subnets: A List of subnets that access is allowed to on this Virtual Network. An empty + array (but not null) is interpreted to mean that all subnets are allowed within this Virtual + Network. + :type subnets: list[~azure.mgmt.web.v2020_09_01.models.PrivateAccessSubnet] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'key': {'key': 'key', 'type': 'int'}, + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'subnets': {'key': 'subnets', 'type': '[PrivateAccessSubnet]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + key: Optional[int] = None, + resource_id: Optional[str] = None, + subnets: Optional[List["PrivateAccessSubnet"]] = None, + **kwargs + ): + super(PrivateAccessVirtualNetwork, self).__init__(**kwargs) + self.name = name + self.key = key + self.resource_id = resource_id + self.subnets = subnets + + +class PrivateEndpointConnectionResource(ProxyOnlyResource): + """Private Endpoint Connection ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar provisioning_state: + :vartype provisioning_state: str + :param private_endpoint: PrivateEndpoint of a remote private endpoint connection. + :type private_endpoint: ~azure.mgmt.web.v2020_09_01.models.ArmIdWrapper + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'private_endpoint': {'key': 'properties.privateEndpoint', 'type': 'ArmIdWrapper'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + private_endpoint: Optional["ArmIdWrapper"] = None, + private_link_service_connection_state: Optional["PrivateLinkConnectionState"] = None, + **kwargs + ): + super(PrivateEndpointConnectionResource, self).__init__(kind=kind, **kwargs) + self.provisioning_state = None + self.private_endpoint = private_endpoint + self.private_link_service_connection_state = private_link_service_connection_state + + +class PrivateLinkConnectionApprovalRequestResource(ProxyOnlyResource): + """Private Endpoint Connection Approval ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param private_link_service_connection_state: The state of a private link connection. + :type private_link_service_connection_state: + ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'private_link_service_connection_state': {'key': 'properties.privateLinkServiceConnectionState', 'type': 'PrivateLinkConnectionState'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + private_link_service_connection_state: Optional["PrivateLinkConnectionState"] = None, + **kwargs + ): + super(PrivateLinkConnectionApprovalRequestResource, self).__init__(kind=kind, **kwargs) + self.private_link_service_connection_state = private_link_service_connection_state + + +class PrivateLinkConnectionState(msrest.serialization.Model): + """The state of a private link connection. + + :param status: Status of a private link connection. + :type status: str + :param description: Description of a private link connection. + :type description: str + :param actions_required: ActionsRequired for a private link connection. + :type actions_required: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'actions_required': {'key': 'actionsRequired', 'type': 'str'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + description: Optional[str] = None, + actions_required: Optional[str] = None, + **kwargs + ): + super(PrivateLinkConnectionState, self).__init__(**kwargs) + self.status = status + self.description = description + self.actions_required = actions_required + + +class PrivateLinkResource(msrest.serialization.Model): + """A private link resource. + + All required parameters must be populated in order to send to Azure. + + :param id: Required. + :type id: str + :param name: Required. Name of a private link resource. + :type name: str + :param type: Required. + :type type: str + :param properties: Required. Properties of a private link resource. + :type properties: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkResourceProperties + """ + + _validation = { + 'id': {'required': True}, + 'name': {'required': True}, + 'type': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'PrivateLinkResourceProperties'}, + } + + def __init__( + self, + *, + id: str, + name: str, + type: str, + properties: "PrivateLinkResourceProperties", + **kwargs + ): + super(PrivateLinkResource, self).__init__(**kwargs) + self.id = id + self.name = name + self.type = type + self.properties = properties + + +class PrivateLinkResourceProperties(msrest.serialization.Model): + """Properties of a private link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar group_id: GroupId of a private link resource. + :vartype group_id: str + :ivar required_members: RequiredMembers of a private link resource. + :vartype required_members: list[str] + :ivar required_zone_names: RequiredZoneNames of a private link resource. + :vartype required_zone_names: list[str] + """ + + _validation = { + 'group_id': {'readonly': True}, + 'required_members': {'readonly': True}, + 'required_zone_names': {'readonly': True}, + } + + _attribute_map = { + 'group_id': {'key': 'groupId', 'type': 'str'}, + 'required_members': {'key': 'requiredMembers', 'type': '[str]'}, + 'required_zone_names': {'key': 'requiredZoneNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PrivateLinkResourceProperties, self).__init__(**kwargs) + self.group_id = None + self.required_members = None + self.required_zone_names = None + + +class PrivateLinkResourcesWrapper(msrest.serialization.Model): + """Wrapper for a collection of private link resources. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PrivateLinkResource] + """ + + _validation = { + 'value': {'required': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PrivateLinkResource]'}, + } + + def __init__( + self, + *, + value: List["PrivateLinkResource"], + **kwargs + ): + super(PrivateLinkResourcesWrapper, self).__init__(**kwargs) + self.value = value + + +class ProcessInfo(ProxyOnlyResource): + """Process Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar identifier: ARM Identifier for deployment. + :vartype identifier: int + :param deployment_name: Deployment name. + :type deployment_name: str + :param href: HRef URI. + :type href: str + :param minidump: Minidump URI. + :type minidump: str + :param is_profile_running: Is profile running?. + :type is_profile_running: bool + :param is_iis_profile_running: Is the IIS Profile running?. + :type is_iis_profile_running: bool + :param iis_profile_timeout_in_seconds: IIS Profile timeout (seconds). + :type iis_profile_timeout_in_seconds: float + :param parent: Parent process. + :type parent: str + :param children: Child process list. + :type children: list[str] + :param threads: Thread list. + :type threads: list[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfo] + :param open_file_handles: List of open files. + :type open_file_handles: list[str] + :param modules: List of modules. + :type modules: list[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo] + :param file_name: File name of this process. + :type file_name: str + :param command_line: Command line. + :type command_line: str + :param user_name: User name. + :type user_name: str + :param handle_count: Handle count. + :type handle_count: int + :param module_count: Module count. + :type module_count: int + :param thread_count: Thread count. + :type thread_count: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_cpu_time: Total CPU time. + :type total_cpu_time: str + :param user_cpu_time: User CPU time. + :type user_cpu_time: str + :param privileged_cpu_time: Privileged CPU time. + :type privileged_cpu_time: str + :param working_set: Working set. + :type working_set: long + :param peak_working_set: Peak working set. + :type peak_working_set: long + :param private_memory: Private memory size. + :type private_memory: long + :param virtual_memory: Virtual memory size. + :type virtual_memory: long + :param peak_virtual_memory: Peak virtual memory usage. + :type peak_virtual_memory: long + :param paged_system_memory: Paged system memory. + :type paged_system_memory: long + :param non_paged_system_memory: Non-paged system memory. + :type non_paged_system_memory: long + :param paged_memory: Paged memory. + :type paged_memory: long + :param peak_paged_memory: Peak paged memory. + :type peak_paged_memory: long + :param time_stamp: Time stamp. + :type time_stamp: ~datetime.datetime + :param environment_variables: List of environment variables. + :type environment_variables: dict[str, str] + :param is_scm_site: Is this the SCM site?. + :type is_scm_site: bool + :param is_webjob: Is this a Web Job?. + :type is_webjob: bool + :param description: Description of process. + :type description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'deployment_name': {'key': 'properties.deployment_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'minidump': {'key': 'properties.minidump', 'type': 'str'}, + 'is_profile_running': {'key': 'properties.is_profile_running', 'type': 'bool'}, + 'is_iis_profile_running': {'key': 'properties.is_iis_profile_running', 'type': 'bool'}, + 'iis_profile_timeout_in_seconds': {'key': 'properties.iis_profile_timeout_in_seconds', 'type': 'float'}, + 'parent': {'key': 'properties.parent', 'type': 'str'}, + 'children': {'key': 'properties.children', 'type': '[str]'}, + 'threads': {'key': 'properties.threads', 'type': '[ProcessThreadInfo]'}, + 'open_file_handles': {'key': 'properties.open_file_handles', 'type': '[str]'}, + 'modules': {'key': 'properties.modules', 'type': '[ProcessModuleInfo]'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'command_line': {'key': 'properties.command_line', 'type': 'str'}, + 'user_name': {'key': 'properties.user_name', 'type': 'str'}, + 'handle_count': {'key': 'properties.handle_count', 'type': 'int'}, + 'module_count': {'key': 'properties.module_count', 'type': 'int'}, + 'thread_count': {'key': 'properties.thread_count', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_cpu_time': {'key': 'properties.total_cpu_time', 'type': 'str'}, + 'user_cpu_time': {'key': 'properties.user_cpu_time', 'type': 'str'}, + 'privileged_cpu_time': {'key': 'properties.privileged_cpu_time', 'type': 'str'}, + 'working_set': {'key': 'properties.working_set', 'type': 'long'}, + 'peak_working_set': {'key': 'properties.peak_working_set', 'type': 'long'}, + 'private_memory': {'key': 'properties.private_memory', 'type': 'long'}, + 'virtual_memory': {'key': 'properties.virtual_memory', 'type': 'long'}, + 'peak_virtual_memory': {'key': 'properties.peak_virtual_memory', 'type': 'long'}, + 'paged_system_memory': {'key': 'properties.paged_system_memory', 'type': 'long'}, + 'non_paged_system_memory': {'key': 'properties.non_paged_system_memory', 'type': 'long'}, + 'paged_memory': {'key': 'properties.paged_memory', 'type': 'long'}, + 'peak_paged_memory': {'key': 'properties.peak_paged_memory', 'type': 'long'}, + 'time_stamp': {'key': 'properties.time_stamp', 'type': 'iso-8601'}, + 'environment_variables': {'key': 'properties.environment_variables', 'type': '{str}'}, + 'is_scm_site': {'key': 'properties.is_scm_site', 'type': 'bool'}, + 'is_webjob': {'key': 'properties.is_webjob', 'type': 'bool'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + deployment_name: Optional[str] = None, + href: Optional[str] = None, + minidump: Optional[str] = None, + is_profile_running: Optional[bool] = None, + is_iis_profile_running: Optional[bool] = None, + iis_profile_timeout_in_seconds: Optional[float] = None, + parent: Optional[str] = None, + children: Optional[List[str]] = None, + threads: Optional[List["ProcessThreadInfo"]] = None, + open_file_handles: Optional[List[str]] = None, + modules: Optional[List["ProcessModuleInfo"]] = None, + file_name: Optional[str] = None, + command_line: Optional[str] = None, + user_name: Optional[str] = None, + handle_count: Optional[int] = None, + module_count: Optional[int] = None, + thread_count: Optional[int] = None, + start_time: Optional[datetime.datetime] = None, + total_cpu_time: Optional[str] = None, + user_cpu_time: Optional[str] = None, + privileged_cpu_time: Optional[str] = None, + working_set: Optional[int] = None, + peak_working_set: Optional[int] = None, + private_memory: Optional[int] = None, + virtual_memory: Optional[int] = None, + peak_virtual_memory: Optional[int] = None, + paged_system_memory: Optional[int] = None, + non_paged_system_memory: Optional[int] = None, + paged_memory: Optional[int] = None, + peak_paged_memory: Optional[int] = None, + time_stamp: Optional[datetime.datetime] = None, + environment_variables: Optional[Dict[str, str]] = None, + is_scm_site: Optional[bool] = None, + is_webjob: Optional[bool] = None, + description: Optional[str] = None, + **kwargs + ): + super(ProcessInfo, self).__init__(kind=kind, **kwargs) + self.identifier = None + self.deployment_name = deployment_name + self.href = href + self.minidump = minidump + self.is_profile_running = is_profile_running + self.is_iis_profile_running = is_iis_profile_running + self.iis_profile_timeout_in_seconds = iis_profile_timeout_in_seconds + self.parent = parent + self.children = children + self.threads = threads + self.open_file_handles = open_file_handles + self.modules = modules + self.file_name = file_name + self.command_line = command_line + self.user_name = user_name + self.handle_count = handle_count + self.module_count = module_count + self.thread_count = thread_count + self.start_time = start_time + self.total_cpu_time = total_cpu_time + self.user_cpu_time = user_cpu_time + self.privileged_cpu_time = privileged_cpu_time + self.working_set = working_set + self.peak_working_set = peak_working_set + self.private_memory = private_memory + self.virtual_memory = virtual_memory + self.peak_virtual_memory = peak_virtual_memory + self.paged_system_memory = paged_system_memory + self.non_paged_system_memory = non_paged_system_memory + self.paged_memory = paged_memory + self.peak_paged_memory = peak_paged_memory + self.time_stamp = time_stamp + self.environment_variables = environment_variables + self.is_scm_site = is_scm_site + self.is_webjob = is_webjob + self.description = description + + +class ProcessInfoCollection(msrest.serialization.Model): + """Collection of Kudu process information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessInfo"], + **kwargs + ): + super(ProcessInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ProcessModuleInfo(ProxyOnlyResource): + """Process Module Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param base_address: Base address. Used as module identifier in ARM resource URI. + :type base_address: str + :param file_name: File name. + :type file_name: str + :param href: HRef URI. + :type href: str + :param file_path: File path. + :type file_path: str + :param module_memory_size: Module memory size. + :type module_memory_size: int + :param file_version: File version. + :type file_version: str + :param file_description: File description. + :type file_description: str + :param product: Product name. + :type product: str + :param product_version: Product version. + :type product_version: str + :param is_debug: Is debug?. + :type is_debug: bool + :param language: Module language (locale). + :type language: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'base_address': {'key': 'properties.base_address', 'type': 'str'}, + 'file_name': {'key': 'properties.file_name', 'type': 'str'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'file_path': {'key': 'properties.file_path', 'type': 'str'}, + 'module_memory_size': {'key': 'properties.module_memory_size', 'type': 'int'}, + 'file_version': {'key': 'properties.file_version', 'type': 'str'}, + 'file_description': {'key': 'properties.file_description', 'type': 'str'}, + 'product': {'key': 'properties.product', 'type': 'str'}, + 'product_version': {'key': 'properties.product_version', 'type': 'str'}, + 'is_debug': {'key': 'properties.is_debug', 'type': 'bool'}, + 'language': {'key': 'properties.language', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + base_address: Optional[str] = None, + file_name: Optional[str] = None, + href: Optional[str] = None, + file_path: Optional[str] = None, + module_memory_size: Optional[int] = None, + file_version: Optional[str] = None, + file_description: Optional[str] = None, + product: Optional[str] = None, + product_version: Optional[str] = None, + is_debug: Optional[bool] = None, + language: Optional[str] = None, + **kwargs + ): + super(ProcessModuleInfo, self).__init__(kind=kind, **kwargs) + self.base_address = base_address + self.file_name = file_name + self.href = href + self.file_path = file_path + self.module_memory_size = module_memory_size + self.file_version = file_version + self.file_description = file_description + self.product = product + self.product_version = product_version + self.is_debug = is_debug + self.language = language + + +class ProcessModuleInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessModuleInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessModuleInfo"], + **kwargs + ): + super(ProcessModuleInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ProcessThreadInfo(ProxyOnlyResource): + """Process Thread Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar identifier: Site extension ID. + :vartype identifier: int + :param href: HRef URI. + :type href: str + :param process: Process URI. + :type process: str + :param start_address: Start address. + :type start_address: str + :param current_priority: Current thread priority. + :type current_priority: int + :param priority_level: Thread priority level. + :type priority_level: str + :param base_priority: Base priority. + :type base_priority: int + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param total_processor_time: Total processor time. + :type total_processor_time: str + :param user_processor_time: User processor time. + :type user_processor_time: str + :param state: Thread state. + :type state: str + :param wait_reason: Wait reason. + :type wait_reason: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'identifier': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identifier': {'key': 'properties.identifier', 'type': 'int'}, + 'href': {'key': 'properties.href', 'type': 'str'}, + 'process': {'key': 'properties.process', 'type': 'str'}, + 'start_address': {'key': 'properties.start_address', 'type': 'str'}, + 'current_priority': {'key': 'properties.current_priority', 'type': 'int'}, + 'priority_level': {'key': 'properties.priority_level', 'type': 'str'}, + 'base_priority': {'key': 'properties.base_priority', 'type': 'int'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'total_processor_time': {'key': 'properties.total_processor_time', 'type': 'str'}, + 'user_processor_time': {'key': 'properties.user_processor_time', 'type': 'str'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'wait_reason': {'key': 'properties.wait_reason', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + href: Optional[str] = None, + process: Optional[str] = None, + start_address: Optional[str] = None, + current_priority: Optional[int] = None, + priority_level: Optional[str] = None, + base_priority: Optional[int] = None, + start_time: Optional[datetime.datetime] = None, + total_processor_time: Optional[str] = None, + user_processor_time: Optional[str] = None, + state: Optional[str] = None, + wait_reason: Optional[str] = None, + **kwargs + ): + super(ProcessThreadInfo, self).__init__(kind=kind, **kwargs) + self.identifier = None + self.href = href + self.process = process + self.start_address = start_address + self.current_priority = current_priority + self.priority_level = priority_level + self.base_priority = base_priority + self.start_time = start_time + self.total_processor_time = total_processor_time + self.user_processor_time = user_processor_time + self.state = state + self.wait_reason = wait_reason + + +class ProcessThreadInfoCollection(msrest.serialization.Model): + """Collection of Kudu thread information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProcessThreadInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ProcessThreadInfo"], + **kwargs + ): + super(ProcessThreadInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PublicCertificate(ProxyOnlyResource): + """Public certificate object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param blob: Public Certificate byte array. + :type blob: bytearray + :param public_certificate_location: Public Certificate Location. Possible values include: + "CurrentUserMy", "LocalMachineMy", "Unknown". + :type public_certificate_location: str or + ~azure.mgmt.web.v2020_09_01.models.PublicCertificateLocation + :ivar thumbprint: Certificate Thumbprint. + :vartype thumbprint: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'thumbprint': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'blob': {'key': 'properties.blob', 'type': 'bytearray'}, + 'public_certificate_location': {'key': 'properties.publicCertificateLocation', 'type': 'str'}, + 'thumbprint': {'key': 'properties.thumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + blob: Optional[bytearray] = None, + public_certificate_location: Optional[Union[str, "PublicCertificateLocation"]] = None, + **kwargs + ): + super(PublicCertificate, self).__init__(kind=kind, **kwargs) + self.blob = blob + self.public_certificate_location = public_certificate_location + self.thumbprint = None + + +class PublicCertificateCollection(msrest.serialization.Model): + """Collection of public certificates. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.PublicCertificate] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PublicCertificate]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["PublicCertificate"], + **kwargs + ): + super(PublicCertificateCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PushSettings(ProxyOnlyResource): + """Push settings for the App. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param is_push_enabled: Gets or sets a flag indicating whether the Push endpoint is enabled. + :type is_push_enabled: bool + :param tag_whitelist_json: Gets or sets a JSON string containing a list of tags that are + whitelisted for use by the push registration endpoint. + :type tag_whitelist_json: str + :param tags_requiring_auth: Gets or sets a JSON string containing a list of tags that require + user authentication to be used in the push registration endpoint. + Tags can consist of alphanumeric characters and the following: + '_', '@', '#', '.', ':', '-'. + Validation should be performed at the PushRequestHandler. + :type tags_requiring_auth: str + :param dynamic_tags_json: Gets or sets a JSON string containing a list of dynamic tags that + will be evaluated from user claims in the push registration endpoint. + :type dynamic_tags_json: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_push_enabled': {'key': 'properties.isPushEnabled', 'type': 'bool'}, + 'tag_whitelist_json': {'key': 'properties.tagWhitelistJson', 'type': 'str'}, + 'tags_requiring_auth': {'key': 'properties.tagsRequiringAuth', 'type': 'str'}, + 'dynamic_tags_json': {'key': 'properties.dynamicTagsJson', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + is_push_enabled: Optional[bool] = None, + tag_whitelist_json: Optional[str] = None, + tags_requiring_auth: Optional[str] = None, + dynamic_tags_json: Optional[str] = None, + **kwargs + ): + super(PushSettings, self).__init__(kind=kind, **kwargs) + self.is_push_enabled = is_push_enabled + self.tag_whitelist_json = tag_whitelist_json + self.tags_requiring_auth = tags_requiring_auth + self.dynamic_tags_json = dynamic_tags_json + + +class RampUpRule(msrest.serialization.Model): + """Routing rules for ramp up testing. This rule allows to redirect static traffic % to a slot or to gradually change routing % based on performance. + + :param action_host_name: Hostname of a slot to which the traffic will be redirected if decided + to. E.g. myapp-stage.azurewebsites.net. + :type action_host_name: str + :param reroute_percentage: Percentage of the traffic which will be redirected to + :code:`ActionHostName`. + :type reroute_percentage: float + :param change_step: In auto ramp up scenario this is the step to add/remove from + :code:`ReroutePercentage` until it reaches + \n:code:`MinReroutePercentage` or + :code:`MaxReroutePercentage`. Site metrics are checked every N minutes specified + in :code:`ChangeIntervalInMinutes`.\nCustom decision algorithm + can be provided in TiPCallback site extension which URL can be specified in + :code:`ChangeDecisionCallbackUrl`. + :type change_step: float + :param change_interval_in_minutes: Specifies interval in minutes to reevaluate + ReroutePercentage. + :type change_interval_in_minutes: int + :param min_reroute_percentage: Specifies lower boundary above which ReroutePercentage will + stay. + :type min_reroute_percentage: float + :param max_reroute_percentage: Specifies upper boundary below which ReroutePercentage will + stay. + :type max_reroute_percentage: float + :param change_decision_callback_url: Custom decision algorithm can be provided in TiPCallback + site extension which URL can be specified. See TiPCallback site extension for the scaffold and + contracts. + https://www.siteextensions.net/packages/TiPCallback/. + :type change_decision_callback_url: str + :param name: Name of the routing rule. The recommended name would be to point to the slot which + will receive the traffic in the experiment. + :type name: str + """ + + _attribute_map = { + 'action_host_name': {'key': 'actionHostName', 'type': 'str'}, + 'reroute_percentage': {'key': 'reroutePercentage', 'type': 'float'}, + 'change_step': {'key': 'changeStep', 'type': 'float'}, + 'change_interval_in_minutes': {'key': 'changeIntervalInMinutes', 'type': 'int'}, + 'min_reroute_percentage': {'key': 'minReroutePercentage', 'type': 'float'}, + 'max_reroute_percentage': {'key': 'maxReroutePercentage', 'type': 'float'}, + 'change_decision_callback_url': {'key': 'changeDecisionCallbackUrl', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + action_host_name: Optional[str] = None, + reroute_percentage: Optional[float] = None, + change_step: Optional[float] = None, + change_interval_in_minutes: Optional[int] = None, + min_reroute_percentage: Optional[float] = None, + max_reroute_percentage: Optional[float] = None, + change_decision_callback_url: Optional[str] = None, + name: Optional[str] = None, + **kwargs + ): + super(RampUpRule, self).__init__(**kwargs) + self.action_host_name = action_host_name + self.reroute_percentage = reroute_percentage + self.change_step = change_step + self.change_interval_in_minutes = change_interval_in_minutes + self.min_reroute_percentage = min_reroute_percentage + self.max_reroute_percentage = max_reroute_percentage + self.change_decision_callback_url = change_decision_callback_url + self.name = name + + +class Recommendation(ProxyOnlyResource): + """Represents a recommendation result generated by the recommendation engine. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param creation_time: Timestamp when this instance was created. + :type creation_time: ~datetime.datetime + :param recommendation_id: A GUID value that each recommendation object is associated with. + :type recommendation_id: str + :param resource_id: Full ARM resource ID string that this recommendation object is associated + with. + :type resource_id: str + :param resource_scope: Name of a resource type this recommendation applies, e.g. Subscription, + ServerFarm, Site. Possible values include: "ServerFarm", "Subscription", "WebSite". + :type resource_scope: str or ~azure.mgmt.web.v2020_09_01.models.ResourceScopeType + :param rule_name: Unique name of the rule. + :type rule_name: str + :param display_name: UI friendly name of the rule (may not be unique). + :type display_name: str + :param message: Recommendation text. + :type message: str + :param level: Level indicating how critical this recommendation can impact. Possible values + include: "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.NotificationLevel + :param channels: List of channels that this recommendation can apply. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_09_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation belongs to. + :vartype category_tags: list[str] + :param action_name: Name of action recommended by this object. + :type action_name: str + :param enabled: True if this recommendation is still valid (i.e. "actionable"). False if it is + invalid. + :type enabled: int + :param states: The list of states of this recommendation. If it's null then it should be + considered "Active". + :type states: list[str] + :param start_time: The beginning time in UTC of a range that the recommendation refers to. + :type start_time: ~datetime.datetime + :param end_time: The end time in UTC of a range that the recommendation refers to. + :type end_time: ~datetime.datetime + :param next_notification_time: When to notify this recommendation next in UTC. Null means that + this will never be notified anymore. + :type next_notification_time: ~datetime.datetime + :param notification_expiration_time: Date and time in UTC when this notification expires. + :type notification_expiration_time: ~datetime.datetime + :param notified_time: Last timestamp in UTC this instance was actually notified. Null means + that this recommendation hasn't been notified yet. + :type notified_time: ~datetime.datetime + :param score: A metric value measured by the rule. + :type score: float + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'creation_time': {'key': 'properties.creationTime', 'type': 'iso-8601'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'resource_id': {'key': 'properties.resourceId', 'type': 'str'}, + 'resource_scope': {'key': 'properties.resourceScope', 'type': 'str'}, + 'rule_name': {'key': 'properties.ruleName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'int'}, + 'states': {'key': 'properties.states', 'type': '[str]'}, + 'start_time': {'key': 'properties.startTime', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.endTime', 'type': 'iso-8601'}, + 'next_notification_time': {'key': 'properties.nextNotificationTime', 'type': 'iso-8601'}, + 'notification_expiration_time': {'key': 'properties.notificationExpirationTime', 'type': 'iso-8601'}, + 'notified_time': {'key': 'properties.notifiedTime', 'type': 'iso-8601'}, + 'score': {'key': 'properties.score', 'type': 'float'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + creation_time: Optional[datetime.datetime] = None, + recommendation_id: Optional[str] = None, + resource_id: Optional[str] = None, + resource_scope: Optional[Union[str, "ResourceScopeType"]] = None, + rule_name: Optional[str] = None, + display_name: Optional[str] = None, + message: Optional[str] = None, + level: Optional[Union[str, "NotificationLevel"]] = None, + channels: Optional[Union[str, "Channels"]] = None, + action_name: Optional[str] = None, + enabled: Optional[int] = None, + states: Optional[List[str]] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + next_notification_time: Optional[datetime.datetime] = None, + notification_expiration_time: Optional[datetime.datetime] = None, + notified_time: Optional[datetime.datetime] = None, + score: Optional[float] = None, + is_dynamic: Optional[bool] = None, + extension_name: Optional[str] = None, + blade_name: Optional[str] = None, + forward_link: Optional[str] = None, + **kwargs + ): + super(Recommendation, self).__init__(kind=kind, **kwargs) + self.creation_time = creation_time + self.recommendation_id = recommendation_id + self.resource_id = resource_id + self.resource_scope = resource_scope + self.rule_name = rule_name + self.display_name = display_name + self.message = message + self.level = level + self.channels = channels + self.category_tags = None + self.action_name = action_name + self.enabled = enabled + self.states = states + self.start_time = start_time + self.end_time = end_time + self.next_notification_time = next_notification_time + self.notification_expiration_time = notification_expiration_time + self.notified_time = notified_time + self.score = score + self.is_dynamic = is_dynamic + self.extension_name = extension_name + self.blade_name = blade_name + self.forward_link = forward_link + + +class RecommendationCollection(msrest.serialization.Model): + """Collection of recommendations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Recommendation] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Recommendation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Recommendation"], + **kwargs + ): + super(RecommendationCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class RecommendationRule(ProxyOnlyResource): + """Represents a recommendation rule that the recommendation engine can perform. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param recommendation_name: Unique name of the rule. + :type recommendation_name: str + :param display_name: UI friendly name of the rule. + :type display_name: str + :param message: Localized name of the rule (Good for UI). + :type message: str + :param recommendation_id: Recommendation ID of an associated recommendation object tied to the + rule, if exists. + If such an object doesn't exist, it is set to null. + :type recommendation_id: str + :param description: Localized detailed description of the rule. + :type description: str + :param action_name: Name of action that is recommended by this rule in string. + :type action_name: str + :param level: Level of impact indicating how critical this rule is. Possible values include: + "Critical", "Warning", "Information", "NonUrgentSuggestion". + :type level: str or ~azure.mgmt.web.v2020_09_01.models.NotificationLevel + :param channels: List of available channels that this rule applies. Possible values include: + "Notification", "Api", "Email", "Webhook", "All". + :type channels: str or ~azure.mgmt.web.v2020_09_01.models.Channels + :ivar category_tags: The list of category tags that this recommendation rule belongs to. + :vartype category_tags: list[str] + :param is_dynamic: True if this is associated with a dynamically added rule. + :type is_dynamic: bool + :param extension_name: Extension name of the portal if exists. Applicable to dynamic rule only. + :type extension_name: str + :param blade_name: Deep link to a blade on the portal. Applicable to dynamic rule only. + :type blade_name: str + :param forward_link: Forward link to an external document associated with the rule. Applicable + to dynamic rule only. + :type forward_link: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'category_tags': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'recommendation_name': {'key': 'properties.recommendationName', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'message': {'key': 'properties.message', 'type': 'str'}, + 'recommendation_id': {'key': 'properties.recommendationId', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'action_name': {'key': 'properties.actionName', 'type': 'str'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'channels': {'key': 'properties.channels', 'type': 'str'}, + 'category_tags': {'key': 'properties.categoryTags', 'type': '[str]'}, + 'is_dynamic': {'key': 'properties.isDynamic', 'type': 'bool'}, + 'extension_name': {'key': 'properties.extensionName', 'type': 'str'}, + 'blade_name': {'key': 'properties.bladeName', 'type': 'str'}, + 'forward_link': {'key': 'properties.forwardLink', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + recommendation_name: Optional[str] = None, + display_name: Optional[str] = None, + message: Optional[str] = None, + recommendation_id: Optional[str] = None, + description: Optional[str] = None, + action_name: Optional[str] = None, + level: Optional[Union[str, "NotificationLevel"]] = None, + channels: Optional[Union[str, "Channels"]] = None, + is_dynamic: Optional[bool] = None, + extension_name: Optional[str] = None, + blade_name: Optional[str] = None, + forward_link: Optional[str] = None, + **kwargs + ): + super(RecommendationRule, self).__init__(kind=kind, **kwargs) + self.recommendation_name = recommendation_name + self.display_name = display_name + self.message = message + self.recommendation_id = recommendation_id + self.description = description + self.action_name = action_name + self.level = level + self.channels = channels + self.category_tags = None + self.is_dynamic = is_dynamic + self.extension_name = extension_name + self.blade_name = blade_name + self.forward_link = forward_link + + +class ReissueCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate reissue request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_size: Certificate Key Size. + :type key_size: int + :param delay_existing_revoke_in_hours: Delay in hours to revoke existing certificate after the + new certificate is issued. + :type delay_existing_revoke_in_hours: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'delay_existing_revoke_in_hours': {'key': 'properties.delayExistingRevokeInHours', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_size: Optional[int] = None, + delay_existing_revoke_in_hours: Optional[int] = None, + csr: Optional[str] = None, + is_private_key_external: Optional[bool] = None, + **kwargs + ): + super(ReissueCertificateOrderRequest, self).__init__(kind=kind, **kwargs) + self.key_size = key_size + self.delay_existing_revoke_in_hours = delay_existing_revoke_in_hours + self.csr = csr + self.is_private_key_external = is_private_key_external + + +class RelayServiceConnectionEntity(ProxyOnlyResource): + """Hybrid Connection for an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param entity_name: + :type entity_name: str + :param entity_connection_string: + :type entity_connection_string: str + :param resource_type: + :type resource_type: str + :param resource_connection_string: + :type resource_connection_string: str + :param hostname: + :type hostname: str + :param port: + :type port: int + :param biztalk_uri: + :type biztalk_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'entity_name': {'key': 'properties.entityName', 'type': 'str'}, + 'entity_connection_string': {'key': 'properties.entityConnectionString', 'type': 'str'}, + 'resource_type': {'key': 'properties.resourceType', 'type': 'str'}, + 'resource_connection_string': {'key': 'properties.resourceConnectionString', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'port': {'key': 'properties.port', 'type': 'int'}, + 'biztalk_uri': {'key': 'properties.biztalkUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + entity_name: Optional[str] = None, + entity_connection_string: Optional[str] = None, + resource_type: Optional[str] = None, + resource_connection_string: Optional[str] = None, + hostname: Optional[str] = None, + port: Optional[int] = None, + biztalk_uri: Optional[str] = None, + **kwargs + ): + super(RelayServiceConnectionEntity, self).__init__(kind=kind, **kwargs) + self.entity_name = entity_name + self.entity_connection_string = entity_connection_string + self.resource_type = resource_type + self.resource_connection_string = resource_connection_string + self.hostname = hostname + self.port = port + self.biztalk_uri = biztalk_uri + + +class Rendering(msrest.serialization.Model): + """Instructions for rendering the data. + + :param type: Rendering Type. Possible values include: "NoGraph", "Table", "TimeSeries", + "TimeSeriesPerInstance". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.RenderingType + :param title: Title of data. + :type title: str + :param description: Description of the data that will help it be interpreted. + :type description: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "RenderingType"]] = None, + title: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(Rendering, self).__init__(**kwargs) + self.type = type + self.title = title + self.description = description + + +class RenewCertificateOrderRequest(ProxyOnlyResource): + """Class representing certificate renew request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param key_size: Certificate Key Size. + :type key_size: int + :param csr: Csr to be used for re-key operation. + :type csr: str + :param is_private_key_external: Should we change the ASC type (from managed private key to + external private key and vice versa). + :type is_private_key_external: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'key_size': {'key': 'properties.keySize', 'type': 'int'}, + 'csr': {'key': 'properties.csr', 'type': 'str'}, + 'is_private_key_external': {'key': 'properties.isPrivateKeyExternal', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + key_size: Optional[int] = None, + csr: Optional[str] = None, + is_private_key_external: Optional[bool] = None, + **kwargs + ): + super(RenewCertificateOrderRequest, self).__init__(kind=kind, **kwargs) + self.key_size = key_size + self.csr = csr + self.is_private_key_external = is_private_key_external + + +class RequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on total requests. + + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(RequestsBasedTrigger, self).__init__(**kwargs) + self.count = count + self.time_interval = time_interval + + +class ResourceCollection(msrest.serialization.Model): + """Collection of resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[str] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[str]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List[str], + **kwargs + ): + super(ResourceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceHealthMetadata(ProxyOnlyResource): + """Used for getting ResourceHealthCheck settings. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param category: The category that the resource matches in the RHC Policy File. + :type category: str + :param signal_availability: Is there a health signal for the resource. + :type signal_availability: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'category': {'key': 'properties.category', 'type': 'str'}, + 'signal_availability': {'key': 'properties.signalAvailability', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + category: Optional[str] = None, + signal_availability: Optional[bool] = None, + **kwargs + ): + super(ResourceHealthMetadata, self).__init__(kind=kind, **kwargs) + self.category = category + self.signal_availability = signal_availability + + +class ResourceHealthMetadataCollection(msrest.serialization.Model): + """Collection of resource health metadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceHealthMetadata]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ResourceHealthMetadata"], + **kwargs + ): + super(ResourceHealthMetadataCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceMetricAvailability(msrest.serialization.Model): + """Metrics availability and retention. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar time_grain: Time grain . + :vartype time_grain: str + :ivar retention: Retention period for the current time grain. + :vartype retention: str + """ + + _validation = { + 'time_grain': {'readonly': True}, + 'retention': {'readonly': True}, + } + + _attribute_map = { + 'time_grain': {'key': 'timeGrain', 'type': 'str'}, + 'retention': {'key': 'retention', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceMetricAvailability, self).__init__(**kwargs) + self.time_grain = None + self.retention = None + + +class ResourceMetricDefinition(ProxyOnlyResource): + """Metadata for the metrics. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar unit: Unit of the metric. + :vartype unit: str + :ivar primary_aggregation_type: Primary aggregation type. + :vartype primary_aggregation_type: str + :ivar metric_availabilities: List of time grains supported for the metric together with + retention period. + :vartype metric_availabilities: + list[~azure.mgmt.web.v2020_09_01.models.ResourceMetricAvailability] + :ivar resource_uri: Resource URI. + :vartype resource_uri: str + :ivar properties: Resource metric definition properties. + :vartype properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'unit': {'readonly': True}, + 'primary_aggregation_type': {'readonly': True}, + 'metric_availabilities': {'readonly': True}, + 'resource_uri': {'readonly': True}, + 'properties': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'primary_aggregation_type': {'key': 'properties.primaryAggregationType', 'type': 'str'}, + 'metric_availabilities': {'key': 'properties.metricAvailabilities', 'type': '[ResourceMetricAvailability]'}, + 'resource_uri': {'key': 'properties.resourceUri', 'type': 'str'}, + 'properties': {'key': 'properties.properties', 'type': '{str}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(ResourceMetricDefinition, self).__init__(kind=kind, **kwargs) + self.unit = None + self.primary_aggregation_type = None + self.metric_availabilities = None + self.resource_uri = None + self.properties = None + + +class ResourceMetricDefinitionCollection(msrest.serialization.Model): + """Collection of metric definitions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinition] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceMetricDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["ResourceMetricDefinition"], + **kwargs + ): + super(ResourceMetricDefinitionCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceNameAvailability(msrest.serialization.Model): + """Information regarding availability of a resource name. + + :param name_available: :code:`true` indicates name is valid and available. + :code:`false` indicates the name is invalid, unavailable, or both. + :type name_available: bool + :param reason: :code:`Invalid` indicates the name provided does not match Azure + App Service naming requirements. :code:`AlreadyExists` indicates that the name is + already in use and is therefore unavailable. Possible values include: "Invalid", + "AlreadyExists". + :type reason: str or ~azure.mgmt.web.v2020_09_01.models.InAvailabilityReasonType + :param message: If reason == invalid, provide the user with the reason why the given name is + invalid, and provide the resource naming requirements so that the user can select a valid name. + If reason == AlreadyExists, explain that resource name is already in use, and direct them to + select a different name. + :type message: str + """ + + _attribute_map = { + 'name_available': {'key': 'nameAvailable', 'type': 'bool'}, + 'reason': {'key': 'reason', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + name_available: Optional[bool] = None, + reason: Optional[Union[str, "InAvailabilityReasonType"]] = None, + message: Optional[str] = None, + **kwargs + ): + super(ResourceNameAvailability, self).__init__(**kwargs) + self.name_available = name_available + self.reason = reason + self.message = message + + +class ResourceNameAvailabilityRequest(msrest.serialization.Model): + """Resource name availability request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: "Site", + "Slot", "HostingEnvironment", "PublishingUser", "Microsoft.Web/sites", + "Microsoft.Web/sites/slots", "Microsoft.Web/hostingEnvironments", + "Microsoft.Web/publishingUsers". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'is_fqdn': {'key': 'isFqdn', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: str, + type: Union[str, "CheckNameResourceTypes"], + is_fqdn: Optional[bool] = None, + **kwargs + ): + super(ResourceNameAvailabilityRequest, self).__init__(**kwargs) + self.name = name + self.type = type + self.is_fqdn = is_fqdn + + +class ResponseMetaData(msrest.serialization.Model): + """ResponseMetaData. + + :param data_source: Source of the Data. + :type data_source: ~azure.mgmt.web.v2020_09_01.models.DataSource + """ + + _attribute_map = { + 'data_source': {'key': 'dataSource', 'type': 'DataSource'}, + } + + def __init__( + self, + *, + data_source: Optional["DataSource"] = None, + **kwargs + ): + super(ResponseMetaData, self).__init__(**kwargs) + self.data_source = data_source + + +class RestoreRequest(ProxyOnlyResource): + """Description of a restore request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param storage_account_url: SAS URL to the container. + :type storage_account_url: str + :param blob_name: Name of a blob which contains the backup. + :type blob_name: str + :param overwrite: :code:`true` if the restore operation can overwrite target app; + otherwise, :code:`false`. :code:`true` is needed if trying to restore + over an existing app. + :type overwrite: bool + :param site_name: Name of an app. + :type site_name: str + :param databases: Collection of databases which should be restored. This list has to match the + list of databases included in the backup. + :type databases: list[~azure.mgmt.web.v2020_09_01.models.DatabaseBackupSetting] + :param ignore_conflicting_host_names: Changes a logic when restoring an app with custom + domains. :code:`true` to remove custom domains automatically. If + :code:`false`, custom domains are added to + the app's object when it is being restored, but that might fail due to conflicts during the + operation. + :type ignore_conflicting_host_names: bool + :param ignore_databases: Ignore the databases and only restore the site content. + :type ignore_databases: bool + :param app_service_plan: Specify app service plan that will own restored site. + :type app_service_plan: str + :param operation_type: Operation type. Possible values include: "Default", "Clone", + "Relocation", "Snapshot", "CloudFS". Default value: "Default". + :type operation_type: str or ~azure.mgmt.web.v2020_09_01.models.BackupRestoreOperationType + :param adjust_connection_strings: :code:`true` if SiteConfig.ConnectionStrings + should be set in new app; otherwise, :code:`false`. + :type adjust_connection_strings: bool + :param hosting_environment: App Service Environment name, if needed (only when restoring an app + to an App Service Environment). + :type hosting_environment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'storage_account_url': {'key': 'properties.storageAccountUrl', 'type': 'str'}, + 'blob_name': {'key': 'properties.blobName', 'type': 'str'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'site_name': {'key': 'properties.siteName', 'type': 'str'}, + 'databases': {'key': 'properties.databases', 'type': '[DatabaseBackupSetting]'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'ignore_databases': {'key': 'properties.ignoreDatabases', 'type': 'bool'}, + 'app_service_plan': {'key': 'properties.appServicePlan', 'type': 'str'}, + 'operation_type': {'key': 'properties.operationType', 'type': 'str'}, + 'adjust_connection_strings': {'key': 'properties.adjustConnectionStrings', 'type': 'bool'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + storage_account_url: Optional[str] = None, + blob_name: Optional[str] = None, + overwrite: Optional[bool] = None, + site_name: Optional[str] = None, + databases: Optional[List["DatabaseBackupSetting"]] = None, + ignore_conflicting_host_names: Optional[bool] = False, + ignore_databases: Optional[bool] = False, + app_service_plan: Optional[str] = None, + operation_type: Optional[Union[str, "BackupRestoreOperationType"]] = "Default", + adjust_connection_strings: Optional[bool] = None, + hosting_environment: Optional[str] = None, + **kwargs + ): + super(RestoreRequest, self).__init__(kind=kind, **kwargs) + self.storage_account_url = storage_account_url + self.blob_name = blob_name + self.overwrite = overwrite + self.site_name = site_name + self.databases = databases + self.ignore_conflicting_host_names = ignore_conflicting_host_names + self.ignore_databases = ignore_databases + self.app_service_plan = app_service_plan + self.operation_type = operation_type + self.adjust_connection_strings = adjust_connection_strings + self.hosting_environment = hosting_environment + + +class ServiceSpecification(msrest.serialization.Model): + """Resource metrics service provided by Microsoft.Insights resource provider. + + :param metric_specifications: + :type metric_specifications: list[~azure.mgmt.web.v2020_09_01.models.MetricSpecification] + :param log_specifications: + :type log_specifications: list[~azure.mgmt.web.v2020_09_01.models.LogSpecification] + """ + + _attribute_map = { + 'metric_specifications': {'key': 'metricSpecifications', 'type': '[MetricSpecification]'}, + 'log_specifications': {'key': 'logSpecifications', 'type': '[LogSpecification]'}, + } + + def __init__( + self, + *, + metric_specifications: Optional[List["MetricSpecification"]] = None, + log_specifications: Optional[List["LogSpecification"]] = None, + **kwargs + ): + super(ServiceSpecification, self).__init__(**kwargs) + self.metric_specifications = metric_specifications + self.log_specifications = log_specifications + + +class Site(Resource): + """A web app, a mobile app backend, or an API app. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_09_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_09_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_09_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_09_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_09_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_09_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_09_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedServiceIdentity"] = None, + enabled: Optional[bool] = None, + host_name_ssl_states: Optional[List["HostNameSslState"]] = None, + server_farm_id: Optional[str] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + site_config: Optional["SiteConfig"] = None, + scm_site_also_stopped: Optional[bool] = False, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + client_affinity_enabled: Optional[bool] = None, + client_cert_enabled: Optional[bool] = None, + client_cert_mode: Optional[Union[str, "ClientCertMode"]] = None, + client_cert_exclusion_paths: Optional[str] = None, + host_names_disabled: Optional[bool] = None, + custom_domain_verification_id: Optional[str] = None, + container_size: Optional[int] = None, + daily_memory_time_quota: Optional[int] = None, + cloning_info: Optional["CloningInfo"] = None, + https_only: Optional[bool] = None, + redundancy_mode: Optional[Union[str, "RedundancyMode"]] = None, + **kwargs + ): + super(Site, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.identity = identity + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = enabled + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = host_name_ssl_states + self.server_farm_id = server_farm_id + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.last_modified_time_utc = None + self.site_config = site_config + self.traffic_manager_host_names = None + self.scm_site_also_stopped = scm_site_also_stopped + self.target_swap_slot = None + self.hosting_environment_profile = hosting_environment_profile + self.client_affinity_enabled = client_affinity_enabled + self.client_cert_enabled = client_cert_enabled + self.client_cert_mode = client_cert_mode + self.client_cert_exclusion_paths = client_cert_exclusion_paths + self.host_names_disabled = host_names_disabled + self.custom_domain_verification_id = custom_domain_verification_id + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = container_size + self.daily_memory_time_quota = daily_memory_time_quota + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = cloning_info + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = https_only + self.redundancy_mode = redundancy_mode + self.in_progress_operation_id = None + + +class SiteAuthSettings(ProxyOnlyResource): + """Configuration settings for the Azure App Service Authentication / Authorization feature. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: :code:`true` if the Authentication / Authorization feature is + enabled for the current app; otherwise, :code:`false`. + :type enabled: bool + :param runtime_version: The RuntimeVersion of the Authentication / Authorization feature in use + for the current app. + The setting in this value can control the behavior of certain features in the Authentication / + Authorization module. + :type runtime_version: str + :param unauthenticated_client_action: The action to take when an unauthenticated client + attempts to access the app. Possible values include: "RedirectToLoginPage", "AllowAnonymous". + :type unauthenticated_client_action: str or + ~azure.mgmt.web.v2020_09_01.models.UnauthenticatedClientAction + :param token_store_enabled: :code:`true` to durably store platform-specific + security tokens that are obtained during login flows; otherwise, :code:`false`. + The default is :code:`false`. + :type token_store_enabled: bool + :param allowed_external_redirect_urls: External URLs that can be redirected to as part of + logging in or logging out of the app. Note that the query string part of the URL is ignored. + This is an advanced setting typically only needed by Windows Store application backends. + Note that URLs within the current domain are always implicitly allowed. + :type allowed_external_redirect_urls: list[str] + :param default_provider: The default authentication provider to use when multiple providers are + configured. + This setting is only needed if multiple providers are configured and the unauthenticated + client + action is set to "RedirectToLoginPage". Possible values include: "AzureActiveDirectory", + "Facebook", "Google", "MicrosoftAccount", "Twitter", "Github". + :type default_provider: str or ~azure.mgmt.web.v2020_09_01.models.BuiltInAuthenticationProvider + :param token_refresh_extension_hours: The number of hours after session token expiration that a + session token can be used to + call the token refresh API. The default is 72 hours. + :type token_refresh_extension_hours: float + :param client_id: The Client ID of this relying party application, known as the client_id. + This setting is required for enabling OpenID Connection authentication with Azure Active + Directory or + other 3rd party OpenID Connect providers. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_id: str + :param client_secret: The Client Secret of this relying party application (in Azure Active + Directory, this is also referred to as the Key). + This setting is optional. If no client secret is configured, the OpenID Connect implicit auth + flow is used to authenticate end users. + Otherwise, the OpenID Connect Authorization Code Flow is used to authenticate end users. + More information on OpenID Connect: http://openid.net/specs/openid-connect-core-1_0.html. + :type client_secret: str + :param client_secret_setting_name: The app setting name that contains the client secret of the + relying party application. + :type client_secret_setting_name: str + :param client_secret_certificate_thumbprint: An alternative to the client secret, that is the + thumbprint of a certificate used for signing purposes. This property acts as + a replacement for the Client Secret. It is also optional. + :type client_secret_certificate_thumbprint: str + :param issuer: The OpenID Connect Issuer URI that represents the entity which issues access + tokens for this application. + When using Azure Active Directory, this value is the URI of the directory tenant, e.g. + https://sts.windows.net/{tenant-guid}/. + This URI is a case-sensitive identifier for the token issuer. + More information on OpenID Connect Discovery: http://openid.net/specs/openid-connect- + discovery-1_0.html. + :type issuer: str + :param validate_issuer: Gets a value indicating whether the issuer should be a valid HTTPS url + and be validated as such. + :type validate_issuer: bool + :param allowed_audiences: Allowed audience values to consider when validating JWTs issued by + Azure Active Directory. Note that the :code:`ClientID` value is always considered + an + allowed audience, regardless of this setting. + :type allowed_audiences: list[str] + :param additional_login_params: Login parameters to send to the OpenID Connect authorization + endpoint when + a user logs in. Each parameter must be in the form "key=value". + :type additional_login_params: list[str] + :param aad_claims_authorization: Gets a JSON string containing the Azure AD Acl settings. + :type aad_claims_authorization: str + :param google_client_id: The OpenID Connect Client ID for the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_id: str + :param google_client_secret: The client secret associated with the Google web application. + This setting is required for enabling Google Sign-In. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_client_secret: str + :param google_client_secret_setting_name: The app setting name that contains the client secret + associated with + the Google web application. + :type google_client_secret_setting_name: str + :param google_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Google + Sign-In authentication. + This setting is optional. If not specified, "openid", "profile", and "email" are used as + default scopes. + Google Sign-In documentation: https://developers.google.com/identity/sign-in/web/. + :type google_o_auth_scopes: list[str] + :param facebook_app_id: The App ID of the Facebook app used for login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_id: str + :param facebook_app_secret: The App Secret of the Facebook app used for Facebook Login. + This setting is required for enabling Facebook Login. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_app_secret: str + :param facebook_app_secret_setting_name: The app setting name that contains the app secret used + for Facebook Login. + :type facebook_app_secret_setting_name: str + :param facebook_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of Facebook + Login authentication. + This setting is optional. + Facebook Login documentation: https://developers.facebook.com/docs/facebook-login. + :type facebook_o_auth_scopes: list[str] + :param git_hub_client_id: The Client Id of the GitHub app used for login. + This setting is required for enabling Github login. + :type git_hub_client_id: str + :param git_hub_client_secret: The Client Secret of the GitHub app used for Github Login. + This setting is required for enabling Github login. + :type git_hub_client_secret: str + :param git_hub_client_secret_setting_name: The app setting name that contains the client secret + of the Github + app used for GitHub Login. + :type git_hub_client_secret_setting_name: str + :param git_hub_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of GitHub + Login authentication. + This setting is optional. + :type git_hub_o_auth_scopes: list[str] + :param twitter_consumer_key: The OAuth 1.0a consumer key of the Twitter application used for + sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_key: str + :param twitter_consumer_secret: The OAuth 1.0a consumer secret of the Twitter application used + for sign-in. + This setting is required for enabling Twitter Sign-In. + Twitter Sign-In documentation: https://dev.twitter.com/web/sign-in. + :type twitter_consumer_secret: str + :param twitter_consumer_secret_setting_name: The app setting name that contains the OAuth 1.0a + consumer secret of the Twitter + application used for sign-in. + :type twitter_consumer_secret_setting_name: str + :param microsoft_account_client_id: The OAuth 2.0 client ID that was created for the app used + for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_id: str + :param microsoft_account_client_secret: The OAuth 2.0 client secret that was created for the + app used for authentication. + This setting is required for enabling Microsoft Account authentication. + Microsoft Account OAuth documentation: https://dev.onedrive.com/auth/msa_oauth.htm. + :type microsoft_account_client_secret: str + :param microsoft_account_client_secret_setting_name: The app setting name containing the OAuth + 2.0 client secret that was created for the + app used for authentication. + :type microsoft_account_client_secret_setting_name: str + :param microsoft_account_o_auth_scopes: The OAuth 2.0 scopes that will be requested as part of + Microsoft Account authentication. + This setting is optional. If not specified, "wl.basic" is used as the default scope. + Microsoft Account Scopes and permissions documentation: https://msdn.microsoft.com/en- + us/library/dn631845.aspx. + :type microsoft_account_o_auth_scopes: list[str] + :param is_auth_from_file: "true" if the auth config settings should be read from a file, + "false" otherwise. + :type is_auth_from_file: str + :param auth_file_path: The path of the config file containing auth settings. + If the path is relative, base will the site's root directory. + :type auth_file_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'runtime_version': {'key': 'properties.runtimeVersion', 'type': 'str'}, + 'unauthenticated_client_action': {'key': 'properties.unauthenticatedClientAction', 'type': 'str'}, + 'token_store_enabled': {'key': 'properties.tokenStoreEnabled', 'type': 'bool'}, + 'allowed_external_redirect_urls': {'key': 'properties.allowedExternalRedirectUrls', 'type': '[str]'}, + 'default_provider': {'key': 'properties.defaultProvider', 'type': 'str'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'client_id': {'key': 'properties.clientId', 'type': 'str'}, + 'client_secret': {'key': 'properties.clientSecret', 'type': 'str'}, + 'client_secret_setting_name': {'key': 'properties.clientSecretSettingName', 'type': 'str'}, + 'client_secret_certificate_thumbprint': {'key': 'properties.clientSecretCertificateThumbprint', 'type': 'str'}, + 'issuer': {'key': 'properties.issuer', 'type': 'str'}, + 'validate_issuer': {'key': 'properties.validateIssuer', 'type': 'bool'}, + 'allowed_audiences': {'key': 'properties.allowedAudiences', 'type': '[str]'}, + 'additional_login_params': {'key': 'properties.additionalLoginParams', 'type': '[str]'}, + 'aad_claims_authorization': {'key': 'properties.aadClaimsAuthorization', 'type': 'str'}, + 'google_client_id': {'key': 'properties.googleClientId', 'type': 'str'}, + 'google_client_secret': {'key': 'properties.googleClientSecret', 'type': 'str'}, + 'google_client_secret_setting_name': {'key': 'properties.googleClientSecretSettingName', 'type': 'str'}, + 'google_o_auth_scopes': {'key': 'properties.googleOAuthScopes', 'type': '[str]'}, + 'facebook_app_id': {'key': 'properties.facebookAppId', 'type': 'str'}, + 'facebook_app_secret': {'key': 'properties.facebookAppSecret', 'type': 'str'}, + 'facebook_app_secret_setting_name': {'key': 'properties.facebookAppSecretSettingName', 'type': 'str'}, + 'facebook_o_auth_scopes': {'key': 'properties.facebookOAuthScopes', 'type': '[str]'}, + 'git_hub_client_id': {'key': 'properties.gitHubClientId', 'type': 'str'}, + 'git_hub_client_secret': {'key': 'properties.gitHubClientSecret', 'type': 'str'}, + 'git_hub_client_secret_setting_name': {'key': 'properties.gitHubClientSecretSettingName', 'type': 'str'}, + 'git_hub_o_auth_scopes': {'key': 'properties.gitHubOAuthScopes', 'type': '[str]'}, + 'twitter_consumer_key': {'key': 'properties.twitterConsumerKey', 'type': 'str'}, + 'twitter_consumer_secret': {'key': 'properties.twitterConsumerSecret', 'type': 'str'}, + 'twitter_consumer_secret_setting_name': {'key': 'properties.twitterConsumerSecretSettingName', 'type': 'str'}, + 'microsoft_account_client_id': {'key': 'properties.microsoftAccountClientId', 'type': 'str'}, + 'microsoft_account_client_secret': {'key': 'properties.microsoftAccountClientSecret', 'type': 'str'}, + 'microsoft_account_client_secret_setting_name': {'key': 'properties.microsoftAccountClientSecretSettingName', 'type': 'str'}, + 'microsoft_account_o_auth_scopes': {'key': 'properties.microsoftAccountOAuthScopes', 'type': '[str]'}, + 'is_auth_from_file': {'key': 'properties.isAuthFromFile', 'type': 'str'}, + 'auth_file_path': {'key': 'properties.authFilePath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + runtime_version: Optional[str] = None, + unauthenticated_client_action: Optional[Union[str, "UnauthenticatedClientAction"]] = None, + token_store_enabled: Optional[bool] = None, + allowed_external_redirect_urls: Optional[List[str]] = None, + default_provider: Optional[Union[str, "BuiltInAuthenticationProvider"]] = None, + token_refresh_extension_hours: Optional[float] = None, + client_id: Optional[str] = None, + client_secret: Optional[str] = None, + client_secret_setting_name: Optional[str] = None, + client_secret_certificate_thumbprint: Optional[str] = None, + issuer: Optional[str] = None, + validate_issuer: Optional[bool] = None, + allowed_audiences: Optional[List[str]] = None, + additional_login_params: Optional[List[str]] = None, + aad_claims_authorization: Optional[str] = None, + google_client_id: Optional[str] = None, + google_client_secret: Optional[str] = None, + google_client_secret_setting_name: Optional[str] = None, + google_o_auth_scopes: Optional[List[str]] = None, + facebook_app_id: Optional[str] = None, + facebook_app_secret: Optional[str] = None, + facebook_app_secret_setting_name: Optional[str] = None, + facebook_o_auth_scopes: Optional[List[str]] = None, + git_hub_client_id: Optional[str] = None, + git_hub_client_secret: Optional[str] = None, + git_hub_client_secret_setting_name: Optional[str] = None, + git_hub_o_auth_scopes: Optional[List[str]] = None, + twitter_consumer_key: Optional[str] = None, + twitter_consumer_secret: Optional[str] = None, + twitter_consumer_secret_setting_name: Optional[str] = None, + microsoft_account_client_id: Optional[str] = None, + microsoft_account_client_secret: Optional[str] = None, + microsoft_account_client_secret_setting_name: Optional[str] = None, + microsoft_account_o_auth_scopes: Optional[List[str]] = None, + is_auth_from_file: Optional[str] = None, + auth_file_path: Optional[str] = None, + **kwargs + ): + super(SiteAuthSettings, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.runtime_version = runtime_version + self.unauthenticated_client_action = unauthenticated_client_action + self.token_store_enabled = token_store_enabled + self.allowed_external_redirect_urls = allowed_external_redirect_urls + self.default_provider = default_provider + self.token_refresh_extension_hours = token_refresh_extension_hours + self.client_id = client_id + self.client_secret = client_secret + self.client_secret_setting_name = client_secret_setting_name + self.client_secret_certificate_thumbprint = client_secret_certificate_thumbprint + self.issuer = issuer + self.validate_issuer = validate_issuer + self.allowed_audiences = allowed_audiences + self.additional_login_params = additional_login_params + self.aad_claims_authorization = aad_claims_authorization + self.google_client_id = google_client_id + self.google_client_secret = google_client_secret + self.google_client_secret_setting_name = google_client_secret_setting_name + self.google_o_auth_scopes = google_o_auth_scopes + self.facebook_app_id = facebook_app_id + self.facebook_app_secret = facebook_app_secret + self.facebook_app_secret_setting_name = facebook_app_secret_setting_name + self.facebook_o_auth_scopes = facebook_o_auth_scopes + self.git_hub_client_id = git_hub_client_id + self.git_hub_client_secret = git_hub_client_secret + self.git_hub_client_secret_setting_name = git_hub_client_secret_setting_name + self.git_hub_o_auth_scopes = git_hub_o_auth_scopes + self.twitter_consumer_key = twitter_consumer_key + self.twitter_consumer_secret = twitter_consumer_secret + self.twitter_consumer_secret_setting_name = twitter_consumer_secret_setting_name + self.microsoft_account_client_id = microsoft_account_client_id + self.microsoft_account_client_secret = microsoft_account_client_secret + self.microsoft_account_client_secret_setting_name = microsoft_account_client_secret_setting_name + self.microsoft_account_o_auth_scopes = microsoft_account_o_auth_scopes + self.is_auth_from_file = is_auth_from_file + self.auth_file_path = auth_file_path + + +class SiteAuthSettingsV2(ProxyOnlyResource): + """SiteAuthSettingsV2. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param platform: + :type platform: ~azure.mgmt.web.v2020_09_01.models.AuthPlatform + :param global_validation: + :type global_validation: ~azure.mgmt.web.v2020_09_01.models.GlobalValidation + :param identity_providers: + :type identity_providers: ~azure.mgmt.web.v2020_09_01.models.IdentityProviders + :param login: + :type login: ~azure.mgmt.web.v2020_09_01.models.Login + :param http_settings: + :type http_settings: ~azure.mgmt.web.v2020_09_01.models.HttpSettings + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'platform': {'key': 'properties.platform', 'type': 'AuthPlatform'}, + 'global_validation': {'key': 'properties.globalValidation', 'type': 'GlobalValidation'}, + 'identity_providers': {'key': 'properties.identityProviders', 'type': 'IdentityProviders'}, + 'login': {'key': 'properties.login', 'type': 'Login'}, + 'http_settings': {'key': 'properties.httpSettings', 'type': 'HttpSettings'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + platform: Optional["AuthPlatform"] = None, + global_validation: Optional["GlobalValidation"] = None, + identity_providers: Optional["IdentityProviders"] = None, + login: Optional["Login"] = None, + http_settings: Optional["HttpSettings"] = None, + **kwargs + ): + super(SiteAuthSettingsV2, self).__init__(kind=kind, **kwargs) + self.platform = platform + self.global_validation = global_validation + self.identity_providers = identity_providers + self.login = login + self.http_settings = http_settings + + +class SiteCloneability(msrest.serialization.Model): + """Represents whether or not an app is cloneable. + + :param result: Name of app. Possible values include: "Cloneable", "PartiallyCloneable", + "NotCloneable". + :type result: str or ~azure.mgmt.web.v2020_09_01.models.CloneAbilityResult + :param blocking_features: List of features enabled on app that prevent cloning. + :type blocking_features: list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + :param unsupported_features: List of features enabled on app that are non-blocking but cannot + be cloned. The app can still be cloned + but the features in this list will not be set up on cloned app. + :type unsupported_features: list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + :param blocking_characteristics: List of blocking application characteristics. + :type blocking_characteristics: + list[~azure.mgmt.web.v2020_09_01.models.SiteCloneabilityCriterion] + """ + + _attribute_map = { + 'result': {'key': 'result', 'type': 'str'}, + 'blocking_features': {'key': 'blockingFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'unsupported_features': {'key': 'unsupportedFeatures', 'type': '[SiteCloneabilityCriterion]'}, + 'blocking_characteristics': {'key': 'blockingCharacteristics', 'type': '[SiteCloneabilityCriterion]'}, + } + + def __init__( + self, + *, + result: Optional[Union[str, "CloneAbilityResult"]] = None, + blocking_features: Optional[List["SiteCloneabilityCriterion"]] = None, + unsupported_features: Optional[List["SiteCloneabilityCriterion"]] = None, + blocking_characteristics: Optional[List["SiteCloneabilityCriterion"]] = None, + **kwargs + ): + super(SiteCloneability, self).__init__(**kwargs) + self.result = result + self.blocking_features = blocking_features + self.unsupported_features = unsupported_features + self.blocking_characteristics = blocking_characteristics + + +class SiteCloneabilityCriterion(msrest.serialization.Model): + """An app cloneability criterion. + + :param name: Name of criterion. + :type name: str + :param description: Description of criterion. + :type description: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(SiteCloneabilityCriterion, self).__init__(**kwargs) + self.name = name + self.description = description + + +class SiteConfig(msrest.serialization.Model): + """Configuration of an App Service app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_09_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_09_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_09_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_09_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_09_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_09_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_09_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_09_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_09_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_09_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_09_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_09_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_09_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_09_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'number_of_workers': {'key': 'numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'phpVersion', 'type': 'str'}, + 'python_version': {'key': 'pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'javaVersion', 'type': 'str'}, + 'java_container': {'key': 'javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'experiments', 'type': 'Experiments'}, + 'limits': {'key': 'limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'cors', 'type': 'CorsSettings'}, + 'push': {'key': 'push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + *, + number_of_workers: Optional[int] = None, + default_documents: Optional[List[str]] = None, + net_framework_version: Optional[str] = "v4.6", + php_version: Optional[str] = None, + python_version: Optional[str] = None, + node_version: Optional[str] = None, + power_shell_version: Optional[str] = None, + linux_fx_version: Optional[str] = None, + windows_fx_version: Optional[str] = None, + request_tracing_enabled: Optional[bool] = None, + request_tracing_expiration_time: Optional[datetime.datetime] = None, + remote_debugging_enabled: Optional[bool] = None, + remote_debugging_version: Optional[str] = None, + http_logging_enabled: Optional[bool] = None, + logs_directory_size_limit: Optional[int] = None, + detailed_error_logging_enabled: Optional[bool] = None, + publishing_username: Optional[str] = None, + app_settings: Optional[List["NameValuePair"]] = None, + connection_strings: Optional[List["ConnStringInfo"]] = None, + handler_mappings: Optional[List["HandlerMapping"]] = None, + document_root: Optional[str] = None, + scm_type: Optional[Union[str, "ScmType"]] = None, + use32_bit_worker_process: Optional[bool] = None, + web_sockets_enabled: Optional[bool] = None, + always_on: Optional[bool] = None, + java_version: Optional[str] = None, + java_container: Optional[str] = None, + java_container_version: Optional[str] = None, + app_command_line: Optional[str] = None, + managed_pipeline_mode: Optional[Union[str, "ManagedPipelineMode"]] = None, + virtual_applications: Optional[List["VirtualApplication"]] = None, + load_balancing: Optional[Union[str, "SiteLoadBalancing"]] = None, + experiments: Optional["Experiments"] = None, + limits: Optional["SiteLimits"] = None, + auto_heal_enabled: Optional[bool] = None, + auto_heal_rules: Optional["AutoHealRules"] = None, + tracing_options: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_route_all_enabled: Optional[bool] = None, + vnet_private_ports_count: Optional[int] = None, + cors: Optional["CorsSettings"] = None, + push: Optional["PushSettings"] = None, + api_definition: Optional["ApiDefinitionInfo"] = None, + api_management_config: Optional["ApiManagementConfig"] = None, + auto_swap_slot_name: Optional[str] = None, + local_my_sql_enabled: Optional[bool] = False, + managed_service_identity_id: Optional[int] = None, + x_managed_service_identity_id: Optional[int] = None, + ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions_use_main: Optional[bool] = None, + http20_enabled: Optional[bool] = True, + min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + scm_min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + ftps_state: Optional[Union[str, "FtpsState"]] = None, + pre_warmed_instance_count: Optional[int] = None, + health_check_path: Optional[str] = None, + **kwargs + ): + super(SiteConfig, self).__init__(**kwargs) + self.number_of_workers = number_of_workers + self.default_documents = default_documents + self.net_framework_version = net_framework_version + self.php_version = php_version + self.python_version = python_version + self.node_version = node_version + self.power_shell_version = power_shell_version + self.linux_fx_version = linux_fx_version + self.windows_fx_version = windows_fx_version + self.request_tracing_enabled = request_tracing_enabled + self.request_tracing_expiration_time = request_tracing_expiration_time + self.remote_debugging_enabled = remote_debugging_enabled + self.remote_debugging_version = remote_debugging_version + self.http_logging_enabled = http_logging_enabled + self.logs_directory_size_limit = logs_directory_size_limit + self.detailed_error_logging_enabled = detailed_error_logging_enabled + self.publishing_username = publishing_username + self.app_settings = app_settings + self.connection_strings = connection_strings + self.machine_key = None + self.handler_mappings = handler_mappings + self.document_root = document_root + self.scm_type = scm_type + self.use32_bit_worker_process = use32_bit_worker_process + self.web_sockets_enabled = web_sockets_enabled + self.always_on = always_on + self.java_version = java_version + self.java_container = java_container + self.java_container_version = java_container_version + self.app_command_line = app_command_line + self.managed_pipeline_mode = managed_pipeline_mode + self.virtual_applications = virtual_applications + self.load_balancing = load_balancing + self.experiments = experiments + self.limits = limits + self.auto_heal_enabled = auto_heal_enabled + self.auto_heal_rules = auto_heal_rules + self.tracing_options = tracing_options + self.vnet_name = vnet_name + self.vnet_route_all_enabled = vnet_route_all_enabled + self.vnet_private_ports_count = vnet_private_ports_count + self.cors = cors + self.push = push + self.api_definition = api_definition + self.api_management_config = api_management_config + self.auto_swap_slot_name = auto_swap_slot_name + self.local_my_sql_enabled = local_my_sql_enabled + self.managed_service_identity_id = managed_service_identity_id + self.x_managed_service_identity_id = x_managed_service_identity_id + self.ip_security_restrictions = ip_security_restrictions + self.scm_ip_security_restrictions = scm_ip_security_restrictions + self.scm_ip_security_restrictions_use_main = scm_ip_security_restrictions_use_main + self.http20_enabled = http20_enabled + self.min_tls_version = min_tls_version + self.scm_min_tls_version = scm_min_tls_version + self.ftps_state = ftps_state + self.pre_warmed_instance_count = pre_warmed_instance_count + self.health_check_path = health_check_path + + +class SiteConfigResource(ProxyOnlyResource): + """Web app configuration ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param number_of_workers: Number of workers. + :type number_of_workers: int + :param default_documents: Default documents. + :type default_documents: list[str] + :param net_framework_version: .NET Framework version. + :type net_framework_version: str + :param php_version: Version of PHP. + :type php_version: str + :param python_version: Version of Python. + :type python_version: str + :param node_version: Version of Node.js. + :type node_version: str + :param power_shell_version: Version of PowerShell. + :type power_shell_version: str + :param linux_fx_version: Linux App Framework and version. + :type linux_fx_version: str + :param windows_fx_version: Xenon App Framework and version. + :type windows_fx_version: str + :param request_tracing_enabled: :code:`true` if request tracing is enabled; + otherwise, :code:`false`. + :type request_tracing_enabled: bool + :param request_tracing_expiration_time: Request tracing expiration time. + :type request_tracing_expiration_time: ~datetime.datetime + :param remote_debugging_enabled: :code:`true` if remote debugging is enabled; + otherwise, :code:`false`. + :type remote_debugging_enabled: bool + :param remote_debugging_version: Remote debugging version. + :type remote_debugging_version: str + :param http_logging_enabled: :code:`true` if HTTP logging is enabled; otherwise, + :code:`false`. + :type http_logging_enabled: bool + :param logs_directory_size_limit: HTTP logs directory size limit. + :type logs_directory_size_limit: int + :param detailed_error_logging_enabled: :code:`true` if detailed error logging is + enabled; otherwise, :code:`false`. + :type detailed_error_logging_enabled: bool + :param publishing_username: Publishing user name. + :type publishing_username: str + :param app_settings: Application settings. + :type app_settings: list[~azure.mgmt.web.v2020_09_01.models.NameValuePair] + :param connection_strings: Connection strings. + :type connection_strings: list[~azure.mgmt.web.v2020_09_01.models.ConnStringInfo] + :ivar machine_key: Site MachineKey. + :vartype machine_key: ~azure.mgmt.web.v2020_09_01.models.SiteMachineKey + :param handler_mappings: Handler mappings. + :type handler_mappings: list[~azure.mgmt.web.v2020_09_01.models.HandlerMapping] + :param document_root: Document root. + :type document_root: str + :param scm_type: SCM type. Possible values include: "None", "Dropbox", "Tfs", "LocalGit", + "GitHub", "CodePlexGit", "CodePlexHg", "BitbucketGit", "BitbucketHg", "ExternalGit", + "ExternalHg", "OneDrive", "VSO", "VSTSRM". + :type scm_type: str or ~azure.mgmt.web.v2020_09_01.models.ScmType + :param use32_bit_worker_process: :code:`true` to use 32-bit worker process; + otherwise, :code:`false`. + :type use32_bit_worker_process: bool + :param web_sockets_enabled: :code:`true` if WebSocket is enabled; otherwise, + :code:`false`. + :type web_sockets_enabled: bool + :param always_on: :code:`true` if Always On is enabled; otherwise, + :code:`false`. + :type always_on: bool + :param java_version: Java version. + :type java_version: str + :param java_container: Java container. + :type java_container: str + :param java_container_version: Java container version. + :type java_container_version: str + :param app_command_line: App command line to launch. + :type app_command_line: str + :param managed_pipeline_mode: Managed pipeline mode. Possible values include: "Integrated", + "Classic". + :type managed_pipeline_mode: str or ~azure.mgmt.web.v2020_09_01.models.ManagedPipelineMode + :param virtual_applications: Virtual applications. + :type virtual_applications: list[~azure.mgmt.web.v2020_09_01.models.VirtualApplication] + :param load_balancing: Site load balancing. Possible values include: "WeightedRoundRobin", + "LeastRequests", "LeastResponseTime", "WeightedTotalTraffic", "RequestHash". + :type load_balancing: str or ~azure.mgmt.web.v2020_09_01.models.SiteLoadBalancing + :param experiments: This is work around for polymorphic types. + :type experiments: ~azure.mgmt.web.v2020_09_01.models.Experiments + :param limits: Site limits. + :type limits: ~azure.mgmt.web.v2020_09_01.models.SiteLimits + :param auto_heal_enabled: :code:`true` if Auto Heal is enabled; otherwise, + :code:`false`. + :type auto_heal_enabled: bool + :param auto_heal_rules: Auto Heal rules. + :type auto_heal_rules: ~azure.mgmt.web.v2020_09_01.models.AutoHealRules + :param tracing_options: Tracing options. + :type tracing_options: str + :param vnet_name: Virtual Network name. + :type vnet_name: str + :param vnet_route_all_enabled: Virtual Network Route All enabled. This causes all outbound + traffic to have Virtual Network Security Groups and User Defined Routes applied. + :type vnet_route_all_enabled: bool + :param vnet_private_ports_count: The number of private ports assigned to this app. These will + be assigned dynamically on runtime. + :type vnet_private_ports_count: int + :param cors: Cross-Origin Resource Sharing (CORS) settings. + :type cors: ~azure.mgmt.web.v2020_09_01.models.CorsSettings + :param push: Push endpoint settings. + :type push: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :param api_definition: Information about the formal API definition for the app. + :type api_definition: ~azure.mgmt.web.v2020_09_01.models.ApiDefinitionInfo + :param api_management_config: Azure API management settings linked to the app. + :type api_management_config: ~azure.mgmt.web.v2020_09_01.models.ApiManagementConfig + :param auto_swap_slot_name: Auto-swap slot name. + :type auto_swap_slot_name: str + :param local_my_sql_enabled: :code:`true` to enable local MySQL; otherwise, + :code:`false`. + :type local_my_sql_enabled: bool + :param managed_service_identity_id: Managed Service Identity Id. + :type managed_service_identity_id: int + :param x_managed_service_identity_id: Explicit Managed Service Identity Id. + :type x_managed_service_identity_id: int + :param ip_security_restrictions: IP security restrictions for main. + :type ip_security_restrictions: list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions: IP security restrictions for scm. + :type scm_ip_security_restrictions: + list[~azure.mgmt.web.v2020_09_01.models.IpSecurityRestriction] + :param scm_ip_security_restrictions_use_main: IP security restrictions for scm to use main. + :type scm_ip_security_restrictions_use_main: bool + :param http20_enabled: Http20Enabled: configures a web site to allow clients to connect over + http2.0. + :type http20_enabled: bool + :param min_tls_version: MinTlsVersion: configures the minimum version of TLS required for SSL + requests. Possible values include: "1.0", "1.1", "1.2". + :type min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param scm_min_tls_version: ScmMinTlsVersion: configures the minimum version of TLS required + for SSL requests for SCM site. Possible values include: "1.0", "1.1", "1.2". + :type scm_min_tls_version: str or ~azure.mgmt.web.v2020_09_01.models.SupportedTlsVersions + :param ftps_state: State of FTP / FTPS service. Possible values include: "AllAllowed", + "FtpsOnly", "Disabled". + :type ftps_state: str or ~azure.mgmt.web.v2020_09_01.models.FtpsState + :param pre_warmed_instance_count: Number of preWarmed instances. + This setting only applies to the Consumption and Elastic Plans. + :type pre_warmed_instance_count: int + :param health_check_path: Health check path. + :type health_check_path: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'machine_key': {'readonly': True}, + 'pre_warmed_instance_count': {'maximum': 10, 'minimum': 0}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'number_of_workers': {'key': 'properties.numberOfWorkers', 'type': 'int'}, + 'default_documents': {'key': 'properties.defaultDocuments', 'type': '[str]'}, + 'net_framework_version': {'key': 'properties.netFrameworkVersion', 'type': 'str'}, + 'php_version': {'key': 'properties.phpVersion', 'type': 'str'}, + 'python_version': {'key': 'properties.pythonVersion', 'type': 'str'}, + 'node_version': {'key': 'properties.nodeVersion', 'type': 'str'}, + 'power_shell_version': {'key': 'properties.powerShellVersion', 'type': 'str'}, + 'linux_fx_version': {'key': 'properties.linuxFxVersion', 'type': 'str'}, + 'windows_fx_version': {'key': 'properties.windowsFxVersion', 'type': 'str'}, + 'request_tracing_enabled': {'key': 'properties.requestTracingEnabled', 'type': 'bool'}, + 'request_tracing_expiration_time': {'key': 'properties.requestTracingExpirationTime', 'type': 'iso-8601'}, + 'remote_debugging_enabled': {'key': 'properties.remoteDebuggingEnabled', 'type': 'bool'}, + 'remote_debugging_version': {'key': 'properties.remoteDebuggingVersion', 'type': 'str'}, + 'http_logging_enabled': {'key': 'properties.httpLoggingEnabled', 'type': 'bool'}, + 'logs_directory_size_limit': {'key': 'properties.logsDirectorySizeLimit', 'type': 'int'}, + 'detailed_error_logging_enabled': {'key': 'properties.detailedErrorLoggingEnabled', 'type': 'bool'}, + 'publishing_username': {'key': 'properties.publishingUsername', 'type': 'str'}, + 'app_settings': {'key': 'properties.appSettings', 'type': '[NameValuePair]'}, + 'connection_strings': {'key': 'properties.connectionStrings', 'type': '[ConnStringInfo]'}, + 'machine_key': {'key': 'properties.machineKey', 'type': 'SiteMachineKey'}, + 'handler_mappings': {'key': 'properties.handlerMappings', 'type': '[HandlerMapping]'}, + 'document_root': {'key': 'properties.documentRoot', 'type': 'str'}, + 'scm_type': {'key': 'properties.scmType', 'type': 'str'}, + 'use32_bit_worker_process': {'key': 'properties.use32BitWorkerProcess', 'type': 'bool'}, + 'web_sockets_enabled': {'key': 'properties.webSocketsEnabled', 'type': 'bool'}, + 'always_on': {'key': 'properties.alwaysOn', 'type': 'bool'}, + 'java_version': {'key': 'properties.javaVersion', 'type': 'str'}, + 'java_container': {'key': 'properties.javaContainer', 'type': 'str'}, + 'java_container_version': {'key': 'properties.javaContainerVersion', 'type': 'str'}, + 'app_command_line': {'key': 'properties.appCommandLine', 'type': 'str'}, + 'managed_pipeline_mode': {'key': 'properties.managedPipelineMode', 'type': 'str'}, + 'virtual_applications': {'key': 'properties.virtualApplications', 'type': '[VirtualApplication]'}, + 'load_balancing': {'key': 'properties.loadBalancing', 'type': 'str'}, + 'experiments': {'key': 'properties.experiments', 'type': 'Experiments'}, + 'limits': {'key': 'properties.limits', 'type': 'SiteLimits'}, + 'auto_heal_enabled': {'key': 'properties.autoHealEnabled', 'type': 'bool'}, + 'auto_heal_rules': {'key': 'properties.autoHealRules', 'type': 'AutoHealRules'}, + 'tracing_options': {'key': 'properties.tracingOptions', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_route_all_enabled': {'key': 'properties.vnetRouteAllEnabled', 'type': 'bool'}, + 'vnet_private_ports_count': {'key': 'properties.vnetPrivatePortsCount', 'type': 'int'}, + 'cors': {'key': 'properties.cors', 'type': 'CorsSettings'}, + 'push': {'key': 'properties.push', 'type': 'PushSettings'}, + 'api_definition': {'key': 'properties.apiDefinition', 'type': 'ApiDefinitionInfo'}, + 'api_management_config': {'key': 'properties.apiManagementConfig', 'type': 'ApiManagementConfig'}, + 'auto_swap_slot_name': {'key': 'properties.autoSwapSlotName', 'type': 'str'}, + 'local_my_sql_enabled': {'key': 'properties.localMySqlEnabled', 'type': 'bool'}, + 'managed_service_identity_id': {'key': 'properties.managedServiceIdentityId', 'type': 'int'}, + 'x_managed_service_identity_id': {'key': 'properties.xManagedServiceIdentityId', 'type': 'int'}, + 'ip_security_restrictions': {'key': 'properties.ipSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions': {'key': 'properties.scmIpSecurityRestrictions', 'type': '[IpSecurityRestriction]'}, + 'scm_ip_security_restrictions_use_main': {'key': 'properties.scmIpSecurityRestrictionsUseMain', 'type': 'bool'}, + 'http20_enabled': {'key': 'properties.http20Enabled', 'type': 'bool'}, + 'min_tls_version': {'key': 'properties.minTlsVersion', 'type': 'str'}, + 'scm_min_tls_version': {'key': 'properties.scmMinTlsVersion', 'type': 'str'}, + 'ftps_state': {'key': 'properties.ftpsState', 'type': 'str'}, + 'pre_warmed_instance_count': {'key': 'properties.preWarmedInstanceCount', 'type': 'int'}, + 'health_check_path': {'key': 'properties.healthCheckPath', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + number_of_workers: Optional[int] = None, + default_documents: Optional[List[str]] = None, + net_framework_version: Optional[str] = "v4.6", + php_version: Optional[str] = None, + python_version: Optional[str] = None, + node_version: Optional[str] = None, + power_shell_version: Optional[str] = None, + linux_fx_version: Optional[str] = None, + windows_fx_version: Optional[str] = None, + request_tracing_enabled: Optional[bool] = None, + request_tracing_expiration_time: Optional[datetime.datetime] = None, + remote_debugging_enabled: Optional[bool] = None, + remote_debugging_version: Optional[str] = None, + http_logging_enabled: Optional[bool] = None, + logs_directory_size_limit: Optional[int] = None, + detailed_error_logging_enabled: Optional[bool] = None, + publishing_username: Optional[str] = None, + app_settings: Optional[List["NameValuePair"]] = None, + connection_strings: Optional[List["ConnStringInfo"]] = None, + handler_mappings: Optional[List["HandlerMapping"]] = None, + document_root: Optional[str] = None, + scm_type: Optional[Union[str, "ScmType"]] = None, + use32_bit_worker_process: Optional[bool] = None, + web_sockets_enabled: Optional[bool] = None, + always_on: Optional[bool] = None, + java_version: Optional[str] = None, + java_container: Optional[str] = None, + java_container_version: Optional[str] = None, + app_command_line: Optional[str] = None, + managed_pipeline_mode: Optional[Union[str, "ManagedPipelineMode"]] = None, + virtual_applications: Optional[List["VirtualApplication"]] = None, + load_balancing: Optional[Union[str, "SiteLoadBalancing"]] = None, + experiments: Optional["Experiments"] = None, + limits: Optional["SiteLimits"] = None, + auto_heal_enabled: Optional[bool] = None, + auto_heal_rules: Optional["AutoHealRules"] = None, + tracing_options: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_route_all_enabled: Optional[bool] = None, + vnet_private_ports_count: Optional[int] = None, + cors: Optional["CorsSettings"] = None, + push: Optional["PushSettings"] = None, + api_definition: Optional["ApiDefinitionInfo"] = None, + api_management_config: Optional["ApiManagementConfig"] = None, + auto_swap_slot_name: Optional[str] = None, + local_my_sql_enabled: Optional[bool] = False, + managed_service_identity_id: Optional[int] = None, + x_managed_service_identity_id: Optional[int] = None, + ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions: Optional[List["IpSecurityRestriction"]] = None, + scm_ip_security_restrictions_use_main: Optional[bool] = None, + http20_enabled: Optional[bool] = True, + min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + scm_min_tls_version: Optional[Union[str, "SupportedTlsVersions"]] = None, + ftps_state: Optional[Union[str, "FtpsState"]] = None, + pre_warmed_instance_count: Optional[int] = None, + health_check_path: Optional[str] = None, + **kwargs + ): + super(SiteConfigResource, self).__init__(kind=kind, **kwargs) + self.number_of_workers = number_of_workers + self.default_documents = default_documents + self.net_framework_version = net_framework_version + self.php_version = php_version + self.python_version = python_version + self.node_version = node_version + self.power_shell_version = power_shell_version + self.linux_fx_version = linux_fx_version + self.windows_fx_version = windows_fx_version + self.request_tracing_enabled = request_tracing_enabled + self.request_tracing_expiration_time = request_tracing_expiration_time + self.remote_debugging_enabled = remote_debugging_enabled + self.remote_debugging_version = remote_debugging_version + self.http_logging_enabled = http_logging_enabled + self.logs_directory_size_limit = logs_directory_size_limit + self.detailed_error_logging_enabled = detailed_error_logging_enabled + self.publishing_username = publishing_username + self.app_settings = app_settings + self.connection_strings = connection_strings + self.machine_key = None + self.handler_mappings = handler_mappings + self.document_root = document_root + self.scm_type = scm_type + self.use32_bit_worker_process = use32_bit_worker_process + self.web_sockets_enabled = web_sockets_enabled + self.always_on = always_on + self.java_version = java_version + self.java_container = java_container + self.java_container_version = java_container_version + self.app_command_line = app_command_line + self.managed_pipeline_mode = managed_pipeline_mode + self.virtual_applications = virtual_applications + self.load_balancing = load_balancing + self.experiments = experiments + self.limits = limits + self.auto_heal_enabled = auto_heal_enabled + self.auto_heal_rules = auto_heal_rules + self.tracing_options = tracing_options + self.vnet_name = vnet_name + self.vnet_route_all_enabled = vnet_route_all_enabled + self.vnet_private_ports_count = vnet_private_ports_count + self.cors = cors + self.push = push + self.api_definition = api_definition + self.api_management_config = api_management_config + self.auto_swap_slot_name = auto_swap_slot_name + self.local_my_sql_enabled = local_my_sql_enabled + self.managed_service_identity_id = managed_service_identity_id + self.x_managed_service_identity_id = x_managed_service_identity_id + self.ip_security_restrictions = ip_security_restrictions + self.scm_ip_security_restrictions = scm_ip_security_restrictions + self.scm_ip_security_restrictions_use_main = scm_ip_security_restrictions_use_main + self.http20_enabled = http20_enabled + self.min_tls_version = min_tls_version + self.scm_min_tls_version = scm_min_tls_version + self.ftps_state = ftps_state + self.pre_warmed_instance_count = pre_warmed_instance_count + self.health_check_path = health_check_path + + +class SiteConfigResourceCollection(msrest.serialization.Model): + """Collection of site configurations. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteConfigResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteConfigResource"], + **kwargs + ): + super(SiteConfigResourceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteConfigurationSnapshotInfo(ProxyOnlyResource): + """A snapshot of a web app configuration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar time: The time the snapshot was taken. + :vartype time: ~datetime.datetime + :ivar snapshot_id: The id of the snapshot. + :vartype snapshot_id: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'time': {'readonly': True}, + 'snapshot_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'time': {'key': 'properties.time', 'type': 'iso-8601'}, + 'snapshot_id': {'key': 'properties.snapshotId', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(SiteConfigurationSnapshotInfo, self).__init__(kind=kind, **kwargs) + self.time = None + self.snapshot_id = None + + +class SiteConfigurationSnapshotInfoCollection(msrest.serialization.Model): + """Collection of metadata for the app configuration snapshots that can be restored. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteConfigurationSnapshotInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteConfigurationSnapshotInfo"], + **kwargs + ): + super(SiteConfigurationSnapshotInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteExtensionInfo(ProxyOnlyResource): + """Site Extension Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param extension_id: Site extension ID. + :type extension_id: str + :param title: + :type title: str + :param extension_type: Site extension type. Possible values include: "Gallery", "WebRoot". + :type extension_type: str or ~azure.mgmt.web.v2020_09_01.models.SiteExtensionType + :param summary: Summary description. + :type summary: str + :param description: Detailed description. + :type description: str + :param version: Version information. + :type version: str + :param extension_url: Extension URL. + :type extension_url: str + :param project_url: Project URL. + :type project_url: str + :param icon_url: Icon URL. + :type icon_url: str + :param license_url: License URL. + :type license_url: str + :param feed_url: Feed URL. + :type feed_url: str + :param authors: List of authors. + :type authors: list[str] + :param installer_command_line_params: Installer command line parameters. + :type installer_command_line_params: str + :param published_date_time: Published timestamp. + :type published_date_time: ~datetime.datetime + :param download_count: Count of downloads. + :type download_count: int + :param local_is_latest_version: :code:`true` if the local version is the latest + version; :code:`false` otherwise. + :type local_is_latest_version: bool + :param local_path: Local path. + :type local_path: str + :param installed_date_time: Installed timestamp. + :type installed_date_time: ~datetime.datetime + :param provisioning_state: Provisioning state. + :type provisioning_state: str + :param comment: Site Extension comment. + :type comment: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'extension_id': {'key': 'properties.extension_id', 'type': 'str'}, + 'title': {'key': 'properties.title', 'type': 'str'}, + 'extension_type': {'key': 'properties.extension_type', 'type': 'str'}, + 'summary': {'key': 'properties.summary', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'extension_url': {'key': 'properties.extension_url', 'type': 'str'}, + 'project_url': {'key': 'properties.project_url', 'type': 'str'}, + 'icon_url': {'key': 'properties.icon_url', 'type': 'str'}, + 'license_url': {'key': 'properties.license_url', 'type': 'str'}, + 'feed_url': {'key': 'properties.feed_url', 'type': 'str'}, + 'authors': {'key': 'properties.authors', 'type': '[str]'}, + 'installer_command_line_params': {'key': 'properties.installer_command_line_params', 'type': 'str'}, + 'published_date_time': {'key': 'properties.published_date_time', 'type': 'iso-8601'}, + 'download_count': {'key': 'properties.download_count', 'type': 'int'}, + 'local_is_latest_version': {'key': 'properties.local_is_latest_version', 'type': 'bool'}, + 'local_path': {'key': 'properties.local_path', 'type': 'str'}, + 'installed_date_time': {'key': 'properties.installed_date_time', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'comment': {'key': 'properties.comment', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + extension_id: Optional[str] = None, + title: Optional[str] = None, + extension_type: Optional[Union[str, "SiteExtensionType"]] = None, + summary: Optional[str] = None, + description: Optional[str] = None, + version: Optional[str] = None, + extension_url: Optional[str] = None, + project_url: Optional[str] = None, + icon_url: Optional[str] = None, + license_url: Optional[str] = None, + feed_url: Optional[str] = None, + authors: Optional[List[str]] = None, + installer_command_line_params: Optional[str] = None, + published_date_time: Optional[datetime.datetime] = None, + download_count: Optional[int] = None, + local_is_latest_version: Optional[bool] = None, + local_path: Optional[str] = None, + installed_date_time: Optional[datetime.datetime] = None, + provisioning_state: Optional[str] = None, + comment: Optional[str] = None, + **kwargs + ): + super(SiteExtensionInfo, self).__init__(kind=kind, **kwargs) + self.extension_id = extension_id + self.title = title + self.extension_type = extension_type + self.summary = summary + self.description = description + self.version = version + self.extension_url = extension_url + self.project_url = project_url + self.icon_url = icon_url + self.license_url = license_url + self.feed_url = feed_url + self.authors = authors + self.installer_command_line_params = installer_command_line_params + self.published_date_time = published_date_time + self.download_count = download_count + self.local_is_latest_version = local_is_latest_version + self.local_path = local_path + self.installed_date_time = installed_date_time + self.provisioning_state = provisioning_state + self.comment = comment + + +class SiteExtensionInfoCollection(msrest.serialization.Model): + """Collection of Kudu site extension information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SiteExtensionInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SiteExtensionInfo"], + **kwargs + ): + super(SiteExtensionInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SiteLimits(msrest.serialization.Model): + """Metric limits set on an app. + + :param max_percentage_cpu: Maximum allowed CPU usage percentage. + :type max_percentage_cpu: float + :param max_memory_in_mb: Maximum allowed memory usage in MB. + :type max_memory_in_mb: long + :param max_disk_size_in_mb: Maximum allowed disk size usage in MB. + :type max_disk_size_in_mb: long + """ + + _attribute_map = { + 'max_percentage_cpu': {'key': 'maxPercentageCpu', 'type': 'float'}, + 'max_memory_in_mb': {'key': 'maxMemoryInMb', 'type': 'long'}, + 'max_disk_size_in_mb': {'key': 'maxDiskSizeInMb', 'type': 'long'}, + } + + def __init__( + self, + *, + max_percentage_cpu: Optional[float] = None, + max_memory_in_mb: Optional[int] = None, + max_disk_size_in_mb: Optional[int] = None, + **kwargs + ): + super(SiteLimits, self).__init__(**kwargs) + self.max_percentage_cpu = max_percentage_cpu + self.max_memory_in_mb = max_memory_in_mb + self.max_disk_size_in_mb = max_disk_size_in_mb + + +class SiteLogsConfig(ProxyOnlyResource): + """Configuration of App Service site logs. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param application_logs: Application logs configuration. + :type application_logs: ~azure.mgmt.web.v2020_09_01.models.ApplicationLogsConfig + :param http_logs: HTTP logs configuration. + :type http_logs: ~azure.mgmt.web.v2020_09_01.models.HttpLogsConfig + :param failed_requests_tracing: Failed requests tracing configuration. + :type failed_requests_tracing: ~azure.mgmt.web.v2020_09_01.models.EnabledConfig + :param detailed_error_messages: Detailed error messages configuration. + :type detailed_error_messages: ~azure.mgmt.web.v2020_09_01.models.EnabledConfig + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'application_logs': {'key': 'properties.applicationLogs', 'type': 'ApplicationLogsConfig'}, + 'http_logs': {'key': 'properties.httpLogs', 'type': 'HttpLogsConfig'}, + 'failed_requests_tracing': {'key': 'properties.failedRequestsTracing', 'type': 'EnabledConfig'}, + 'detailed_error_messages': {'key': 'properties.detailedErrorMessages', 'type': 'EnabledConfig'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + application_logs: Optional["ApplicationLogsConfig"] = None, + http_logs: Optional["HttpLogsConfig"] = None, + failed_requests_tracing: Optional["EnabledConfig"] = None, + detailed_error_messages: Optional["EnabledConfig"] = None, + **kwargs + ): + super(SiteLogsConfig, self).__init__(kind=kind, **kwargs) + self.application_logs = application_logs + self.http_logs = http_logs + self.failed_requests_tracing = failed_requests_tracing + self.detailed_error_messages = detailed_error_messages + + +class SiteMachineKey(msrest.serialization.Model): + """MachineKey of an app. + + :param validation: MachineKey validation. + :type validation: str + :param validation_key: Validation key. + :type validation_key: str + :param decryption: Algorithm used for decryption. + :type decryption: str + :param decryption_key: Decryption key. + :type decryption_key: str + """ + + _attribute_map = { + 'validation': {'key': 'validation', 'type': 'str'}, + 'validation_key': {'key': 'validationKey', 'type': 'str'}, + 'decryption': {'key': 'decryption', 'type': 'str'}, + 'decryption_key': {'key': 'decryptionKey', 'type': 'str'}, + } + + def __init__( + self, + *, + validation: Optional[str] = None, + validation_key: Optional[str] = None, + decryption: Optional[str] = None, + decryption_key: Optional[str] = None, + **kwargs + ): + super(SiteMachineKey, self).__init__(**kwargs) + self.validation = validation + self.validation_key = validation_key + self.decryption = decryption + self.decryption_key = decryption_key + + +class SitePatchResource(ProxyOnlyResource): + """ARM resource for a site. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param identity: Managed service identity. + :type identity: ~azure.mgmt.web.v2020_09_01.models.ManagedServiceIdentity + :ivar state: Current state of the app. + :vartype state: str + :ivar host_names: Hostnames associated with the app. + :vartype host_names: list[str] + :ivar repository_site_name: Name of the repository site. + :vartype repository_site_name: str + :ivar usage_state: State indicating whether the app has exceeded its quota usage. Read-only. + Possible values include: "Normal", "Exceeded". + :vartype usage_state: str or ~azure.mgmt.web.v2020_09_01.models.UsageState + :param enabled: :code:`true` if the app is enabled; otherwise, + :code:`false`. Setting this value to false disables the app (takes the app + offline). + :type enabled: bool + :ivar enabled_host_names: Enabled hostnames for the app.Hostnames need to be assigned (see + HostNames) AND enabled. Otherwise, + the app is not served on those hostnames. + :vartype enabled_host_names: list[str] + :ivar availability_state: Management information availability state for the app. Possible + values include: "Normal", "Limited", "DisasterRecoveryMode". + :vartype availability_state: str or ~azure.mgmt.web.v2020_09_01.models.SiteAvailabilityState + :param host_name_ssl_states: Hostname SSL states are used to manage the SSL bindings for app's + hostnames. + :type host_name_ssl_states: list[~azure.mgmt.web.v2020_09_01.models.HostNameSslState] + :param server_farm_id: Resource ID of the associated App Service plan, formatted as: + "/subscriptions/{subscriptionID}/resourceGroups/{groupName}/providers/Microsoft.Web/serverfarms/{appServicePlanName}". + :type server_farm_id: str + :param reserved: :code:`true` if reserved; otherwise, :code:`false`. + :type reserved: bool + :param is_xenon: Obsolete: Hyper-V sandbox. + :type is_xenon: bool + :param hyper_v: Hyper-V sandbox. + :type hyper_v: bool + :ivar last_modified_time_utc: Last time the app was modified, in UTC. Read-only. + :vartype last_modified_time_utc: ~datetime.datetime + :param site_config: Configuration of the app. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfig + :ivar traffic_manager_host_names: Azure Traffic Manager hostnames associated with the app. + Read-only. + :vartype traffic_manager_host_names: list[str] + :param scm_site_also_stopped: :code:`true` to stop SCM (KUDU) site when the app is + stopped; otherwise, :code:`false`. The default is :code:`false`. + :type scm_site_also_stopped: bool + :ivar target_swap_slot: Specifies which deployment slot this app will swap into. Read-only. + :vartype target_swap_slot: str + :param hosting_environment_profile: App Service Environment to use for the app. + :type hosting_environment_profile: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentProfile + :param client_affinity_enabled: :code:`true` to enable client affinity; + :code:`false` to stop sending session affinity cookies, which route client + requests in the same session to the same instance. Default is :code:`true`. + :type client_affinity_enabled: bool + :param client_cert_enabled: :code:`true` to enable client certificate + authentication (TLS mutual authentication); otherwise, :code:`false`. Default is + :code:`false`. + :type client_cert_enabled: bool + :param client_cert_mode: This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. Possible values include: "Required", "Optional". + :type client_cert_mode: str or ~azure.mgmt.web.v2020_09_01.models.ClientCertMode + :param client_cert_exclusion_paths: client certificate authentication comma-separated exclusion + paths. + :type client_cert_exclusion_paths: str + :param host_names_disabled: :code:`true` to disable the public hostnames of the + app; otherwise, :code:`false`. + If :code:`true`, the app is only accessible via API management process. + :type host_names_disabled: bool + :param custom_domain_verification_id: Unique identifier that verifies the custom domains + assigned to the app. Customer will add this id to a txt record for verification. + :type custom_domain_verification_id: str + :ivar outbound_ip_addresses: List of IP addresses that the app uses for outbound connections + (e.g. database access). Includes VIPs from tenants that site can be hosted with current + settings. Read-only. + :vartype outbound_ip_addresses: str + :ivar possible_outbound_ip_addresses: List of IP addresses that the app uses for outbound + connections (e.g. database access). Includes VIPs from all tenants except dataComponent. Read- + only. + :vartype possible_outbound_ip_addresses: str + :param container_size: Size of the function container. + :type container_size: int + :param daily_memory_time_quota: Maximum allowed daily memory-time quota (applicable on dynamic + apps only). + :type daily_memory_time_quota: int + :ivar suspended_till: App suspended till in case memory-time quota is exceeded. + :vartype suspended_till: ~datetime.datetime + :ivar max_number_of_workers: Maximum number of workers. + This only applies to Functions container. + :vartype max_number_of_workers: int + :param cloning_info: If specified during app creation, the app is cloned from a source app. + :type cloning_info: ~azure.mgmt.web.v2020_09_01.models.CloningInfo + :ivar resource_group: Name of the resource group the app belongs to. Read-only. + :vartype resource_group: str + :ivar is_default_container: :code:`true` if the app is a default container; + otherwise, :code:`false`. + :vartype is_default_container: bool + :ivar default_host_name: Default hostname of the app. Read-only. + :vartype default_host_name: str + :ivar slot_swap_status: Status of the last deployment slot swap operation. + :vartype slot_swap_status: ~azure.mgmt.web.v2020_09_01.models.SlotSwapStatus + :param https_only: HttpsOnly: configures a web site to accept only https requests. Issues + redirect for + http requests. + :type https_only: bool + :param redundancy_mode: Site redundancy mode. Possible values include: "None", "Manual", + "Failover", "ActiveActive", "GeoRedundant". + :type redundancy_mode: str or ~azure.mgmt.web.v2020_09_01.models.RedundancyMode + :ivar in_progress_operation_id: Specifies an operation id if this site has a pending operation. + :vartype in_progress_operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'state': {'readonly': True}, + 'host_names': {'readonly': True}, + 'repository_site_name': {'readonly': True}, + 'usage_state': {'readonly': True}, + 'enabled_host_names': {'readonly': True}, + 'availability_state': {'readonly': True}, + 'last_modified_time_utc': {'readonly': True}, + 'traffic_manager_host_names': {'readonly': True}, + 'target_swap_slot': {'readonly': True}, + 'outbound_ip_addresses': {'readonly': True}, + 'possible_outbound_ip_addresses': {'readonly': True}, + 'suspended_till': {'readonly': True}, + 'max_number_of_workers': {'readonly': True}, + 'resource_group': {'readonly': True}, + 'is_default_container': {'readonly': True}, + 'default_host_name': {'readonly': True}, + 'slot_swap_status': {'readonly': True}, + 'in_progress_operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedServiceIdentity'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'host_names': {'key': 'properties.hostNames', 'type': '[str]'}, + 'repository_site_name': {'key': 'properties.repositorySiteName', 'type': 'str'}, + 'usage_state': {'key': 'properties.usageState', 'type': 'str'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'enabled_host_names': {'key': 'properties.enabledHostNames', 'type': '[str]'}, + 'availability_state': {'key': 'properties.availabilityState', 'type': 'str'}, + 'host_name_ssl_states': {'key': 'properties.hostNameSslStates', 'type': '[HostNameSslState]'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'reserved': {'key': 'properties.reserved', 'type': 'bool'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'hyper_v': {'key': 'properties.hyperV', 'type': 'bool'}, + 'last_modified_time_utc': {'key': 'properties.lastModifiedTimeUtc', 'type': 'iso-8601'}, + 'site_config': {'key': 'properties.siteConfig', 'type': 'SiteConfig'}, + 'traffic_manager_host_names': {'key': 'properties.trafficManagerHostNames', 'type': '[str]'}, + 'scm_site_also_stopped': {'key': 'properties.scmSiteAlsoStopped', 'type': 'bool'}, + 'target_swap_slot': {'key': 'properties.targetSwapSlot', 'type': 'str'}, + 'hosting_environment_profile': {'key': 'properties.hostingEnvironmentProfile', 'type': 'HostingEnvironmentProfile'}, + 'client_affinity_enabled': {'key': 'properties.clientAffinityEnabled', 'type': 'bool'}, + 'client_cert_enabled': {'key': 'properties.clientCertEnabled', 'type': 'bool'}, + 'client_cert_mode': {'key': 'properties.clientCertMode', 'type': 'str'}, + 'client_cert_exclusion_paths': {'key': 'properties.clientCertExclusionPaths', 'type': 'str'}, + 'host_names_disabled': {'key': 'properties.hostNamesDisabled', 'type': 'bool'}, + 'custom_domain_verification_id': {'key': 'properties.customDomainVerificationId', 'type': 'str'}, + 'outbound_ip_addresses': {'key': 'properties.outboundIpAddresses', 'type': 'str'}, + 'possible_outbound_ip_addresses': {'key': 'properties.possibleOutboundIpAddresses', 'type': 'str'}, + 'container_size': {'key': 'properties.containerSize', 'type': 'int'}, + 'daily_memory_time_quota': {'key': 'properties.dailyMemoryTimeQuota', 'type': 'int'}, + 'suspended_till': {'key': 'properties.suspendedTill', 'type': 'iso-8601'}, + 'max_number_of_workers': {'key': 'properties.maxNumberOfWorkers', 'type': 'int'}, + 'cloning_info': {'key': 'properties.cloningInfo', 'type': 'CloningInfo'}, + 'resource_group': {'key': 'properties.resourceGroup', 'type': 'str'}, + 'is_default_container': {'key': 'properties.isDefaultContainer', 'type': 'bool'}, + 'default_host_name': {'key': 'properties.defaultHostName', 'type': 'str'}, + 'slot_swap_status': {'key': 'properties.slotSwapStatus', 'type': 'SlotSwapStatus'}, + 'https_only': {'key': 'properties.httpsOnly', 'type': 'bool'}, + 'redundancy_mode': {'key': 'properties.redundancyMode', 'type': 'str'}, + 'in_progress_operation_id': {'key': 'properties.inProgressOperationId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + identity: Optional["ManagedServiceIdentity"] = None, + enabled: Optional[bool] = None, + host_name_ssl_states: Optional[List["HostNameSslState"]] = None, + server_farm_id: Optional[str] = None, + reserved: Optional[bool] = False, + is_xenon: Optional[bool] = False, + hyper_v: Optional[bool] = False, + site_config: Optional["SiteConfig"] = None, + scm_site_also_stopped: Optional[bool] = False, + hosting_environment_profile: Optional["HostingEnvironmentProfile"] = None, + client_affinity_enabled: Optional[bool] = None, + client_cert_enabled: Optional[bool] = None, + client_cert_mode: Optional[Union[str, "ClientCertMode"]] = None, + client_cert_exclusion_paths: Optional[str] = None, + host_names_disabled: Optional[bool] = None, + custom_domain_verification_id: Optional[str] = None, + container_size: Optional[int] = None, + daily_memory_time_quota: Optional[int] = None, + cloning_info: Optional["CloningInfo"] = None, + https_only: Optional[bool] = None, + redundancy_mode: Optional[Union[str, "RedundancyMode"]] = None, + **kwargs + ): + super(SitePatchResource, self).__init__(kind=kind, **kwargs) + self.identity = identity + self.state = None + self.host_names = None + self.repository_site_name = None + self.usage_state = None + self.enabled = enabled + self.enabled_host_names = None + self.availability_state = None + self.host_name_ssl_states = host_name_ssl_states + self.server_farm_id = server_farm_id + self.reserved = reserved + self.is_xenon = is_xenon + self.hyper_v = hyper_v + self.last_modified_time_utc = None + self.site_config = site_config + self.traffic_manager_host_names = None + self.scm_site_also_stopped = scm_site_also_stopped + self.target_swap_slot = None + self.hosting_environment_profile = hosting_environment_profile + self.client_affinity_enabled = client_affinity_enabled + self.client_cert_enabled = client_cert_enabled + self.client_cert_mode = client_cert_mode + self.client_cert_exclusion_paths = client_cert_exclusion_paths + self.host_names_disabled = host_names_disabled + self.custom_domain_verification_id = custom_domain_verification_id + self.outbound_ip_addresses = None + self.possible_outbound_ip_addresses = None + self.container_size = container_size + self.daily_memory_time_quota = daily_memory_time_quota + self.suspended_till = None + self.max_number_of_workers = None + self.cloning_info = cloning_info + self.resource_group = None + self.is_default_container = None + self.default_host_name = None + self.slot_swap_status = None + self.https_only = https_only + self.redundancy_mode = redundancy_mode + self.in_progress_operation_id = None + + +class SitePhpErrorLogFlag(ProxyOnlyResource): + """Used for getting PHP error logging flag. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param local_log_errors: Local log_errors setting. + :type local_log_errors: str + :param master_log_errors: Master log_errors setting. + :type master_log_errors: str + :param local_log_errors_max_length: Local log_errors_max_len setting. + :type local_log_errors_max_length: str + :param master_log_errors_max_length: Master log_errors_max_len setting. + :type master_log_errors_max_length: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'local_log_errors': {'key': 'properties.localLogErrors', 'type': 'str'}, + 'master_log_errors': {'key': 'properties.masterLogErrors', 'type': 'str'}, + 'local_log_errors_max_length': {'key': 'properties.localLogErrorsMaxLength', 'type': 'str'}, + 'master_log_errors_max_length': {'key': 'properties.masterLogErrorsMaxLength', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + local_log_errors: Optional[str] = None, + master_log_errors: Optional[str] = None, + local_log_errors_max_length: Optional[str] = None, + master_log_errors_max_length: Optional[str] = None, + **kwargs + ): + super(SitePhpErrorLogFlag, self).__init__(kind=kind, **kwargs) + self.local_log_errors = local_log_errors + self.master_log_errors = master_log_errors + self.local_log_errors_max_length = local_log_errors_max_length + self.master_log_errors_max_length = master_log_errors_max_length + + +class SiteSeal(msrest.serialization.Model): + """Site seal. + + All required parameters must be populated in order to send to Azure. + + :param html: Required. HTML snippet. + :type html: str + """ + + _validation = { + 'html': {'required': True}, + } + + _attribute_map = { + 'html': {'key': 'html', 'type': 'str'}, + } + + def __init__( + self, + *, + html: str, + **kwargs + ): + super(SiteSeal, self).__init__(**kwargs) + self.html = html + + +class SiteSealRequest(msrest.serialization.Model): + """Site seal request. + + :param light_theme: If :code:`true` use the light color theme for site seal; + otherwise, use the default color theme. + :type light_theme: bool + :param locale: Locale of site seal. + :type locale: str + """ + + _attribute_map = { + 'light_theme': {'key': 'lightTheme', 'type': 'bool'}, + 'locale': {'key': 'locale', 'type': 'str'}, + } + + def __init__( + self, + *, + light_theme: Optional[bool] = None, + locale: Optional[str] = None, + **kwargs + ): + super(SiteSealRequest, self).__init__(**kwargs) + self.light_theme = light_theme + self.locale = locale + + +class SiteSourceControl(ProxyOnlyResource): + """Source control configuration for an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repo_url: Repository or source control URL. + :type repo_url: str + :param branch: Name of branch to use for deployment. + :type branch: str + :param is_manual_integration: :code:`true` to limit to manual integration; + :code:`false` to enable continuous integration (which configures webhooks into + online repos like GitHub). + :type is_manual_integration: bool + :param is_git_hub_action: :code:`true` if this is deployed via GitHub action. + :type is_git_hub_action: bool + :param deployment_rollback_enabled: :code:`true` to enable deployment rollback; + otherwise, :code:`false`. + :type deployment_rollback_enabled: bool + :param is_mercurial: :code:`true` for a Mercurial repository; + :code:`false` for a Git repository. + :type is_mercurial: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repo_url': {'key': 'properties.repoUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'is_manual_integration': {'key': 'properties.isManualIntegration', 'type': 'bool'}, + 'is_git_hub_action': {'key': 'properties.isGitHubAction', 'type': 'bool'}, + 'deployment_rollback_enabled': {'key': 'properties.deploymentRollbackEnabled', 'type': 'bool'}, + 'is_mercurial': {'key': 'properties.isMercurial', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repo_url: Optional[str] = None, + branch: Optional[str] = None, + is_manual_integration: Optional[bool] = None, + is_git_hub_action: Optional[bool] = None, + deployment_rollback_enabled: Optional[bool] = None, + is_mercurial: Optional[bool] = None, + **kwargs + ): + super(SiteSourceControl, self).__init__(kind=kind, **kwargs) + self.repo_url = repo_url + self.branch = branch + self.is_manual_integration = is_manual_integration + self.is_git_hub_action = is_git_hub_action + self.deployment_rollback_enabled = deployment_rollback_enabled + self.is_mercurial = is_mercurial + + +class SkuCapacity(msrest.serialization.Model): + """Description of the App Service plan scale options. + + :param minimum: Minimum number of workers for this App Service plan SKU. + :type minimum: int + :param maximum: Maximum number of workers for this App Service plan SKU. + :type maximum: int + :param default: Default number of workers for this App Service plan SKU. + :type default: int + :param scale_type: Available scale configurations for an App Service plan. + :type scale_type: str + """ + + _attribute_map = { + 'minimum': {'key': 'minimum', 'type': 'int'}, + 'maximum': {'key': 'maximum', 'type': 'int'}, + 'default': {'key': 'default', 'type': 'int'}, + 'scale_type': {'key': 'scaleType', 'type': 'str'}, + } + + def __init__( + self, + *, + minimum: Optional[int] = None, + maximum: Optional[int] = None, + default: Optional[int] = None, + scale_type: Optional[str] = None, + **kwargs + ): + super(SkuCapacity, self).__init__(**kwargs) + self.minimum = minimum + self.maximum = maximum + self.default = default + self.scale_type = scale_type + + +class SkuDescription(msrest.serialization.Model): + """Description of a SKU for a scalable resource. + + :param name: Name of the resource SKU. + :type name: str + :param tier: Service tier of the resource SKU. + :type tier: str + :param size: Size specifier of the resource SKU. + :type size: str + :param family: Family code of the resource SKU. + :type family: str + :param capacity: Current number of instances assigned to the resource. + :type capacity: int + :param sku_capacity: Min, max, and default scale values of the SKU. + :type sku_capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + :param locations: Locations of the SKU. + :type locations: list[str] + :param capabilities: Capabilities of the SKU, e.g., is traffic manager enabled?. + :type capabilities: list[~azure.mgmt.web.v2020_09_01.models.Capability] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + 'sku_capacity': {'key': 'skuCapacity', 'type': 'SkuCapacity'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'capabilities': {'key': 'capabilities', 'type': '[Capability]'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[str] = None, + size: Optional[str] = None, + family: Optional[str] = None, + capacity: Optional[int] = None, + sku_capacity: Optional["SkuCapacity"] = None, + locations: Optional[List[str]] = None, + capabilities: Optional[List["Capability"]] = None, + **kwargs + ): + super(SkuDescription, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.size = size + self.family = family + self.capacity = capacity + self.sku_capacity = sku_capacity + self.locations = locations + self.capabilities = capabilities + + +class SkuInfo(msrest.serialization.Model): + """SKU discovery information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param sku: Name and tier of the SKU. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param capacity: Min, max, and default scale values of the SKU. + :type capacity: ~azure.mgmt.web.v2020_09_01.models.SkuCapacity + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'capacity': {'key': 'capacity', 'type': 'SkuCapacity'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + sku: Optional["SkuDescription"] = None, + capacity: Optional["SkuCapacity"] = None, + **kwargs + ): + super(SkuInfo, self).__init__(**kwargs) + self.resource_type = resource_type + self.sku = sku + self.capacity = capacity + + +class SkuInfoCollection(msrest.serialization.Model): + """Collection of SKU information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SkuInfo] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SkuInfo]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SkuInfo"], + **kwargs + ): + super(SkuInfoCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SkuInfos(msrest.serialization.Model): + """Collection of SKU information. + + :param resource_type: Resource type that this SKU applies to. + :type resource_type: str + :param skus: List of SKUs the subscription is able to use. + :type skus: list[~azure.mgmt.web.v2020_09_01.models.GlobalCsmSkuDescription] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'skus': {'key': 'skus', 'type': '[GlobalCsmSkuDescription]'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + skus: Optional[List["GlobalCsmSkuDescription"]] = None, + **kwargs + ): + super(SkuInfos, self).__init__(**kwargs) + self.resource_type = resource_type + self.skus = skus + + +class SlotConfigNamesResource(ProxyOnlyResource): + """Slot Config names azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param connection_string_names: List of connection string names. + :type connection_string_names: list[str] + :param app_setting_names: List of application settings names. + :type app_setting_names: list[str] + :param azure_storage_config_names: List of external Azure storage account identifiers. + :type azure_storage_config_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'connection_string_names': {'key': 'properties.connectionStringNames', 'type': '[str]'}, + 'app_setting_names': {'key': 'properties.appSettingNames', 'type': '[str]'}, + 'azure_storage_config_names': {'key': 'properties.azureStorageConfigNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + connection_string_names: Optional[List[str]] = None, + app_setting_names: Optional[List[str]] = None, + azure_storage_config_names: Optional[List[str]] = None, + **kwargs + ): + super(SlotConfigNamesResource, self).__init__(kind=kind, **kwargs) + self.connection_string_names = connection_string_names + self.app_setting_names = app_setting_names + self.azure_storage_config_names = azure_storage_config_names + + +class SlotDifference(ProxyOnlyResource): + """A setting difference between two deployment slots of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar level: Level of the difference: Information, Warning or Error. + :vartype level: str + :ivar setting_type: The type of the setting: General, AppSetting or ConnectionString. + :vartype setting_type: str + :ivar diff_rule: Rule that describes how to process the setting difference during a slot swap. + :vartype diff_rule: str + :ivar setting_name: Name of the setting. + :vartype setting_name: str + :ivar value_in_current_slot: Value of the setting in the current slot. + :vartype value_in_current_slot: str + :ivar value_in_target_slot: Value of the setting in the target slot. + :vartype value_in_target_slot: str + :ivar description: Description of the setting difference. + :vartype description: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'level': {'readonly': True}, + 'setting_type': {'readonly': True}, + 'diff_rule': {'readonly': True}, + 'setting_name': {'readonly': True}, + 'value_in_current_slot': {'readonly': True}, + 'value_in_target_slot': {'readonly': True}, + 'description': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'level': {'key': 'properties.level', 'type': 'str'}, + 'setting_type': {'key': 'properties.settingType', 'type': 'str'}, + 'diff_rule': {'key': 'properties.diffRule', 'type': 'str'}, + 'setting_name': {'key': 'properties.settingName', 'type': 'str'}, + 'value_in_current_slot': {'key': 'properties.valueInCurrentSlot', 'type': 'str'}, + 'value_in_target_slot': {'key': 'properties.valueInTargetSlot', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(SlotDifference, self).__init__(kind=kind, **kwargs) + self.level = None + self.setting_type = None + self.diff_rule = None + self.setting_name = None + self.value_in_current_slot = None + self.value_in_target_slot = None + self.description = None + + +class SlotDifferenceCollection(msrest.serialization.Model): + """Collection of slot differences. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SlotDifference] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SlotDifference]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SlotDifference"], + **kwargs + ): + super(SlotDifferenceCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SlotSwapStatus(msrest.serialization.Model): + """The status of the last successful slot swap operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar timestamp_utc: The time the last successful slot swap completed. + :vartype timestamp_utc: ~datetime.datetime + :ivar source_slot_name: The source slot of the last swap operation. + :vartype source_slot_name: str + :ivar destination_slot_name: The destination slot of the last swap operation. + :vartype destination_slot_name: str + """ + + _validation = { + 'timestamp_utc': {'readonly': True}, + 'source_slot_name': {'readonly': True}, + 'destination_slot_name': {'readonly': True}, + } + + _attribute_map = { + 'timestamp_utc': {'key': 'timestampUtc', 'type': 'iso-8601'}, + 'source_slot_name': {'key': 'sourceSlotName', 'type': 'str'}, + 'destination_slot_name': {'key': 'destinationSlotName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SlotSwapStatus, self).__init__(**kwargs) + self.timestamp_utc = None + self.source_slot_name = None + self.destination_slot_name = None + + +class SlowRequestsBasedTrigger(msrest.serialization.Model): + """Trigger based on request execution time. + + :param time_taken: Time taken. + :type time_taken: str + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'time_taken': {'key': 'timeTaken', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + time_taken: Optional[str] = None, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(SlowRequestsBasedTrigger, self).__init__(**kwargs) + self.time_taken = time_taken + self.count = count + self.time_interval = time_interval + + +class Snapshot(ProxyOnlyResource): + """A snapshot of an app. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar time: The time the snapshot was taken. + :vartype time: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'time': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'time': {'key': 'properties.time', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(Snapshot, self).__init__(kind=kind, **kwargs) + self.time = None + + +class SnapshotCollection(msrest.serialization.Model): + """Collection of snapshots which can be used to revert an app to a previous time. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Snapshot] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Snapshot]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Snapshot"], + **kwargs + ): + super(SnapshotCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class SnapshotRecoverySource(msrest.serialization.Model): + """Specifies the web app that snapshot contents will be retrieved from. + + :param location: Geographical location of the source web app, e.g. SouthEastAsia, + SouthCentralUS. + :type location: str + :param id: ARM resource ID of the source app. + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName} + for production slots and + /subscriptions/{subId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slotName} + for other slots. + :type id: str + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + id: Optional[str] = None, + **kwargs + ): + super(SnapshotRecoverySource, self).__init__(**kwargs) + self.location = location + self.id = id + + +class SnapshotRestoreRequest(ProxyOnlyResource): + """Details about app recovery operation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param snapshot_time: Point in time in which the app restore should be done, formatted as a + DateTime string. + :type snapshot_time: str + :param recovery_source: Optional. Specifies the web app that snapshot contents will be + retrieved from. + If empty, the targeted web app will be used as the source. + :type recovery_source: ~azure.mgmt.web.v2020_09_01.models.SnapshotRecoverySource + :param overwrite: If :code:`true` the restore operation can overwrite source app; + otherwise, :code:`false`. + :type overwrite: bool + :param recover_configuration: If true, site configuration, in addition to content, will be + reverted. + :type recover_configuration: bool + :param ignore_conflicting_host_names: If true, custom hostname conflicts will be ignored when + recovering to a target web app. + This setting is only necessary when RecoverConfiguration is enabled. + :type ignore_conflicting_host_names: bool + :param use_dr_secondary: If true, the snapshot is retrieved from DRSecondary endpoint. + :type use_dr_secondary: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'snapshot_time': {'key': 'properties.snapshotTime', 'type': 'str'}, + 'recovery_source': {'key': 'properties.recoverySource', 'type': 'SnapshotRecoverySource'}, + 'overwrite': {'key': 'properties.overwrite', 'type': 'bool'}, + 'recover_configuration': {'key': 'properties.recoverConfiguration', 'type': 'bool'}, + 'ignore_conflicting_host_names': {'key': 'properties.ignoreConflictingHostNames', 'type': 'bool'}, + 'use_dr_secondary': {'key': 'properties.useDRSecondary', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + snapshot_time: Optional[str] = None, + recovery_source: Optional["SnapshotRecoverySource"] = None, + overwrite: Optional[bool] = None, + recover_configuration: Optional[bool] = None, + ignore_conflicting_host_names: Optional[bool] = None, + use_dr_secondary: Optional[bool] = None, + **kwargs + ): + super(SnapshotRestoreRequest, self).__init__(kind=kind, **kwargs) + self.snapshot_time = snapshot_time + self.recovery_source = recovery_source + self.overwrite = overwrite + self.recover_configuration = recover_configuration + self.ignore_conflicting_host_names = ignore_conflicting_host_names + self.use_dr_secondary = use_dr_secondary + + +class Solution(msrest.serialization.Model): + """Class Representing Solution for problems detected. + + :param id: Solution Id. + :type id: float + :param display_name: Display Name of the solution. + :type display_name: str + :param order: Order of the solution. + :type order: float + :param description: Description of the solution. + :type description: str + :param type: Type of Solution. Possible values include: "QuickSolution", "DeepInvestigation", + "BestPractices". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.SolutionType + :param data: Solution Data. + :type data: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + :param metadata: Solution Metadata. + :type metadata: list[list[~azure.mgmt.web.v2020_09_01.models.NameValuePair]] + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'float'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'order': {'key': 'order', 'type': 'float'}, + 'description': {'key': 'description', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'data': {'key': 'data', 'type': '[[NameValuePair]]'}, + 'metadata': {'key': 'metadata', 'type': '[[NameValuePair]]'}, + } + + def __init__( + self, + *, + id: Optional[float] = None, + display_name: Optional[str] = None, + order: Optional[float] = None, + description: Optional[str] = None, + type: Optional[Union[str, "SolutionType"]] = None, + data: Optional[List[List["NameValuePair"]]] = None, + metadata: Optional[List[List["NameValuePair"]]] = None, + **kwargs + ): + super(Solution, self).__init__(**kwargs) + self.id = id + self.display_name = display_name + self.order = order + self.description = description + self.type = type + self.data = data + self.metadata = metadata + + +class SourceControl(ProxyOnlyResource): + """The source control OAuth token. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param token: OAuth access token. + :type token: str + :param token_secret: OAuth access token secret. + :type token_secret: str + :param refresh_token: OAuth refresh token. + :type refresh_token: str + :param expiration_time: OAuth token expiration. + :type expiration_time: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'token': {'key': 'properties.token', 'type': 'str'}, + 'token_secret': {'key': 'properties.tokenSecret', 'type': 'str'}, + 'refresh_token': {'key': 'properties.refreshToken', 'type': 'str'}, + 'expiration_time': {'key': 'properties.expirationTime', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + token: Optional[str] = None, + token_secret: Optional[str] = None, + refresh_token: Optional[str] = None, + expiration_time: Optional[datetime.datetime] = None, + **kwargs + ): + super(SourceControl, self).__init__(kind=kind, **kwargs) + self.token = token + self.token_secret = token_secret + self.refresh_token = refresh_token + self.expiration_time = expiration_time + + +class SourceControlCollection(msrest.serialization.Model): + """Collection of source controls. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.SourceControl] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[SourceControl]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["SourceControl"], + **kwargs + ): + super(SourceControlCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StackMajorVersion(msrest.serialization.Model): + """Application stack major version. + + :param display_version: Application stack major version (display only). + :type display_version: str + :param runtime_version: Application stack major version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default major version; otherwise, + :code:`false`. + :type is_default: bool + :param minor_versions: Minor versions associated with the major version. + :type minor_versions: list[~azure.mgmt.web.v2020_09_01.models.StackMinorVersion] + :param application_insights: :code:`true` if this supports Application Insights; + otherwise, :code:`false`. + :type application_insights: bool + :param is_preview: :code:`true` if this stack is in Preview, otherwise + :code:`false`. + :type is_preview: bool + :param is_deprecated: :code:`true` if this stack has been deprecated, otherwise + :code:`false`. + :type is_deprecated: bool + :param is_hidden: :code:`true` if this stack should be hidden for new customers on + portal, otherwise :code:`false`. + :type is_hidden: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'minor_versions': {'key': 'minorVersions', 'type': '[StackMinorVersion]'}, + 'application_insights': {'key': 'applicationInsights', 'type': 'bool'}, + 'is_preview': {'key': 'isPreview', 'type': 'bool'}, + 'is_deprecated': {'key': 'isDeprecated', 'type': 'bool'}, + 'is_hidden': {'key': 'isHidden', 'type': 'bool'}, + } + + def __init__( + self, + *, + display_version: Optional[str] = None, + runtime_version: Optional[str] = None, + is_default: Optional[bool] = None, + minor_versions: Optional[List["StackMinorVersion"]] = None, + application_insights: Optional[bool] = None, + is_preview: Optional[bool] = None, + is_deprecated: Optional[bool] = None, + is_hidden: Optional[bool] = None, + **kwargs + ): + super(StackMajorVersion, self).__init__(**kwargs) + self.display_version = display_version + self.runtime_version = runtime_version + self.is_default = is_default + self.minor_versions = minor_versions + self.application_insights = application_insights + self.is_preview = is_preview + self.is_deprecated = is_deprecated + self.is_hidden = is_hidden + + +class StackMinorVersion(msrest.serialization.Model): + """Application stack minor version. + + :param display_version: Application stack minor version (display only). + :type display_version: str + :param runtime_version: Application stack minor version (runtime only). + :type runtime_version: str + :param is_default: :code:`true` if this is the default minor version; otherwise, + :code:`false`. + :type is_default: bool + :param is_remote_debugging_enabled: :code:`true` if this supports Remote + Debugging, otherwise :code:`false`. + :type is_remote_debugging_enabled: bool + """ + + _attribute_map = { + 'display_version': {'key': 'displayVersion', 'type': 'str'}, + 'runtime_version': {'key': 'runtimeVersion', 'type': 'str'}, + 'is_default': {'key': 'isDefault', 'type': 'bool'}, + 'is_remote_debugging_enabled': {'key': 'isRemoteDebuggingEnabled', 'type': 'bool'}, + } + + def __init__( + self, + *, + display_version: Optional[str] = None, + runtime_version: Optional[str] = None, + is_default: Optional[bool] = None, + is_remote_debugging_enabled: Optional[bool] = None, + **kwargs + ): + super(StackMinorVersion, self).__init__(**kwargs) + self.display_version = display_version + self.runtime_version = runtime_version + self.is_default = is_default + self.is_remote_debugging_enabled = is_remote_debugging_enabled + + +class StampCapacity(msrest.serialization.Model): + """Stamp capacity information. + + :param name: Name of the stamp. + :type name: str + :param available_capacity: Available capacity (# of machines, bytes of storage etc...). + :type available_capacity: long + :param total_capacity: Total capacity (# of machines, bytes of storage etc...). + :type total_capacity: long + :param unit: Name of the unit. + :type unit: str + :param compute_mode: Shared/dedicated workers. Possible values include: "Shared", "Dedicated", + "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: Size of the machines. Possible values include: "Small", "Medium", "Large", + "D1", "D2", "D3", "NestedSmall", "Default". + :type worker_size: str or ~azure.mgmt.web.v2020_09_01.models.WorkerSizeOptions + :param worker_size_id: Size ID of machines: + 0 - Small + 1 - Medium + 2 - Large. + :type worker_size_id: int + :param exclude_from_capacity_allocation: If :code:`true`, it includes basic apps. + Basic apps are not used for capacity allocation. + :type exclude_from_capacity_allocation: bool + :param is_applicable_for_all_compute_modes: :code:`true` if capacity is applicable + for all apps; otherwise, :code:`false`. + :type is_applicable_for_all_compute_modes: bool + :param site_mode: Shared or Dedicated. + :type site_mode: str + :param is_linux: Is this a linux stamp capacity. + :type is_linux: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'available_capacity': {'key': 'availableCapacity', 'type': 'long'}, + 'total_capacity': {'key': 'totalCapacity', 'type': 'long'}, + 'unit': {'key': 'unit', 'type': 'str'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'exclude_from_capacity_allocation': {'key': 'excludeFromCapacityAllocation', 'type': 'bool'}, + 'is_applicable_for_all_compute_modes': {'key': 'isApplicableForAllComputeModes', 'type': 'bool'}, + 'site_mode': {'key': 'siteMode', 'type': 'str'}, + 'is_linux': {'key': 'isLinux', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + available_capacity: Optional[int] = None, + total_capacity: Optional[int] = None, + unit: Optional[str] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[Union[str, "WorkerSizeOptions"]] = None, + worker_size_id: Optional[int] = None, + exclude_from_capacity_allocation: Optional[bool] = None, + is_applicable_for_all_compute_modes: Optional[bool] = None, + site_mode: Optional[str] = None, + is_linux: Optional[bool] = None, + **kwargs + ): + super(StampCapacity, self).__init__(**kwargs) + self.name = name + self.available_capacity = available_capacity + self.total_capacity = total_capacity + self.unit = unit + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_size_id = worker_size_id + self.exclude_from_capacity_allocation = exclude_from_capacity_allocation + self.is_applicable_for_all_compute_modes = is_applicable_for_all_compute_modes + self.site_mode = site_mode + self.is_linux = is_linux + + +class StampCapacityCollection(msrest.serialization.Model): + """Collection of stamp capacities. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StampCapacity] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StampCapacity]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StampCapacity"], + **kwargs + ): + super(StampCapacityCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteARMResource(Resource): + """Static Site ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :param location: Required. Resource Location. + :type location: str + :ivar type: Resource type. + :vartype type: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'location': {'required': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + location: str, + kind: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + sku: Optional["SkuDescription"] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + repository_token: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSiteARMResource, self).__init__(kind=kind, location=location, tags=tags, **kwargs) + self.sku = sku + self.default_hostname = None + self.repository_url = repository_url + self.branch = branch + self.custom_domains = None + self.repository_token = repository_token + self.build_properties = build_properties + + +class StaticSiteBuildARMResource(ProxyOnlyResource): + """Static Site Build ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar build_id: An identifier for the static site build. + :vartype build_id: str + :ivar source_branch: The source branch. + :vartype source_branch: str + :ivar pull_request_title: The title of a pull request that a static site build is related to. + :vartype pull_request_title: str + :ivar hostname: The hostname for a static site build. + :vartype hostname: str + :ivar created_time_utc: When this build was created. + :vartype created_time_utc: ~datetime.datetime + :ivar last_updated_on: When this build was updated. + :vartype last_updated_on: ~datetime.datetime + :ivar status: The status of the static site build. Possible values include: + "WaitingForDeployment", "Uploading", "Deploying", "Ready", "Failed", "Deleting", "Detached". + :vartype status: str or ~azure.mgmt.web.v2020_09_01.models.BuildStatus + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'build_id': {'readonly': True}, + 'source_branch': {'readonly': True}, + 'pull_request_title': {'readonly': True}, + 'hostname': {'readonly': True}, + 'created_time_utc': {'readonly': True}, + 'last_updated_on': {'readonly': True}, + 'status': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'build_id': {'key': 'properties.buildId', 'type': 'str'}, + 'source_branch': {'key': 'properties.sourceBranch', 'type': 'str'}, + 'pull_request_title': {'key': 'properties.pullRequestTitle', 'type': 'str'}, + 'hostname': {'key': 'properties.hostname', 'type': 'str'}, + 'created_time_utc': {'key': 'properties.createdTimeUtc', 'type': 'iso-8601'}, + 'last_updated_on': {'key': 'properties.lastUpdatedOn', 'type': 'iso-8601'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteBuildARMResource, self).__init__(kind=kind, **kwargs) + self.build_id = None + self.source_branch = None + self.pull_request_title = None + self.hostname = None + self.created_time_utc = None + self.last_updated_on = None + self.status = None + + +class StaticSiteBuildCollection(msrest.serialization.Model): + """Collection of static site builds. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteBuildARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteBuildARMResource"], + **kwargs + ): + super(StaticSiteBuildCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteBuildProperties(msrest.serialization.Model): + """Build properties for the static site. + + :param app_location: The path to the app code within the repository. + :type app_location: str + :param api_location: The path to the api code within the repository. + :type api_location: str + :param app_artifact_location: The path of the app artifacts after building. + :type app_artifact_location: str + """ + + _attribute_map = { + 'app_location': {'key': 'appLocation', 'type': 'str'}, + 'api_location': {'key': 'apiLocation', 'type': 'str'}, + 'app_artifact_location': {'key': 'appArtifactLocation', 'type': 'str'}, + } + + def __init__( + self, + *, + app_location: Optional[str] = None, + api_location: Optional[str] = None, + app_artifact_location: Optional[str] = None, + **kwargs + ): + super(StaticSiteBuildProperties, self).__init__(**kwargs) + self.app_location = app_location + self.api_location = api_location + self.app_artifact_location = app_artifact_location + + +class StaticSiteCollection(msrest.serialization.Model): + """Collection of static sites. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteARMResource"], + **kwargs + ): + super(StaticSiteCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteCustomDomainOverviewARMResource(ProxyOnlyResource): + """Static Site Custom Domain Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar domain_name: The domain name for the static site custom domain. + :vartype domain_name: str + :ivar created_on: The date and time on which the custom domain was created for the static site. + :vartype created_on: ~datetime.datetime + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'domain_name': {'readonly': True}, + 'created_on': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'domain_name': {'key': 'properties.domainName', 'type': 'str'}, + 'created_on': {'key': 'properties.createdOn', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteCustomDomainOverviewARMResource, self).__init__(kind=kind, **kwargs) + self.domain_name = None + self.created_on = None + + +class StaticSiteCustomDomainOverviewCollection(msrest.serialization.Model): + """Collection of static site custom domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteCustomDomainOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteCustomDomainOverviewARMResource"], + **kwargs + ): + super(StaticSiteCustomDomainOverviewCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteFunctionOverviewARMResource(ProxyOnlyResource): + """Static Site Function Overview ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar function_name: The name for the function. + :vartype function_name: str + :ivar trigger_type: The trigger type of the function. Possible values include: "HttpTrigger", + "Unknown". + :vartype trigger_type: str or ~azure.mgmt.web.v2020_09_01.models.TriggerTypes + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'function_name': {'readonly': True}, + 'trigger_type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'function_name': {'key': 'properties.functionName', 'type': 'str'}, + 'trigger_type': {'key': 'properties.triggerType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteFunctionOverviewARMResource, self).__init__(kind=kind, **kwargs) + self.function_name = None + self.trigger_type = None + + +class StaticSiteFunctionOverviewCollection(msrest.serialization.Model): + """Collection of static site functions. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteFunctionOverviewARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteFunctionOverviewARMResource"], + **kwargs + ): + super(StaticSiteFunctionOverviewCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSitePatchResource(ProxyOnlyResource): + """ARM resource for a static site when patching. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar default_hostname: The default autogenerated hostname for the static site. + :vartype default_hostname: str + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :ivar custom_domains: The custom domains associated with this static site. + :vartype custom_domains: list[str] + :param repository_token: A user's github repository token. This is used to setup the Github + Actions workflow file and API secrets. + :type repository_token: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'default_hostname': {'readonly': True}, + 'custom_domains': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'default_hostname': {'key': 'properties.defaultHostname', 'type': 'str'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'custom_domains': {'key': 'properties.customDomains', 'type': '[str]'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + repository_token: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSitePatchResource, self).__init__(kind=kind, **kwargs) + self.default_hostname = None + self.repository_url = repository_url + self.branch = branch + self.custom_domains = None + self.repository_token = repository_token + self.build_properties = build_properties + + +class StaticSiteResetPropertiesARMResource(ProxyOnlyResource): + """Static Site Reset Properties ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repository_token: The token which proves admin privileges to the repository. + :type repository_token: str + :param should_update_repository: Determines whether the repository should be updated with the + new properties. + :type should_update_repository: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repository_token': {'key': 'properties.repositoryToken', 'type': 'str'}, + 'should_update_repository': {'key': 'properties.shouldUpdateRepository', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_token: Optional[str] = None, + should_update_repository: Optional[bool] = None, + **kwargs + ): + super(StaticSiteResetPropertiesARMResource, self).__init__(kind=kind, **kwargs) + self.repository_token = repository_token + self.should_update_repository = should_update_repository + + +class StaticSitesWorkflowPreview(ProxyOnlyResource): + """Preview for the Static Site Workflow to be generated. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar path: The path for the workflow file to be generated. + :vartype path: str + :ivar contents: The contents for the workflow file to be generated. + :vartype contents: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'path': {'readonly': True}, + 'contents': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'path': {'key': 'properties.path', 'type': 'str'}, + 'contents': {'key': 'properties.contents', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSitesWorkflowPreview, self).__init__(kind=kind, **kwargs) + self.path = None + self.contents = None + + +class StaticSitesWorkflowPreviewRequest(ProxyOnlyResource): + """Request entity for previewing the Static Site workflow. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param repository_url: URL for the repository of the static site. + :type repository_url: str + :param branch: The target branch in the repository. + :type branch: str + :param build_properties: Build properties to configure on the repository. + :type build_properties: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'repository_url': {'key': 'properties.repositoryUrl', 'type': 'str'}, + 'branch': {'key': 'properties.branch', 'type': 'str'}, + 'build_properties': {'key': 'properties.buildProperties', 'type': 'StaticSiteBuildProperties'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + repository_url: Optional[str] = None, + branch: Optional[str] = None, + build_properties: Optional["StaticSiteBuildProperties"] = None, + **kwargs + ): + super(StaticSitesWorkflowPreviewRequest, self).__init__(kind=kind, **kwargs) + self.repository_url = repository_url + self.branch = branch + self.build_properties = build_properties + + +class StaticSiteUserARMResource(ProxyOnlyResource): + """Static Site User ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar provider: The identity provider for the static site user. + :vartype provider: str + :ivar user_id: The user id for the static site user. + :vartype user_id: str + :ivar display_name: The display name for the static site user. + :vartype display_name: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provider': {'readonly': True}, + 'user_id': {'readonly': True}, + 'display_name': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_id': {'key': 'properties.userId', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + roles: Optional[str] = None, + **kwargs + ): + super(StaticSiteUserARMResource, self).__init__(kind=kind, **kwargs) + self.provider = None + self.user_id = None + self.display_name = None + self.roles = roles + + +class StaticSiteUserCollection(msrest.serialization.Model): + """Collection of static site custom users. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[StaticSiteUserARMResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["StaticSiteUserARMResource"], + **kwargs + ): + super(StaticSiteUserCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class StaticSiteUserInvitationRequestResource(ProxyOnlyResource): + """Static sites user roles invitation resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param domain: The domain name for the static site custom domain. + :type domain: str + :param provider: The identity provider for the static site user. + :type provider: str + :param user_details: The user id for the static site user. + :type user_details: str + :param roles: The roles for the static site user, in free-form string format. + :type roles: str + :param num_hours_to_expiration: The number of hours the sas token stays valid. + :type num_hours_to_expiration: int + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'domain': {'key': 'properties.domain', 'type': 'str'}, + 'provider': {'key': 'properties.provider', 'type': 'str'}, + 'user_details': {'key': 'properties.userDetails', 'type': 'str'}, + 'roles': {'key': 'properties.roles', 'type': 'str'}, + 'num_hours_to_expiration': {'key': 'properties.numHoursToExpiration', 'type': 'int'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + domain: Optional[str] = None, + provider: Optional[str] = None, + user_details: Optional[str] = None, + roles: Optional[str] = None, + num_hours_to_expiration: Optional[int] = None, + **kwargs + ): + super(StaticSiteUserInvitationRequestResource, self).__init__(kind=kind, **kwargs) + self.domain = domain + self.provider = provider + self.user_details = user_details + self.roles = roles + self.num_hours_to_expiration = num_hours_to_expiration + + +class StaticSiteUserInvitationResponseResource(ProxyOnlyResource): + """Static sites user roles invitation link resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar expires_on: The expiration time of the invitation. + :vartype expires_on: ~datetime.datetime + :ivar invitation_url: The url for the invitation link. + :vartype invitation_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'expires_on': {'readonly': True}, + 'invitation_url': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'invitation_url': {'key': 'properties.invitationUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StaticSiteUserInvitationResponseResource, self).__init__(kind=kind, **kwargs) + self.expires_on = None + self.invitation_url = None + + +class StatusCodesBasedTrigger(msrest.serialization.Model): + """Trigger based on status code. + + :param status: HTTP status code. + :type status: int + :param sub_status: Request Sub Status. + :type sub_status: int + :param win32_status: Win32 error code. + :type win32_status: int + :param count: Request Count. + :type count: int + :param time_interval: Time interval. + :type time_interval: str + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'int'}, + 'sub_status': {'key': 'subStatus', 'type': 'int'}, + 'win32_status': {'key': 'win32Status', 'type': 'int'}, + 'count': {'key': 'count', 'type': 'int'}, + 'time_interval': {'key': 'timeInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + status: Optional[int] = None, + sub_status: Optional[int] = None, + win32_status: Optional[int] = None, + count: Optional[int] = None, + time_interval: Optional[str] = None, + **kwargs + ): + super(StatusCodesBasedTrigger, self).__init__(**kwargs) + self.status = status + self.sub_status = sub_status + self.win32_status = win32_status + self.count = count + self.time_interval = time_interval + + +class StorageMigrationOptions(ProxyOnlyResource): + """Options for app content migration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param azurefiles_connection_string: AzureFiles connection string. + :type azurefiles_connection_string: str + :param azurefiles_share: AzureFiles share. + :type azurefiles_share: str + :param switch_site_after_migration: :code:`true`if the app should be switched + over; otherwise, :code:`false`. + :type switch_site_after_migration: bool + :param block_write_access_to_site: :code:`true` if the app should be read only + during copy operation; otherwise, :code:`false`. + :type block_write_access_to_site: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'azurefiles_connection_string': {'key': 'properties.azurefilesConnectionString', 'type': 'str'}, + 'azurefiles_share': {'key': 'properties.azurefilesShare', 'type': 'str'}, + 'switch_site_after_migration': {'key': 'properties.switchSiteAfterMigration', 'type': 'bool'}, + 'block_write_access_to_site': {'key': 'properties.blockWriteAccessToSite', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + azurefiles_connection_string: Optional[str] = None, + azurefiles_share: Optional[str] = None, + switch_site_after_migration: Optional[bool] = False, + block_write_access_to_site: Optional[bool] = False, + **kwargs + ): + super(StorageMigrationOptions, self).__init__(kind=kind, **kwargs) + self.azurefiles_connection_string = azurefiles_connection_string + self.azurefiles_share = azurefiles_share + self.switch_site_after_migration = switch_site_after_migration + self.block_write_access_to_site = block_write_access_to_site + + +class StorageMigrationResponse(ProxyOnlyResource): + """Response for a migration of app content request. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar operation_id: When server starts the migration process, it will return an operation ID + identifying that particular migration operation. + :vartype operation_id: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'operation_id': {'key': 'properties.operationId', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(StorageMigrationResponse, self).__init__(kind=kind, **kwargs) + self.operation_id = None + + +class StringDictionary(ProxyOnlyResource): + """String dictionary resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param properties: Settings. + :type properties: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + properties: Optional[Dict[str, str]] = None, + **kwargs + ): + super(StringDictionary, self).__init__(kind=kind, **kwargs) + self.properties = properties + + +class SwiftVirtualNetwork(ProxyOnlyResource): + """Swift Virtual Network Contract. This is used to enable the new Swift way of doing virtual network integration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param subnet_resource_id: The Virtual Network subnet's resource ID. This is the subnet that + this Web App will join. This subnet must have a delegation to Microsoft.Web/serverFarms defined + first. + :type subnet_resource_id: str + :param swift_supported: A flag that specifies if the scale unit this Web App is on supports + Swift integration. + :type swift_supported: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'subnet_resource_id': {'key': 'properties.subnetResourceId', 'type': 'str'}, + 'swift_supported': {'key': 'properties.swiftSupported', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + subnet_resource_id: Optional[str] = None, + swift_supported: Optional[bool] = None, + **kwargs + ): + super(SwiftVirtualNetwork, self).__init__(kind=kind, **kwargs) + self.subnet_resource_id = subnet_resource_id + self.swift_supported = swift_supported + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. Possible values + include: "User", "Application", "ManagedIdentity", "Key". + :type created_by_type: str or ~azure.mgmt.web.v2020_09_01.models.CreatedByType + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. Possible + values include: "User", "Application", "ManagedIdentity", "Key". + :type last_modified_by_type: str or ~azure.mgmt.web.v2020_09_01.models.CreatedByType + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + created_by: Optional[str] = None, + created_by_type: Optional[Union[str, "CreatedByType"]] = None, + created_at: Optional[datetime.datetime] = None, + last_modified_by: Optional[str] = None, + last_modified_by_type: Optional[Union[str, "CreatedByType"]] = None, + last_modified_at: Optional[datetime.datetime] = None, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = created_by + self.created_by_type = created_by_type + self.created_at = created_at + self.last_modified_by = last_modified_by + self.last_modified_by_type = last_modified_by_type + self.last_modified_at = last_modified_at + + +class TldLegalAgreement(msrest.serialization.Model): + """Legal agreement for a top level domain. + + All required parameters must be populated in order to send to Azure. + + :param agreement_key: Required. Unique identifier for the agreement. + :type agreement_key: str + :param title: Required. Agreement title. + :type title: str + :param content: Required. Agreement details. + :type content: str + :param url: URL where a copy of the agreement details is hosted. + :type url: str + """ + + _validation = { + 'agreement_key': {'required': True}, + 'title': {'required': True}, + 'content': {'required': True}, + } + + _attribute_map = { + 'agreement_key': {'key': 'agreementKey', 'type': 'str'}, + 'title': {'key': 'title', 'type': 'str'}, + 'content': {'key': 'content', 'type': 'str'}, + 'url': {'key': 'url', 'type': 'str'}, + } + + def __init__( + self, + *, + agreement_key: str, + title: str, + content: str, + url: Optional[str] = None, + **kwargs + ): + super(TldLegalAgreement, self).__init__(**kwargs) + self.agreement_key = agreement_key + self.title = title + self.content = content + self.url = url + + +class TldLegalAgreementCollection(msrest.serialization.Model): + """Collection of top-level domain legal agreements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TldLegalAgreement] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TldLegalAgreement]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TldLegalAgreement"], + **kwargs + ): + super(TldLegalAgreementCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TokenStore(ProxyOnlyResource): + """TokenStore. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param token_refresh_extension_hours: + :type token_refresh_extension_hours: float + :param file_system: + :type file_system: ~azure.mgmt.web.v2020_09_01.models.FileSystemTokenStore + :param azure_blob_storage: + :type azure_blob_storage: ~azure.mgmt.web.v2020_09_01.models.BlobStorageTokenStore + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'token_refresh_extension_hours': {'key': 'properties.tokenRefreshExtensionHours', 'type': 'float'}, + 'file_system': {'key': 'properties.fileSystem', 'type': 'FileSystemTokenStore'}, + 'azure_blob_storage': {'key': 'properties.azureBlobStorage', 'type': 'BlobStorageTokenStore'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + token_refresh_extension_hours: Optional[float] = None, + file_system: Optional["FileSystemTokenStore"] = None, + azure_blob_storage: Optional["BlobStorageTokenStore"] = None, + **kwargs + ): + super(TokenStore, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.token_refresh_extension_hours = token_refresh_extension_hours + self.file_system = file_system + self.azure_blob_storage = azure_blob_storage + + +class TopLevelDomain(ProxyOnlyResource): + """A top level domain object. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param privacy: If :code:`true`, then the top level domain supports domain + privacy; otherwise, :code:`false`. + :type privacy: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'privacy': {'key': 'properties.privacy', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + privacy: Optional[bool] = None, + **kwargs + ): + super(TopLevelDomain, self).__init__(kind=kind, **kwargs) + self.privacy = privacy + + +class TopLevelDomainAgreementOption(msrest.serialization.Model): + """Options for retrieving the list of top level domain legal agreements. + + :param include_privacy: If :code:`true`, then the list of agreements will include + agreements for domain privacy as well; otherwise, :code:`false`. + :type include_privacy: bool + :param for_transfer: If :code:`true`, then the list of agreements will include + agreements for domain transfer as well; otherwise, :code:`false`. + :type for_transfer: bool + """ + + _attribute_map = { + 'include_privacy': {'key': 'includePrivacy', 'type': 'bool'}, + 'for_transfer': {'key': 'forTransfer', 'type': 'bool'}, + } + + def __init__( + self, + *, + include_privacy: Optional[bool] = None, + for_transfer: Optional[bool] = None, + **kwargs + ): + super(TopLevelDomainAgreementOption, self).__init__(**kwargs) + self.include_privacy = include_privacy + self.for_transfer = for_transfer + + +class TopLevelDomainCollection(msrest.serialization.Model): + """Collection of Top-level domains. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TopLevelDomain] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TopLevelDomain]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TopLevelDomain"], + **kwargs + ): + super(TopLevelDomainCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TriggeredJobHistory(ProxyOnlyResource): + """Triggered Web Job History. List of Triggered Web Job Run Information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param runs: List of triggered web job runs. + :type runs: list[~azure.mgmt.web.v2020_09_01.models.TriggeredJobRun] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'runs': {'key': 'properties.runs', 'type': '[TriggeredJobRun]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + runs: Optional[List["TriggeredJobRun"]] = None, + **kwargs + ): + super(TriggeredJobHistory, self).__init__(kind=kind, **kwargs) + self.runs = runs + + +class TriggeredJobHistoryCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredJobHistory]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TriggeredJobHistory"], + **kwargs + ): + super(TriggeredJobHistoryCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TriggeredJobRun(ProxyOnlyResource): + """Triggered Web Job Run Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param web_job_id: Job ID. + :type web_job_id: str + :param web_job_name: Job name. + :type web_job_name: str + :param status: Job status. Possible values include: "Success", "Failed", "Error". + :type status: str or ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobStatus + :param start_time: Start time. + :type start_time: ~datetime.datetime + :param end_time: End time. + :type end_time: ~datetime.datetime + :param duration: Job duration. + :type duration: str + :param output_url: Output URL. + :type output_url: str + :param error_url: Error URL. + :type error_url: str + :param url: Job URL. + :type url: str + :param job_name: Job name. + :type job_name: str + :param trigger: Job trigger. + :type trigger: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'web_job_id': {'key': 'properties.web_job_id', 'type': 'str'}, + 'web_job_name': {'key': 'properties.web_job_name', 'type': 'str'}, + 'status': {'key': 'properties.status', 'type': 'str'}, + 'start_time': {'key': 'properties.start_time', 'type': 'iso-8601'}, + 'end_time': {'key': 'properties.end_time', 'type': 'iso-8601'}, + 'duration': {'key': 'properties.duration', 'type': 'str'}, + 'output_url': {'key': 'properties.output_url', 'type': 'str'}, + 'error_url': {'key': 'properties.error_url', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'job_name': {'key': 'properties.job_name', 'type': 'str'}, + 'trigger': {'key': 'properties.trigger', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + web_job_id: Optional[str] = None, + web_job_name: Optional[str] = None, + status: Optional[Union[str, "TriggeredWebJobStatus"]] = None, + start_time: Optional[datetime.datetime] = None, + end_time: Optional[datetime.datetime] = None, + duration: Optional[str] = None, + output_url: Optional[str] = None, + error_url: Optional[str] = None, + url: Optional[str] = None, + job_name: Optional[str] = None, + trigger: Optional[str] = None, + **kwargs + ): + super(TriggeredJobRun, self).__init__(kind=kind, **kwargs) + self.web_job_id = web_job_id + self.web_job_name = web_job_name + self.status = status + self.start_time = start_time + self.end_time = end_time + self.duration = duration + self.output_url = output_url + self.error_url = error_url + self.url = url + self.job_name = job_name + self.trigger = trigger + + +class TriggeredWebJob(ProxyOnlyResource): + """Triggered Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param latest_run: Latest job run information. + :type latest_run: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobRun + :param history_url: History URL. + :type history_url: str + :param scheduler_logs_url: Scheduler Logs URL. + :type scheduler_logs_url: str + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'latest_run': {'key': 'properties.latest_run', 'type': 'TriggeredJobRun'}, + 'history_url': {'key': 'properties.history_url', 'type': 'str'}, + 'scheduler_logs_url': {'key': 'properties.scheduler_logs_url', 'type': 'str'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + latest_run: Optional["TriggeredJobRun"] = None, + history_url: Optional[str] = None, + scheduler_logs_url: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(TriggeredWebJob, self).__init__(kind=kind, **kwargs) + self.latest_run = latest_run + self.history_url = history_url + self.scheduler_logs_url = scheduler_logs_url + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class TriggeredWebJobCollection(msrest.serialization.Model): + """Collection of Kudu continuous web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TriggeredWebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["TriggeredWebJob"], + **kwargs + ): + super(TriggeredWebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class Twitter(ProxyOnlyResource): + """Twitter. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param enabled: + :type enabled: bool + :param registration: + :type registration: ~azure.mgmt.web.v2020_09_01.models.TwitterRegistration + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'enabled': {'key': 'properties.enabled', 'type': 'bool'}, + 'registration': {'key': 'properties.registration', 'type': 'TwitterRegistration'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + enabled: Optional[bool] = None, + registration: Optional["TwitterRegistration"] = None, + **kwargs + ): + super(Twitter, self).__init__(kind=kind, **kwargs) + self.enabled = enabled + self.registration = registration + + +class TwitterRegistration(ProxyOnlyResource): + """TwitterRegistration. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param consumer_key: + :type consumer_key: str + :param consumer_secret_setting_name: + :type consumer_secret_setting_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'consumer_key': {'key': 'properties.consumerKey', 'type': 'str'}, + 'consumer_secret_setting_name': {'key': 'properties.consumerSecretSettingName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + consumer_key: Optional[str] = None, + consumer_secret_setting_name: Optional[str] = None, + **kwargs + ): + super(TwitterRegistration, self).__init__(kind=kind, **kwargs) + self.consumer_key = consumer_key + self.consumer_secret_setting_name = consumer_secret_setting_name + + +class Usage(ProxyOnlyResource): + """Usage of the quota resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :ivar display_name: Friendly name shown in the UI. + :vartype display_name: str + :ivar resource_name: Name of the quota resource. + :vartype resource_name: str + :ivar unit: Units of measurement for the quota resource. + :vartype unit: str + :ivar current_value: The current value of the resource counter. + :vartype current_value: long + :ivar limit: The resource limit. + :vartype limit: long + :ivar next_reset_time: Next reset time for the resource counter. + :vartype next_reset_time: ~datetime.datetime + :ivar compute_mode: Compute mode used for this usage. Possible values include: "Shared", + "Dedicated", "Dynamic". + :vartype compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :ivar site_mode: Site mode used for this usage. + :vartype site_mode: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'display_name': {'readonly': True}, + 'resource_name': {'readonly': True}, + 'unit': {'readonly': True}, + 'current_value': {'readonly': True}, + 'limit': {'readonly': True}, + 'next_reset_time': {'readonly': True}, + 'compute_mode': {'readonly': True}, + 'site_mode': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'resource_name': {'key': 'properties.resourceName', 'type': 'str'}, + 'unit': {'key': 'properties.unit', 'type': 'str'}, + 'current_value': {'key': 'properties.currentValue', 'type': 'long'}, + 'limit': {'key': 'properties.limit', 'type': 'long'}, + 'next_reset_time': {'key': 'properties.nextResetTime', 'type': 'iso-8601'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'site_mode': {'key': 'properties.siteMode', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + **kwargs + ): + super(Usage, self).__init__(kind=kind, **kwargs) + self.display_name = None + self.resource_name = None + self.unit = None + self.current_value = None + self.limit = None + self.next_reset_time = None + self.compute_mode = None + self.site_mode = None + + +class UsageCollection(msrest.serialization.Model): + """Collection of usages. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Usage] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Usage]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Usage"], + **kwargs + ): + super(UsageCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class User(ProxyOnlyResource): + """User credentials used for publishing activity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param publishing_user_name: Username used for publishing. + :type publishing_user_name: str + :param publishing_password: Password used for publishing. + :type publishing_password: str + :param publishing_password_hash: Password hash used for publishing. + :type publishing_password_hash: str + :param publishing_password_hash_salt: Password hash salt used for publishing. + :type publishing_password_hash_salt: str + :param scm_uri: Url of SCM site. + :type scm_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'publishing_user_name': {'key': 'properties.publishingUserName', 'type': 'str'}, + 'publishing_password': {'key': 'properties.publishingPassword', 'type': 'str'}, + 'publishing_password_hash': {'key': 'properties.publishingPasswordHash', 'type': 'str'}, + 'publishing_password_hash_salt': {'key': 'properties.publishingPasswordHashSalt', 'type': 'str'}, + 'scm_uri': {'key': 'properties.scmUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + publishing_user_name: Optional[str] = None, + publishing_password: Optional[str] = None, + publishing_password_hash: Optional[str] = None, + publishing_password_hash_salt: Optional[str] = None, + scm_uri: Optional[str] = None, + **kwargs + ): + super(User, self).__init__(kind=kind, **kwargs) + self.publishing_user_name = publishing_user_name + self.publishing_password = publishing_password + self.publishing_password_hash = publishing_password_hash + self.publishing_password_hash_salt = publishing_password_hash_salt + self.scm_uri = scm_uri + + +class ValidateRequest(msrest.serialization.Model): + """Resource validation request content. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Resource name to verify. + :type name: str + :param type: Required. Resource type used for verification. Possible values include: + "ServerFarm", "Site". + :type type: str or ~azure.mgmt.web.v2020_09_01.models.ValidateResourceTypes + :param location: Required. Expected location of the resource. + :type location: str + :param server_farm_id: ARM resource ID of an App Service plan that would host the app. + :type server_farm_id: str + :param sku_name: Name of the target SKU for the App Service plan. + :type sku_name: str + :param need_linux_workers: :code:`true` if App Service plan is for Linux workers; + otherwise, :code:`false`. + :type need_linux_workers: bool + :param is_spot: :code:`true` if App Service plan is for Spot instances; otherwise, + :code:`false`. + :type is_spot: bool + :param capacity: Target capacity of the App Service plan (number of VMs). + :type capacity: int + :param hosting_environment: Name of App Service Environment where app or App Service plan + should be created. + :type hosting_environment: str + :param is_xenon: :code:`true` if App Service plan is running as a windows + container. + :type is_xenon: bool + :param container_registry_base_url: Base URL of the container registry. + :type container_registry_base_url: str + :param container_registry_username: Username for to access the container registry. + :type container_registry_username: str + :param container_registry_password: Password for to access the container registry. + :type container_registry_password: str + :param container_image_repository: Repository name (image name). + :type container_image_repository: str + :param container_image_tag: Image tag. + :type container_image_tag: str + :param container_image_platform: Platform (windows or linux). + :type container_image_platform: str + """ + + _validation = { + 'name': {'required': True}, + 'type': {'required': True}, + 'location': {'required': True}, + 'capacity': {'minimum': 1}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'server_farm_id': {'key': 'properties.serverFarmId', 'type': 'str'}, + 'sku_name': {'key': 'properties.skuName', 'type': 'str'}, + 'need_linux_workers': {'key': 'properties.needLinuxWorkers', 'type': 'bool'}, + 'is_spot': {'key': 'properties.isSpot', 'type': 'bool'}, + 'capacity': {'key': 'properties.capacity', 'type': 'int'}, + 'hosting_environment': {'key': 'properties.hostingEnvironment', 'type': 'str'}, + 'is_xenon': {'key': 'properties.isXenon', 'type': 'bool'}, + 'container_registry_base_url': {'key': 'properties.containerRegistryBaseUrl', 'type': 'str'}, + 'container_registry_username': {'key': 'properties.containerRegistryUsername', 'type': 'str'}, + 'container_registry_password': {'key': 'properties.containerRegistryPassword', 'type': 'str'}, + 'container_image_repository': {'key': 'properties.containerImageRepository', 'type': 'str'}, + 'container_image_tag': {'key': 'properties.containerImageTag', 'type': 'str'}, + 'container_image_platform': {'key': 'properties.containerImagePlatform', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + type: Union[str, "ValidateResourceTypes"], + location: str, + server_farm_id: Optional[str] = None, + sku_name: Optional[str] = None, + need_linux_workers: Optional[bool] = None, + is_spot: Optional[bool] = None, + capacity: Optional[int] = None, + hosting_environment: Optional[str] = None, + is_xenon: Optional[bool] = None, + container_registry_base_url: Optional[str] = None, + container_registry_username: Optional[str] = None, + container_registry_password: Optional[str] = None, + container_image_repository: Optional[str] = None, + container_image_tag: Optional[str] = None, + container_image_platform: Optional[str] = None, + **kwargs + ): + super(ValidateRequest, self).__init__(**kwargs) + self.name = name + self.type = type + self.location = location + self.server_farm_id = server_farm_id + self.sku_name = sku_name + self.need_linux_workers = need_linux_workers + self.is_spot = is_spot + self.capacity = capacity + self.hosting_environment = hosting_environment + self.is_xenon = is_xenon + self.container_registry_base_url = container_registry_base_url + self.container_registry_username = container_registry_username + self.container_registry_password = container_registry_password + self.container_image_repository = container_image_repository + self.container_image_tag = container_image_tag + self.container_image_platform = container_image_platform + + +class ValidateResponse(msrest.serialization.Model): + """Describes the result of resource validation. + + :param status: Result of validation. + :type status: str + :param error: Error details for the case when validation fails. + :type error: ~azure.mgmt.web.v2020_09_01.models.ValidateResponseError + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ValidateResponseError'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + error: Optional["ValidateResponseError"] = None, + **kwargs + ): + super(ValidateResponse, self).__init__(**kwargs) + self.status = status + self.error = error + + +class ValidateResponseError(msrest.serialization.Model): + """Error details for when validation fails. + + :param code: Validation error code. + :type code: str + :param message: Validation error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ValidateResponseError, self).__init__(**kwargs) + self.code = code + self.message = message + + +class VirtualApplication(msrest.serialization.Model): + """Virtual application in an app. + + :param virtual_path: Virtual path. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + :param preload_enabled: :code:`true` if preloading is enabled; otherwise, + :code:`false`. + :type preload_enabled: bool + :param virtual_directories: Virtual directories for virtual application. + :type virtual_directories: list[~azure.mgmt.web.v2020_09_01.models.VirtualDirectory] + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + 'preload_enabled': {'key': 'preloadEnabled', 'type': 'bool'}, + 'virtual_directories': {'key': 'virtualDirectories', 'type': '[VirtualDirectory]'}, + } + + def __init__( + self, + *, + virtual_path: Optional[str] = None, + physical_path: Optional[str] = None, + preload_enabled: Optional[bool] = None, + virtual_directories: Optional[List["VirtualDirectory"]] = None, + **kwargs + ): + super(VirtualApplication, self).__init__(**kwargs) + self.virtual_path = virtual_path + self.physical_path = physical_path + self.preload_enabled = preload_enabled + self.virtual_directories = virtual_directories + + +class VirtualDirectory(msrest.serialization.Model): + """Directory for virtual application. + + :param virtual_path: Path to virtual application. + :type virtual_path: str + :param physical_path: Physical path. + :type physical_path: str + """ + + _attribute_map = { + 'virtual_path': {'key': 'virtualPath', 'type': 'str'}, + 'physical_path': {'key': 'physicalPath', 'type': 'str'}, + } + + def __init__( + self, + *, + virtual_path: Optional[str] = None, + physical_path: Optional[str] = None, + **kwargs + ): + super(VirtualDirectory, self).__init__(**kwargs) + self.virtual_path = virtual_path + self.physical_path = physical_path + + +class VirtualIPMapping(msrest.serialization.Model): + """Virtual IP mapping. + + :param virtual_ip: Virtual IP address. + :type virtual_ip: str + :param internal_http_port: Internal HTTP port. + :type internal_http_port: int + :param internal_https_port: Internal HTTPS port. + :type internal_https_port: int + :param in_use: Is virtual IP mapping in use. + :type in_use: bool + :param service_name: name of the service that virtual IP is assigned to. + :type service_name: str + """ + + _attribute_map = { + 'virtual_ip': {'key': 'virtualIP', 'type': 'str'}, + 'internal_http_port': {'key': 'internalHttpPort', 'type': 'int'}, + 'internal_https_port': {'key': 'internalHttpsPort', 'type': 'int'}, + 'in_use': {'key': 'inUse', 'type': 'bool'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + *, + virtual_ip: Optional[str] = None, + internal_http_port: Optional[int] = None, + internal_https_port: Optional[int] = None, + in_use: Optional[bool] = None, + service_name: Optional[str] = None, + **kwargs + ): + super(VirtualIPMapping, self).__init__(**kwargs) + self.virtual_ip = virtual_ip + self.internal_http_port = internal_http_port + self.internal_https_port = internal_https_port + self.in_use = in_use + self.service_name = service_name + + +class VirtualNetworkProfile(msrest.serialization.Model): + """Specification for using a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param id: Resource id of the Virtual Network. + :type id: str + :ivar name: Name of the Virtual Network (read-only). + :vartype name: str + :ivar type: Resource type of the Virtual Network (read-only). + :vartype type: str + :param subnet: Subnet within the Virtual Network. + :type subnet: str + """ + + _validation = { + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'subnet': {'key': 'subnet', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + subnet: Optional[str] = None, + **kwargs + ): + super(VirtualNetworkProfile, self).__init__(**kwargs) + self.id = id + self.name = None + self.type = None + self.subnet = subnet + + +class VnetGateway(ProxyOnlyResource): + """The Virtual Network gateway contract. This is used to give the Virtual Network gateway access to the VPN package. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_name: The Virtual Network name. + :type vnet_name: str + :param vpn_package_uri: The URI where the VPN package can be downloaded. + :type vpn_package_uri: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vpn_package_uri': {'key': 'properties.vpnPackageUri', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_name: Optional[str] = None, + vpn_package_uri: Optional[str] = None, + **kwargs + ): + super(VnetGateway, self).__init__(kind=kind, **kwargs) + self.vnet_name = vnet_name + self.vpn_package_uri = vpn_package_uri + + +class VnetInfo(ProxyOnlyResource): + """Virtual Network information contract. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_resource_id: The Virtual Network's resource ID. + :type vnet_resource_id: str + :ivar cert_thumbprint: The client certificate thumbprint. + :vartype cert_thumbprint: str + :param cert_blob: A certificate file (.cer) blob containing the public key of the private key + used to authenticate a + Point-To-Site VPN connection. + :type cert_blob: str + :ivar routes: The routes that this Virtual Network connection uses. + :vartype routes: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] + :ivar resync_required: :code:`true` if a resync is required; otherwise, + :code:`false`. + :vartype resync_required: bool + :param dns_servers: DNS servers to be used by this Virtual Network. This should be a comma- + separated list of IP addresses. + :type dns_servers: str + :param is_swift: Flag that is used to denote if this is VNET injection. + :type is_swift: bool + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'cert_thumbprint': {'readonly': True}, + 'routes': {'readonly': True}, + 'resync_required': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_resource_id': {'key': 'properties.vnetResourceId', 'type': 'str'}, + 'cert_thumbprint': {'key': 'properties.certThumbprint', 'type': 'str'}, + 'cert_blob': {'key': 'properties.certBlob', 'type': 'str'}, + 'routes': {'key': 'properties.routes', 'type': '[VnetRoute]'}, + 'resync_required': {'key': 'properties.resyncRequired', 'type': 'bool'}, + 'dns_servers': {'key': 'properties.dnsServers', 'type': 'str'}, + 'is_swift': {'key': 'properties.isSwift', 'type': 'bool'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_resource_id: Optional[str] = None, + cert_blob: Optional[str] = None, + dns_servers: Optional[str] = None, + is_swift: Optional[bool] = None, + **kwargs + ): + super(VnetInfo, self).__init__(kind=kind, **kwargs) + self.vnet_resource_id = vnet_resource_id + self.cert_thumbprint = None + self.cert_blob = cert_blob + self.routes = None + self.resync_required = None + self.dns_servers = dns_servers + self.is_swift = is_swift + + +class VnetParameters(ProxyOnlyResource): + """The required set of inputs to validate a VNET. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param vnet_resource_group: The Resource Group of the VNET to be validated. + :type vnet_resource_group: str + :param vnet_name: The name of the VNET to be validated. + :type vnet_name: str + :param vnet_subnet_name: The subnet name to be validated. + :type vnet_subnet_name: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'vnet_resource_group': {'key': 'properties.vnetResourceGroup', 'type': 'str'}, + 'vnet_name': {'key': 'properties.vnetName', 'type': 'str'}, + 'vnet_subnet_name': {'key': 'properties.vnetSubnetName', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + vnet_resource_group: Optional[str] = None, + vnet_name: Optional[str] = None, + vnet_subnet_name: Optional[str] = None, + **kwargs + ): + super(VnetParameters, self).__init__(kind=kind, **kwargs) + self.vnet_resource_group = vnet_resource_group + self.vnet_name = vnet_name + self.vnet_subnet_name = vnet_subnet_name + + +class VnetRoute(ProxyOnlyResource): + """Virtual Network route contract used to pass routing information for a Virtual Network. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param start_address: The starting address for this route. This may also include a CIDR + notation, in which case the end address must not be specified. + :type start_address: str + :param end_address: The ending address for this route. If the start address is specified in + CIDR notation, this must be omitted. + :type end_address: str + :param route_type: The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + Possible values include: "DEFAULT", "INHERITED", "STATIC". + :type route_type: str or ~azure.mgmt.web.v2020_09_01.models.RouteType + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'start_address': {'key': 'properties.startAddress', 'type': 'str'}, + 'end_address': {'key': 'properties.endAddress', 'type': 'str'}, + 'route_type': {'key': 'properties.routeType', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + start_address: Optional[str] = None, + end_address: Optional[str] = None, + route_type: Optional[Union[str, "RouteType"]] = None, + **kwargs + ): + super(VnetRoute, self).__init__(kind=kind, **kwargs) + self.start_address = start_address + self.end_address = end_address + self.route_type = route_type + + +class VnetValidationFailureDetails(ProxyOnlyResource): + """A class that describes the reason for a validation failure. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param failed: A flag describing whether or not validation failed. + :type failed: bool + :param failed_tests: A list of tests that failed in the validation. + :type failed_tests: list[~azure.mgmt.web.v2020_09_01.models.VnetValidationTestFailure] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'failed': {'key': 'properties.failed', 'type': 'bool'}, + 'failed_tests': {'key': 'properties.failedTests', 'type': '[VnetValidationTestFailure]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + failed: Optional[bool] = None, + failed_tests: Optional[List["VnetValidationTestFailure"]] = None, + **kwargs + ): + super(VnetValidationFailureDetails, self).__init__(kind=kind, **kwargs) + self.failed = failed + self.failed_tests = failed_tests + + +class VnetValidationTestFailure(ProxyOnlyResource): + """A class that describes a test that failed during NSG and UDR validation. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param test_name: The name of the test that failed. + :type test_name: str + :param details: The details of what caused the failure, e.g. the blocking rule name, etc. + :type details: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'test_name': {'key': 'properties.testName', 'type': 'str'}, + 'details': {'key': 'properties.details', 'type': 'str'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + test_name: Optional[str] = None, + details: Optional[str] = None, + **kwargs + ): + super(VnetValidationTestFailure, self).__init__(kind=kind, **kwargs) + self.test_name = test_name + self.details = details + + +class WebAppCollection(msrest.serialization.Model): + """Collection of App Service apps. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.Site] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Site]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["Site"], + **kwargs + ): + super(WebAppCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebAppInstanceStatusCollection(msrest.serialization.Model): + """Collection of app instances. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebSiteInstanceStatus]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WebSiteInstanceStatus"], + **kwargs + ): + super(WebAppInstanceStatusCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebJob(ProxyOnlyResource): + """Web Job Information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param run_command: Run command. + :type run_command: str + :param url: Job URL. + :type url: str + :param extra_info_url: Extra Info URL. + :type extra_info_url: str + :param web_job_type: Job type. Possible values include: "Continuous", "Triggered". + :type web_job_type: str or ~azure.mgmt.web.v2020_09_01.models.WebJobType + :param error: Error information. + :type error: str + :param using_sdk: Using SDK?. + :type using_sdk: bool + :param settings: Job settings. + :type settings: dict[str, object] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'run_command': {'key': 'properties.run_command', 'type': 'str'}, + 'url': {'key': 'properties.url', 'type': 'str'}, + 'extra_info_url': {'key': 'properties.extra_info_url', 'type': 'str'}, + 'web_job_type': {'key': 'properties.web_job_type', 'type': 'str'}, + 'error': {'key': 'properties.error', 'type': 'str'}, + 'using_sdk': {'key': 'properties.using_sdk', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': '{object}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + run_command: Optional[str] = None, + url: Optional[str] = None, + extra_info_url: Optional[str] = None, + web_job_type: Optional[Union[str, "WebJobType"]] = None, + error: Optional[str] = None, + using_sdk: Optional[bool] = None, + settings: Optional[Dict[str, object]] = None, + **kwargs + ): + super(WebJob, self).__init__(kind=kind, **kwargs) + self.run_command = run_command + self.url = url + self.extra_info_url = extra_info_url + self.web_job_type = web_job_type + self.error = error + self.using_sdk = using_sdk + self.settings = settings + + +class WebJobCollection(msrest.serialization.Model): + """Collection of Kudu web job information elements. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WebJob] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WebJob]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WebJob"], + **kwargs + ): + super(WebJobCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WebSiteInstanceStatus(ProxyOnlyResource): + """WebSiteInstanceStatus. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param state: Possible values include: "READY", "STOPPED", "UNKNOWN". + :type state: str or ~azure.mgmt.web.v2020_09_01.models.SiteRuntimeState + :param status_url: Link to the GetStatusApi in Kudu. + :type status_url: str + :param detector_url: Link to the Diagnose and Solve Portal. + :type detector_url: str + :param console_url: Link to the console to web app instance. + :type console_url: str + :param health_check_url: Link to the console to web app instance. + :type health_check_url: str + :param containers: Dictionary of :code:``. + :type containers: dict[str, ~azure.mgmt.web.v2020_09_01.models.ContainerInfo] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'state': {'key': 'properties.state', 'type': 'str'}, + 'status_url': {'key': 'properties.statusUrl', 'type': 'str'}, + 'detector_url': {'key': 'properties.detectorUrl', 'type': 'str'}, + 'console_url': {'key': 'properties.consoleUrl', 'type': 'str'}, + 'health_check_url': {'key': 'properties.healthCheckUrl', 'type': 'str'}, + 'containers': {'key': 'properties.containers', 'type': '{ContainerInfo}'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + state: Optional[Union[str, "SiteRuntimeState"]] = None, + status_url: Optional[str] = None, + detector_url: Optional[str] = None, + console_url: Optional[str] = None, + health_check_url: Optional[str] = None, + containers: Optional[Dict[str, "ContainerInfo"]] = None, + **kwargs + ): + super(WebSiteInstanceStatus, self).__init__(kind=kind, **kwargs) + self.state = state + self.status_url = status_url + self.detector_url = detector_url + self.console_url = console_url + self.health_check_url = health_check_url + self.containers = containers + + +class WorkerPool(msrest.serialization.Model): + """Worker pool of an App Service Environment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'worker_size_id': {'key': 'workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'computeMode', 'type': 'str'}, + 'worker_size': {'key': 'workerSize', 'type': 'str'}, + 'worker_count': {'key': 'workerCount', 'type': 'int'}, + 'instance_names': {'key': 'instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + worker_size_id: Optional[int] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[str] = None, + worker_count: Optional[int] = None, + **kwargs + ): + super(WorkerPool, self).__init__(**kwargs) + self.worker_size_id = worker_size_id + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_count = worker_count + self.instance_names = None + + +class WorkerPoolCollection(msrest.serialization.Model): + """Collection of worker pools. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param value: Required. Collection of resources. + :type value: list[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :ivar next_link: Link to next page of resources. + :vartype next_link: str + """ + + _validation = { + 'value': {'required': True}, + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[WorkerPoolResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: List["WorkerPoolResource"], + **kwargs + ): + super(WorkerPoolCollection, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class WorkerPoolResource(ProxyOnlyResource): + """Worker pool of an App Service Environment ARM resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource Id. + :vartype id: str + :ivar name: Resource Name. + :vartype name: str + :param kind: Kind of resource. + :type kind: str + :ivar type: Resource type. + :vartype type: str + :ivar system_data: The system metadata relating to this resource. + :vartype system_data: ~azure.mgmt.web.v2020_09_01.models.SystemData + :param sku: Description of a SKU for a scalable resource. + :type sku: ~azure.mgmt.web.v2020_09_01.models.SkuDescription + :param worker_size_id: Worker size ID for referencing this worker pool. + :type worker_size_id: int + :param compute_mode: Shared or dedicated app hosting. Possible values include: "Shared", + "Dedicated", "Dynamic". + :type compute_mode: str or ~azure.mgmt.web.v2020_09_01.models.ComputeModeOptions + :param worker_size: VM size of the worker pool instances. + :type worker_size: str + :param worker_count: Number of instances in the worker pool. + :type worker_count: int + :ivar instance_names: Names of all instances in the worker pool (read only). + :vartype instance_names: list[str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'instance_names': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'SkuDescription'}, + 'worker_size_id': {'key': 'properties.workerSizeId', 'type': 'int'}, + 'compute_mode': {'key': 'properties.computeMode', 'type': 'str'}, + 'worker_size': {'key': 'properties.workerSize', 'type': 'str'}, + 'worker_count': {'key': 'properties.workerCount', 'type': 'int'}, + 'instance_names': {'key': 'properties.instanceNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + kind: Optional[str] = None, + sku: Optional["SkuDescription"] = None, + worker_size_id: Optional[int] = None, + compute_mode: Optional[Union[str, "ComputeModeOptions"]] = None, + worker_size: Optional[str] = None, + worker_count: Optional[int] = None, + **kwargs + ): + super(WorkerPoolResource, self).__init__(kind=kind, **kwargs) + self.sku = sku + self.worker_size_id = worker_size_id + self.compute_mode = compute_mode + self.worker_size = worker_size + self.worker_count = worker_count + self.instance_names = None diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_web_site_management_client_enums.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_web_site_management_client_enums.py new file mode 100644 index 000000000000..0e0a8d94b03a --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/models/_web_site_management_client_enums.py @@ -0,0 +1,760 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from enum import Enum, EnumMeta +from six import with_metaclass + +class _CaseInsensitiveEnumMeta(EnumMeta): + def __getitem__(self, name): + return super().__getitem__(name.upper()) + + def __getattr__(cls, name): + """Return the enum member matching `name` + We use __getattr__ instead of descriptors or inserting into the enum + class' __dict__ in order to support `name` and `value` being both + properties for enum members (which live in the class' __dict__) and + enum members themselves. + """ + try: + return cls._member_map_[name.upper()] + except KeyError: + raise AttributeError(name) + + +class AccessControlEntryAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Action object. + """ + + PERMIT = "Permit" + DENY = "Deny" + +class AppServiceCertificateOrderPatchResourcePropertiesAppServiceCertificateNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class AppServiceCertificateOrderPropertiesAppServiceCertificateNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class AppServicePlanRestrictions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """App Service plans this offer is restricted to. + """ + + NONE = "None" + FREE = "Free" + SHARED = "Shared" + BASIC = "Basic" + STANDARD = "Standard" + PREMIUM = "Premium" + +class AutoHealActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Predefined action to be taken. + """ + + RECYCLE = "Recycle" + LOG_EVENT = "LogEvent" + CUSTOM_ACTION = "CustomAction" + +class AzureResourceType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the Azure resource the hostname is assigned to. + """ + + WEBSITE = "Website" + TRAFFIC_MANAGER = "TrafficManager" + +class AzureStorageState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State of the storage account. + """ + + OK = "Ok" + INVALID_CREDENTIALS = "InvalidCredentials" + INVALID_SHARE = "InvalidShare" + +class AzureStorageType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of storage. + """ + + AZURE_FILES = "AzureFiles" + AZURE_BLOB = "AzureBlob" + +class BackupItemStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Backup status. + """ + + IN_PROGRESS = "InProgress" + FAILED = "Failed" + SUCCEEDED = "Succeeded" + TIMED_OUT = "TimedOut" + CREATED = "Created" + SKIPPED = "Skipped" + PARTIALLY_SUCCEEDED = "PartiallySucceeded" + DELETE_IN_PROGRESS = "DeleteInProgress" + DELETE_FAILED = "DeleteFailed" + DELETED = "Deleted" + +class BackupRestoreOperationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Operation type. + """ + + DEFAULT = "Default" + CLONE = "Clone" + RELOCATION = "Relocation" + SNAPSHOT = "Snapshot" + CLOUD_FS = "CloudFS" + +class BuildStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The status of the static site build. + """ + + WAITING_FOR_DEPLOYMENT = "WaitingForDeployment" + UPLOADING = "Uploading" + DEPLOYING = "Deploying" + READY = "Ready" + FAILED = "Failed" + DELETING = "Deleting" + DETACHED = "Detached" + +class BuiltInAuthenticationProvider(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The default authentication provider to use when multiple providers are configured. + This setting is only needed if multiple providers are configured and the unauthenticated client + action is set to "RedirectToLoginPage". + """ + + AZURE_ACTIVE_DIRECTORY = "AzureActiveDirectory" + FACEBOOK = "Facebook" + GOOGLE = "Google" + MICROSOFT_ACCOUNT = "MicrosoftAccount" + TWITTER = "Twitter" + GITHUB = "Github" + +class CertificateOrderActionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Action type. + """ + + CERTIFICATE_ISSUED = "CertificateIssued" + CERTIFICATE_ORDER_CANCELED = "CertificateOrderCanceled" + CERTIFICATE_ORDER_CREATED = "CertificateOrderCreated" + CERTIFICATE_REVOKED = "CertificateRevoked" + DOMAIN_VALIDATION_COMPLETE = "DomainValidationComplete" + FRAUD_DETECTED = "FraudDetected" + ORG_NAME_CHANGE = "OrgNameChange" + ORG_VALIDATION_COMPLETE = "OrgValidationComplete" + SAN_DROP = "SanDrop" + FRAUD_CLEARED = "FraudCleared" + CERTIFICATE_EXPIRED = "CertificateExpired" + CERTIFICATE_EXPIRATION_WARNING = "CertificateExpirationWarning" + FRAUD_DOCUMENTATION_REQUIRED = "FraudDocumentationRequired" + UNKNOWN = "Unknown" + +class CertificateOrderStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current order status. + """ + + PENDINGISSUANCE = "Pendingissuance" + ISSUED = "Issued" + REVOKED = "Revoked" + CANCELED = "Canceled" + DENIED = "Denied" + PENDINGREVOCATION = "Pendingrevocation" + PENDING_REKEY = "PendingRekey" + UNUSED = "Unused" + EXPIRED = "Expired" + NOT_SUBMITTED = "NotSubmitted" + +class CertificateProductType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Certificate product type. + """ + + STANDARD_DOMAIN_VALIDATED_SSL = "StandardDomainValidatedSsl" + STANDARD_DOMAIN_VALIDATED_WILD_CARD_SSL = "StandardDomainValidatedWildCardSsl" + +class Channels(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """List of channels that this recommendation can apply. + """ + + NOTIFICATION = "Notification" + API = "Api" + EMAIL = "Email" + WEBHOOK = "Webhook" + ALL = "All" + +class CheckNameResourceTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Resource type used for verification. + """ + + SITE = "Site" + SLOT = "Slot" + HOSTING_ENVIRONMENT = "HostingEnvironment" + PUBLISHING_USER = "PublishingUser" + MICROSOFT_WEB_SITES = "Microsoft.Web/sites" + MICROSOFT_WEB_SITES_SLOTS = "Microsoft.Web/sites/slots" + MICROSOFT_WEB_HOSTING_ENVIRONMENTS = "Microsoft.Web/hostingEnvironments" + MICROSOFT_WEB_PUBLISHING_USERS = "Microsoft.Web/publishingUsers" + +class ClientCertMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """This composes with ClientCertEnabled setting. + + + * ClientCertEnabled: false means ClientCert is ignored. + * ClientCertEnabled: true and ClientCertMode: Required means ClientCert is required. + * ClientCertEnabled: true and ClientCertMode: Optional means ClientCert is optional or + accepted. + """ + + REQUIRED = "Required" + OPTIONAL = "Optional" + +class CloneAbilityResult(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of app. + """ + + CLONEABLE = "Cloneable" + PARTIALLY_CLONEABLE = "PartiallyCloneable" + NOT_CLONEABLE = "NotCloneable" + +class ComputeModeOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Shared/dedicated workers. + """ + + SHARED = "Shared" + DEDICATED = "Dedicated" + DYNAMIC = "Dynamic" + +class ConnectionStringType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of database. + """ + + MY_SQL = "MySql" + SQL_SERVER = "SQLServer" + SQL_AZURE = "SQLAzure" + CUSTOM = "Custom" + NOTIFICATION_HUB = "NotificationHub" + SERVICE_BUS = "ServiceBus" + EVENT_HUB = "EventHub" + API_HUB = "ApiHub" + DOC_DB = "DocDb" + REDIS_CACHE = "RedisCache" + POSTGRE_SQL = "PostgreSQL" + +class ContinuousWebJobStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job status. + """ + + INITIALIZING = "Initializing" + STARTING = "Starting" + RUNNING = "Running" + PENDING_RESTART = "PendingRestart" + STOPPED = "Stopped" + +class CookieExpirationConvention(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + FIXED_TIME = "FixedTime" + IDENTITY_PROVIDER_DERIVED = "IdentityProviderDerived" + +class CreatedByType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of identity that created the resource. + """ + + USER = "User" + APPLICATION = "Application" + MANAGED_IDENTITY = "ManagedIdentity" + KEY = "Key" + +class CustomHostNameDnsRecordType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the DNS record. + """ + + C_NAME = "CName" + A = "A" + +class DatabaseType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Database type (e.g. SqlAzure / MySql). + """ + + SQL_AZURE = "SqlAzure" + MY_SQL = "MySql" + LOCAL_MY_SQL = "LocalMySql" + POSTGRE_SQL = "PostgreSql" + +class DnsType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current DNS type + """ + + AZURE_DNS = "AzureDns" + DEFAULT_DOMAIN_REGISTRAR_DNS = "DefaultDomainRegistrarDns" + +class DnsVerificationTestResult(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """DNS verification test result. + """ + + PASSED = "Passed" + FAILED = "Failed" + SKIPPED = "Skipped" + +class DomainPatchResourcePropertiesDomainNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class DomainPropertiesDomainNotRenewableReasonsItem(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REGISTRATION_STATUS_NOT_SUPPORTED_FOR_RENEWAL = "RegistrationStatusNotSupportedForRenewal" + EXPIRATION_NOT_IN_RENEWAL_TIME_RANGE = "ExpirationNotInRenewalTimeRange" + SUBSCRIPTION_NOT_ACTIVE = "SubscriptionNotActive" + +class DomainStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Domain registration status. + """ + + ACTIVE = "Active" + AWAITING = "Awaiting" + CANCELLED = "Cancelled" + CONFISCATED = "Confiscated" + DISABLED = "Disabled" + EXCLUDED = "Excluded" + EXPIRED = "Expired" + FAILED = "Failed" + HELD = "Held" + LOCKED = "Locked" + PARKED = "Parked" + PENDING = "Pending" + RESERVED = "Reserved" + REVERTED = "Reverted" + SUSPENDED = "Suspended" + TRANSFERRED = "Transferred" + UNKNOWN = "Unknown" + UNLOCKED = "Unlocked" + UNPARKED = "Unparked" + UPDATED = "Updated" + JSON_CONVERTER_FAILED = "JsonConverterFailed" + +class DomainType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Valid values are Regular domain: Azure will charge the full price of domain registration, + SoftDeleted: Purchasing this domain will simply restore it and this operation will not cost + anything. + """ + + REGULAR = "Regular" + SOFT_DELETED = "SoftDeleted" + +class Enum5(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + WINDOWS = "Windows" + LINUX = "Linux" + WINDOWS_FUNCTIONS = "WindowsFunctions" + LINUX_FUNCTIONS = "LinuxFunctions" + +class Enum6(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + WINDOWS = "Windows" + LINUX = "Linux" + WINDOWS_FUNCTIONS = "WindowsFunctions" + LINUX_FUNCTIONS = "LinuxFunctions" + +class ForwardProxyConvention(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + NO_PROXY = "NoProxy" + STANDARD = "Standard" + CUSTOM = "Custom" + +class FrequencyUnit(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The unit of time for how often the backup should be executed (e.g. for weekly backup, this + should be set to Day and FrequencyInterval should be set to 7) + """ + + DAY = "Day" + HOUR = "Hour" + +class FtpsState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State of FTP / FTPS service + """ + + ALL_ALLOWED = "AllAllowed" + FTPS_ONLY = "FtpsOnly" + DISABLED = "Disabled" + +class HostingEnvironmentStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Current status of the App Service Environment. + """ + + PREPARING = "Preparing" + READY = "Ready" + SCALING = "Scaling" + DELETING = "Deleting" + +class HostNameType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of the hostname. + """ + + VERIFIED = "Verified" + MANAGED = "Managed" + +class HostType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Indicates whether the hostname is a standard or repository hostname. + """ + + STANDARD = "Standard" + REPOSITORY = "Repository" + +class InAvailabilityReasonType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """:code:`Invalid` indicates the name provided does not match Azure App Service + naming requirements. :code:`AlreadyExists` indicates that the name is already in + use and is therefore unavailable. + """ + + INVALID = "Invalid" + ALREADY_EXISTS = "AlreadyExists" + +class IpFilterTag(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Defines what this IP filter will be used for. This is to support IP filtering on proxies. + """ + + DEFAULT = "Default" + XFF_PROXY = "XffProxy" + SERVICE_TAG = "ServiceTag" + +class IssueType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Represents the type of the Detector + """ + + SERVICE_INCIDENT = "ServiceIncident" + APP_DEPLOYMENT = "AppDeployment" + APP_CRASH = "AppCrash" + RUNTIME_ISSUE_DETECTED = "RuntimeIssueDetected" + ASE_DEPLOYMENT = "AseDeployment" + USER_ISSUE = "UserIssue" + PLATFORM_ISSUE = "PlatformIssue" + OTHER = "Other" + +class KeyVaultSecretStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of the Key Vault secret. + """ + + INITIALIZED = "Initialized" + WAITING_ON_CERTIFICATE_ORDER = "WaitingOnCertificateOrder" + SUCCEEDED = "Succeeded" + CERTIFICATE_ORDER_FAILED = "CertificateOrderFailed" + OPERATION_NOT_PERMITTED_ON_KEY_VAULT = "OperationNotPermittedOnKeyVault" + AZURE_SERVICE_UNAUTHORIZED_TO_ACCESS_KEY_VAULT = "AzureServiceUnauthorizedToAccessKeyVault" + KEY_VAULT_DOES_NOT_EXIST = "KeyVaultDoesNotExist" + KEY_VAULT_SECRET_DOES_NOT_EXIST = "KeyVaultSecretDoesNotExist" + UNKNOWN_ERROR = "UnknownError" + EXTERNAL_PRIVATE_KEY = "ExternalPrivateKey" + UNKNOWN = "Unknown" + +class LoadBalancingMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Specifies which endpoints to serve internally in the Virtual Network for the App Service + Environment. + """ + + NONE = "None" + WEB = "Web" + PUBLISHING = "Publishing" + WEB_PUBLISHING = "Web,Publishing" + +class LogLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Log level. + """ + + OFF = "Off" + VERBOSE = "Verbose" + INFORMATION = "Information" + WARNING = "Warning" + ERROR = "Error" + +class ManagedPipelineMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Managed pipeline mode. + """ + + INTEGRATED = "Integrated" + CLASSIC = "Classic" + +class ManagedServiceIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of managed service identity. + """ + + SYSTEM_ASSIGNED = "SystemAssigned" + USER_ASSIGNED = "UserAssigned" + SYSTEM_ASSIGNED_USER_ASSIGNED = "SystemAssigned, UserAssigned" + NONE = "None" + +class MSDeployLogEntryType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Log entry type + """ + + MESSAGE = "Message" + WARNING = "Warning" + ERROR = "Error" + +class MSDeployProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Provisioning state + """ + + ACCEPTED = "accepted" + RUNNING = "running" + SUCCEEDED = "succeeded" + FAILED = "failed" + CANCELED = "canceled" + +class MySqlMigrationType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of migration operation to be done + """ + + LOCAL_TO_REMOTE = "LocalToRemote" + REMOTE_TO_LOCAL = "RemoteToLocal" + +class NotificationLevel(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Level indicating how critical this recommendation can impact. + """ + + CRITICAL = "Critical" + WARNING = "Warning" + INFORMATION = "Information" + NON_URGENT_SUGGESTION = "NonUrgentSuggestion" + +class OperationStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current status of the operation. + """ + + IN_PROGRESS = "InProgress" + FAILED = "Failed" + SUCCEEDED = "Succeeded" + TIMED_OUT = "TimedOut" + CREATED = "Created" + +class ProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Status of certificate order. + """ + + SUCCEEDED = "Succeeded" + FAILED = "Failed" + CANCELED = "Canceled" + IN_PROGRESS = "InProgress" + DELETING = "Deleting" + +class PublicCertificateLocation(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Public Certificate Location + """ + + CURRENT_USER_MY = "CurrentUserMy" + LOCAL_MACHINE_MY = "LocalMachineMy" + UNKNOWN = "Unknown" + +class PublishingProfileFormat(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of the format. Valid values are: + FileZilla3 + WebDeploy -- default + Ftp + """ + + FILE_ZILLA3 = "FileZilla3" + WEB_DEPLOY = "WebDeploy" + FTP = "Ftp" + +class RedundancyMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site redundancy mode + """ + + NONE = "None" + MANUAL = "Manual" + FAILOVER = "Failover" + ACTIVE_ACTIVE = "ActiveActive" + GEO_REDUNDANT = "GeoRedundant" + +class RenderingType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Rendering Type + """ + + NO_GRAPH = "NoGraph" + TABLE = "Table" + TIME_SERIES = "TimeSeries" + TIME_SERIES_PER_INSTANCE = "TimeSeriesPerInstance" + +class ResourceScopeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Name of a resource type this recommendation applies, e.g. Subscription, ServerFarm, Site. + """ + + SERVER_FARM = "ServerFarm" + SUBSCRIPTION = "Subscription" + WEB_SITE = "WebSite" + +class RouteType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of route this is: + DEFAULT - By default, every app has routes to the local address ranges specified by RFC1918 + INHERITED - Routes inherited from the real Virtual Network routes + STATIC - Static route set on the app only + + These values will be used for syncing an app's routes with those from a Virtual Network. + """ + + DEFAULT = "DEFAULT" + INHERITED = "INHERITED" + STATIC = "STATIC" + +class ScmType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """SCM type. + """ + + NONE = "None" + DROPBOX = "Dropbox" + TFS = "Tfs" + LOCAL_GIT = "LocalGit" + GIT_HUB = "GitHub" + CODE_PLEX_GIT = "CodePlexGit" + CODE_PLEX_HG = "CodePlexHg" + BITBUCKET_GIT = "BitbucketGit" + BITBUCKET_HG = "BitbucketHg" + EXTERNAL_GIT = "ExternalGit" + EXTERNAL_HG = "ExternalHg" + ONE_DRIVE = "OneDrive" + VSO = "VSO" + VSTSRM = "VSTSRM" + +class SiteAvailabilityState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Management information availability state for the app. + """ + + NORMAL = "Normal" + LIMITED = "Limited" + DISASTER_RECOVERY_MODE = "DisasterRecoveryMode" + +class SiteExtensionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site extension type. + """ + + GALLERY = "Gallery" + WEB_ROOT = "WebRoot" + +class SiteLoadBalancing(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Site load balancing. + """ + + WEIGHTED_ROUND_ROBIN = "WeightedRoundRobin" + LEAST_REQUESTS = "LeastRequests" + LEAST_RESPONSE_TIME = "LeastResponseTime" + WEIGHTED_TOTAL_TRAFFIC = "WeightedTotalTraffic" + REQUEST_HASH = "RequestHash" + +class SiteRuntimeState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + READY = "READY" + STOPPED = "STOPPED" + UNKNOWN = "UNKNOWN" + +class SkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + FREE = "Free" + SHARED = "Shared" + BASIC = "Basic" + STANDARD = "Standard" + PREMIUM = "Premium" + DYNAMIC = "Dynamic" + ISOLATED = "Isolated" + PREMIUM_V2 = "PremiumV2" + ELASTIC_PREMIUM = "ElasticPremium" + ELASTIC_ISOLATED = "ElasticIsolated" + +class SolutionType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of Solution + """ + + QUICK_SOLUTION = "QuickSolution" + DEEP_INVESTIGATION = "DeepInvestigation" + BEST_PRACTICES = "BestPractices" + +class SslState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """SSL type. + """ + + DISABLED = "Disabled" + SNI_ENABLED = "SniEnabled" + IP_BASED_ENABLED = "IpBasedEnabled" + +class StatusOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """App Service plan status. + """ + + READY = "Ready" + PENDING = "Pending" + CREATING = "Creating" + +class SupportedTlsVersions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """MinTlsVersion: configures the minimum version of TLS required for SSL requests + """ + + ONE0 = "1.0" + ONE1 = "1.1" + ONE2 = "1.2" + +class TriggeredWebJobStatus(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job status. + """ + + SUCCESS = "Success" + FAILED = "Failed" + ERROR = "Error" + +class TriggerTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The trigger type of the function + """ + + HTTP_TRIGGER = "HttpTrigger" + UNKNOWN = "Unknown" + +class UnauthenticatedClientAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The action to take when an unauthenticated client attempts to access the app. + """ + + REDIRECT_TO_LOGIN_PAGE = "RedirectToLoginPage" + ALLOW_ANONYMOUS = "AllowAnonymous" + +class UnauthenticatedClientActionV2(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + REDIRECT_TO_LOGIN_PAGE = "RedirectToLoginPage" + ALLOW_ANONYMOUS = "AllowAnonymous" + RETURN401 = "Return401" + RETURN403 = "Return403" + +class UsageState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """State indicating whether the app has exceeded its quota usage. Read-only. + """ + + NORMAL = "Normal" + EXCEEDED = "Exceeded" + +class ValidateResourceTypes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Resource type used for verification. + """ + + SERVER_FARM = "ServerFarm" + SITE = "Site" + +class WebJobType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Job type. + """ + + CONTINUOUS = "Continuous" + TRIGGERED = "Triggered" + +class WorkerSizeOptions(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Size of the machines. + """ + + SMALL = "Small" + MEDIUM = "Medium" + LARGE = "Large" + D1 = "D1" + D2 = "D2" + D3 = "D3" + NESTED_SMALL = "NestedSmall" + DEFAULT = "Default" diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/__init__.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/__init__.py new file mode 100644 index 000000000000..8f414125deed --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/__init__.py @@ -0,0 +1,43 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._app_service_certificate_orders_operations import AppServiceCertificateOrdersOperations +from ._certificate_registration_provider_operations import CertificateRegistrationProviderOperations +from ._domains_operations import DomainsOperations +from ._top_level_domains_operations import TopLevelDomainsOperations +from ._domain_registration_provider_operations import DomainRegistrationProviderOperations +from ._certificates_operations import CertificatesOperations +from ._deleted_web_apps_operations import DeletedWebAppsOperations +from ._diagnostics_operations import DiagnosticsOperations +from ._provider_operations import ProviderOperations +from ._recommendations_operations import RecommendationsOperations +from ._web_site_management_client_operations import WebSiteManagementClientOperationsMixin +from ._web_apps_operations import WebAppsOperations +from ._static_sites_operations import StaticSitesOperations +from ._app_service_environments_operations import AppServiceEnvironmentsOperations +from ._app_service_plans_operations import AppServicePlansOperations +from ._resource_health_metadata_operations import ResourceHealthMetadataOperations + +__all__ = [ + 'AppServiceCertificateOrdersOperations', + 'CertificateRegistrationProviderOperations', + 'DomainsOperations', + 'TopLevelDomainsOperations', + 'DomainRegistrationProviderOperations', + 'CertificatesOperations', + 'DeletedWebAppsOperations', + 'DiagnosticsOperations', + 'ProviderOperations', + 'RecommendationsOperations', + 'WebSiteManagementClientOperationsMixin', + 'WebAppsOperations', + 'StaticSitesOperations', + 'AppServiceEnvironmentsOperations', + 'AppServicePlansOperations', + 'ResourceHealthMetadataOperations', +] diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_certificate_orders_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_certificate_orders_operations.py new file mode 100644 index 000000000000..08b36985a546 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_certificate_orders_operations.py @@ -0,0 +1,1517 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceCertificateOrdersOperations(object): + """AppServiceCertificateOrdersOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateOrderCollection"] + """List all certificate orders in a subscription. + + Description for List all certificate orders in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + def validate_purchase_information( + self, + app_service_certificate_order, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> None + """Validate information for a certificate order. + + Description for Validate information for a certificate order. + + :param app_service_certificate_order: Information for a certificate order. + :type app_service_certificate_order: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_purchase_information.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_certificate_order, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_purchase_information.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.CertificateRegistration/validateCertificateRegistrationInformation'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateOrderCollection"] + """Get certificate orders in a resource group. + + Description for Get certificate orders in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateOrderCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrderCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrderCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders'} # type: ignore + + def get( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + """Get a certificate order. + + Description for Get a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order.. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrder') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrder" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceCertificateOrder"] + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceCertificateOrder or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + certificate_distinguished_name=certificate_distinguished_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete an existing certificate order. + + Description for Delete an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + certificate_distinguished_name, # type: "_models.AppServiceCertificateOrderPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateOrder" + """Create or update a certificate purchase order. + + Description for Create or update a certificate purchase order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param certificate_distinguished_name: Distinguished name to use for the certificate order. + :type certificate_distinguished_name: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrderPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateOrder, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateOrder + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateOrder"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_distinguished_name, 'AppServiceCertificateOrderPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateOrder', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}'} # type: ignore + + def list_certificates( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceCertificateCollection"] + """List all certificates associated with a certificate order. + + Description for List all certificates associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates'} # type: ignore + + def get_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + """Get the certificate associated with a certificate order. + + Description for Get the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def _create_or_update_certificate_initial( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificateResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_certificate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificateResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_certificate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def begin_create_or_update_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificateResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceCertificateResource"] + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceCertificateResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_certificate_initial( + resource_group_name=resource_group_name, + certificate_order_name=certificate_order_name, + name=name, + key_vault_certificate=key_vault_certificate, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def delete_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete the certificate associated with a certificate order. + + Description for Delete the certificate associated with a certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def update_certificate( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name, # type: str + key_vault_certificate, # type: "_models.AppServiceCertificatePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceCertificateResource" + """Creates or updates a certificate and associates with key vault secret. + + Description for Creates or updates a certificate and associates with key vault secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name: Name of the certificate. + :type name: str + :param key_vault_certificate: Key vault certificate resource Id. + :type key_vault_certificate: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceCertificateResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceCertificateResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceCertificateResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key_vault_certificate, 'AppServiceCertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceCertificateResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/certificates/{name}'} # type: ignore + + def reissue( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + reissue_certificate_order_request, # type: "_models.ReissueCertificateOrderRequest" + **kwargs # type: Any + ): + # type: (...) -> None + """Reissue an existing certificate order. + + Description for Reissue an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param reissue_certificate_order_request: Parameters for the reissue. + :type reissue_certificate_order_request: ~azure.mgmt.web.v2020_09_01.models.ReissueCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reissue.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reissue_certificate_order_request, 'ReissueCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reissue.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/reissue'} # type: ignore + + def renew( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + renew_certificate_order_request, # type: "_models.RenewCertificateOrderRequest" + **kwargs # type: Any + ): + # type: (...) -> None + """Renew an existing certificate order. + + Description for Renew an existing certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param renew_certificate_order_request: Renew parameters. + :type renew_certificate_order_request: ~azure.mgmt.web.v2020_09_01.models.RenewCertificateOrderRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(renew_certificate_order_request, 'RenewCertificateOrderRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/renew'} # type: ignore + + def resend_email( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resend certificate email. + + Description for Resend certificate email. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.resend_email.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_email.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendEmail'} # type: ignore + + def resend_request_emails( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + name_identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> None + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param name_identifier: Email address. + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.resend_request_emails.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + resend_request_emails.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/resendRequestEmails'} # type: ignore + + def retrieve_site_seal( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + site_seal_request, # type: "_models.SiteSealRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSeal" + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :param site_seal_request: Site seal request. + :type site_seal_request: ~azure.mgmt.web.v2020_09_01.models.SiteSealRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSeal, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSeal + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSeal"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.retrieve_site_seal.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_seal_request, 'SiteSealRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteSeal', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_site_seal.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/retrieveSiteSeal'} # type: ignore + + def verify_domain_ownership( + self, + resource_group_name, # type: str + certificate_order_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Verify domain ownership for this certificate order. + + Description for Verify domain ownership for this certificate order. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param certificate_order_name: Name of the certificate order. + :type certificate_order_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.verify_domain_ownership.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'certificateOrderName': self._serialize.url("certificate_order_name", certificate_order_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + verify_domain_ownership.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{certificateOrderName}/verifyDomainOwnership'} # type: ignore + + def retrieve_certificate_actions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.CertificateOrderAction"] + """Retrieve the list of certificate actions. + + Description for Retrieve the list of certificate actions. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateOrderAction, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.CertificateOrderAction] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateOrderAction"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_actions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateOrderAction]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_actions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveCertificateActions'} # type: ignore + + def retrieve_certificate_email_history( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.CertificateEmail"] + """Retrieve email history. + + Description for Retrieve email history. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate order. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of CertificateEmail, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.CertificateEmail] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.CertificateEmail"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.retrieve_certificate_email_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[CertificateEmail]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + retrieve_certificate_email_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.CertificateRegistration/certificateOrders/{name}/retrieveEmailHistory'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_environments_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_environments_operations.py new file mode 100644 index 000000000000..b1b0cc978095 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_environments_operations.py @@ -0,0 +1,3293 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServiceEnvironmentsOperations(object): + """AppServiceEnvironmentsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceEnvironmentCollection"] + """Get all App Service Environments for a subscription. + + Description for Get all App Service Environments for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServiceEnvironmentCollection"] + """Get all App Service Environments in a resource group. + + Description for Get all App Service Environments in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServiceEnvironmentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + """Get the properties of an App Service Environment. + + Description for Get the properties of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServiceEnvironmentResource"] + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServiceEnvironmentResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + hosting_environment_envelope=hosting_environment_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + name, # type: str + force_delete=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_delete is not None: + query_parameters['forceDelete'] = self._serialize.query("force_delete", force_delete, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + name, # type: str + force_delete=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Delete an App Service Environment. + + Description for Delete an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param force_delete: Specify :code:`true` to force the deletion even if the App + Service Environment contains resources. The default is :code:`false`. + :type force_delete: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + name=name, + force_delete=force_delete, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + hosting_environment_envelope, # type: "_models.AppServiceEnvironmentPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServiceEnvironmentResource" + """Create or update an App Service Environment. + + Description for Create or update an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param hosting_environment_envelope: Configuration details of the App Service Environment. + :type hosting_environment_envelope: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServiceEnvironmentResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServiceEnvironmentResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServiceEnvironmentResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(hosting_environment_envelope, 'AppServiceEnvironmentPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServiceEnvironmentResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}'} # type: ignore + + def list_capacities( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StampCapacityCollection"] + """Get the used, available, and total worker capacity an App Service Environment. + + Description for Get the used, available, and total worker capacity an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StampCapacityCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StampCapacityCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StampCapacityCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_capacities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StampCapacityCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_capacities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/compute'} # type: ignore + + def get_vip_info( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AddressResponse" + """Get IP addresses assigned to an App Service Environment. + + Description for Get IP addresses assigned to an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AddressResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AddressResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AddressResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vip_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AddressResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vip_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/capacities/virtualip'} # type: ignore + + def _change_vnet_initial( + self, + resource_group_name, # type: str + name, # type: str + vnet_info, # type: "_models.VirtualNetworkProfile" + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._change_vnet_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _change_vnet_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + def begin_change_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_info, # type: "_models.VirtualNetworkProfile" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Move an App Service Environment to a different VNET. + + Description for Move an App Service Environment to a different VNET. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param vnet_info: Details for the new virtual network. + :type vnet_info: ~azure.mgmt.web.v2020_09_01.models.VirtualNetworkProfile + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.change_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(vnet_info, 'VirtualNetworkProfile') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._change_vnet_initial( + resource_group_name=resource_group_name, + name=name, + vnet_info=vnet_info, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_change_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/changeVirtualNetwork'} # type: ignore + + def list_diagnostics( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.HostingEnvironmentDiagnostics"] + """Get diagnostic information for an App Service Environment. + + Description for Get diagnostic information for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDiagnostics] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.HostingEnvironmentDiagnostics"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_diagnostics.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[HostingEnvironmentDiagnostics]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_diagnostics.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics'} # type: ignore + + def get_diagnostics_item( + self, + resource_group_name, # type: str + name, # type: str + diagnostics_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostingEnvironmentDiagnostics" + """Get a diagnostics item for an App Service Environment. + + Description for Get a diagnostics item for an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param diagnostics_name: Name of the diagnostics item. + :type diagnostics_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostingEnvironmentDiagnostics, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostingEnvironmentDiagnostics + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostingEnvironmentDiagnostics"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostics_item.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'diagnosticsName': self._serialize.url("diagnostics_name", diagnostics_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostingEnvironmentDiagnostics', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostics_item.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/diagnostics/{diagnosticsName}'} # type: ignore + + def get_inbound_network_dependencies_endpoints( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.InboundEnvironmentEndpointCollection"] + """Get the network endpoints of all inbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all inbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either InboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.InboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.InboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_inbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('InboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_inbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/inboundNetworkDependenciesEndpoints'} # type: ignore + + def list_multi_role_pools( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WorkerPoolCollection"] + """Get all multi-role pools. + + Description for Get all multi-role pools. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools'} # type: ignore + + def get_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Get properties of a multi-role pool. + + Description for Get properties of a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def _create_or_update_multi_role_pool_initial( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_multi_role_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_multi_role_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def begin_create_or_update_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WorkerPoolResource"] + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_multi_role_pool_initial( + resource_group_name=resource_group_name, + name=name, + multi_role_pool_envelope=multi_role_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def update_multi_role_pool( + self, + resource_group_name, # type: str + name, # type: str + multi_role_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Create or update a multi-role pool. + + Description for Create or update a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param multi_role_pool_envelope: Properties of the multi-role pool. + :type multi_role_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_multi_role_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(multi_role_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_multi_role_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default'} # type: ignore + + def list_multi_role_pool_instance_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + instance, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a specific instance of a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a multi-role pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param instance: Name of the instance in the multi-role pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/instances/{instance}/metricdefinitions'} # type: ignore + + def list_multi_role_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a multi-role pool of an App Service Environment. + + Description for Get metric definitions for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/metricdefinitions'} # type: ignore + + def list_multi_role_pool_skus( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SkuInfoCollection"] + """Get available SKUs for scaling a multi-role pool. + + Description for Get available SKUs for scaling a multi-role pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/skus'} # type: ignore + + def list_multi_role_usages( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.UsageCollection"] + """Get usage metrics for a multi-role pool of an App Service Environment. + + Description for Get usage metrics for a multi-role pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_multi_role_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_multi_role_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/multiRolePools/default/usages'} # type: ignore + + def list_operations( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.Operation"] + """List all currently running operations on the App Service Environment. + + Description for List all currently running operations on the App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Operation, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.Operation] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Operation"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Operation]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_operations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/operations'} # type: ignore + + def get_outbound_network_dependencies_endpoints( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.OutboundEnvironmentEndpointCollection"] + """Get the network endpoints of all outbound dependencies of an App Service Environment. + + Description for Get the network endpoints of all outbound dependencies of an App Service + Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OutboundEnvironmentEndpointCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.OutboundEnvironmentEndpointCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OutboundEnvironmentEndpointCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_outbound_network_dependencies_endpoints.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('OutboundEnvironmentEndpointCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_outbound_network_dependencies_endpoints.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/outboundNetworkDependenciesEndpoints'} # type: ignore + + def reboot( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reboot all machines in an App Service Environment. + + Description for Reboot all machines in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reboot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/reboot'} # type: ignore + + def _resume_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._resume_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _resume_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def begin_resume( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Resume an App Service Environment. + + Description for Resume an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.resume.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._resume_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_resume.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/resume'} # type: ignore + + def list_app_service_plans( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans in an App Service Environment. + + Description for Get all App Service plans in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_app_service_plans.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_app_service_plans.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/serverfarms'} # type: ignore + + def list_web_apps( + self, + resource_group_name, # type: str + name, # type: str + properties_to_include=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps in an App Service Environment. + + Description for Get all apps in an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param properties_to_include: Comma separated list of app properties to include. + :type properties_to_include: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if properties_to_include is not None: + query_parameters['propertiesToInclude'] = self._serialize.query("properties_to_include", properties_to_include, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/sites'} # type: ignore + + def _suspend_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebAppCollection" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._suspend_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WebAppCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _suspend_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def begin_suspend( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[ItemPaged["_models.WebAppCollection"]] + """Suspend an App Service Environment. + + Description for Suspend an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns an iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.suspend.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._suspend_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + def get_long_running_output(pipeline_response): + def internal_get_next(next_link=None): + if next_link is None: + return pipeline_response + else: + return get_next(next_link) + + return ItemPaged( + internal_get_next, extract_data + ) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_suspend.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/suspend'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Get global usage metrics of an App Service Environment. + + Description for Get global usage metrics of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/usages'} # type: ignore + + def list_worker_pools( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WorkerPoolCollection"] + """Get all worker pools of an App Service Environment. + + Description for Get all worker pools of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WorkerPoolCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WorkerPoolCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pools.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WorkerPoolCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pools.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools'} # type: ignore + + def get_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Get properties of a worker pool. + + Description for Get properties of a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def _create_or_update_worker_pool_initial( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_worker_pool_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_worker_pool_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def begin_create_or_update_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WorkerPoolResource"] + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WorkerPoolResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_worker_pool_initial( + resource_group_name=resource_group_name, + name=name, + worker_pool_name=worker_pool_name, + worker_pool_envelope=worker_pool_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def update_worker_pool( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + worker_pool_envelope, # type: "_models.WorkerPoolResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.WorkerPoolResource" + """Create or update a worker pool. + + Description for Create or update a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param worker_pool_envelope: Properties of the worker pool. + :type worker_pool_envelope: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WorkerPoolResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WorkerPoolResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WorkerPoolResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_worker_pool.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(worker_pool_envelope, 'WorkerPoolResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('WorkerPoolResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_worker_pool.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}'} # type: ignore + + def list_worker_pool_instance_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + instance, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a specific instance of a worker pool of an App Service Environment. + + Description for Get metric definitions for a specific instance of a worker pool of an App + Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :param instance: Name of the instance in the worker pool. + :type instance: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_instance_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'instance': self._serialize.url("instance", instance, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pool_instance_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/instances/{instance}/metricdefinitions'} # type: ignore + + def list_web_worker_metric_definitions( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceMetricDefinitionCollection"] + """Get metric definitions for a worker pool of an App Service Environment. + + Description for Get metric definitions for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceMetricDefinitionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceMetricDefinitionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceMetricDefinitionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_metric_definitions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceMetricDefinitionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_worker_metric_definitions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/metricdefinitions'} # type: ignore + + def list_worker_pool_skus( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SkuInfoCollection"] + """Get available SKUs for scaling a worker pool. + + Description for Get available SKUs for scaling a worker pool. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SkuInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SkuInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_worker_pool_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SkuInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_worker_pool_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/skus'} # type: ignore + + def list_web_worker_usages( + self, + resource_group_name, # type: str + name, # type: str + worker_pool_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.UsageCollection"] + """Get usage metrics for a worker pool of an App Service Environment. + + Description for Get usage metrics for a worker pool of an App Service Environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service Environment. + :type name: str + :param worker_pool_name: Name of the worker pool. + :type worker_pool_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either UsageCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.UsageCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.UsageCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_worker_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerPoolName': self._serialize.url("worker_pool_name", worker_pool_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('UsageCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_worker_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/workerPools/{workerPoolName}/usages'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_plans_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_plans_operations.py new file mode 100644 index 000000000000..b459c63c355e --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_app_service_plans_operations.py @@ -0,0 +1,2039 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class AppServicePlansOperations(object): + """AppServicePlansOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + detailed=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans for a subscription. + + Description for Get all App Service plans for a subscription. + + :param detailed: Specify :code:`true` to return all App Service plan properties. + The default is :code:`false`, which returns a subset of the properties. + Retrieval of all properties may increase the API latency. + :type detailed: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if detailed is not None: + query_parameters['detailed'] = self._serialize.query("detailed", detailed, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.AppServicePlanCollection"] + """Get all App Service plans in a resource group. + + Description for Get all App Service plans in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either AppServicePlanCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.AppServicePlanCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlanCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('AppServicePlanCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.AppServicePlan"] + """Get an App Service plan. + + Description for Get an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.AppServicePlan"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlan" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServicePlan" + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlan') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlan" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.AppServicePlan"] + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either AppServicePlan or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.AppServicePlan] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + app_service_plan=app_service_plan, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete an App Service plan. + + Description for Delete an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + app_service_plan, # type: "_models.AppServicePlanPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AppServicePlan" + """Creates or updates an App Service Plan. + + Description for Creates or updates an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param app_service_plan: Details of the App Service plan. + :type app_service_plan: ~azure.mgmt.web.v2020_09_01.models.AppServicePlanPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppServicePlan, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppServicePlan + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppServicePlan"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_service_plan, 'AppServicePlanPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('AppServicePlan', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}'} # type: ignore + + def list_capabilities( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.Capability"] + """List all capabilities of an App Service plan. + + Description for List all capabilities of an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of Capability, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.Capability] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.Capability"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_capabilities.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[Capability]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_capabilities.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/capabilities'} # type: ignore + + def get_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieve a Hybrid Connection in use in an App Service plan. + + Description for Retrieve a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a Hybrid Connection in use in an App Service plan. + + Description for Delete a Hybrid Connection in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: Name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connection_keys( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnectionKey" + """Get the send key name and value of a Hybrid Connection. + + Description for Get the send key name and value of a Hybrid Connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: The name of the Service Bus namespace. + :type namespace_name: str + :param relay_name: The name of the Service Bus relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionKey, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnectionKey + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionKey"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connection_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionKey', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connection_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/listKeys'} # type: ignore + + def list_web_apps_by_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceCollection"] + """Get all apps that use a Hybrid Connection in an App Service Plan. + + Description for Get all apps that use a Hybrid Connection in an App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param namespace_name: Name of the Hybrid Connection namespace. + :type namespace_name: str + :param relay_name: Name of the Hybrid Connection relay. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps_by_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps_by_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}/sites'} # type: ignore + + def get_hybrid_connection_plan_limit( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnectionLimits" + """Get the maximum number of Hybrid Connections allowed in an App Service plan. + + Description for Get the maximum number of Hybrid Connections allowed in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnectionLimits, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnectionLimits + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionLimits"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_plan_limit.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnectionLimits', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_plan_limit.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionPlanLimits/limit'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HybridConnectionCollection"] + """Retrieve all Hybrid Connections in use in an App Service plan. + + Description for Retrieve all Hybrid Connections in use in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HybridConnectionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.HybridConnectionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnectionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HybridConnectionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/hybridConnectionRelays'} # type: ignore + + def restart_web_apps( + self, + resource_group_name, # type: str + name, # type: str + soft_restart=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restart all apps in an App Service plan. + + Description for Restart all apps in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param soft_restart: Specify :code:`true` to perform a soft restart, applies the + configuration settings and restarts the apps if necessary. The default is + :code:`false`, which always restarts and reprovisions the apps. + :type soft_restart: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/restartSites'} # type: ignore + + def list_web_apps( + self, + resource_group_name, # type: str + name, # type: str + skip_token=None, # type: Optional[str] + filter=None, # type: Optional[str] + top=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps associated with an App Service plan. + + Description for Get all apps associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param skip_token: Skip to a web app in the list of webapps associated with app service plan. + If specified, the resulting list will contain web apps starting from (including) the skipToken. + Otherwise, the resulting list contains web apps from the start of the list. + :type skip_token: str + :param filter: Supported filter: $filter=state eq running. Returns only web apps that are + currently running. + :type filter: str + :param top: List page size. If specified, results are paged. + :type top: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_apps.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if skip_token is not None: + query_parameters['$skipToken'] = self._serialize.query("skip_token", skip_token, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_apps.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/sites'} # type: ignore + + def get_server_farm_skus( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> object + """Gets all selectable SKUs for a given App Service Plan. + + Description for Gets all selectable SKUs for a given App Service Plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: object, or the result of cls(response) + :rtype: object + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_server_farm_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_server_farm_skus.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/skus'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets server farm usage information. + + Description for Gets server farm usage information. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of App Service Plan. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2'). + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/usages'} # type: ignore + + def list_vnets( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Get all Virtual Networks associated with an App Service plan. + + Description for Get all Virtual Networks associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections'} # type: ignore + + def get_vnet_from_server_farm( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetInfo"] + """Get a Virtual Network associated with an App Service plan. + + Description for Get a Virtual Network associated with an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_from_server_farm.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_from_server_farm.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Get a Virtual Network gateway. + + Description for Get a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Update a Virtual Network gateway. + + Description for Update a Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Only the 'primary' gateway is supported. + :type gateway_name: str + :param connection_envelope: Definition of the gateway. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_routes_for_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetRoute"] + """Get all routes that are associated with a Virtual Network in an App Service plan. + + Description for Get all routes that are associated with a Virtual Network in an App Service + plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_routes_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_routes_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes'} # type: ignore + + def get_route_for_vnet( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[List["_models.VnetRoute"]] + """Get a Virtual Network route in an App Service plan. + + Description for Get a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetRoute, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetRoute] or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[List["_models.VnetRoute"]]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_route_for_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('[VnetRoute]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_route_for_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def create_or_update_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + route, # type: "_models.VnetRoute" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetRoute"] + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_09_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def delete_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a Virtual Network route in an App Service plan. + + Description for Delete a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def update_vnet_route( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + route_name, # type: str + route, # type: "_models.VnetRoute" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetRoute"] + """Create or update a Virtual Network route in an App Service plan. + + Description for Create or update a Virtual Network route in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param route_name: Name of the Virtual Network route. + :type route_name: str + :param route: Definition of the Virtual Network route. + :type route: ~azure.mgmt.web.v2020_09_01.models.VnetRoute + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetRoute, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetRoute or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetRoute"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_route.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'routeName': self._serialize.url("route_name", route_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(route, 'VnetRoute') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 400, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetRoute', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_route.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/virtualNetworkConnections/{vnetName}/routes/{routeName}'} # type: ignore + + def reboot_worker( + self, + resource_group_name, # type: str + name, # type: str + worker_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reboot a worker machine in an App Service plan. + + Description for Reboot a worker machine in an App Service plan. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the App Service plan. + :type name: str + :param worker_name: Name of worker machine, which typically starts with RD. + :type worker_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reboot_worker.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'workerName': self._serialize.url("worker_name", worker_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reboot_worker.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/serverfarms/{name}/workers/{workerName}/reboot'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificate_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificate_registration_provider_operations.py new file mode 100644 index 000000000000..8816273cd752 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificate_registration_provider_operations.py @@ -0,0 +1,113 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class CertificateRegistrationProviderOperations(object): + """CertificateRegistrationProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.CertificateRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificates_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificates_operations.py new file mode 100644 index 000000000000..bb1f4719c1d6 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_certificates_operations.py @@ -0,0 +1,451 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class CertificatesOperations(object): + """CertificatesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CertificateCollection"] + """Get all certificates for a subscription. + + Description for Get all certificates for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/certificates'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CertificateCollection"] + """Get all certificates in a resource group. + + Description for Get all certificates in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Get a certificate. + + Description for Get a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + name, # type: str + certificate_envelope, # type: "_models.Certificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_09_01.models.Certificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'Certificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a certificate. + + Description for Delete a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + certificate_envelope, # type: "_models.CertificatePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Certificate" + """Create or update a certificate. + + Description for Create or update a certificate. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the certificate. + :type name: str + :param certificate_envelope: Details of certificate, if it exists already. + :type certificate_envelope: ~azure.mgmt.web.v2020_09_01.models.CertificatePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Certificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Certificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Certificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(certificate_envelope, 'CertificatePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Certificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/certificates/{name}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_deleted_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_deleted_web_apps_operations.py new file mode 100644 index 000000000000..bda5e272d417 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_deleted_web_apps_operations.py @@ -0,0 +1,252 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DeletedWebAppsOperations(object): + """DeletedWebAppsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeletedWebAppCollection"] + """Get all deleted apps for a subscription. + + Description for Get all deleted apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deletedSites'} # type: ignore + + def list_by_location( + self, + location, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeletedWebAppCollection"] + """Get all deleted apps for a subscription at location. + + Description for Get all deleted apps for a subscription at location. + + :param location: + :type location: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeletedWebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DeletedWebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedWebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeletedWebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites'} # type: ignore + + def get_deleted_web_app_by_location( + self, + location, # type: str + deleted_site_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeletedSite" + """Get deleted app for a subscription at location. + + Description for Get deleted app for a subscription at location. + + :param location: + :type location: str + :param deleted_site_id: The numeric ID of the deleted app, e.g. 12345. + :type deleted_site_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeletedSite, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeletedSite + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeletedSite"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deleted_web_app_by_location.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'deletedSiteId': self._serialize.url("deleted_site_id", deleted_site_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeletedSite', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deleted_web_app_by_location.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/deletedSites/{deletedSiteId}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_diagnostics_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_diagnostics_operations.py new file mode 100644 index 000000000000..94a410117764 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_diagnostics_operations.py @@ -0,0 +1,1800 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +import datetime +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DiagnosticsOperations(object): + """DiagnosticsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_hosting_environment_detector_responses( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Hosting Environment Detector Responses. + + Description for List Hosting Environment Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_hosting_environment_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_hosting_environment_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors'} # type: ignore + + def get_hosting_environment_detector_response( + self, + resource_group_name, # type: str + name, # type: str + detector_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get Hosting Environment Detector Response. + + Description for Get Hosting Environment Detector Response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: App Service Environment Name. + :type name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hosting_environment_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hosting_environment_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{name}/detectors/{detectorName}'} # type: ignore + + def list_site_detector_responses( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detector_responses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors'} # type: ignore + + def get_site_detector_response( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticCategoryCollection"] + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics'} # type: ignore + + def get_site_diagnostic_category( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticCategory" + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticAnalysisCollection"] + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_analyses.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + def get_site_analysis( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AnalysisDefinition" + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + def execute_site_analysis( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticAnalysis" + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticDetectorCollection"] + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detectors.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + def get_site_detector( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + detector_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorDefinition" + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + def execute_site_detector( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + diagnostic_category, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticDetectorResponse" + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore + + def list_site_detector_responses_slot( + self, + resource_group_name, # type: str + site_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DetectorResponseCollection"] + """List Site Detector Responses. + + Description for List Site Detector Responses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DetectorResponseCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DetectorResponseCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponseCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detector_responses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DetectorResponseCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detector_responses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors'} # type: ignore + + def get_site_detector_response_slot( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorResponse" + """Get site detector response. + + Description for Get site detector response. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_response_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_response_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/detectors/{detectorName}'} # type: ignore + + def list_site_diagnostic_categories_slot( + self, + resource_group_name, # type: str + site_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticCategoryCollection"] + """Get Diagnostics Categories. + + Description for Get Diagnostics Categories. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticCategoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticCategoryCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_diagnostic_categories_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticCategoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_diagnostic_categories_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics'} # type: ignore + + def get_site_diagnostic_category_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticCategory" + """Get Diagnostics Category. + + Description for Get Diagnostics Category. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticCategory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticCategory + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticCategory"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_diagnostic_category_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticCategory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_diagnostic_category_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}'} # type: ignore + + def list_site_analyses_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticAnalysisCollection"] + """Get Site Analyses. + + Description for Get Site Analyses. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticAnalysisCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysisCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysisCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_analyses_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticAnalysisCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_analyses_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses'} # type: ignore + + def get_site_analysis_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AnalysisDefinition" + """Get Site Analysis. + + Description for Get Site Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param analysis_name: Analysis Name. + :type analysis_name: str + :param slot: Slot - optional. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AnalysisDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AnalysisDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AnalysisDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AnalysisDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}'} # type: ignore + + def execute_site_analysis_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + analysis_name, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticAnalysis" + """Execute Analysis. + + Description for Execute Analysis. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param analysis_name: Analysis Resource Name. + :type analysis_name: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticAnalysis, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticAnalysis + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticAnalysis"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_analysis_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'analysisName': self._serialize.url("analysis_name", analysis_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticAnalysis', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_analysis_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/analyses/{analysisName}/execute'} # type: ignore + + def list_site_detectors_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DiagnosticDetectorCollection"] + """Get Detectors. + + Description for Get Detectors. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DiagnosticDetectorCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_detectors_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DiagnosticDetectorCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_detectors_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors'} # type: ignore + + def get_site_detector_slot( + self, + resource_group_name, # type: str + site_name, # type: str + diagnostic_category, # type: str + detector_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DetectorDefinition" + """Get Detector. + + Description for Get Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param diagnostic_category: Diagnostic Category. + :type diagnostic_category: str + :param detector_name: Detector Name. + :type detector_name: str + :param slot: Slot Name. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DetectorDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DetectorDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DetectorDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DetectorDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}'} # type: ignore + + def execute_site_detector_slot( + self, + resource_group_name, # type: str + site_name, # type: str + detector_name, # type: str + diagnostic_category, # type: str + slot, # type: str + start_time=None, # type: Optional[datetime.datetime] + end_time=None, # type: Optional[datetime.datetime] + time_grain=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.DiagnosticDetectorResponse" + """Execute Detector. + + Description for Execute Detector. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site Name. + :type site_name: str + :param detector_name: Detector Resource Name. + :type detector_name: str + :param diagnostic_category: Category Name. + :type diagnostic_category: str + :param slot: Slot Name. + :type slot: str + :param start_time: Start Time. + :type start_time: ~datetime.datetime + :param end_time: End Time. + :type end_time: ~datetime.datetime + :param time_grain: Time Grain. + :type time_grain: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DiagnosticDetectorResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DiagnosticDetectorResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DiagnosticDetectorResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.execute_site_detector_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'detectorName': self._serialize.url("detector_name", detector_name, 'str'), + 'diagnosticCategory': self._serialize.url("diagnostic_category", diagnostic_category, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if start_time is not None: + query_parameters['startTime'] = self._serialize.query("start_time", start_time, 'iso-8601') + if end_time is not None: + query_parameters['endTime'] = self._serialize.query("end_time", end_time, 'iso-8601') + if time_grain is not None: + query_parameters['timeGrain'] = self._serialize.query("time_grain", time_grain, 'str', pattern=r'PT[1-9][0-9]+[SMH]') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DiagnosticDetectorResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + execute_site_detector_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/slots/{slot}/diagnostics/{diagnosticCategory}/detectors/{detectorName}/execute'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domain_registration_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domain_registration_provider_operations.py new file mode 100644 index 000000000000..2683ac8ac526 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domain_registration_provider_operations.py @@ -0,0 +1,113 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DomainRegistrationProviderOperations(object): + """DomainRegistrationProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Implements Csm operations Api to exposes the list of available Csm Apis under the resource provider. + + Description for Implements Csm operations Api to exposes the list of available Csm Apis under + the resource provider. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.DomainRegistration/operations'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domains_operations.py new file mode 100644 index 000000000000..f91b5c15b4c5 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_domains_operations.py @@ -0,0 +1,1139 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DomainsOperations(object): + """DomainsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def check_availability( + self, + identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainAvailabilityCheckResult" + """Check if a domain is available for registration. + + Description for Check if a domain is available for registration. + + :param identifier: Name of the domain. + :type identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainAvailabilityCheckResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainAvailabilityCheckResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainAvailabilityCheckResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainAvailabilityCheckResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/checkDomainAvailability'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainCollection"] + """Get all domains in a subscription. + + Description for Get all domains in a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + def get_control_center_sso_request( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainControlCenterSsoRequest" + """Generate a single sign-on request for the domain management portal. + + Description for Generate a single sign-on request for the domain management portal. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainControlCenterSsoRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainControlCenterSsoRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainControlCenterSsoRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_control_center_sso_request.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainControlCenterSsoRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_control_center_sso_request.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/generateSsoRequest'} # type: ignore + + def list_recommendations( + self, + parameters, # type: "_models.DomainRecommendationSearchParameters" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NameIdentifierCollection"] + """Get domain name recommendations based on keywords. + + Description for Get domain name recommendations based on keywords. + + :param parameters: Search parameters for domain name recommendations. + :type parameters: ~azure.mgmt.web.v2020_09_01.models.DomainRecommendationSearchParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NameIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.NameIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NameIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommendations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DomainRecommendationSearchParameters') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NameIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommendations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/listDomainRecommendations'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainCollection"] + """Get all domains in a resource group. + + Description for Get all domains in a resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains'} # type: ignore + + def get( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + """Get a domain. + + Description for Get a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.Domain" + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'Domain') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.Domain" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Domain"] + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_09_01.models.Domain + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Domain or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.Domain] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + domain_name=domain_name, + domain=domain, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + domain_name, # type: str + force_hard_delete_domain=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a domain. + + Description for Delete a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param force_hard_delete_domain: Specify :code:`true` to delete the domain + immediately. The default is :code:`false` which deletes the domain after 24 hours. + :type force_hard_delete_domain: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if force_hard_delete_domain is not None: + query_parameters['forceHardDeleteDomain'] = self._serialize.query("force_hard_delete_domain", force_hard_delete_domain, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + domain_name, # type: str + domain, # type: "_models.DomainPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Domain" + """Creates or updates a domain. + + Description for Creates or updates a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :param domain: Domain registration information. + :type domain: ~azure.mgmt.web.v2020_09_01.models.DomainPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Domain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Domain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Domain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str', pattern=r'[a-zA-Z0-9][a-zA-Z0-9\.-]+'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain, 'DomainPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Domain', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Domain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}'} # type: ignore + + def list_ownership_identifiers( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DomainOwnershipIdentifierCollection"] + """Lists domain ownership identifiers. + + Description for Lists domain ownership identifiers. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DomainOwnershipIdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DomainOwnershipIdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers'} # type: ignore + + def get_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Get ownership identifier for domain. + + Description for Get ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def create_or_update_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + domain_ownership_identifier, # type: "_models.DomainOwnershipIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def delete_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete ownership identifier for domain. + + Description for Delete ownership identifier for domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def update_ownership_identifier( + self, + resource_group_name, # type: str + domain_name, # type: str + name, # type: str + domain_ownership_identifier, # type: "_models.DomainOwnershipIdentifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.DomainOwnershipIdentifier" + """Creates an ownership identifier for a domain or updates identifier details for an existing identifer. + + Description for Creates an ownership identifier for a domain or updates identifier details for + an existing identifer. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of domain. + :type domain_name: str + :param name: Name of identifier. + :type name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DomainOwnershipIdentifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DomainOwnershipIdentifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DomainOwnershipIdentifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'DomainOwnershipIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DomainOwnershipIdentifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/domainOwnershipIdentifiers/{name}'} # type: ignore + + def renew( + self, + resource_group_name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Renew a domain. + + Description for Renew a domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param domain_name: Name of the domain. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.renew.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + renew.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.DomainRegistration/domains/{domainName}/renew'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_provider_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_provider_operations.py new file mode 100644 index 000000000000..715be1343359 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_provider_operations.py @@ -0,0 +1,259 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ProviderOperations(object): + """ProviderOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_available_stacks( + self, + os_type_selected=None, # type: Optional[Union[str, "_models.Enum5"]] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationStackCollection"] + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_09_01.models.Enum5 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_available_stacks.metadata = {'url': '/providers/Microsoft.Web/availableStacks'} # type: ignore + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmOperationCollection"] + """Gets all available operations for the Microsoft.Web resource provider. Also exposes resource metric definitions. + + Description for Gets all available operations for the Microsoft.Web resource provider. Also + exposes resource metric definitions. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmOperationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmOperationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmOperationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmOperationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Web/operations'} # type: ignore + + def get_available_stacks_on_prem( + self, + os_type_selected=None, # type: Optional[Union[str, "_models.Enum6"]] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationStackCollection"] + """Get available application frameworks and their versions. + + Description for Get available application frameworks and their versions. + + :param os_type_selected: + :type os_type_selected: str or ~azure.mgmt.web.v2020_09_01.models.Enum6 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationStackCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ApplicationStackCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationStackCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_available_stacks_on_prem.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if os_type_selected is not None: + query_parameters['osTypeSelected'] = self._serialize.query("os_type_selected", os_type_selected, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationStackCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_available_stacks_on_prem.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/availableStacks'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_recommendations_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_recommendations_operations.py new file mode 100644 index 000000000000..67588f9771f5 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_recommendations_operations.py @@ -0,0 +1,1128 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class RecommendationsOperations(object): + """RecommendationsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """List all recommendations for a subscription. + + Description for List all recommendations for a subscription. + + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations'} # type: ignore + + def reset_all_filters( + self, + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for a subscription. + + Description for Reset all recommendation opt-out settings for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/reset'} # type: ignore + + def disable_recommendation_for_subscription( + self, + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specified rule so it will not apply to a subscription in the future. + + Description for Disables the specified rule so it will not apply to a subscription in the + future. + + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/recommendations/{name}/disable'} # type: ignore + + def list_history_for_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + expired_only=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_history_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get all recommendations for a hosting environment. + + Description for Get all recommendations for a hosting environment. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the app. + :type hosting_environment_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations'} # type: ignore + + def disable_all_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/disable'} # type: ignore + + def reset_all_filters_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Name of the app. + :type environment_name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/reset'} # type: ignore + + def get_rule_details_by_hosting_environment( + self, + resource_group_name, # type: str + hosting_environment_name, # type: str + name, # type: str + update_seen=None, # type: Optional[bool] + recommendation_id=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RecommendationRule" + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param hosting_environment_name: Name of the hosting environment. + :type hosting_environment_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}'} # type: ignore + + def disable_recommendation_for_hosting_environment( + self, + resource_group_name, # type: str + environment_name, # type: str + name, # type: str + hosting_environment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param environment_name: Site name. + :type environment_name: str + :param name: Rule name. + :type name: str + :param hosting_environment_name: + :type hosting_environment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_hosting_environment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostingEnvironmentName': self._serialize.url("hosting_environment_name", hosting_environment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['environmentName'] = self._serialize.query("environment_name", environment_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_hosting_environment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/hostingEnvironments/{hostingEnvironmentName}/recommendations/{name}/disable'} # type: ignore + + def list_history_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + expired_only=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get past recommendations for an app, optionally specified by the time range. + + Description for Get past recommendations for an app, optionally specified by the time range. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param expired_only: Specify :code:`false` to return all recommendations. The + default is :code:`true`, which returns only expired recommendations. + :type expired_only: bool + :param filter: Filter is specified by using OData syntax. Example: $filter=channel eq 'Api' or + channel eq 'Notification' and startTime eq 2014-01-01T00:00:00Z and endTime eq + 2014-12-31T23:59:59Z and timeGrain eq duration'[PT1H|PT1M|P1D]. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_history_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expired_only is not None: + query_parameters['expiredOnly'] = self._serialize.query("expired_only", expired_only, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_history_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendationHistory'} # type: ignore + + def list_recommended_rules_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + featured=None, # type: Optional[bool] + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.RecommendationCollection"] + """Get all recommendations for an app. + + Description for Get all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param featured: Specify :code:`true` to return only the most critical + recommendations. The default is :code:`false`, which returns all recommendations. + :type featured: bool + :param filter: Return only channels specified in the filter. Filter is specified by using OData + syntax. Example: $filter=channel eq 'Api' or channel eq 'Notification'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either RecommendationCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.RecommendationCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_recommended_rules_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if featured is not None: + query_parameters['featured'] = self._serialize.query("featured", featured, 'bool') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('RecommendationCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_recommended_rules_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations'} # type: ignore + + def disable_all_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disable all recommendations for an app. + + Description for Disable all recommendations for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_all_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_all_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/disable'} # type: ignore + + def reset_all_filters_for_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reset all recommendation opt-out settings for an app. + + Description for Reset all recommendation opt-out settings for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_all_filters_for_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_all_filters_for_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/reset'} # type: ignore + + def get_rule_details_by_web_app( + self, + resource_group_name, # type: str + site_name, # type: str + name, # type: str + update_seen=None, # type: Optional[bool] + recommendation_id=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.RecommendationRule" + """Get a recommendation rule for an app. + + Description for Get a recommendation rule for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Name of the app. + :type site_name: str + :param name: Name of the recommendation. + :type name: str + :param update_seen: Specify :code:`true` to update the last-seen timestamp of the + recommendation object. + :type update_seen: bool + :param recommendation_id: The GUID of the recommendation object if you query an expired one. + You don't need to specify it to query an active entry. + :type recommendation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RecommendationRule, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RecommendationRule + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RecommendationRule"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_rule_details_by_web_app.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if update_seen is not None: + query_parameters['updateSeen'] = self._serialize.query("update_seen", update_seen, 'bool') + if recommendation_id is not None: + query_parameters['recommendationId'] = self._serialize.query("recommendation_id", recommendation_id, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RecommendationRule', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_rule_details_by_web_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}'} # type: ignore + + def disable_recommendation_for_site( + self, + resource_group_name, # type: str + site_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Disables the specific rule for a web site permanently. + + Description for Disables the specific rule for a web site permanently. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param site_name: Site name. + :type site_name: str + :param name: Rule name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.disable_recommendation_for_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'siteName': self._serialize.url("site_name", site_name, 'str'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + disable_recommendation_for_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{siteName}/recommendations/{name}/disable'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_resource_health_metadata_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_resource_health_metadata_operations.py new file mode 100644 index 000000000000..2e812e3a18aa --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_resource_health_metadata_operations.py @@ -0,0 +1,481 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ResourceHealthMetadataOperations(object): + """ResourceHealthMetadataOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """List all ResourceHealthMetadata for all sites in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """List all ResourceHealthMetadata for all sites in the resource group in the subscription. + + Description for List all ResourceHealthMetadata for all sites in the resource group in the + subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/resourceHealthMetadata'} # type: ignore + + def list_by_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata'} # type: ignore + + def get_by_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceHealthMetadata" + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resourceHealthMetadata/default'} # type: ignore + + def list_by_site_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceHealthMetadataCollection"] + """Gets the category of ResourceHealthMetadata to use for the given site as a collection. + + Description for Gets the category of ResourceHealthMetadata to use for the given site as a + collection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceHealthMetadataCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadataCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadataCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceHealthMetadataCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata'} # type: ignore + + def get_by_site_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceHealthMetadata" + """Gets the category of ResourceHealthMetadata to use for the given site. + + Description for Gets the category of ResourceHealthMetadata to use for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceHealthMetadata, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceHealthMetadata + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceHealthMetadata"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_site_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceHealthMetadata', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_site_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resourceHealthMetadata/default'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_static_sites_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_static_sites_operations.py new file mode 100644 index 000000000000..a36a2ab7313d --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_static_sites_operations.py @@ -0,0 +1,1944 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class StaticSitesOperations(object): + """StaticSitesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def preview_workflow( + self, + location, # type: str + static_sites_workflow_preview_request, # type: "_models.StaticSitesWorkflowPreviewRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSitesWorkflowPreview" + """Generates a preview workflow file for the static site. + + Description for Generates a preview workflow file for the static site. + + :param location: Location where you plan to create the static site. + :type location: str + :param static_sites_workflow_preview_request: A JSON representation of the + StaticSitesWorkflowPreviewRequest properties. See example. + :type static_sites_workflow_preview_request: ~azure.mgmt.web.v2020_09_01.models.StaticSitesWorkflowPreviewRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSitesWorkflowPreview, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSitesWorkflowPreview + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSitesWorkflowPreview"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.preview_workflow.metadata['url'] # type: ignore + path_format_arguments = { + 'location': self._serialize.url("location", location, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_sites_workflow_preview_request, 'StaticSitesWorkflowPreviewRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSitesWorkflowPreview', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + preview_workflow.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/locations/{location}/previewStaticSiteWorkflowFile'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCollection"] + """Get all Static Sites for a subscription. + + Description for Get all Static Sites for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_sites_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCollection"] + """Gets all static sites in the specified resource group. + + Description for Gets all static sites in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_sites_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_static_sites_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites'} # type: ignore + + def get_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Gets the details of a static site. + + Description for Gets the details of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def create_or_update_static_site( + self, + resource_group_name, # type: str + name, # type: str + static_site_envelope, # type: "_models.StaticSiteARMResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSiteARMResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def delete_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a static site. + + Description for Deletes a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to delete. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def update_static_site( + self, + resource_group_name, # type: str + name, # type: str + static_site_envelope, # type: "_models.StaticSitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteARMResource" + """Creates a new static site in an existing resource group, or updates an existing static site. + + Description for Creates a new static site in an existing resource group, or updates an existing + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to create or update. + :type name: str + :param static_site_envelope: A JSON representation of the staticsite properties. See example. + :type static_site_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_envelope, 'StaticSitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}'} # type: ignore + + def list_static_site_users( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteUserCollection"] + """Gets the list of users of a static site. + + Description for Gets the list of users of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for the users. + :type authprovider: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteUserCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteUserCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_users.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteUserCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_users.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/listUsers'} # type: ignore + + def delete_static_site_user( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + userid, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the user entry from the static site. + + Description for Deletes the user entry from the static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the staticsite. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def update_static_site_user( + self, + resource_group_name, # type: str + name, # type: str + authprovider, # type: str + userid, # type: str + static_site_user_envelope, # type: "_models.StaticSiteUserARMResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteUserARMResource" + """Updates a user entry with the listed roles. + + Description for Updates a user entry with the listed roles. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param authprovider: The auth provider for this user. + :type authprovider: str + :param userid: The user id of the user. + :type userid: str + :param static_site_user_envelope: A JSON representation of the StaticSiteUser properties. See + example. + :type static_site_user_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_static_site_user.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'authprovider': self._serialize.url("authprovider", authprovider, 'str'), + 'userid': self._serialize.url("userid", userid, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_envelope, 'StaticSiteUserARMResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_static_site_user.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/authproviders/{authprovider}/users/{userid}'} # type: ignore + + def get_static_site_builds( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteBuildCollection"] + """Gets all static site builds for a particular static site. + + Description for Gets all static site builds for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteBuildCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.get_static_site_builds.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteBuildCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + get_static_site_builds.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds'} # type: ignore + + def get_static_site_build( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteBuildARMResource" + """Gets the details of a static site build. + + Description for Gets the details of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteBuildARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteBuildARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteBuildARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteBuildARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + def delete_static_site_build( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a static site build. + + Description for Deletes a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_build.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_build.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}'} # type: ignore + + def create_or_update_static_site_build_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Creates or updates the function app settings of a static site build. + + Description for Creates or updates the function app settings of a static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/config/functionappsettings'} # type: ignore + + def list_static_site_build_functions( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteFunctionOverviewCollection"] + """Gets the functions of a particular static site build. + + Description for Gets the functions of a particular static site build. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_build_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_build_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/functions'} # type: ignore + + def list_static_site_build_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + pr_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param pr_id: The stage site identifier. + :type pr_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_build_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'prId': self._serialize.url("pr_id", pr_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_build_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/builds/{prId}/listFunctionAppSettings'} # type: ignore + + def create_or_update_static_site_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Creates or updates the function app settings of a static site. + + Description for Creates or updates the function app settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param app_settings: + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/config/functionappsettings'} # type: ignore + + def create_user_roles_invitation_link( + self, + resource_group_name, # type: str + name, # type: str + static_site_user_roles_invitation_envelope, # type: "_models.StaticSiteUserInvitationRequestResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteUserInvitationResponseResource" + """Creates an invitation link for a user with the role. + + Description for Creates an invitation link for a user with the role. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param static_site_user_roles_invitation_envelope: + :type static_site_user_roles_invitation_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserInvitationRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteUserInvitationResponseResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteUserInvitationResponseResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteUserInvitationResponseResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_user_roles_invitation_link.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(static_site_user_roles_invitation_envelope, 'StaticSiteUserInvitationRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StaticSiteUserInvitationResponseResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_user_roles_invitation_link.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/createUserInvitation'} # type: ignore + + def list_static_site_custom_domains( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteCustomDomainOverviewCollection"] + """Gets all static site custom domains for a particular static site. + + Description for Gets all static site custom domains for a particular static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site resource to search in. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteCustomDomainOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_custom_domains.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteCustomDomainOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_custom_domains.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains'} # type: ignore + + def create_or_update_static_site_custom_domain( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StaticSiteCustomDomainOverviewARMResource" + """Creates a new static site custom domain in an existing resource group and static site. + + Description for Creates a new static site custom domain in an existing resource group and + static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to create. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StaticSiteCustomDomainOverviewARMResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StaticSiteCustomDomainOverviewARMResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteCustomDomainOverviewARMResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StaticSiteCustomDomainOverviewARMResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + def delete_static_site_custom_domain( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a custom domain. + + Description for Deletes a custom domain. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to delete. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_static_site_custom_domain.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_static_site_custom_domain.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}'} # type: ignore + + def validate_custom_domain_can_be_added_to_static_site( + self, + resource_group_name, # type: str + name, # type: str + domain_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Validates a particular custom domain can be added to a static site. + + Description for Validates a particular custom domain can be added to a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param domain_name: The custom domain to validate. + :type domain_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.validate_custom_domain_can_be_added_to_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainName': self._serialize.url("domain_name", domain_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_custom_domain_can_be_added_to_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/customDomains/{domainName}/validate'} # type: ignore + + def detach_static_site( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Detaches a static site. + + Description for Detaches a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site to detach. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.detach_static_site.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + detach_static_site.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/detach'} # type: ignore + + def list_static_site_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.StaticSiteFunctionOverviewCollection"] + """Gets the functions of a static site. + + Description for Gets the functions of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either StaticSiteFunctionOverviewCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.StaticSiteFunctionOverviewCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StaticSiteFunctionOverviewCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_static_site_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('StaticSiteFunctionOverviewCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_static_site_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/functions'} # type: ignore + + def list_static_site_function_app_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of a static site. + + Description for Gets the application settings of a static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_function_app_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_function_app_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listFunctionAppSettings'} # type: ignore + + def list_static_site_secrets( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Lists the secrets for an existing static site. + + Description for Lists the secrets for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_static_site_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_static_site_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/listSecrets'} # type: ignore + + def reset_static_site_api_key( + self, + resource_group_name, # type: str + name, # type: str + reset_properties_envelope, # type: "_models.StaticSiteResetPropertiesARMResource" + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the api key for an existing static site. + + Description for Resets the api key for an existing static site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the static site. + :type name: str + :param reset_properties_envelope: + :type reset_properties_envelope: ~azure.mgmt.web.v2020_09_01.models.StaticSiteResetPropertiesARMResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.reset_static_site_api_key.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(reset_properties_envelope, 'StaticSiteResetPropertiesARMResource') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_static_site_api_key.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/staticSites/{name}/resetapikey'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_top_level_domains_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_top_level_domains_operations.py new file mode 100644 index 000000000000..192cb6cb501d --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_top_level_domains_operations.py @@ -0,0 +1,259 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class TopLevelDomainsOperations(object): + """TopLevelDomainsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TopLevelDomainCollection"] + """Get all top-level domains supported for registration. + + Description for Get all top-level domains supported for registration. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TopLevelDomainCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TopLevelDomainCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomainCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TopLevelDomainCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains'} # type: ignore + + def get( + self, + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.TopLevelDomain" + """Get details of a top-level domain. + + Description for Get details of a top-level domain. + + :param name: Name of the top-level domain. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TopLevelDomain, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TopLevelDomain + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TopLevelDomain"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TopLevelDomain', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}'} # type: ignore + + def list_agreements( + self, + name, # type: str + agreement_option, # type: "_models.TopLevelDomainAgreementOption" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TldLegalAgreementCollection"] + """Gets all legal agreements that user needs to accept before purchasing a domain. + + Description for Gets all legal agreements that user needs to accept before purchasing a domain. + + :param name: Name of the top-level domain. + :type name: str + :param agreement_option: Domain agreement options. + :type agreement_option: ~azure.mgmt.web.v2020_09_01.models.TopLevelDomainAgreementOption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TldLegalAgreementCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TldLegalAgreementCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TldLegalAgreementCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_agreements.metadata['url'] # type: ignore + path_format_arguments = { + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(agreement_option, 'TopLevelDomainAgreementOption') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TldLegalAgreementCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_agreements.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.DomainRegistration/topLevelDomains/{name}/listAgreements'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_apps_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_apps_operations.py new file mode 100644 index 000000000000..410a72c91d64 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_apps_operations.py @@ -0,0 +1,28958 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, IO, Iterable, List, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class WebAppsOperations(object): + """WebAppsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.web.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Get all apps for a subscription. + + Description for Get all apps for a subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/sites'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + include_slots=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Gets all web, mobile, and API apps in the specified resource group. + + Description for Gets all web, mobile, and API apps in the specified resource group. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param include_slots: Specify :code:`true` to include deployment slots in + results. The default is false, which only gives you the production slot of all apps. + :type include_slots: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if include_slots is not None: + query_parameters['includeSlots'] = self._serialize.query("include_slots", include_slots, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites'} # type: ignore + + def get( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.Site"] + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Site"] + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + name=name, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def delete( + self, + resource_group_name, # type: str + name, # type: str + delete_metrics=None, # type: Optional[bool] + delete_empty_server_farm=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify false if you want to keep empty App Service plan. By + default, empty App Service plan is deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + name, # type: str + site_envelope, # type: "_models.SitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}'} # type: ignore + + def analyze_custom_hostname( + self, + resource_group_name, # type: str + name, # type: str + host_name=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomHostnameAnalysisResult" + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/analyzeCustomHostname'} # type: ignore + + def apply_slot_config_to_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_config_to_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_config_to_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/applySlotConfig'} # type: ignore + + def backup( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backup'} # type: ignore + + def list_backups( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups'} # type: ignore + + def get_backup_status( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + def delete_backup( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}'} # type: ignore + + def list_backup_status_secrets( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/list'} # type: ignore + + def _restore_initial( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + def begin_restore( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/backups/{backupId}/restore'} # type: ignore + + def get_basic_publishing_credentials_policies( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesCollection" + """Returns whether Scm basic auth is allowed and whether Ftp is allowed for a given site. + + Description for Returns whether Scm basic auth is allowed and whether Ftp is allowed for a + given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesCollection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesCollection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_basic_publishing_credentials_policies.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesCollection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_basic_publishing_credentials_policies.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies'} # type: ignore + + def get_ftp_allowed( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Returns whether FTP is allowed on the site or not. + + Description for Returns whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + def update_ftp_allowed( + self, + resource_group_name, # type: str + name, # type: str + csm_publishing_access_policies_entity, # type: "_models.CsmPublishingCredentialsPoliciesEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Updates whether FTP is allowed on the site or not. + + Description for Updates whether FTP is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_ftp_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_ftp_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/ftp'} # type: ignore + + def get_scm_allowed( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Returns whether Scm basic auth is allowed on the site or not. + + Description for Returns whether Scm basic auth is allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def update_scm_allowed( + self, + resource_group_name, # type: str + name, # type: str + csm_publishing_access_policies_entity, # type: "_models.CsmPublishingCredentialsPoliciesEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.CsmPublishingCredentialsPoliciesEntity" + """Updates whether user publishing credentials are allowed on the site or not. + + Description for Updates whether user publishing credentials are allowed on the site or not. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param csm_publishing_access_policies_entity: + :type csm_publishing_access_policies_entity: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CsmPublishingCredentialsPoliciesEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingCredentialsPoliciesEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmPublishingCredentialsPoliciesEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_scm_allowed.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(csm_publishing_access_policies_entity, 'CsmPublishingCredentialsPoliciesEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CsmPublishingCredentialsPoliciesEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_scm_allowed.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/basicPublishingCredentialsPolicies/scm'} # type: ignore + + def list_configurations( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigResourceCollection"] + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configurations.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config'} # type: ignore + + def update_application_settings( + self, + resource_group_name, # type: str + name, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings'} # type: ignore + + def list_application_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/appsettings/list'} # type: ignore + + def update_auth_settings( + self, + resource_group_name, # type: str + name, # type: str + site_auth_settings, # type: "_models.SiteAuthSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings'} # type: ignore + + def get_auth_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettings/list'} # type: ignore + + def update_auth_settings_v2( + self, + resource_group_name, # type: str + name, # type: str + site_auth_settings_v2, # type: "_models.SiteAuthSettingsV2" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2'} # type: ignore + + def get_auth_settings_v2( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/authsettingsV2/list'} # type: ignore + + def update_azure_storage_accounts( + self, + resource_group_name, # type: str + name, # type: str + azure_storage_accounts, # type: "_models.AzureStoragePropertyDictionaryResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts'} # type: ignore + + def list_azure_storage_accounts( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/azurestorageaccounts/list'} # type: ignore + + def update_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + def delete_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup'} # type: ignore + + def get_backup_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/backup/list'} # type: ignore + + def update_connection_strings( + self, + resource_group_name, # type: str + name, # type: str + connection_strings, # type: "_models.ConnectionStringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings'} # type: ignore + + def list_connection_strings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/connectionstrings/list'} # type: ignore + + def get_diagnostic_logs_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + def update_diagnostic_logs_config( + self, + resource_group_name, # type: str + name, # type: str + site_logs_config, # type: "_models.SiteLogsConfig" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/logs'} # type: ignore + + def update_metadata( + self, + resource_group_name, # type: str + name, # type: str + metadata, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata'} # type: ignore + + def list_metadata( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/metadata/list'} # type: ignore + + def _list_publishing_credentials_initial( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + def begin_list_publishing_credentials( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.User"] + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._list_publishing_credentials_initial( + resource_group_name=resource_group_name, + name=name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/publishingcredentials/list'} # type: ignore + + def update_site_push_settings( + self, + resource_group_name, # type: str + name, # type: str + push_settings, # type: "_models.PushSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings'} # type: ignore + + def list_site_push_settings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/pushsettings/list'} # type: ignore + + def list_slot_configuration_names( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SlotConfigNamesResource" + """Gets the names of app settings and connection strings that stick to the slot (not swapped). + + Description for Gets the names of app settings and connection strings that stick to the slot + (not swapped). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + def update_slot_configuration_names( + self, + resource_group_name, # type: str + name, # type: str + slot_config_names, # type: "_models.SlotConfigNamesResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SlotConfigNamesResource" + """Updates the names of application settings and connection string that remain with the slot during swap operation. + + Description for Updates the names of application settings and connection string that remain + with the slot during swap operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_config_names: Names of application settings and connection strings. See example. + :type slot_config_names: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SlotConfigNamesResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SlotConfigNamesResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotConfigNamesResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot_configuration_names.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_config_names, 'SlotConfigNamesResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SlotConfigNamesResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot_configuration_names.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/slotConfigNames'} # type: ignore + + def get_configuration( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def create_or_update_configuration( + self, + resource_group_name, # type: str + name, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def update_configuration( + self, + resource_group_name, # type: str + name, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web'} # type: ignore + + def list_configuration_snapshot_info( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigurationSnapshotInfoCollection"] + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots'} # type: ignore + + def get_configuration_snapshot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}'} # type: ignore + + def recover_site_configuration_snapshot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + def get_web_site_container_logs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs'} # type: ignore + + def get_container_logs_zip( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ContinuousWebJobCollection"] + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs'} # type: ignore + + def get_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ContinuousWebJob"] + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + def delete_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}'} # type: ignore + + def start_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/start'} # type: ignore + + def stop_continuous_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentCollection"] + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_deployments.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments'} # type: ignore + + def get_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def create_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + deployment, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_09_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def delete_deployment( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}'} # type: ignore + + def list_deployment_log( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/deployments/{id}/log'} # type: ignore + + def discover_backup( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.RestoreRequest" + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers'} # type: ignore + + def get_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def create_or_update_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def delete_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def update_domain_ownership_identifier( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def get_ms_deploy_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def _create_ms_deploy_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def begin_create_ms_deploy_operation( + self, + resource_group_name, # type: str + name, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy'} # type: ignore + + def get_ms_deploy_log( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/extensions/MSDeploy/log'} # type: ignore + + def list_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FunctionEnvelopeCollection"] + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions'} # type: ignore + + def get_functions_admin_token( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> str + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/admin/token'} # type: ignore + + def get_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.FunctionEnvelope"] + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def _create_function_initial( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionEnvelope" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_function_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_function_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def begin_create_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FunctionEnvelope"] + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_function_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def delete_function( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}'} # type: ignore + + def create_or_update_function_secret( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def delete_function_secret( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def list_function_keys( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listkeys'} # type: ignore + + def list_function_secrets( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/functions/{functionName}/listsecrets'} # type: ignore + + def list_host_keys( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostKeys" + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listkeys'} # type: ignore + + def list_sync_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/listsyncstatus'} # type: ignore + + def sync_functions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/sync'} # type: ignore + + def create_or_update_host_secret( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def delete_host_secret( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HostNameBindingCollection"] + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_host_name_bindings.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings'} # type: ignore + + def get_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def create_or_update_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + host_name_binding, # type: "_models.HostNameBinding" + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def delete_host_name_binding( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hostNameBindings/{hostName}'} # type: ignore + + def get_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def create_or_update_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def update_hybrid_connection( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridConnectionRelays'} # type: ignore + + def list_relay_service_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection'} # type: ignore + + def get_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def create_or_update_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def delete_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def update_relay_service_connection( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppInstanceStatusCollection"] + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_identifiers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances'} # type: ignore + + def get_instance_info( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebSiteInstanceStatus" + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}'} # type: ignore + + def get_instance_ms_deploy_status( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def _create_instance_ms_deploy_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def begin_create_instance_ms_deploy_operation( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_ms_deploy_operation_initial( + resource_group_name=resource_group_name, + name=name, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def get_instance_ms_deploy_log( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes'} # type: ignore + + def get_instance_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def delete_instance_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def get_instance_process_dump( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + def get_instance_process_module( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + def is_cloneable( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteCloneability" + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/iscloneable'} # type: ignore + + def list_site_backups( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_backups.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listbackups'} # type: ignore + + def list_sync_function_triggers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/listsyncfunctiontriggerstatus'} # type: ignore + + def _migrate_storage_initial( + self, + subscription_name, # type: str + resource_group_name, # type: str + name, # type: str + migration_options, # type: "_models.StorageMigrationOptions" + **kwargs # type: Any + ): + # type: (...) -> "_models.StorageMigrationResponse" + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_storage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['subscriptionName'] = self._serialize.query("subscription_name", subscription_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_options, 'StorageMigrationOptions') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_storage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + def begin_migrate_storage( + self, + subscription_name, # type: str + resource_group_name, # type: str + name, # type: str + migration_options, # type: "_models.StorageMigrationOptions" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.StorageMigrationResponse"] + """Restores a web app. + + Description for Restores a web app. + + :param subscription_name: Azure subscription. + :type subscription_name: str + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_options: Migration migrationOptions. + :type migration_options: ~azure.mgmt.web.v2020_09_01.models.StorageMigrationOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either StorageMigrationResponse or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.StorageMigrationResponse] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.StorageMigrationResponse"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._migrate_storage_initial( + subscription_name=subscription_name, + resource_group_name=resource_group_name, + name=name, + migration_options=migration_options, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('StorageMigrationResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_storage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migrate'} # type: ignore + + def _migrate_my_sql_initial( + self, + resource_group_name, # type: str + name, # type: str + migration_request_envelope, # type: "_models.MigrateMySqlRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.Operation" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._migrate_my_sql_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(migration_request_envelope, 'MigrateMySqlRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _migrate_my_sql_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + def begin_migrate_my_sql( + self, + resource_group_name, # type: str + name, # type: str + migration_request_envelope, # type: "_models.MigrateMySqlRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Operation"] + """Migrates a local (in-app) MySql database to a remote MySql database. + + Description for Migrates a local (in-app) MySql database to a remote MySql database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param migration_request_envelope: MySql migration options. + :type migration_request_envelope: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Operation or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.Operation] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Operation"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._migrate_my_sql_initial( + resource_group_name=resource_group_name, + name=name, + migration_request_envelope=migration_request_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Operation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_migrate_my_sql.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql'} # type: ignore + + def get_migrate_my_sql_status( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MigrateMySqlStatus" + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/migratemysql/status'} # type: ignore + + def get_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def create_or_update_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def delete_swift_virtual_network( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def update_swift_virtual_network_connection( + self, + resource_group_name, # type: str + name, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkConfig/virtualNetwork'} # type: ignore + + def list_network_features( + self, + resource_group_name, # type: str + name, # type: str + view, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.NetworkFeatures"] + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkFeatures/{view}'} # type: ignore + + def get_network_trace_operation( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/operationresults/{operationId}'} # type: ignore + + def start_web_site_network_trace( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> str + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/start'} # type: ignore + + def _start_web_site_network_trace_operation_initial( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + def begin_start_web_site_network_trace_operation( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_web_site_network_trace_operation_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/startOperation'} # type: ignore + + def stop_web_site_network_trace( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/stop'} # type: ignore + + def get_network_traces( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTrace/{operationId}'} # type: ignore + + def get_network_trace_operation_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + def get_network_traces_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/networkTraces/{operationId}'} # type: ignore + + def generate_new_site_publishing_password( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/newpassword'} # type: ignore + + def list_perf_mon_counters( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PerfMonCounterCollection"] + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_perf_mon_counters.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/perfcounters'} # type: ignore + + def get_site_php_error_log_flag( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SitePhpErrorLogFlag" + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/phplogging'} # type: ignore + + def list_premier_add_ons( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons'} # type: ignore + + def get_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def add_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + premier_add_on, # type: "_models.PremierAddOn" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def delete_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def update_premier_add_on( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + premier_add_on, # type: "_models.PremierAddOnPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/premieraddons/{premierAddOnName}'} # type: ignore + + def get_private_access( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def put_private_access_vnet( + self, + resource_group_name, # type: str + name, # type: str + access, # type: "_models.PrivateAccess" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateAccess/virtualNetworks'} # type: ignore + + def list_processes( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_processes.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes'} # type: ignore + + def get_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + def delete_process( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_process.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}'} # type: ignore + + def get_process_dump( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/dump'} # type: ignore + + def list_process_modules( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_modules.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules'} # type: ignore + + def get_process_module( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_threads.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicCertificateCollection"] + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_public_certificates.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates'} # type: ignore + + def get_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def create_or_update_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + public_certificate, # type: "_models.PublicCertificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def delete_public_certificate( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publicCertificates/{publicCertificateName}'} # type: ignore + + def list_publishing_profile_xml_with_secrets( + self, + resource_group_name, # type: str + name, # type: str + publishing_profile_options, # type: "_models.CsmPublishingProfileOptions" + **kwargs # type: Any + ): + # type: (...) -> IO + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/publishxml'} # type: ignore + + def reset_production_slot_config( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_production_slot_config.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_production_slot_config.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/resetSlotConfig'} # type: ignore + + def restart( + self, + resource_group_name, # type: str + name, # type: str + soft_restart=None, # type: Optional[bool] + synchronous=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restart'} # type: ignore + + def _restore_from_backup_blob_initial( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + def begin_restore_from_backup_blob( + self, + resource_group_name, # type: str + name, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_backup_blob_initial( + resource_group_name=resource_group_name, + name=name, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromBackupBlob'} # type: ignore + + def _restore_from_deleted_app_initial( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + def begin_restore_from_deleted_app( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_deleted_app_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreFromDeletedApp'} # type: ignore + + def _restore_snapshot_initial( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def begin_restore_snapshot( + self, + resource_group_name, # type: str + name, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_snapshot_initial( + resource_group_name=resource_group_name, + name=name, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/restoreSnapshot'} # type: ignore + + def list_site_extensions( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteExtensionInfoCollection"] + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_extensions.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions'} # type: ignore + + def get_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def _install_site_extension_initial( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def begin_install_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteExtensionInfo"] + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._install_site_extension_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def delete_site_extension( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/siteextensions/{siteExtensionId}'} # type: ignore + + def _copy_production_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_production_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_production_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def begin_copy_production_slot( + self, + resource_group_name, # type: str + name, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_09_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._copy_production_slot_initial( + resource_group_name=resource_group_name, + name=name, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_production_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotcopy'} # type: ignore + + def list_slots( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppCollection"] + """Gets an app's deployment slots. + + Description for Gets an app's deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots'} # type: ignore + + def get_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.Site"] + """Gets the details of a web, mobile, or API app. + + Description for Gets the details of a web, mobile, or API app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Site"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def _create_or_update_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'Site') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def begin_create_or_update_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.Site" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.Site"] + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.Site + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either Site or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.Site] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_envelope=site_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def delete_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + delete_metrics=None, # type: Optional[bool] + delete_empty_server_farm=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a web, mobile, or API app, or one of the deployment slots. + + Description for Deletes a web, mobile, or API app, or one of the deployment slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app to delete. + :type name: str + :param slot: Name of the deployment slot to delete. By default, the API deletes the production + slot. + :type slot: str + :param delete_metrics: If true, web app metrics are also deleted. + :type delete_metrics: bool + :param delete_empty_server_farm: Specify true if the App Service plan will be empty after app + deletion and you want to delete the empty App Service plan. By default, the empty App Service + plan is not deleted. + :type delete_empty_server_farm: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if delete_metrics is not None: + query_parameters['deleteMetrics'] = self._serialize.query("delete_metrics", delete_metrics, 'bool') + if delete_empty_server_farm is not None: + query_parameters['deleteEmptyServerFarm'] = self._serialize.query("delete_empty_server_farm", delete_empty_server_farm, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def update_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_envelope, # type: "_models.SitePatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.Site" + """Creates a new web, mobile, or API app in an existing resource group, or updates an existing app. + + Description for Creates a new web, mobile, or API app in an existing resource group, or updates + an existing app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Unique name of the app to create or update. To create or update a deployment slot, + use the {slot} parameter. + :type name: str + :param slot: Name of the deployment slot to create or update. By default, this API attempts to + create or modify the production slot. + :type slot: str + :param site_envelope: A JSON representation of the app properties. See example. + :type site_envelope: ~azure.mgmt.web.v2020_09_01.models.SitePatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Site, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Site + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Site"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_envelope, 'SitePatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('Site', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('Site', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}'} # type: ignore + + def analyze_custom_hostname_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.CustomHostnameAnalysisResult" + """Analyze a custom hostname. + + Description for Analyze a custom hostname. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param host_name: Custom hostname. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: CustomHostnameAnalysisResult, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.CustomHostnameAnalysisResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CustomHostnameAnalysisResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.analyze_custom_hostname_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if host_name is not None: + query_parameters['hostName'] = self._serialize.query("host_name", host_name, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('CustomHostnameAnalysisResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + analyze_custom_hostname_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/analyzeCustomHostname'} # type: ignore + + def apply_slot_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + """Applies the configuration settings from the target slot onto the current slot. + + Description for Applies the configuration settings from the target slot onto the current slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.apply_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + apply_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/applySlotConfig'} # type: ignore + + def backup_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Creates a backup of an app. + + Description for Creates a backup of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + backup for the production slot. + :type slot: str + :param request: Backup configuration. You can use the JSON response from the POST action as + input here. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backup'} # type: ignore + + def list_backups_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups'} # type: ignore + + def get_backup_status_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets a backup of an app by its ID. + + Description for Gets a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a backup + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + def delete_backup_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a backup of an app by its ID. + + Description for Deletes a backup of an app by its ID. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + backup of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}'} # type: ignore + + def list_backup_status_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupItem" + """Gets status of a web app backup that may be in progress, including secrets associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the SAS URL for the backup if a new URL is passed in the request body. + + Description for Gets status of a web app backup that may be in progress, including secrets + associated with the backup, such as the Azure Storage SAS URL. Also can be used to update the + SAS URL for the backup if a new URL is passed in the request body. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param backup_id: ID of backup. + :type backup_id: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param request: Information on backup request. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupItem, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupItem + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItem"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.list_backup_status_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupItem', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_backup_status_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/list'} # type: ignore + + def _restore_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def begin_restore_slot( + self, + resource_group_name, # type: str + name, # type: str + backup_id, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a specific backup to another app (or deployment slot, if specified). + + Description for Restores a specific backup to another app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param backup_id: ID of the backup. + :type backup_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_slot_initial( + resource_group_name=resource_group_name, + name=name, + backup_id=backup_id, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'backupId': self._serialize.url("backup_id", backup_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/backups/{backupId}/restore'} # type: ignore + + def list_configurations_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigResourceCollection"] + """List the configurations of an app. + + Description for List the configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigResourceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigResourceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResourceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configurations_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigResourceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configurations_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config'} # type: ignore + + def update_application_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + app_settings, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the application settings of an app. + + Description for Replaces the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + application settings for the production slot. + :type slot: str + :param app_settings: Application settings of the app. + :type app_settings: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(app_settings, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings'} # type: ignore + + def list_application_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the application settings of an app. + + Description for Gets the application settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + application settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_application_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_application_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/appsettings/list'} # type: ignore + + def update_auth_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_auth_settings, # type: "_models.SiteAuthSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Updates the Authentication / Authorization settings associated with web app. + + Description for Updates the Authentication / Authorization settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings: Auth settings associated with web app. + :type site_auth_settings: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings, 'SiteAuthSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings'} # type: ignore + + def get_auth_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettings" + """Gets the Authentication/Authorization settings of an app. + + Description for Gets the Authentication/Authorization settings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettings/list'} # type: ignore + + def update_auth_settings_v2_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_auth_settings_v2, # type: "_models.SiteAuthSettingsV2" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Updates site's Authentication / Authorization settings for apps via the V2 format. + + Description for Updates site's Authentication / Authorization settings for apps via the V2 + format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param site_auth_settings_v2: Auth settings associated with web app. + :type site_auth_settings_v2: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_auth_settings_v2, 'SiteAuthSettingsV2') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2'} # type: ignore + + def get_auth_settings_v2_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteAuthSettingsV2" + """Gets site's Authentication / Authorization settings for apps via the V2 format. + + Description for Gets site's Authentication / Authorization settings for apps via the V2 format. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteAuthSettingsV2, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteAuthSettingsV2 + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteAuthSettingsV2"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_auth_settings_v2_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteAuthSettingsV2', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_auth_settings_v2_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/authsettingsV2/list'} # type: ignore + + def update_azure_storage_accounts_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + azure_storage_accounts, # type: "_models.AzureStoragePropertyDictionaryResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Updates the Azure storage account configurations of an app. + + Description for Updates the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :param azure_storage_accounts: Azure storage accounts of the app. + :type azure_storage_accounts: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(azure_storage_accounts, 'AzureStoragePropertyDictionaryResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts'} # type: ignore + + def list_azure_storage_accounts_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AzureStoragePropertyDictionaryResource" + """Gets the Azure storage account configurations of an app. + + Description for Gets the Azure storage account configurations of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + Azure storage account configurations for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AzureStoragePropertyDictionaryResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AzureStoragePropertyDictionaryResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AzureStoragePropertyDictionaryResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_azure_storage_accounts_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AzureStoragePropertyDictionaryResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_azure_storage_accounts_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/azurestorageaccounts/list'} # type: ignore + + def update_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.BackupRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Updates the backup configuration of an app. + + Description for Updates the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + backup configuration for the production slot. + :type slot: str + :param request: Edited backup configuration. + :type request: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'BackupRequest') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + def delete_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the backup configuration of an app. + + Description for Deletes the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup'} # type: ignore + + def get_backup_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.BackupRequest" + """Gets the backup configuration of an app. + + Description for Gets the backup configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + backup configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: BackupRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.BackupRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_backup_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('BackupRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_backup_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/backup/list'} # type: ignore + + def update_connection_strings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_strings, # type: "_models.ConnectionStringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Replaces the connection strings of an app. + + Description for Replaces the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + connection settings for the production slot. + :type slot: str + :param connection_strings: Connection strings of the app or deployment slot. See example. + :type connection_strings: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_strings, 'ConnectionStringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings'} # type: ignore + + def list_connection_strings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ConnectionStringDictionary" + """Gets the connection strings of an app. + + Description for Gets the connection strings of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + connection settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ConnectionStringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ConnectionStringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ConnectionStringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_connection_strings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ConnectionStringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_connection_strings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/connectionstrings/list'} # type: ignore + + def get_diagnostic_logs_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Gets the logging configuration of an app. + + Description for Gets the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + logging configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_diagnostic_logs_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_diagnostic_logs_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + def update_diagnostic_logs_config_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_logs_config, # type: "_models.SiteLogsConfig" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteLogsConfig" + """Updates the logging configuration of an app. + + Description for Updates the logging configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + logging configuration for the production slot. + :type slot: str + :param site_logs_config: A SiteLogsConfig JSON object that contains the logging configuration + to change in the "properties" property. + :type site_logs_config: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteLogsConfig, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteLogsConfig + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteLogsConfig"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_diagnostic_logs_config_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_logs_config, 'SiteLogsConfig') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteLogsConfig', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_diagnostic_logs_config_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/logs'} # type: ignore + + def update_metadata_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + metadata, # type: "_models.StringDictionary" + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Replaces the metadata of an app. + + Description for Replaces the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + metadata for the production slot. + :type slot: str + :param metadata: Edited metadata of the app or deployment slot. See example. + :type metadata: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(metadata, 'StringDictionary') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata'} # type: ignore + + def list_metadata_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Gets the metadata of an app. + + Description for Gets the metadata of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + metadata for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_metadata_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_metadata_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/metadata/list'} # type: ignore + + def _list_publishing_credentials_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._list_publishing_credentials_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _list_publishing_credentials_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + def begin_list_publishing_credentials_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.User"] + """Gets the Git/FTP publishing credentials of an app. + + Description for Gets the Git/FTP publishing credentials of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing credentials for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either User or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.User] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._list_publishing_credentials_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_list_publishing_credentials_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/publishingcredentials/list'} # type: ignore + + def update_site_push_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + push_settings, # type: "_models.PushSettings" + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Updates the Push settings associated with web app. + + Description for Updates the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param push_settings: Push settings associated with web app. + :type push_settings: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(push_settings, 'PushSettings') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings'} # type: ignore + + def list_site_push_settings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PushSettings" + """Gets the Push settings associated with web app. + + Description for Gets the Push settings associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PushSettings, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PushSettings + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PushSettings"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_site_push_settings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PushSettings', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_site_push_settings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/pushsettings/list'} # type: ignore + + def get_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets the configuration of an app, such as platform version and bitness, default documents, virtual applications, Always On, etc. + + Description for Gets the configuration of an app, such as platform version and bitness, default + documents, virtual applications, Always On, etc. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def create_or_update_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def update_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_config, # type: "_models.SiteConfigResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Updates the configuration of an app. + + Description for Updates the configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update + configuration for the production slot. + :type slot: str + :param site_config: JSON representation of a SiteConfig object. See example. + :type site_config: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_config, 'SiteConfigResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web'} # type: ignore + + def list_configuration_snapshot_info_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteConfigurationSnapshotInfoCollection"] + """Gets a list of web app configuration snapshots identifiers. Each element of the list contains a timestamp and the ID of the snapshot. + + Description for Gets a list of web app configuration snapshots identifiers. Each element of the + list contains a timestamp and the ID of the snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteConfigurationSnapshotInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteConfigurationSnapshotInfoCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigurationSnapshotInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_configuration_snapshot_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteConfigurationSnapshotInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_configuration_snapshot_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots'} # type: ignore + + def get_configuration_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteConfigResource" + """Gets a snapshot of the configuration of an app at a previous point in time. + + Description for Gets a snapshot of the configuration of an app at a previous point in time. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteConfigResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteConfigResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteConfigResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteConfigResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}'} # type: ignore + + def recover_site_configuration_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + snapshot_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Reverts the configuration of an app to a previous snapshot. + + Description for Reverts the configuration of an app to a previous snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param snapshot_id: The ID of the snapshot to read. + :type snapshot_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will return + configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.recover_site_configuration_snapshot_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'snapshotId': self._serialize.url("snapshot_id", snapshot_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + recover_site_configuration_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/config/web/snapshots/{snapshotId}/recover'} # type: ignore + + def get_web_site_container_logs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the last lines of docker logs for the given site. + + Description for Gets the last lines of docker logs for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/octet-stream" + + # Construct URL + url = self.get_web_site_container_logs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_site_container_logs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs'} # type: ignore + + def get_container_logs_zip_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Gets the ZIP archived docker log files for the given site. + + Description for Gets the ZIP archived docker log files for the given site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/zip" + + # Construct URL + url = self.get_container_logs_zip_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_container_logs_zip_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/containerlogs/zip/download'} # type: ignore + + def list_continuous_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ContinuousWebJobCollection"] + """List continuous web jobs for an app, or a deployment slot. + + Description for List continuous web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ContinuousWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ContinuousWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ContinuousWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_continuous_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ContinuousWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_continuous_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs'} # type: ignore + + def get_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ContinuousWebJob"] + """Gets a continuous web job by its ID for an app, or a deployment slot. + + Description for Gets a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ContinuousWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ContinuousWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ContinuousWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ContinuousWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + def delete_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a continuous web job by its ID for an app, or a deployment slot. + + Description for Delete a continuous web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}'} # type: ignore + + def start_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Start a continuous web job for an app, or a deployment slot. + + Description for Start a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/start'} # type: ignore + + def stop_continuous_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop a continuous web job for an app, or a deployment slot. + + Description for Stop a continuous web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_continuous_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_continuous_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/continuouswebjobs/{webJobName}/stop'} # type: ignore + + def list_deployments_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentCollection"] + """List deployments for an app, or a deployment slot. + + Description for List deployments for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.DeploymentCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_deployments_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_deployments_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments'} # type: ignore + + def get_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Get a deployment by its ID for an app, or a deployment slot. + + Description for Get a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets a deployment + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def create_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + deployment, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """Create a deployment for an app, or a deployment slot. + + Description for Create a deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: ID of an existing deployment. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API creates a + deployment for the production slot. + :type slot: str + :param deployment: Deployment details. + :type deployment: ~azure.mgmt.web.v2020_09_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(deployment, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def delete_deployment_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a deployment by its ID for an app, or a deployment slot. + + Description for Delete a deployment by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: Deployment ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_deployment_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_deployment_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}'} # type: ignore + + def list_deployment_log_slot( + self, + resource_group_name, # type: str + name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Deployment" + """List deployment log for specific deployment for an app, or a deployment slot. + + Description for List deployment log for specific deployment for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param id: The ID of a specific deployment. This is the value of the name property in the JSON + response from "GET /api/sites/{siteName}/deployments". + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Deployment, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Deployment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Deployment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_deployment_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Deployment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_deployment_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/deployments/{id}/log'} # type: ignore + + def discover_backup_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.RestoreRequest" + """Discovers an existing app backup that can be restored from a blob in Azure storage. Use this to get information about the databases stored in a backup. + + Description for Discovers an existing app backup that can be restored from a blob in Azure + storage. Use this to get information about the databases stored in a backup. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will perform + discovery for the production slot. + :type slot: str + :param request: A RestoreRequest object that includes Azure storage URL and blog name for + discovery of backup. + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RestoreRequest, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RestoreRequest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.discover_backup_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RestoreRequest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + discover_backup_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/discoverbackup'} # type: ignore + + def list_domain_ownership_identifiers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """Lists ownership identifiers for domain associated with web app. + + Description for Lists ownership identifiers for domain associated with web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_domain_ownership_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_domain_ownership_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers'} # type: ignore + + def get_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Get domain ownership identifier for web app. + + Description for Get domain ownership identifier for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def create_or_update_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def delete_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a domain ownership identifier for a web app. + + Description for Deletes a domain ownership identifier for a web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def update_domain_ownership_identifier_slot( + self, + resource_group_name, # type: str + name, # type: str + domain_ownership_identifier_name, # type: str + slot, # type: str + domain_ownership_identifier, # type: "_models.Identifier" + **kwargs # type: Any + ): + # type: (...) -> "_models.Identifier" + """Creates a domain ownership identifier for web app, or updates an existing ownership identifier. + + Description for Creates a domain ownership identifier for web app, or updates an existing + ownership identifier. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param domain_ownership_identifier_name: Name of domain ownership identifier. + :type domain_ownership_identifier_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param domain_ownership_identifier: A JSON representation of the domain ownership properties. + :type domain_ownership_identifier: ~azure.mgmt.web.v2020_09_01.models.Identifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Identifier, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.Identifier + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Identifier"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_domain_ownership_identifier_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'domainOwnershipIdentifierName': self._serialize.url("domain_ownership_identifier_name", domain_ownership_identifier_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(domain_ownership_identifier, 'Identifier') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Identifier', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_domain_ownership_identifier_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/domainOwnershipIdentifiers/{domainOwnershipIdentifierName}'} # type: ignore + + def get_ms_deploy_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def _create_ms_deploy_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def begin_create_ms_deploy_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy'} # type: ignore + + def get_ms_deploy_log_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_functions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.FunctionEnvelopeCollection"] + """List the functions for a web site, or a deployment slot. + + Description for List the functions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either FunctionEnvelopeCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelopeCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelopeCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('FunctionEnvelopeCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions'} # type: ignore + + def get_functions_admin_token_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> str + """Fetch a short lived token that can be exchanged for a master key. + + Description for Fetch a short lived token that can be exchanged for a master key. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_functions_admin_token_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_functions_admin_token_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/admin/token'} # type: ignore + + def get_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.FunctionEnvelope"] + """Get function information by its ID for web site, or a deployment slot. + + Description for Get function information by its ID for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionEnvelope, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.FunctionEnvelope"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def _create_instance_function_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionEnvelope" + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_function_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(function_envelope, 'FunctionEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_function_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def begin_create_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + function_envelope, # type: "_models.FunctionEnvelope" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.FunctionEnvelope"] + """Create function for web site, or a deployment slot. + + Description for Create function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param function_envelope: Function details. + :type function_envelope: ~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either FunctionEnvelope or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.FunctionEnvelope] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionEnvelope"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_function_slot_initial( + resource_group_name=resource_group_name, + name=name, + function_name=function_name, + slot=slot, + function_envelope=function_envelope, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('FunctionEnvelope', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def delete_instance_function_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function for web site, or a deployment slot. + + Description for Delete a function for web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_function_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_function_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}'} # type: ignore + + def create_or_update_function_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + slot, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a function secret. + + Description for Add or update a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def delete_function_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + key_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a function secret. + + Description for Delete a function secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: The name of the function. + :type function_name: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_function_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_function_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/keys/{keyName}'} # type: ignore + + def list_function_keys_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.StringDictionary" + """Get function keys for a function in a web site, or a deployment slot. + + Description for Get function keys for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: StringDictionary, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.StringDictionary + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.StringDictionary"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('StringDictionary', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listkeys'} # type: ignore + + def list_function_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + function_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """Get function secrets for a function in a web site, or a deployment slot. + + Description for Get function secrets for a function in a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param function_name: Function name. + :type function_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_function_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'functionName': self._serialize.url("function_name", function_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_function_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/functions/{functionName}/listsecrets'} # type: ignore + + def list_host_keys_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostKeys" + """Get host secrets for a function app. + + Description for Get host secrets for a function app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostKeys, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostKeys + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostKeys"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_host_keys_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostKeys', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_host_keys_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listkeys'} # type: ignore + + def list_sync_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + list_sync_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/listsyncstatus'} # type: ignore + + def sync_functions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_functions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_functions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/sync'} # type: ignore + + def create_or_update_host_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + slot, # type: str + key, # type: "_models.KeyInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.KeyInfo" + """Add or update a host level secret. + + Description for Add or update a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :param key: The key to create or update. + :type key: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: KeyInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.KeyInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.KeyInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(key, 'KeyInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('KeyInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def delete_host_secret_slot( + self, + resource_group_name, # type: str + name, # type: str + key_type, # type: str + key_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a host level secret. + + Description for Delete a host level secret. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param key_type: The type of host key. + :type key_type: str + :param key_name: The name of the key. + :type key_name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_secret_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'keyType': self._serialize.url("key_type", key_type, 'str'), + 'keyName': self._serialize.url("key_name", key_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_secret_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/host/default/{keyType}/{keyName}'} # type: ignore + + def list_host_name_bindings_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.HostNameBindingCollection"] + """Get hostname bindings for an app or a deployment slot. + + Description for Get hostname bindings for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either HostNameBindingCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.HostNameBindingCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBindingCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_host_name_bindings_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('HostNameBindingCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_host_name_bindings_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings'} # type: ignore + + def get_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Get the named hostname binding for an app (or deployment slot, if specified). + + Description for Get the named hostname binding for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def create_or_update_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + host_name, # type: str + slot, # type: str + host_name_binding, # type: "_models.HostNameBinding" + **kwargs # type: Any + ): + # type: (...) -> "_models.HostNameBinding" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param host_name_binding: Binding details. This is the JSON representation of a HostNameBinding + object. + :type host_name_binding: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HostNameBinding, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HostNameBinding + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HostNameBinding"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(host_name_binding, 'HostNameBinding') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HostNameBinding', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def delete_host_name_binding_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + host_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param host_name: Hostname in the hostname binding. + :type host_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_host_name_binding_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'hostName': self._serialize.url("host_name", host_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_host_name_binding_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hostNameBindings/{hostName}'} # type: ignore + + def get_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + Description for Retrieves a specific Service Bus Hybrid Connection used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def create_or_update_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def delete_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Removes a Hybrid Connection from this site. + + Description for Removes a Hybrid Connection from this site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def update_hybrid_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + namespace_name, # type: str + relay_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.HybridConnection" + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Creates a new Hybrid Connection using a Service Bus relay. + + Description for Creates a new Hybrid Connection using a Service Bus relay. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param namespace_name: The namespace for this hybrid connection. + :type namespace_name: str + :param relay_name: The relay name for this hybrid connection. + :type relay_name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param connection_envelope: The details of the hybrid connection. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_hybrid_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'namespaceName': self._serialize.url("namespace_name", namespace_name, 'str'), + 'relayName': self._serialize.url("relay_name", relay_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'HybridConnection') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_hybrid_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionNamespaces/{namespaceName}/relays/{relayName}'} # type: ignore + + def list_hybrid_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.HybridConnection" + """Retrieves all Service Bus Hybrid Connections used by this Web App. + + Description for Retrieves all Service Bus Hybrid Connections used by this Web App. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: HybridConnection, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.HybridConnection + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.HybridConnection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_hybrid_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('HybridConnection', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_hybrid_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridConnectionRelays'} # type: ignore + + def list_relay_service_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets hybrid connections configured for an app (or deployment slot, if specified). + + Description for Gets hybrid connections configured for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get hybrid + connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_relay_service_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_relay_service_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection'} # type: ignore + + def get_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Gets a hybrid connection configuration by its name. + + Description for Gets a hybrid connection configuration by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a hybrid + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def create_or_update_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def delete_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a relay service connection by its name. + + Description for Deletes a relay service connection by its name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete a + hybrid connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def update_relay_service_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + entity_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.RelayServiceConnectionEntity" + **kwargs # type: Any + ): + # type: (...) -> "_models.RelayServiceConnectionEntity" + """Creates a new hybrid connection configuration (PUT), or updates an existing one (PATCH). + + Description for Creates a new hybrid connection configuration (PUT), or updates an existing one + (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param entity_name: Name of the hybrid connection configuration. + :type entity_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create or + update a hybrid connection for the production slot. + :type slot: str + :param connection_envelope: Details of the hybrid connection configuration. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: RelayServiceConnectionEntity, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.RelayServiceConnectionEntity + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.RelayServiceConnectionEntity"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_relay_service_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'entityName': self._serialize.url("entity_name", entity_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'RelayServiceConnectionEntity') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('RelayServiceConnectionEntity', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_relay_service_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/hybridconnection/{entityName}'} # type: ignore + + def list_instance_identifiers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebAppInstanceStatusCollection"] + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebAppInstanceStatusCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebAppInstanceStatusCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebAppInstanceStatusCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_identifiers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebAppInstanceStatusCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_identifiers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances'} # type: ignore + + def get_instance_info_slot( + self, + resource_group_name, # type: str + name, # type: str + instance_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebSiteInstanceStatus" + """Gets all scale-out instances of an app. + + Description for Gets all scale-out instances of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param instance_id: + :type instance_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets the + production slot instances. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebSiteInstanceStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebSiteInstanceStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebSiteInstanceStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_info_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebSiteInstanceStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_info_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}'} # type: ignore + + def get_instance_ms_deploy_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MSDeployStatus" + """Get the status of the last MSDeploy operation. + + Description for Get the status of the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def _create_instance_ms_deploy_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployStatus"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployStatus"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_instance_ms_deploy_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(ms_deploy, 'MSDeploy') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201, 409]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 201: + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_instance_ms_deploy_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def begin_create_instance_ms_deploy_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + ms_deploy, # type: "_models.MSDeploy" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.MSDeployStatus"] + """Invoke the MSDeploy web app extension. + + Description for Invoke the MSDeploy web app extension. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :param ms_deploy: Details of MSDeploy operation. + :type ms_deploy: ~azure.mgmt.web.v2020_09_01.models.MSDeploy + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either MSDeployStatus or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.MSDeployStatus] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.MSDeployStatus"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_instance_ms_deploy_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + instance_id=instance_id, + ms_deploy=ms_deploy, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('MSDeployStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_instance_ms_deploy_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy'} # type: ignore + + def get_instance_ms_deploy_log_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.MSDeployLog"] + """Get the MSDeploy Log for the last MSDeploy operation. + + Description for Get the MSDeploy Log for the last MSDeploy operation. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param instance_id: ID of web app instance. + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MSDeployLog, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MSDeployLog or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.MSDeployLog"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_ms_deploy_log_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('MSDeployLog', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_ms_deploy_log_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/extensions/MSDeploy/log'} # type: ignore + + def list_instance_processes_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes'} # type: ignore + + def get_instance_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def delete_instance_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_instance_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_instance_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}'} # type: ignore + + def get_instance_process_dump_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/dump'} # type: ignore + + def list_instance_process_modules_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules'} # type: ignore + + def get_instance_process_module_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_instance_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_instance_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_instance_process_threads_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + instance_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :param instance_id: ID of a specific scaled-out instance. This is the value of the name + property in the JSON response from "GET api/sites/{siteName}/instances". + :type instance_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_instance_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'instanceId': self._serialize.url("instance_id", instance_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_instance_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/instances/{instanceId}/processes/{processId}/threads'} # type: ignore + + def is_cloneable_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteCloneability" + """Shows whether an app can be cloned to another resource group or subscription. + + Description for Shows whether an app can be cloned to another resource group or subscription. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. By default, this API returns information on the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteCloneability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteCloneability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteCloneability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.is_cloneable_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SiteCloneability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + is_cloneable_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/iscloneable'} # type: ignore + + def list_site_backups_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BackupItemCollection"] + """Gets existing backups of an app. + + Description for Gets existing backups of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get backups + of the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BackupItemCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BackupItemCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BackupItemCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_backups_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BackupItemCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_backups_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listbackups'} # type: ignore + + def list_sync_function_triggers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.FunctionSecrets" + """This is to allow calling via powershell and ARM template. + + Description for This is to allow calling via powershell and ARM template. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: FunctionSecrets, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.FunctionSecrets + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.FunctionSecrets"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('FunctionSecrets', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/listsyncfunctiontriggerstatus'} # type: ignore + + def get_migrate_my_sql_status_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.MigrateMySqlStatus" + """Returns the status of MySql in app migration, if one is active, and whether or not MySql in app is enabled. + + Description for Returns the status of MySql in app migration, if one is active, and whether or + not MySql in app is enabled. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: MigrateMySqlStatus, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.MigrateMySqlStatus + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.MigrateMySqlStatus"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_migrate_my_sql_status_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('MigrateMySqlStatus', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_migrate_my_sql_status_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/migratemysql/status'} # type: ignore + + def get_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Gets a Swift Virtual Network connection. + + Description for Gets a Swift Virtual Network connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def create_or_update_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def delete_swift_virtual_network_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a Swift Virtual Network connection from an app (or deployment slot). + + Description for Deletes a Swift Virtual Network connection from an app (or deployment slot). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_swift_virtual_network_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_swift_virtual_network_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def update_swift_virtual_network_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + connection_envelope, # type: "_models.SwiftVirtualNetwork" + **kwargs # type: Any + ): + # type: (...) -> "_models.SwiftVirtualNetwork" + """Integrates this Web App with a Virtual Network. This requires that 1) "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + Description for Integrates this Web App with a Virtual Network. This requires that 1) + "swiftSupported" is true when doing a GET against this resource, and 2) that the target Subnet + has already been delegated, and is not + in use by another App Service Plan other than the one this App is in. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SwiftVirtualNetwork, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SwiftVirtualNetwork + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SwiftVirtualNetwork"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_swift_virtual_network_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'SwiftVirtualNetwork') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SwiftVirtualNetwork', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_swift_virtual_network_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkConfig/virtualNetwork'} # type: ignore + + def list_network_features_slot( + self, + resource_group_name, # type: str + name, # type: str + view, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.NetworkFeatures"] + """Gets all network features used by the app (or deployment slot, if specified). + + Description for Gets all network features used by the app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param view: The type of view. This can either be "summary" or "detailed". + :type view: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get network + features for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NetworkFeatures, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.NetworkFeatures or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.NetworkFeatures"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_network_features_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'view': self._serialize.url("view", view, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('NetworkFeatures', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_network_features_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkFeatures/{view}'} # type: ignore + + def get_network_trace_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/operationresults/{operationId}'} # type: ignore + + def start_web_site_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> str + """Start capturing network packets for the site (To be deprecated). + + Description for Start capturing network packets for the site (To be deprecated). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: str, or the result of cls(response) + :rtype: str + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[str] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('str', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + start_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/start'} # type: ignore + + def _start_web_site_network_trace_operation_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_web_site_network_trace_operation_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_web_site_network_trace_operation_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + def begin_start_web_site_network_trace_operation_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_web_site_network_trace_operation_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_web_site_network_trace_operation_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/startOperation'} # type: ignore + + def stop_web_site_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_web_site_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_web_site_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/stop'} # type: ignore + + def get_network_traces_slot( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTrace/{operationId}'} # type: ignore + + def get_network_trace_operation_slot_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_trace_operation_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_trace_operation_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/current/operationresults/{operationId}'} # type: ignore + + def get_network_traces_slot_v2( + self, + resource_group_name, # type: str + name, # type: str + operation_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + """Gets a named operation for a network trace capturing (or deployment slot, if specified). + + Description for Gets a named operation for a network trace capturing (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param operation_id: GUID of the operation. + :type operation_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get an + operation for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of NetworkTrace, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_network_traces_slot_v2.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_network_traces_slot_v2.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/networkTraces/{operationId}'} # type: ignore + + def generate_new_site_publishing_password_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Generates a new publishing password for an app (or deployment slot, if specified). + + Description for Generates a new publishing password for an app (or deployment slot, if + specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API generate a new + publishing password for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.generate_new_site_publishing_password_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + generate_new_site_publishing_password_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/newpassword'} # type: ignore + + def list_perf_mon_counters_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PerfMonCounterCollection"] + """Gets perfmon counters for web app. + + Description for Gets perfmon counters for web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param filter: Return only usages/metrics specified in the filter. Filter conforms to odata + syntax. Example: $filter=(startTime eq 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z + and timeGrain eq duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PerfMonCounterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PerfMonCounterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PerfMonCounterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_perf_mon_counters_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PerfMonCounterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_perf_mon_counters_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/perfcounters'} # type: ignore + + def get_site_php_error_log_flag_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SitePhpErrorLogFlag" + """Gets web app's event logs. + + Description for Gets web app's event logs. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SitePhpErrorLogFlag, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SitePhpErrorLogFlag + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SitePhpErrorLogFlag"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_php_error_log_flag_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SitePhpErrorLogFlag', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_php_error_log_flag_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/phplogging'} # type: ignore + + def list_premier_add_ons_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets the premier add-ons of an app. + + Description for Gets the premier add-ons of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + premier add-ons for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_premier_add_ons_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_premier_add_ons_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons'} # type: ignore + + def get_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Gets a named add-on of an app. + + Description for Gets a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def add_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + premier_add_on, # type: "_models.PremierAddOn" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.add_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOn') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + add_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def delete_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a premier add-on from an app. + + Description for Delete a premier add-on from an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + named add-on for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def update_premier_add_on_slot( + self, + resource_group_name, # type: str + name, # type: str + premier_add_on_name, # type: str + slot, # type: str + premier_add_on, # type: "_models.PremierAddOnPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PremierAddOn" + """Updates a named add-on of an app. + + Description for Updates a named add-on of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param premier_add_on_name: Add-on name. + :type premier_add_on_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + named add-on for the production slot. + :type slot: str + :param premier_add_on: A JSON representation of the edited premier add-on. + :type premier_add_on: ~azure.mgmt.web.v2020_09_01.models.PremierAddOnPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PremierAddOn, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PremierAddOn + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOn"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_premier_add_on_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'premierAddOnName': self._serialize.url("premier_add_on_name", premier_add_on_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(premier_add_on, 'PremierAddOnPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PremierAddOn', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_premier_add_on_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/premieraddons/{premierAddOnName}'} # type: ignore + + def get_private_access_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Gets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Gets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_access_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_access_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + def put_private_access_vnet_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + access, # type: "_models.PrivateAccess" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateAccess" + """Sets data around private site access enablement and authorized Virtual Networks that can access the site. + + Description for Sets data around private site access enablement and authorized Virtual Networks + that can access the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for the web app. + :type slot: str + :param access: The information for the private access. + :type access: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateAccess, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateAccess + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateAccess"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.put_private_access_vnet_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(access, 'PrivateAccess') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateAccess', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + put_private_access_vnet_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/privateAccess/virtualNetworks'} # type: ignore + + def get_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnectionResource" + """Gets a private endpoint connection. + + Description for Gets a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateEndpointConnectionResource, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateEndpointConnectionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_endpoint_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def _approve_or_reject_private_endpoint_connection_initial( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + private_endpoint_wrapper, # type: "_models.PrivateLinkConnectionApprovalRequestResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateEndpointConnectionResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._approve_or_reject_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(private_endpoint_wrapper, 'PrivateLinkConnectionApprovalRequestResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _approve_or_reject_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def begin_approve_or_reject_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + private_endpoint_wrapper, # type: "_models.PrivateLinkConnectionApprovalRequestResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.PrivateEndpointConnectionResource"] + """Approves or rejects a private endpoint connection. + + Description for Approves or rejects a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :param private_endpoint_wrapper: + :type private_endpoint_wrapper: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkConnectionApprovalRequestResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either PrivateEndpointConnectionResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.PrivateEndpointConnectionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateEndpointConnectionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._approve_or_reject_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + private_endpoint_wrapper=private_endpoint_wrapper, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('PrivateEndpointConnectionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_approve_or_reject_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def _delete_private_endpoint_connection_initial( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> object + cls = kwargs.pop('cls', None) # type: ClsType[object] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._delete_private_endpoint_connection_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('object', pipeline_response) + + if response.status_code == 204: + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _delete_private_endpoint_connection_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def begin_delete_private_endpoint_connection( + self, + resource_group_name, # type: str + name, # type: str + private_endpoint_connection_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[object] + """Deletes a private endpoint connection. + + Description for Deletes a private endpoint connection. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :param private_endpoint_connection_name: + :type private_endpoint_connection_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either object or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[object] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[object] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_private_endpoint_connection_initial( + resource_group_name=resource_group_name, + name=name, + private_endpoint_connection_name=private_endpoint_connection_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('object', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'privateEndpointConnectionName': self._serialize.url("private_endpoint_connection_name", private_endpoint_connection_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_private_endpoint_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateEndpointConnections/{privateEndpointConnectionName}'} # type: ignore + + def get_private_link_resources( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PrivateLinkResourcesWrapper" + """Gets the private link resources. + + Description for Gets the private link resources. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the site. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PrivateLinkResourcesWrapper, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PrivateLinkResourcesWrapper + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PrivateLinkResourcesWrapper"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_private_link_resources.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PrivateLinkResourcesWrapper', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_private_link_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/privateLinkResources'} # type: ignore + + def list_processes_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessInfoCollection"] + """Get list of processes for a web site, or a deployment slot, or for a specific scaled-out instance in a web site. + + Description for Get list of processes for a web site, or a deployment slot, or for a specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_processes_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_processes_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes'} # type: ignore + + def get_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + def delete_process_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Terminate a process by its ID for a web site, or a deployment slot, or specific scaled-out instance in a web site. + + Description for Terminate a process by its ID for a web site, or a deployment slot, or specific + scaled-out instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_process_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_process_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}'} # type: ignore + + def get_process_dump_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional[IO] + """Get a memory dump of a process by its ID for a specific scaled-out instance in a web site. + + Description for Get a memory dump of a process by its ID for a specific scaled-out instance in + a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional[IO]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_dump_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_dump_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/dump'} # type: ignore + + def list_process_modules_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessModuleInfoCollection"] + """List module information for a process by its ID for a specific scaled-out instance in a web site. + + Description for List module information for a process by its ID for a specific scaled-out + instance in a web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessModuleInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessModuleInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_modules_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessModuleInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_modules_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules'} # type: ignore + + def get_process_module_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + base_address, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ProcessModuleInfo"] + """Get process information by its ID for a specific scaled-out instance in a web site. + + Description for Get process information by its ID for a specific scaled-out instance in a web + site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param base_address: Module base address. + :type base_address: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProcessModuleInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ProcessModuleInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ProcessModuleInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_process_module_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'baseAddress': self._serialize.url("base_address", base_address, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ProcessModuleInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_process_module_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/modules/{baseAddress}'} # type: ignore + + def list_process_threads_slot( + self, + resource_group_name, # type: str + name, # type: str + process_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProcessThreadInfoCollection"] + """List the threads in a process by its ID for a specific scaled-out instance in a web site. + + Description for List the threads in a process by its ID for a specific scaled-out instance in a + web site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param process_id: PID. + :type process_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProcessThreadInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.ProcessThreadInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProcessThreadInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_process_threads_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'processId': self._serialize.url("process_id", process_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProcessThreadInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_process_threads_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/processes/{processId}/threads'} # type: ignore + + def list_public_certificates_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PublicCertificateCollection"] + """Get public certificates for an app or a deployment slot. + + Description for Get public certificates for an app or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API gets hostname + bindings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PublicCertificateCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PublicCertificateCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificateCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_public_certificates_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PublicCertificateCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_public_certificates_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates'} # type: ignore + + def get_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Get the named public certificate for an app (or deployment slot, if specified). + + Description for Get the named public certificate for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API the named binding + for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def create_or_update_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + public_certificate_name, # type: str + slot, # type: str + public_certificate, # type: "_models.PublicCertificate" + **kwargs # type: Any + ): + # type: (...) -> "_models.PublicCertificate" + """Creates a hostname binding for an app. + + Description for Creates a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will create a + binding for the production slot. + :type slot: str + :param public_certificate: Public certificate details. This is the JSON representation of a + PublicCertificate object. + :type public_certificate: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PublicCertificate, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.PublicCertificate + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PublicCertificate"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(public_certificate, 'PublicCertificate') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PublicCertificate', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def delete_public_certificate_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + public_certificate_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a hostname binding for an app. + + Description for Deletes a hostname binding for an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + binding for the production slot. + :type slot: str + :param public_certificate_name: Public certificate name. + :type public_certificate_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_public_certificate_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'publicCertificateName': self._serialize.url("public_certificate_name", public_certificate_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_public_certificate_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publicCertificates/{publicCertificateName}'} # type: ignore + + def list_publishing_profile_xml_with_secrets_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + publishing_profile_options, # type: "_models.CsmPublishingProfileOptions" + **kwargs # type: Any + ): + # type: (...) -> IO + """Gets the publishing profile for an app (or deployment slot, if specified). + + Description for Gets the publishing profile for an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + publishing profile for the production slot. + :type slot: str + :param publishing_profile_options: Specifies publishingProfileOptions for publishing profile. + For example, use {"format": "FileZilla3"} to get a FileZilla publishing profile. + :type publishing_profile_options: ~azure.mgmt.web.v2020_09_01.models.CsmPublishingProfileOptions + :keyword callable cls: A custom type or function that will be passed the direct response + :return: IO, or the result of cls(response) + :rtype: IO + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[IO] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/xml" + + # Construct URL + url = self.list_publishing_profile_xml_with_secrets_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(publishing_profile_options, 'CsmPublishingProfileOptions') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=True, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = response.stream_download(self._client._pipeline) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_publishing_profile_xml_with_secrets_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/publishxml'} # type: ignore + + def reset_slot_configuration_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Resets the configuration settings of the current slot if they were previously modified by calling the API with POST. + + Description for Resets the configuration settings of the current slot if they were previously + modified by calling the API with POST. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API resets + configuration settings for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.reset_slot_configuration_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + reset_slot_configuration_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/resetSlotConfig'} # type: ignore + + def restart_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + soft_restart=None, # type: Optional[bool] + synchronous=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> None + """Restarts an app (or deployment slot, if specified). + + Description for Restarts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restart the + production slot. + :type slot: str + :param soft_restart: Specify true to apply the configuration settings and restarts the app only + if necessary. By default, the API always restarts and reprovisions the app. + :type soft_restart: bool + :param synchronous: Specify true to block until the app is restarted. By default, it is set to + false, and the API responds immediately (asynchronous). + :type synchronous: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.restart_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if soft_restart is not None: + query_parameters['softRestart'] = self._serialize.query("soft_restart", soft_restart, 'bool') + if synchronous is not None: + query_parameters['synchronous'] = self._serialize.query("synchronous", synchronous, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + restart_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restart'} # type: ignore + + def _restore_from_backup_blob_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_backup_blob_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request, 'RestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_backup_blob_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + def begin_restore_from_backup_blob_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + request, # type: "_models.RestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores an app from a backup blob in Azure Storage. + + Description for Restores an app from a backup blob in Azure Storage. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will restore a + backup of the production slot. + :type slot: str + :param request: Information on restore request . + :type request: ~azure.mgmt.web.v2020_09_01.models.RestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_backup_blob_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + request=request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_backup_blob_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromBackupBlob'} # type: ignore + + def _restore_from_deleted_app_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_from_deleted_app_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'DeletedAppRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_from_deleted_app_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + def begin_restore_from_deleted_app_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.DeletedAppRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a deleted web app to this web app. + + Description for Restores a deleted web app to this web app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Deleted web app restore information. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.DeletedAppRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_from_deleted_app_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_from_deleted_app_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreFromDeletedApp'} # type: ignore + + def _restore_snapshot_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restore_snapshot_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(restore_request, 'SnapshotRestoreRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restore_snapshot_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def begin_restore_snapshot_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + restore_request, # type: "_models.SnapshotRestoreRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restores a web app from a snapshot. + + Description for Restores a web app from a snapshot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :param restore_request: Snapshot restore settings. Snapshot information can be obtained by + calling GetDeletedSites or GetSiteSnapshots API. + :type restore_request: ~azure.mgmt.web.v2020_09_01.models.SnapshotRestoreRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restore_snapshot_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + restore_request=restore_request, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restore_snapshot_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/restoreSnapshot'} # type: ignore + + def list_site_extensions_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SiteExtensionInfoCollection"] + """Get list of siteextensions for a web site, or a deployment slot. + + Description for Get list of siteextensions for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SiteExtensionInfoCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfoCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfoCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_extensions_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfoCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_extensions_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions'} # type: ignore + + def get_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + """Get site extension information by its ID for a web site, or a deployment slot. + + Description for Get site extension information by its ID for a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteExtensionInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def _install_site_extension_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.SiteExtensionInfo"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.SiteExtensionInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._install_site_extension_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 429]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _install_site_extension_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def begin_install_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteExtensionInfo"] + """Install site extension on a web site, or a deployment slot. + + Description for Install site extension on a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteExtensionInfo or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.SiteExtensionInfo] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteExtensionInfo"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._install_site_extension_slot_initial( + resource_group_name=resource_group_name, + name=name, + site_extension_id=site_extension_id, + slot=slot, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteExtensionInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_install_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def delete_site_extension_slot( + self, + resource_group_name, # type: str + name, # type: str + site_extension_id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Remove a site extension from a web site, or a deployment slot. + + Description for Remove a site extension from a web site, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param site_extension_id: Site extension name. + :type site_extension_id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_site_extension_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'siteExtensionId': self._serialize.url("site_extension_id", site_extension_id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_site_extension_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/siteextensions/{siteExtensionId}'} # type: ignore + + def _copy_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._copy_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(copy_slot_entity, 'CsmCopySlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _copy_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def begin_copy_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + copy_slot_entity, # type: "_models.CsmCopySlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Copies a deployment slot to another deployment slot of an app. + + Description for Copies a deployment slot to another deployment slot of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param copy_slot_entity: JSON object that contains the target slot name and site config + properties to override the source slot config. See example. + :type copy_slot_entity: ~azure.mgmt.web.v2020_09_01.models.CsmCopySlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._copy_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + copy_slot_entity=copy_slot_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_copy_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotcopy'} # type: ignore + + def list_slot_differences_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SlotDifferenceCollection"] + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slot_differences_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsdiffs'} # type: ignore + + def _swap_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def begin_swap_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the source slot. If a slot is not specified, the production slot is used + as the source slot. + :type slot: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._swap_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/slotsswap'} # type: ignore + + def list_snapshots_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :param slot: Website Slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/snapshotsdr'} # type: ignore + + def get_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def _create_or_update_source_control_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def begin_create_or_update_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteSourceControl"] + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_source_control_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def delete_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + source control configuration for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def update_source_control_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will update the + source control configuration for the production slot. + :type slot: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sourcecontrols/web'} # type: ignore + + def start_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will start the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/start'} # type: ignore + + def _start_network_trace_slot_initial( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_slot_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_slot_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + def begin_start_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_network_trace_slot_initial( + resource_group_name=resource_group_name, + name=name, + slot=slot, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/startNetworkTrace'} # type: ignore + + def stop_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will stop the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stop'} # type: ignore + + def stop_network_trace_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param slot: The name of the slot for this web app. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/stopNetworkTrace'} # type: ignore + + def sync_repository_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :param slot: Name of web app slot. If not specified then will default to production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/sync'} # type: ignore + + def sync_function_triggers_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredWebJobCollection"] + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes a + deployment for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs'} # type: ignore + + def get_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredWebJob"] + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def delete_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API deletes web job + for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredJobHistoryCollection"] + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + def get_triggered_web_job_history_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + id, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredJobHistory"] + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + def run_triggered_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API uses the + production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get quota + information of the production slot. + :type slot: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/usages'} # type: ignore + + def list_vnet_connections_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get virtual + network connections for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections'} # type: ignore + + def get_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get the + named virtual network for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def create_or_update_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def delete_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will delete the + connection for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def update_vnet_connection_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update connections for the production slot. + :type slot: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetGateway"] + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will get a + gateway for the production slot's Virtual Network. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def create_or_update_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_connection_gateway_slot( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + slot, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API will add or + update a gateway for the production slot's Virtual Network. + :type slot: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs_slot( + self, + resource_group_name, # type: str + name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebJobCollection"] + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_jobs_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs'} # type: ignore + + def get_web_job_slot( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + slot, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebJob" + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :param slot: Name of the deployment slot. If a slot is not specified, the API returns + deployments for the production slot. + :type slot: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job_slot.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'slot': self._serialize.url("slot", slot, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job_slot.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slots/{slot}/webjobs/{webJobName}'} # type: ignore + + def list_slot_differences_from_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SlotDifferenceCollection"] + """Get the difference in configuration settings between two web app slots. + + Description for Get the difference in configuration settings between two web app slots. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SlotDifferenceCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SlotDifferenceCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SlotDifferenceCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_slot_differences_from_production.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SlotDifferenceCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_slot_differences_from_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsdiffs'} # type: ignore + + def _swap_slot_with_production_initial( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._swap_slot_with_production_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(slot_swap_entity, 'CsmSlotEntity') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _swap_slot_with_production_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def begin_swap_slot_with_production( + self, + resource_group_name, # type: str + name, # type: str + slot_swap_entity, # type: "_models.CsmSlotEntity" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Swaps two deployment slots of an app. + + Description for Swaps two deployment slots of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param slot_swap_entity: JSON object that contains the target slot name. See example. + :type slot_swap_entity: ~azure.mgmt.web.v2020_09_01.models.CsmSlotEntity + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._swap_slot_with_production_initial( + resource_group_name=resource_group_name, + name=name, + slot_swap_entity=slot_swap_entity, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_swap_slot_with_production.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/slotsswap'} # type: ignore + + def list_snapshots( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user. + + Description for Returns all Snapshots to the user. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshots'} # type: ignore + + def list_snapshots_from_dr_secondary( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SnapshotCollection"] + """Returns all Snapshots to the user from DRSecondary endpoint. + + Description for Returns all Snapshots to the user from DRSecondary endpoint. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Website Name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SnapshotCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SnapshotCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SnapshotCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_snapshots_from_dr_secondary.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SnapshotCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_snapshots_from_dr_secondary.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/snapshotsdr'} # type: ignore + + def get_source_control( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Gets the source control configuration of an app. + + Description for Gets the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def _create_or_update_source_control_initial( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_source_control_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_source_control_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def begin_create_or_update_source_control( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.SiteSourceControl"] + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either SiteSourceControl or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.web.v2020_09_01.models.SiteSourceControl] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_source_control_initial( + resource_group_name=resource_group_name, + name=name, + site_source_control=site_source_control, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def delete_source_control( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the source control configuration of an app. + + Description for Deletes the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def update_source_control( + self, + resource_group_name, # type: str + name, # type: str + site_source_control, # type: "_models.SiteSourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SiteSourceControl" + """Updates the source control configuration of an app. + + Description for Updates the source control configuration of an app. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param site_source_control: JSON representation of a SiteSourceControl object. See example. + :type site_source_control: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SiteSourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SiteSourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SiteSourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(site_source_control, 'SiteSourceControl') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('SiteSourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sourcecontrols/web'} # type: ignore + + def start( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Starts an app (or deployment slot, if specified). + + Description for Starts an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.start.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + start.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/start'} # type: ignore + + def _start_network_trace_initial( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> List["_models.NetworkTrace"] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self._start_network_trace_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if duration_in_seconds is not None: + query_parameters['durationInSeconds'] = self._serialize.query("duration_in_seconds", duration_in_seconds, 'int') + if max_frame_length is not None: + query_parameters['maxFrameLength'] = self._serialize.query("max_frame_length", max_frame_length, 'int') + if sas_url is not None: + query_parameters['sasUrl'] = self._serialize.query("sas_url", sas_url, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _start_network_trace_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + def begin_start_network_trace( + self, + resource_group_name, # type: str + name, # type: str + duration_in_seconds=None, # type: Optional[int] + max_frame_length=None, # type: Optional[int] + sas_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> LROPoller[List["_models.NetworkTrace"]] + """Start capturing network packets for the site. + + Description for Start capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :param duration_in_seconds: The duration to keep capturing in seconds. + :type duration_in_seconds: int + :param max_frame_length: The maximum frame length in bytes (Optional). + :type max_frame_length: int + :param sas_url: The Blob URL to store capture file. + :type sas_url: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either list of NetworkTrace or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[list[~azure.mgmt.web.v2020_09_01.models.NetworkTrace]] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.NetworkTrace"]] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._start_network_trace_initial( + resource_group_name=resource_group_name, + name=name, + duration_in_seconds=duration_in_seconds, + max_frame_length=max_frame_length, + sas_url=sas_url, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('[NetworkTrace]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_start_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/startNetworkTrace'} # type: ignore + + def stop( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stops an app (or deployment slot, if specified). + + Description for Stops an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stop'} # type: ignore + + def stop_network_trace( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Stop ongoing capturing network packets for the site. + + Description for Stop ongoing capturing network packets for the site. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: The name of the web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.stop_network_trace.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + stop_network_trace.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/stopNetworkTrace'} # type: ignore + + def sync_repository( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Sync web app repository. + + Description for Sync web app repository. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of web app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_repository.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_repository.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/sync'} # type: ignore + + def sync_function_triggers( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Syncs function trigger metadata to the management database. + + Description for Syncs function trigger metadata to the management database. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.sync_function_triggers.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + sync_function_triggers.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/syncfunctiontriggers'} # type: ignore + + def list_triggered_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredWebJobCollection"] + """List triggered web jobs for an app, or a deployment slot. + + Description for List triggered web jobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredWebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredWebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredWebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredWebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs'} # type: ignore + + def get_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredWebJob"] + """Gets a triggered web job by its ID for an app, or a deployment slot. + + Description for Gets a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredWebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredWebJob or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredWebJob"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredWebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def delete_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Delete a triggered web job by its ID for an app, or a deployment slot. + + Description for Delete a triggered web job by its ID for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}'} # type: ignore + + def list_triggered_web_job_history( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TriggeredJobHistoryCollection"] + """List a triggered web job's history for an app, or a deployment slot. + + Description for List a triggered web job's history for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TriggeredJobHistoryCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistoryCollectionor None] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TriggeredJobHistoryCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TriggeredJobHistoryCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history'} # type: ignore + + def get_triggered_web_job_history( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.TriggeredJobHistory"] + """Gets a triggered web job's history by its ID for an app, , or a deployment slot. + + Description for Gets a triggered web job's history by its ID for an app, , or a deployment + slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :param id: History ID. + :type id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TriggeredJobHistory, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.TriggeredJobHistory or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.TriggeredJobHistory"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_triggered_web_job_history.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'id': self._serialize.url("id", id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('TriggeredJobHistory', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_triggered_web_job_history.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/history/{id}'} # type: ignore + + def run_triggered_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Run a triggered web job for an app, or a deployment slot. + + Description for Run a triggered web job for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of Web Job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.run_triggered_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + run_triggered_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/triggeredwebjobs/{webJobName}/run'} # type: ignore + + def list_usages( + self, + resource_group_name, # type: str + name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.CsmUsageQuotaCollection"] + """Gets the quota usage information of an app (or deployment slot, if specified). + + Description for Gets the quota usage information of an app (or deployment slot, if specified). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param filter: Return only information specified in the filter (using OData syntax). For + example: $filter=(name.value eq 'Metric1' or name.value eq 'Metric2') and startTime eq + 2014-01-01T00:00:00Z and endTime eq 2014-12-31T23:59:59Z and timeGrain eq + duration'[Hour|Minute|Day]'. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either CsmUsageQuotaCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.CsmUsageQuotaCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.CsmUsageQuotaCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_usages.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('CsmUsageQuotaCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_usages.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/usages'} # type: ignore + + def list_vnet_connections( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> List["_models.VnetInfo"] + """Gets the virtual networks the app (or deployment slot) is connected to. + + Description for Gets the virtual networks the app (or deployment slot) is connected to. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: list of VnetInfo, or the result of cls(response) + :rtype: list[~azure.mgmt.web.v2020_09_01.models.VnetInfo] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[List["_models.VnetInfo"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_vnet_connections.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('[VnetInfo]', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_vnet_connections.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections'} # type: ignore + + def get_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Gets a virtual network the app (or deployment slot) is connected to by name. + + Description for Gets a virtual network the app (or deployment slot) is connected to by name. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def create_or_update_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def delete_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a connection from an app (or deployment slot to a named virtual network. + + Description for Deletes a connection from an app (or deployment slot to a named virtual + network. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the virtual network. + :type vnet_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def update_vnet_connection( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + connection_envelope, # type: "_models.VnetInfo" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetInfo" + """Adds a Virtual Network connection to an app or slot (PUT) or updates the connection properties (PATCH). + + Description for Adds a Virtual Network connection to an app or slot (PUT) or updates the + connection properties (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of an existing Virtual Network. + :type vnet_name: str + :param connection_envelope: Properties of the Virtual Network connection. See example. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetInfo, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetInfo + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetInfo"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetInfo') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetInfo', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}'} # type: ignore + + def get_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.VnetGateway"] + """Gets an app's Virtual Network gateway. + + Description for Gets an app's Virtual Network gateway. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.VnetGateway"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def create_or_update_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def update_vnet_connection_gateway( + self, + resource_group_name, # type: str + name, # type: str + vnet_name, # type: str + gateway_name, # type: str + connection_envelope, # type: "_models.VnetGateway" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetGateway" + """Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + Description for Adds a gateway to a connected Virtual Network (PUT) or updates it (PATCH). + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Name of the app. + :type name: str + :param vnet_name: Name of the Virtual Network. + :type vnet_name: str + :param gateway_name: Name of the gateway. Currently, the only supported string is "primary". + :type gateway_name: str + :param connection_envelope: The properties to update this gateway with. + :type connection_envelope: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetGateway, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetGateway + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetGateway"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_vnet_connection_gateway.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'vnetName': self._serialize.url("vnet_name", vnet_name, 'str'), + 'gatewayName': self._serialize.url("gateway_name", gateway_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(connection_envelope, 'VnetGateway') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetGateway', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_vnet_connection_gateway.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/virtualNetworkConnections/{vnetName}/gateways/{gatewayName}'} # type: ignore + + def list_web_jobs( + self, + resource_group_name, # type: str + name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.WebJobCollection"] + """List webjobs for an app, or a deployment slot. + + Description for List webjobs for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either WebJobCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.WebJobCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJobCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_web_jobs.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('WebJobCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_web_jobs.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs'} # type: ignore + + def get_web_job( + self, + resource_group_name, # type: str + name, # type: str + web_job_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.WebJob" + """Get webjob information for an app, or a deployment slot. + + Description for Get webjob information for an app, or a deployment slot. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param name: Site name. + :type name: str + :param web_job_name: Name of the web job. + :type web_job_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: WebJob, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.WebJob + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.WebJob"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_web_job.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'name': self._serialize.url("name", name, 'str'), + 'webJobName': self._serialize.url("web_job_name", web_job_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('WebJob', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_web_job.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/sites/{name}/webjobs/{webJobName}'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_site_management_client_operations.py b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_site_management_client_operations.py new file mode 100644 index 000000000000..af2e33071d62 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/operations/_web_site_management_client_operations.py @@ -0,0 +1,1142 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class WebSiteManagementClientOperationsMixin(object): + + def generate_github_access_token_for_appservice_cli_async( + self, + code, # type: str + state, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.AppserviceGithubToken" + """Exchange code for GitHub access token for AppService CLI. + + Description for Exchange code for GitHub access token for AppService CLI. + + :param code: Code string to exchange for Github Access token. + :type code: str + :param state: State string used for verification. + :type state: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: AppserviceGithubToken, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.AppserviceGithubToken + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.AppserviceGithubToken"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.AppserviceGithubTokenRequest(code=code, state=state) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.generate_github_access_token_for_appservice_cli_async.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'AppserviceGithubTokenRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('AppserviceGithubToken', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + generate_github_access_token_for_appservice_cli_async.metadata = {'url': '/providers/Microsoft.Web/generateGithubAccessTokenForAppserviceCLI'} # type: ignore + + def get_publishing_user( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + """Gets publishing user. + + Description for Gets publishing user. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def update_publishing_user( + self, + user_details, # type: "_models.User" + **kwargs # type: Any + ): + # type: (...) -> "_models.User" + """Updates publishing user. + + Description for Updates publishing user. + + :param user_details: Details of publishing user. + :type user_details: ~azure.mgmt.web.v2020_09_01.models.User + :keyword callable cls: A custom type or function that will be passed the direct response + :return: User, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.User + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.User"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_publishing_user.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(user_details, 'User') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('User', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_publishing_user.metadata = {'url': '/providers/Microsoft.Web/publishingUsers/web'} # type: ignore + + def list_source_controls( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.SourceControlCollection"] + """Gets the source controls available for Azure websites. + + Description for Gets the source controls available for Azure websites. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either SourceControlCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.SourceControlCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControlCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_source_controls.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('SourceControlCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_source_controls.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols'} # type: ignore + + def get_source_control( + self, + source_control_type, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.SourceControl" + """Gets source control token. + + Description for Gets source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def update_source_control( + self, + source_control_type, # type: str + request_message, # type: "_models.SourceControl" + **kwargs # type: Any + ): + # type: (...) -> "_models.SourceControl" + """Updates source control token. + + Description for Updates source control token. + + :param source_control_type: Type of source control. + :type source_control_type: str + :param request_message: Source control token information. + :type request_message: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SourceControl, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SourceControl + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SourceControl"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_source_control.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceControlType': self._serialize.url("source_control_type", source_control_type, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(request_message, 'SourceControl') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SourceControl', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_source_control.metadata = {'url': '/providers/Microsoft.Web/sourcecontrols/{sourceControlType}'} # type: ignore + + def list_billing_meters( + self, + billing_location=None, # type: Optional[str] + os_type=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.BillingMeterCollection"] + """Gets a list of meters for a given location. + + Description for Gets a list of meters for a given location. + + :param billing_location: Azure Location of billable resource. + :type billing_location: str + :param os_type: App Service OS type meters used for. + :type os_type: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either BillingMeterCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.BillingMeterCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.BillingMeterCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_billing_meters.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if billing_location is not None: + query_parameters['billingLocation'] = self._serialize.query("billing_location", billing_location, 'str') + if os_type is not None: + query_parameters['osType'] = self._serialize.query("os_type", os_type, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('BillingMeterCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_billing_meters.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/billingMeters'} # type: ignore + + def check_name_availability( + self, + name, # type: str + type, # type: Union[str, "_models.CheckNameResourceTypes"] + is_fqdn=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceNameAvailability" + """Check if a resource name is available. + + Description for Check if a resource name is available. + + :param name: Resource name to verify. + :type name: str + :param type: Resource type used for verification. + :type type: str or ~azure.mgmt.web.v2020_09_01.models.CheckNameResourceTypes + :param is_fqdn: Is fully qualified domain name. + :type is_fqdn: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceNameAvailability, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ResourceNameAvailability + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceNameAvailability"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + + _request = _models.ResourceNameAvailabilityRequest(name=name, type=type, is_fqdn=is_fqdn) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.check_name_availability.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(_request, 'ResourceNameAvailabilityRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceNameAvailability', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + check_name_availability.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/checknameavailability'} # type: ignore + + def get_subscription_deployment_locations( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentLocations" + """Gets list of available geo regions plus ministamps. + + Description for Gets list of available geo regions plus ministamps. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentLocations, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.DeploymentLocations + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentLocations"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_subscription_deployment_locations.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentLocations', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_subscription_deployment_locations.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/deploymentLocations'} # type: ignore + + def list_geo_regions( + self, + sku=None, # type: Optional[Union[str, "_models.SkuName"]] + linux_workers_enabled=None, # type: Optional[bool] + xenon_workers_enabled=None, # type: Optional[bool] + linux_dynamic_workers_enabled=None, # type: Optional[bool] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.GeoRegionCollection"] + """Get a list of available geographical regions. + + Description for Get a list of available geographical regions. + + :param sku: Name of SKU used to filter the regions. + :type sku: str or ~azure.mgmt.web.v2020_09_01.models.SkuName + :param linux_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Linux workers. + :type linux_workers_enabled: bool + :param xenon_workers_enabled: Specify :code:`true` if you want to filter to only + regions that support Xenon workers. + :type xenon_workers_enabled: bool + :param linux_dynamic_workers_enabled: Specify :code:`true` if you want to filter + to only regions that support Linux Consumption Workers. + :type linux_dynamic_workers_enabled: bool + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either GeoRegionCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.GeoRegionCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GeoRegionCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_geo_regions.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if sku is not None: + query_parameters['sku'] = self._serialize.query("sku", sku, 'str') + if linux_workers_enabled is not None: + query_parameters['linuxWorkersEnabled'] = self._serialize.query("linux_workers_enabled", linux_workers_enabled, 'bool') + if xenon_workers_enabled is not None: + query_parameters['xenonWorkersEnabled'] = self._serialize.query("xenon_workers_enabled", xenon_workers_enabled, 'bool') + if linux_dynamic_workers_enabled is not None: + query_parameters['linuxDynamicWorkersEnabled'] = self._serialize.query("linux_dynamic_workers_enabled", linux_dynamic_workers_enabled, 'bool') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('GeoRegionCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_geo_regions.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/geoRegions'} # type: ignore + + def list_site_identifiers_assigned_to_host_name( + self, + name_identifier, # type: "_models.NameIdentifier" + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.IdentifierCollection"] + """List all apps that are assigned to a hostname. + + Description for List all apps that are assigned to a hostname. + + :param name_identifier: Hostname information. + :type name_identifier: ~azure.mgmt.web.v2020_09_01.models.NameIdentifier + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either IdentifierCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.IdentifierCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.IdentifierCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = "application/json" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_site_identifiers_assigned_to_host_name.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(name_identifier, 'NameIdentifier') + body_content_kwargs['content'] = body_content + request = self._client.get(url, query_parameters, header_parameters, **body_content_kwargs) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('IdentifierCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_site_identifiers_assigned_to_host_name.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/listSitesAssignedToHostName'} # type: ignore + + def list_premier_add_on_offers( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PremierAddOnOfferCollection"] + """List all premier add-on offers. + + Description for List all premier add-on offers. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PremierAddOnOfferCollection or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.web.v2020_09_01.models.PremierAddOnOfferCollection] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PremierAddOnOfferCollection"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_premier_add_on_offers.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PremierAddOnOfferCollection', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.DefaultErrorResponse, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_premier_add_on_offers.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/premieraddonoffers'} # type: ignore + + def list_skus( + self, + **kwargs # type: Any + ): + # type: (...) -> "_models.SkuInfos" + """List all SKUs. + + Description for List all SKUs. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: SkuInfos, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.SkuInfos + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.SkuInfos"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.list_skus.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('SkuInfos', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list_skus.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/skus'} # type: ignore + + def verify_hosting_environment_vnet( + self, + parameters, # type: "_models.VnetParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.VnetValidationFailureDetails" + """Verifies if this VNET is compatible with an App Service Environment by analyzing the Network Security Group rules. + + Description for Verifies if this VNET is compatible with an App Service Environment by + analyzing the Network Security Group rules. + + :param parameters: VNET information. + :type parameters: ~azure.mgmt.web.v2020_09_01.models.VnetParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: VnetValidationFailureDetails, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.VnetValidationFailureDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.VnetValidationFailureDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.verify_hosting_environment_vnet.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'VnetParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('VnetValidationFailureDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + verify_hosting_environment_vnet.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Web/verifyHostingEnvironmentVnet'} # type: ignore + + def move( + self, + resource_group_name, # type: str + move_resource_envelope, # type: "_models.CsmMoveResourceEnvelope" + **kwargs # type: Any + ): + # type: (...) -> None + """Move resources between resource groups. + + Description for Move resources between resource groups. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/moveResources'} # type: ignore + + def validate( + self, + resource_group_name, # type: str + validate_request, # type: "_models.ValidateRequest" + **kwargs # type: Any + ): + # type: (...) -> "_models.ValidateResponse" + """Validate if a resource can be created. + + Description for Validate if a resource can be created. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param validate_request: Request with the resources to validate. + :type validate_request: ~azure.mgmt.web.v2020_09_01.models.ValidateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ValidateResponse, or the result of cls(response) + :rtype: ~azure.mgmt.web.v2020_09_01.models.ValidateResponse + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ValidateResponse"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(validate_request, 'ValidateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ValidateResponse', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Web/validate'} # type: ignore + + def validate_move( + self, + resource_group_name, # type: str + move_resource_envelope, # type: "_models.CsmMoveResourceEnvelope" + **kwargs # type: Any + ): + # type: (...) -> None + """Validate whether a resource can be moved. + + Description for Validate whether a resource can be moved. + + :param resource_group_name: Name of the resource group to which the resource belongs. + :type resource_group_name: str + :param move_resource_envelope: Object that represents the resource to move. + :type move_resource_envelope: ~azure.mgmt.web.v2020_09_01.models.CsmMoveResourceEnvelope + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.validate_move.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+[^\.]$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(move_resource_envelope, 'CsmMoveResourceEnvelope') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.DefaultErrorResponse, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + validate_move.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/validateMoveResources'} # type: ignore diff --git a/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/py.typed b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/appservice/azure-mgmt-web/azure/mgmt/web/v2020_09_01/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_app_service.test_app_service_plan.yaml b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_app_service.test_app_service_plan.yaml index a1cded97a63e..f38abed5d3fe 100644 --- a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_app_service.test_app_service_plan.yaml +++ b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_app_service.test_app_service_plan.yaml @@ -14,23 +14,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname","name":"myname","type":"Microsoft.Web/serverfarms","kind":"app","location":"East - US","properties":{"serverFarmId":19011,"name":"myname","workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":20,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East - US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-199_19011","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname","name":"myname","type":"Microsoft.Web/serverfarms","kind":"app","location":"eastus","properties":{"serverFarmId":7233,"name":"myname","sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1},"workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":0,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East + US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-233_7233","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' headers: cache-control: - no-cache content-length: - - '1493' + - '1564' content-type: - application/json date: - - Mon, 23 Nov 2020 06:37:54 GMT + - Thu, 25 Feb 2021 06:16:51 GMT + etag: + - '"1D70B3DCD5F3B80"' expires: - '-1' pragma: @@ -64,23 +65,23 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname","name":"myname","type":"Microsoft.Web/serverfarms","kind":"app","location":"East - US","properties":{"serverFarmId":19011,"name":"myname","workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":20,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East - US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-199_19011","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' + US","properties":{"serverFarmId":7233,"name":"myname","workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":20,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East + US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-233_7233","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' headers: cache-control: - no-cache content-length: - - '1493' + - '1491' content-type: - application/json date: - - Mon, 23 Nov 2020 06:37:54 GMT + - Thu, 25 Feb 2021 06:16:51 GMT expires: - '-1' pragma: @@ -116,22 +117,22 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname","name":"myname","type":"Microsoft.Web/serverfarms","kind":"app","properties":{"serverFarmId":19011,"name":"myname","sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1},"workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":20,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East - US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-199_19011","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":null,"webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname","name":"myname","type":"Microsoft.Web/serverfarms","kind":"app","properties":{"serverFarmId":7233,"name":"myname","sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1},"workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":20,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East + US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-233_7233","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"P1","tier":"Premium","size":"P1","family":"P","capacity":1}}' headers: cache-control: - no-cache content-length: - - '1540' + - '1545' content-type: - application/json date: - - Mon, 23 Nov 2020 06:38:00 GMT + - Thu, 25 Feb 2021 06:16:55 GMT expires: - '-1' pragma: @@ -167,9 +168,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myname?api-version=2020-09-01 response: body: string: '' @@ -179,7 +180,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:38:08 GMT + - Thu, 25 Feb 2021 06:17:02 GMT expires: - '-1' pragma: diff --git a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_static_site.test_static_site.yaml b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_static_site.test_static_site.yaml index cecb1ce42769..a75da64028ef 100644 --- a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_static_site.test_static_site.yaml +++ b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_static_site.test_static_site.yaml @@ -2,7 +2,7 @@ interactions: - request: body: '{"location": "eastus2", "sku": {"name": "Free"}, "properties": {"repositoryUrl": "https://github.com/00Kai0/html-docs-hello-world", "branch": "master", "repositoryToken": - "009820ffdf19db061b7e8667eabdc7f5188c3252", "buildProperties": {"appLocation": + "4ea23f4a97c54e52c7574a010b4c5d72a13a011f", "buildProperties": {"appLocation": "app", "apiLocation": "api", "appArtifactLocation": "build"}}}' headers: Accept: @@ -16,22 +16,22 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname","name":"myname","type":"Microsoft.Web/staticSites","location":"East - US 2","properties":{"defaultHostname":"happy-ocean-0c2bdca0f.azurestaticapps.net","repositoryUrl":"https://github.com/00Kai0/html-docs-hello-world","branch":"master","provider":"GitHub","customDomains":[],"privateEndpointConnections":[],"contentDistributionEndpoint":"https://content-eus2.infrastructure.azurestaticapps.net"},"sku":{"name":"Free","tier":"Free"}}' + US 2","properties":{"defaultHostname":"jolly-glacier-02b80590f.azurestaticapps.net","repositoryUrl":"https://github.com/00Kai0/html-docs-hello-world","branch":"master","provider":"GitHub","customDomains":[],"privateEndpointConnections":[],"contentDistributionEndpoint":"https://content-eus2.infrastructure.azurestaticapps.net"},"sku":{"name":"Free","tier":"Free"}}' headers: cache-control: - no-cache content-length: - - '624' + - '626' content-type: - application/json date: - - Mon, 23 Nov 2020 06:58:50 GMT + - Thu, 25 Feb 2021 06:17:22 GMT expires: - '-1' pragma: @@ -65,22 +65,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname","name":"myname","type":"Microsoft.Web/staticSites","location":"East - US 2","properties":{"defaultHostname":"happy-ocean-0c2bdca0f.azurestaticapps.net","repositoryUrl":"https://github.com/00Kai0/html-docs-hello-world","branch":"master","provider":"GitHub","customDomains":[],"privateEndpointConnections":[],"contentDistributionEndpoint":"https://content-eus2.infrastructure.azurestaticapps.net"},"sku":{"name":"Free","tier":"Free"}}' + US 2","properties":{"defaultHostname":"jolly-glacier-02b80590f.azurestaticapps.net","repositoryUrl":"https://github.com/00Kai0/html-docs-hello-world","branch":"master","provider":"GitHub","customDomains":[],"privateEndpointConnections":[],"contentDistributionEndpoint":"https://content-eus2.infrastructure.azurestaticapps.net"},"sku":{"name":"Free","tier":"Free"}}' headers: cache-control: - no-cache content-length: - - '624' + - '626' content-type: - application/json date: - - Mon, 23 Nov 2020 06:58:50 GMT + - Thu, 25 Feb 2021 06:17:23 GMT expires: - '-1' pragma: @@ -114,13 +114,13 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/listSecrets?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/listSecrets?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/secrets","name":"secrets","type":"Microsoft.Web/staticSites/secrets","location":"East - US 2","properties":{"apiKey":"10ea75f7af05e747dc6c5d70b4e1821b8a473e8ed20e6a215e2857c6281edd16-16be15f8-11ba-4874-be4f-905b1294581800f4373"}}' + US 2","properties":{"apiKey":"ad9c22e8fa4eeee58cf43f479d8ed61be9c99c8b5db94645b23c6d9e534611b8-cf34ebc8-1194-4cb6-9917-a002b7b704a500f6903"}}' headers: cache-control: - no-cache @@ -129,7 +129,7 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:58:51 GMT + - Thu, 25 Feb 2021 06:17:23 GMT expires: - '-1' pragma: @@ -154,7 +154,7 @@ interactions: code: 200 message: OK - request: - body: '{"properties": {"repositoryToken": "009820ffdf19db061b7e8667eabdc7f5188c3252", + body: '{"properties": {"repositoryToken": "4ea23f4a97c54e52c7574a010b4c5d72a13a011f", "shouldUpdateRepository": true}}' headers: Accept: @@ -168,9 +168,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/resetapikey?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/resetapikey?api-version=2020-09-01 response: body: string: '' @@ -180,7 +180,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:58:51 GMT + - Thu, 25 Feb 2021 06:17:24 GMT expires: - '-1' pragma: @@ -212,9 +212,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/detach?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname/detach?api-version=2020-09-01 response: body: string: '' @@ -224,7 +224,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:58:52 GMT + - Thu, 25 Feb 2021 06:17:24 GMT expires: - '-1' pragma: @@ -256,25 +256,25 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/staticSites/myname?api-version=2020-09-01 response: body: string: '' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web/locations/eastus2/operationResults/1063d04b-0ecf-4559-8075-3db9abb0660a?api-version=2019-01-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web/locations/eastus2/operationResults/ef49ed60-c947-49a6-ae27-f1a3c15f72f8?api-version=2019-01-01 cache-control: - no-cache content-length: - '0' date: - - Mon, 23 Nov 2020 06:58:53 GMT + - Thu, 25 Feb 2021 06:17:25 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web/locations/eastus2/operations/1063d04b-0ecf-4559-8075-3db9abb0660a?api-version=2019-01-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web/locations/eastus2/operations/ef49ed60-c947-49a6-ae27-f1a3c15f72f8?api-version=2019-01-01 pragma: - no-cache server: @@ -286,7 +286,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14999' x-powered-by: - ASP.NET status: diff --git a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app.yaml b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app.yaml index 90d5e566eddc..202f0c3bcc5a 100644 --- a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app.yaml +++ b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app.yaml @@ -14,23 +14,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","name":"myappserviceplan","type":"Microsoft.Web/serverfarms","kind":"app","location":"East - US","properties":{"serverFarmId":7432,"name":"myappserviceplan","workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":3,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East - US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-213_7432","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"B1","tier":"Basic","size":"B1","family":"B","capacity":1}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","name":"myappserviceplan","type":"Microsoft.Web/serverfarms","kind":"app","location":"eastus","properties":{"serverFarmId":51512,"name":"myappserviceplan","sku":{"name":"B1","tier":"Basic","size":"B1","family":"B","capacity":1},"workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":0,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East + US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-139_51512","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"B1","tier":"Basic","size":"B1","family":"B","capacity":1}}' headers: cache-control: - no-cache content-length: - - '1518' + - '1592' content-type: - application/json date: - - Mon, 23 Nov 2020 06:38:53 GMT + - Thu, 25 Feb 2021 06:17:47 GMT + etag: + - '"1D70B3DEE6C3B20"' expires: - '-1' pragma: @@ -72,25 +73,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:38:57.8366667","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-139.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:17:52.36","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow - all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.79.154.194","possibleInboundIpAddresses":"40.79.154.194","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-139.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166","possibleOutboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166,137.117.98.138,137.117.99.211,137.117.97.27","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-139","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '6008' + - '5905' content-type: - application/json date: - - Mon, 23 Nov 2020 06:39:16 GMT + - Thu, 25 Feb 2021 06:18:09 GMT etag: - - '"1D6C16352E16035"' + - '"1D70B3DF32CDD75"' expires: - '-1' pragma: @@ -129,26 +130,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"None","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"None","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3612' + - '3633' content-type: - application/json date: - - Mon, 23 Nov 2020 06:39:18 GMT + - Thu, 25 Feb 2021 06:18:11 GMT etag: - - '"1D6C16352E16035"' + - '"1D70B3DF32CDD75"' expires: - '-1' pragma: @@ -187,9 +188,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -202,9 +203,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:39:30 GMT + - Thu, 25 Feb 2021 06:18:18 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -234,64 +235,14 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 - response: - body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East - US","properties":{"repoUrl":"https://github.com/00Kai0/azure-site-test","branch":"staging","isManualIntegration":true,"isGitHubAction":false,"deploymentRollbackEnabled":false,"isMercurial":false,"provisioningState":"InProgress","provisioningDetails":"2020-11-23T06:40:00.1948671 - https://mysitexxyzz.scm.azurewebsites.net/api/deployments/latest?deployer=GitHub&time=2020-11-23_06-39-38Z","gitHubActionConfiguration":null}}' - headers: - cache-control: - - no-cache - content-length: - - '715' - content-type: - - application/json - date: - - Mon, 23 Nov 2020 06:40:02 GMT - etag: - - '"1D6C1636582C3C0"' - expires: - - '-1' - pragma: - - no-cache - server: - - Microsoft-IIS/10.0 - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding - x-aspnet-version: - - 4.0.30319 - x-content-type-options: - - nosniff - x-powered-by: - - ASP.NET - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East - US","properties":{"repoUrl":"https://github.com/00Kai0/azure-site-test","branch":"staging","isManualIntegration":true,"isGitHubAction":false,"deploymentRollbackEnabled":false,"isMercurial":false,"provisioningState":"InProgress","provisioningDetails":"2020-11-23T06:40:26.2835297 - https://mysitexxyzz.scm.azurewebsites.net/api/deployments/latest?deployer=GitHub&time=2020-11-23_06-39-38Z","gitHubActionConfiguration":null}}' + US","properties":{"repoUrl":"https://github.com/00Kai0/azure-site-test","branch":"staging","isManualIntegration":true,"isGitHubAction":false,"deploymentRollbackEnabled":false,"isMercurial":false,"provisioningState":"InProgress","provisioningDetails":"2021-02-25T06:18:44.8974493 + https://mysitexxyzz.scm.azurewebsites.net/api/deployments/latest?deployer=GitHub&time=2021-02-25_06-18-31Z","gitHubActionConfiguration":null}}' headers: cache-control: - no-cache @@ -300,9 +251,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:40:33 GMT + - Thu, 25 Feb 2021 06:18:50 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -334,9 +285,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -349,9 +300,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:04 GMT + - Thu, 25 Feb 2021 06:19:20 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -383,24 +334,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/config","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3637' + - '3658' content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:04 GMT + - Thu, 25 Feb 2021 06:19:21 GMT expires: - '-1' pragma: @@ -432,24 +383,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"East - US","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:39:30.3","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":null,"scmIpSecurityRestrictions":null,"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":[],"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + US","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-139.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:18:19.05","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":null,"scmIpSecurityRestrictions":null,"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.79.154.194","possibleInboundIpAddresses":"40.79.154.194","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-139.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166","possibleOutboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166,137.117.98.138,137.117.99.211,137.117.97.27","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-139","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":[],"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '5803' + - '5706' content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:05 GMT + - Thu, 25 Feb 2021 06:19:22 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -481,9 +432,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -496,9 +447,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:05 GMT + - Thu, 25 Feb 2021 06:19:24 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -538,26 +489,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"East - US","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:41:09.61","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-139.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:19:28.1666667","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow - all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Basic","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.79.154.194","possibleInboundIpAddresses":"40.79.154.194","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-139.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166","possibleOutboundIpAddresses":"40.79.154.194,137.117.100.130,137.117.103.80,137.117.97.189,137.117.101.166,137.117.98.138,137.117.99.211,137.117.97.27","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-139","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '6004' + - '5911' content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:12 GMT + - Thu, 25 Feb 2021 06:19:31 GMT etag: - - '"1D6C1636582C3C0"' + - '"1D70B3E029DE8A0"' expires: - '-1' pragma: @@ -596,26 +547,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":null,"httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3619' + - '3640' content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:14 GMT + - Thu, 25 Feb 2021 06:19:34 GMT etag: - - '"1D6C163A0B444A0"' + - '"1D70B3E2BD0466B"' expires: - '-1' pragma: @@ -654,9 +605,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -669,9 +620,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:41:14 GMT + - Thu, 25 Feb 2021 06:19:35 GMT etag: - - '"1D6C163A30DF915"' + - '"1D70B3E2F3EAC35"' expires: - '-1' pragma: @@ -707,9 +658,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/start?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/start?api-version=2020-09-01 response: body: string: '' @@ -719,7 +670,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:41:15 GMT + - Thu, 25 Feb 2021 06:19:35 GMT expires: - '-1' pragma: @@ -751,9 +702,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/restart?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/restart?api-version=2020-09-01 response: body: string: '' @@ -763,7 +714,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:41:16 GMT + - Thu, 25 Feb 2021 06:19:36 GMT expires: - '-1' pragma: @@ -795,9 +746,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/stop?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/stop?api-version=2020-09-01 response: body: string: '' @@ -807,7 +758,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:41:16 GMT + - Thu, 25 Feb 2021 06:19:37 GMT expires: - '-1' pragma: @@ -839,9 +790,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/sourcecontrols/web?api-version=2020-09-01 response: body: string: '' @@ -851,9 +802,9 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:41:33 GMT + - Thu, 25 Feb 2021 06:19:47 GMT etag: - - '"1D6C163A5BF2960"' + - '"1D70B3E322851A0"' expires: - '-1' pragma: @@ -885,9 +836,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: string: '' @@ -897,9 +848,9 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:41:44 GMT + - Thu, 25 Feb 2021 06:20:00 GMT etag: - - '"1D6C163A5BF2960"' + - '"1D70B3E322851A0"' expires: - '-1' pragma: diff --git a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app_slot.yaml b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app_slot.yaml index 0470cbfa84e4..e1788d2f6f19 100644 --- a/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app_slot.yaml +++ b/sdk/appservice/azure-mgmt-web/tests/recordings/test_cli_mgmt_web_app.test_web_app_slot.yaml @@ -14,23 +14,24 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","name":"myappserviceplan","type":"Microsoft.Web/serverfarms","kind":"app","location":"East - US","properties":{"serverFarmId":7434,"name":"myappserviceplan","workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":10,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East - US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-213_7434","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"S1","tier":"Standard","size":"S1","family":"S","capacity":1}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","name":"myappserviceplan","type":"Microsoft.Web/serverfarms","kind":"app","location":"eastus","properties":{"serverFarmId":42184,"name":"myappserviceplan","sku":{"name":"S1","tier":"Standard","size":"S1","family":"S","capacity":1},"workerSize":"Default","workerSizeId":0,"workerTierName":null,"numberOfWorkers":1,"currentWorkerSize":"Default","currentWorkerSizeId":0,"currentNumberOfWorkers":1,"status":"Ready","webSpace":"rgname-EastUSwebspace","subscription":"00000000-0000-0000-0000-000000000000","adminSiteName":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"maximumNumberOfWorkers":0,"planName":"VirtualDedicatedPlan","adminRuntimeSiteName":null,"computeMode":"Dedicated","siteMode":null,"geoRegion":"East + US","perSiteScaling":false,"maximumElasticWorkerCount":1,"numberOfSites":0,"hostingEnvironmentId":null,"isSpot":false,"spotExpirationTime":null,"freeOfferExpirationTime":null,"tags":null,"kind":"app","resourceGroup":"rgname","reserved":false,"isXenon":false,"hyperV":false,"mdmId":"waws-prod-blu-143_42184","targetWorkerCount":0,"targetWorkerSizeId":0,"provisioningState":"Succeeded","webSiteId":null,"existingServerFarmIds":null,"azBalancing":false},"sku":{"name":"S1","tier":"Standard","size":"S1","family":"S","capacity":1}}' headers: cache-control: - no-cache content-length: - - '1522' + - '1598' content-type: - application/json date: - - Mon, 23 Nov 2020 06:42:03 GMT + - Thu, 25 Feb 2021 06:20:25 GMT + etag: + - '"1D70B3E4D22F495"' expires: - '-1' pragma: @@ -48,7 +49,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1198' x-powered-by: - ASP.NET status: @@ -72,25 +73,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:42:08.29","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz","name":"mysitexxyzz","type":"Microsoft.Web/sites","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz","state":"Running","hostNames":["mysitexxyzz.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-143.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz.azurewebsites.net","mysitexxyzz.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:20:30.2433333","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow - all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.71.11.133","possibleInboundIpAddresses":"40.71.11.133","ftpUsername":"mysitexxyzz\\$mysitexxyzz","ftpsHostName":"ftps://waws-prod-blu-143.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7","possibleOutboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7,40.114.15.207,137.135.71.113,40.114.53.155","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-143","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '6006' + - '5894' content-type: - application/json date: - - Mon, 23 Nov 2020 06:42:25 GMT + - Thu, 25 Feb 2021 06:20:48 GMT etag: - - '"1D6C163C412532B"' + - '"1D70B3E5140D440"' expires: - '-1' pragma: @@ -108,7 +109,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-resource-requests: - - '497' + - '499' x-powered-by: - ASP.NET status: @@ -128,25 +129,25 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2020-09-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:42:33.0866667","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","kind":"app","location":"eastus","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-143.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:20:52.81","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow - all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__13b4","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__3f44","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.71.11.133","possibleInboundIpAddresses":"40.71.11.133","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-143.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7","possibleOutboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7,40.114.15.207,137.135.71.113,40.114.53.155","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-143","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '6120' + - '5998' content-type: - application/json date: - - Mon, 23 Nov 2020 06:42:49 GMT + - Thu, 25 Feb 2021 06:21:09 GMT etag: - - '"1D6C163C412532B"' + - '"1D70B3E5140D440"' expires: - '-1' pragma: @@ -185,26 +186,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"None","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"None","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3653' + - '3674' content-type: - application/json date: - - Mon, 23 Nov 2020 06:42:51 GMT + - Thu, 25 Feb 2021 06:21:11 GMT etag: - - '"1D6C163D30BD760"' + - '"1D70B3E5EF6DBF5"' expires: - '-1' pragma: @@ -222,7 +223,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1197' x-powered-by: - ASP.NET status: @@ -243,9 +244,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -258,9 +259,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:42:58 GMT + - Thu, 25 Feb 2021 06:21:18 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -274,7 +275,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1196' x-powered-by: - ASP.NET status: @@ -290,14 +291,14 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East - US","properties":{"repoUrl":"https://github.com/00Kai0/azure-site-test","branch":"staging","isManualIntegration":true,"isGitHubAction":false,"deploymentRollbackEnabled":false,"isMercurial":false,"provisioningState":"InProgress","provisioningDetails":"2020-11-23T06:43:20.1613008 - https://mysitexxyzz-staging.scm.azurewebsites.net/api/deployments/latest?deployer=GitHub&time=2020-11-23_06-43-08Z","gitHubActionConfiguration":null}}' + US","properties":{"repoUrl":"https://github.com/00Kai0/azure-site-test","branch":"staging","isManualIntegration":true,"isGitHubAction":false,"deploymentRollbackEnabled":false,"isMercurial":false,"provisioningState":"InProgress","provisioningDetails":"2021-02-25T06:21:48.1220627 + https://mysitexxyzz-staging.scm.azurewebsites.net/api/deployments/latest?deployer=GitHub&time=2021-02-25_06-21-26Z","gitHubActionConfiguration":null}}' headers: cache-control: - no-cache @@ -306,9 +307,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:43:29 GMT + - Thu, 25 Feb 2021 06:21:48 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -340,9 +341,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -355,9 +356,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:01 GMT + - Thu, 25 Feb 2021 06:22:19 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -389,24 +390,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","kind":"app","location":"East - US","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:42:58.7933333","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":null,"scmIpSecurityRestrictions":null,"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__13b4","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":[],"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + US","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-143.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:21:18.0933333","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":null,"scmIpSecurityRestrictions":null,"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__3f44","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.71.11.133","possibleInboundIpAddresses":"40.71.11.133","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-143.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7","possibleOutboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7,40.114.15.207,137.135.71.113,40.114.53.155","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-143","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":[],"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '5921' + - '5804' content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:02 GMT + - Thu, 25 Feb 2021 06:22:19 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -438,24 +439,24 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/config","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3664' + - '3685' content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:03 GMT + - Thu, 25 Feb 2021 06:22:20 GMT expires: - '-1' pragma: @@ -487,9 +488,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -502,9 +503,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:04 GMT + - Thu, 25 Feb 2021 06:22:20 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -540,26 +541,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","kind":"app","location":"East - US","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-213.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2020-11-23T06:42:58.7933333","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"name":"mysitexxyzz(staging)","state":"Running","hostNames":["mysitexxyzz-staging.azurewebsites.net"],"webSpace":"rgname-EastUSwebspace","selfLink":"https://waws-prod-blu-143.api.azurewebsites.windows.net:454/subscriptions/00000000-0000-0000-0000-000000000000/webspaces/rgname-EastUSwebspace/sites/mysitexxyzz","repositorySiteName":"mysitexxyzz","owner":null,"usageState":"Normal","enabled":true,"adminEnabled":true,"enabledHostNames":["mysitexxyzz-staging.azurewebsites.net","mysitexxyzz-staging.scm.azurewebsites.net"],"siteProperties":{"metadata":null,"properties":[{"name":"LinuxFxVersion","value":""},{"name":"WindowsFxVersion","value":null}],"appSettings":null},"availabilityState":"Normal","sslCertificates":null,"csrs":[],"cers":null,"siteMode":null,"hostNameSslStates":[{"name":"mysitexxyzz-staging.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Standard"},{"name":"mysitexxyzz-staging.scm.azurewebsites.net","sslState":"Disabled","ipBasedSslResult":null,"virtualIP":null,"thumbprint":null,"toUpdate":null,"toUpdateIpBasedSsl":null,"ipBasedSslState":"NotConfigured","hostType":"Repository"}],"computeMode":null,"serverFarm":null,"serverFarmId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/serverfarms/myappserviceplan","reserved":false,"isXenon":false,"hyperV":false,"lastModifiedTimeUtc":"2021-02-25T06:22:22.55","storageRecoveryDefaultState":"Running","contentAvailabilityState":"Normal","runtimeAvailabilityState":"Normal","siteConfig":{"numberOfWorkers":null,"defaultDocuments":null,"netFrameworkVersion":null,"phpVersion":null,"pythonVersion":null,"nodeVersion":null,"powerShellVersion":null,"linuxFxVersion":null,"windowsFxVersion":null,"requestTracingEnabled":null,"remoteDebuggingEnabled":null,"remoteDebuggingVersion":null,"httpLoggingEnabled":null,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":null,"detailedErrorLoggingEnabled":null,"publishingUsername":null,"publishingPassword":null,"appSettings":null,"azureStorageAccounts":null,"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":null,"use32BitWorkerProcess":null,"webSocketsEnabled":null,"alwaysOn":null,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":null,"managedPipelineMode":null,"virtualApplications":null,"winAuthAdminState":null,"winAuthTenantState":null,"customAppPoolIdentityAdminState":null,"customAppPoolIdentityTenantState":null,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":null,"routingRules":null,"experiments":null,"limits":null,"autoHealEnabled":null,"autoHealRules":null,"tracingOptions":null,"vnetName":null,"vnetRouteAllEnabled":null,"vnetPrivatePortsCount":null,"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":null,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow - all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__13b4","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"20.49.104.14","possibleInboundIpAddresses":"20.49.104.14","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-213.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64","possibleOutboundIpAddresses":"52.146.80.201,52.146.80.224,52.146.80.233,52.146.80.240,52.146.80.254,52.146.81.59,52.146.82.252,52.146.83.22,52.146.83.64,52.146.81.74,52.146.81.101,52.146.81.141,52.146.81.155,52.146.81.240,52.146.81.254,52.146.82.7,52.146.82.8,52.146.82.17,52.146.82.61,52.146.82.81,52.146.82.87,52.146.82.136,52.146.82.188,52.146.82.209,52.146.82.221,52.146.82.243,52.146.82.244","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-213","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null}}' + all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":null,"http20Enabled":null,"minTlsVersion":null,"scmMinTlsVersion":null,"ftpsState":null,"preWarmedInstanceCount":null,"functionAppScaleLimit":null,"healthCheckPath":null,"fileChangeAuditEnabled":null,"functionsRuntimeScaleMonitoringEnabled":null,"websiteTimeZone":null,"minimumElasticInstanceCount":0},"deploymentId":"mysitexxyzz__3f44","trafficManagerHostNames":null,"sku":"Standard","scmSiteAlsoStopped":false,"targetSwapSlot":null,"hostingEnvironment":null,"hostingEnvironmentProfile":null,"clientAffinityEnabled":true,"clientCertEnabled":false,"clientCertMode":"Required","clientCertExclusionPaths":null,"hostNamesDisabled":false,"domainVerificationIdentifiers":null,"customDomainVerificationId":"55F2E4435A6748F0C3A4666505B3672446A9A9AEFDDC20F98EFEE4B5DCC7807E","kind":"app","inboundIpAddress":"40.71.11.133","possibleInboundIpAddresses":"40.71.11.133","ftpUsername":"mysitexxyzz__staging\\$mysitexxyzz__staging","ftpsHostName":"ftps://waws-prod-blu-143.ftp.azurewebsites.windows.net/site/wwwroot","outboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7","possibleOutboundIpAddresses":"40.71.11.133,23.101.132.11,40.114.52.253,137.135.64.181,40.114.50.7,40.114.15.207,137.135.71.113,40.114.53.155","containerSize":0,"dailyMemoryTimeQuota":0,"suspendedTill":null,"siteDisabledReason":0,"functionExecutionUnitsCache":null,"maxNumberOfWorkers":null,"homeStamp":"waws-prod-blu-143","cloningInfo":null,"hostingEnvironmentId":null,"tags":null,"resourceGroup":"rgname","defaultHostName":"mysitexxyzz-staging.azurewebsites.net","slotSwapStatus":null,"httpsOnly":false,"redundancyMode":"None","inProgressOperationId":null,"geoDistributions":null,"privateEndpointConnections":null,"buildVersion":null,"targetBuildVersion":null,"migrationState":null,"eligibleLogCategories":"AppServiceAppLogs,AppServiceAuditLogs,AppServiceConsoleLogs,AppServiceHTTPLogs,AppServiceIPSecAuditLogs,AppServicePlatformLogs,ScanLogs","storageAccountRequired":false}}' headers: cache-control: - no-cache content-length: - - '6121' + - '5999' content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:06 GMT + - Thu, 25 Feb 2021 06:22:25 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E6D55C0D5"' expires: - '-1' pragma: @@ -598,26 +599,26 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/config/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging","name":"mysitexxyzz/staging","type":"Microsoft.Web/sites/slots","location":"East - US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow + US","properties":{"numberOfWorkers":1,"defaultDocuments":["Default.htm","Default.html","Default.asp","index.htm","index.html","iisstart.htm","default.aspx","index.php","hostingstart.html"],"netFrameworkVersion":"v4.0","phpVersion":"5.6","pythonVersion":"","nodeVersion":"","powerShellVersion":"","linuxFxVersion":"","windowsFxVersion":null,"requestTracingEnabled":false,"remoteDebuggingEnabled":false,"remoteDebuggingVersion":"VS2019","httpLoggingEnabled":false,"azureMonitorLogCategories":null,"acrUseManagedIdentityCreds":false,"acrUserManagedIdentityID":null,"logsDirectorySizeLimit":35,"detailedErrorLoggingEnabled":false,"publishingUsername":"$mysitexxyzz__staging","publishingPassword":null,"appSettings":null,"azureStorageAccounts":{},"metadata":null,"connectionStrings":null,"machineKey":null,"handlerMappings":null,"documentRoot":null,"scmType":"ExternalGit","use32BitWorkerProcess":true,"webSocketsEnabled":true,"alwaysOn":false,"javaVersion":null,"javaContainer":null,"javaContainerVersion":null,"appCommandLine":"","managedPipelineMode":"Integrated","virtualApplications":[{"virtualPath":"/","physicalPath":"site\\wwwroot","preloadEnabled":false,"virtualDirectories":null}],"winAuthAdminState":0,"winAuthTenantState":0,"customAppPoolIdentityAdminState":false,"customAppPoolIdentityTenantState":false,"runtimeADUser":null,"runtimeADUserPassword":null,"loadBalancing":"LeastRequests","routingRules":[],"experiments":{"rampUpRules":[]},"limits":null,"autoHealEnabled":false,"autoHealRules":null,"tracingOptions":null,"vnetName":"","vnetRouteAllEnabled":false,"vnetPrivatePortsCount":0,"siteAuthEnabled":false,"siteAuthSettings":{"enabled":null,"configVersion":null,"unauthenticatedClientAction":null,"tokenStoreEnabled":null,"allowedExternalRedirectUrls":null,"defaultProvider":null,"clientId":null,"clientSecret":null,"clientSecretSettingName":null,"clientSecretCertificateThumbprint":null,"issuer":null,"allowedAudiences":null,"additionalLoginParams":null,"isAadAutoProvisioned":false,"aadClaimsAuthorization":null,"googleClientId":null,"googleClientSecret":null,"googleClientSecretSettingName":null,"googleOAuthScopes":null,"facebookAppId":null,"facebookAppSecret":null,"facebookAppSecretSettingName":null,"facebookOAuthScopes":null,"gitHubClientId":null,"gitHubClientSecret":null,"gitHubClientSecretSettingName":null,"gitHubOAuthScopes":null,"twitterConsumerKey":null,"twitterConsumerSecret":null,"twitterConsumerSecretSettingName":null,"microsoftAccountClientId":null,"microsoftAccountClientSecret":null,"microsoftAccountClientSecretSettingName":null,"microsoftAccountOAuthScopes":null},"cors":null,"push":null,"apiDefinition":null,"apiManagementConfig":null,"autoSwapSlotName":null,"localMySqlEnabled":false,"managedServiceIdentityId":null,"xManagedServiceIdentityId":null,"ipSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictions":[{"ipAddress":"Any","action":"Allow","priority":1,"name":"Allow all","description":"Allow all access"}],"scmIpSecurityRestrictionsUseMain":false,"http20Enabled":true,"minTlsVersion":"1.2","scmMinTlsVersion":"1.0","ftpsState":"AllAllowed","preWarmedInstanceCount":0,"functionAppScaleLimit":0,"healthCheckPath":null,"fileChangeAuditEnabled":false,"functionsRuntimeScaleMonitoringEnabled":false,"websiteTimeZone":null,"minimumElasticInstanceCount":0}}' headers: cache-control: - no-cache content-length: - - '3660' + - '3681' content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:09 GMT + - Thu, 25 Feb 2021 06:22:27 GMT etag: - - '"1D6C163E1C85295"' + - '"1D70B3E93C10F60"' expires: - '-1' pragma: @@ -635,7 +636,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1191' + - '1195' x-powered-by: - ASP.NET status: @@ -656,9 +657,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web","name":"mysitexxyzz","type":"Microsoft.Web/sites/sourcecontrols","location":"East @@ -671,9 +672,9 @@ interactions: content-type: - application/json date: - - Mon, 23 Nov 2020 06:44:10 GMT + - Thu, 25 Feb 2021 06:22:28 GMT etag: - - '"1D6C1640BE29F60"' + - '"1D70B3E9705C015"' expires: - '-1' pragma: @@ -691,7 +692,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1190' + - '1194' x-powered-by: - ASP.NET status: @@ -709,9 +710,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/start?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/start?api-version=2020-09-01 response: body: string: '' @@ -721,7 +722,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:10 GMT + - Thu, 25 Feb 2021 06:22:29 GMT expires: - '-1' pragma: @@ -735,7 +736,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1199' x-powered-by: - ASP.NET status: @@ -753,9 +754,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/restart?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/restart?api-version=2020-09-01 response: body: string: '' @@ -765,7 +766,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:11 GMT + - Thu, 25 Feb 2021 06:22:30 GMT expires: - '-1' pragma: @@ -779,7 +780,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1198' x-powered-by: - ASP.NET status: @@ -797,9 +798,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/stop?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/stop?api-version=2020-09-01 response: body: string: '' @@ -809,7 +810,7 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:12 GMT + - Thu, 25 Feb 2021 06:22:30 GMT expires: - '-1' pragma: @@ -823,7 +824,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1197' x-powered-by: - ASP.NET status: @@ -841,9 +842,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging/sourcecontrols/web?api-version=2020-09-01 response: body: string: '' @@ -853,9 +854,9 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:22 GMT + - Thu, 25 Feb 2021 06:22:41 GMT etag: - - '"1D6C1640E5029F5"' + - '"1D70B3E998DBD80"' expires: - '-1' pragma: @@ -869,7 +870,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14999' x-powered-by: - ASP.NET status: @@ -887,9 +888,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz/slots/staging?api-version=2020-09-01 response: body: string: '' @@ -899,9 +900,9 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:31 GMT + - Thu, 25 Feb 2021 06:22:52 GMT etag: - - '"1D6C1640E5029F5"' + - '"1D70B3E998DBD80"' expires: - '-1' pragma: @@ -915,7 +916,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14998' x-powered-by: - ASP.NET status: @@ -933,9 +934,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-web/1.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-web/2.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2019-08-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Web/sites/mysitexxyzz?api-version=2020-09-01 response: body: string: '' @@ -945,9 +946,9 @@ interactions: content-length: - '0' date: - - Mon, 23 Nov 2020 06:44:37 GMT + - Thu, 25 Feb 2021 06:23:02 GMT etag: - - '"1D6C163C412532B"' + - '"1D70B3E5140D440"' expires: - '-1' pragma: @@ -961,7 +962,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14995' + - '14997' x-powered-by: - ASP.NET status: From bf18e87038b3fab380413704b297d2f8bb9ed423 Mon Sep 17 00:00:00 2001 From: msyyc <70930885+msyyc@users.noreply.github.com> Date: Fri, 26 Feb 2021 14:48:29 +0800 Subject: [PATCH 17/30] version (#16959) --- .../azure-mgmt-digitaltwins/CHANGELOG.md | 3 +++ .../azure/mgmt/digitaltwins/_version.py | 2 +- .../digitaltwins/v2020_03_01_preview/_version.py | 13 +++++++++++++ .../azure/mgmt/digitaltwins/v2020_10_31/_version.py | 13 +++++++++++++ .../azure/mgmt/digitaltwins/v2020_12_01/_version.py | 13 +++++++++++++ 5 files changed, 43 insertions(+), 1 deletion(-) create mode 100644 sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_03_01_preview/_version.py create mode 100644 sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_10_31/_version.py create mode 100644 sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_12_01/_version.py diff --git a/sdk/digitaltwins/azure-mgmt-digitaltwins/CHANGELOG.md b/sdk/digitaltwins/azure-mgmt-digitaltwins/CHANGELOG.md index 788daf0a08ea..d30326757154 100644 --- a/sdk/digitaltwins/azure-mgmt-digitaltwins/CHANGELOG.md +++ b/sdk/digitaltwins/azure-mgmt-digitaltwins/CHANGELOG.md @@ -1,5 +1,8 @@ # Release History +## 6.0.0b2 (2021-02-26) +* Fix version problem. + ## 6.0.0b1 (2021-01-07) This is beta preview version. diff --git a/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/_version.py b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/_version.py index 8e46c21013c7..eb995b3fdcdc 100644 --- a/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/_version.py +++ b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/_version.py @@ -9,5 +9,5 @@ # regenerated. # -------------------------------------------------------------------------- -VERSION = "6.0.0b1" +VERSION = "6.0.0b2" diff --git a/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_03_01_preview/_version.py b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_03_01_preview/_version.py new file mode 100644 index 000000000000..eb995b3fdcdc --- /dev/null +++ b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_03_01_preview/_version.py @@ -0,0 +1,13 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. +# -------------------------------------------------------------------------- + +VERSION = "6.0.0b2" + diff --git a/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_10_31/_version.py b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_10_31/_version.py new file mode 100644 index 000000000000..eb995b3fdcdc --- /dev/null +++ b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_10_31/_version.py @@ -0,0 +1,13 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. +# -------------------------------------------------------------------------- + +VERSION = "6.0.0b2" + diff --git a/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_12_01/_version.py b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_12_01/_version.py new file mode 100644 index 000000000000..eb995b3fdcdc --- /dev/null +++ b/sdk/digitaltwins/azure-mgmt-digitaltwins/azure/mgmt/digitaltwins/v2020_12_01/_version.py @@ -0,0 +1,13 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +# +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is +# regenerated. +# -------------------------------------------------------------------------- + +VERSION = "6.0.0b2" + From 14558bdab1d462732b80b40455f73d75bb447a7c Mon Sep 17 00:00:00 2001 From: Scott Beddall <45376673+scbedd@users.noreply.github.com> Date: Fri, 26 Feb 2021 10:25:06 -0800 Subject: [PATCH 18/30] update documention in depends section of eng_sys_checks.md (#16967) * update documention in depends section of eng_sys_checks.md --- doc/eng_sys_checks.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/doc/eng_sys_checks.md b/doc/eng_sys_checks.md index 416894714eac..05142eb5ffdf 100644 --- a/doc/eng_sys_checks.md +++ b/doc/eng_sys_checks.md @@ -48,7 +48,7 @@ Analyze job in both nightly CI and pull request validation pipeline runs a set o Change log verification is added to ensure package has valid change log for current version. Guidelines to properly maintain the change log is documented [here](https://github.com/Azure/azure-sdk-for-python/blob/master/doc/) ## PR Validation Checks -Each pull request runs various tests using `pytest` in addition to all the tests mentioned above in analyze check. Pull request validation performs 3 different types of test: `whl, sdist and depends`. Following section explains the purpose of each of these tests and how to execute them locally. All pull requests are validated on multiple python versions across different platforms and below is the test matrix for pull request. +Each pull request runs various tests using `pytest` in addition to all the tests mentioned above in analyze check. Pull request validation performs 3 different types of test: `whl, sdist and depends`. The following section explains the purpose of each of these tests and how to execute them locally. All pull requests are validated on multiple python versions across different platforms. Find the test matrix below. |`Python Version`|`Platform` | @@ -73,8 +73,8 @@ This test installs sdist of the package being tested and runs all tests cases in 2. Run following command ``tox -e sdist -c ../../../eng/tox/tox.ini`` -####depends -This test is to ensure all modules in the package being tested can be successfully imported. This is to ensure all package requirement is properly set in setup.py as well as to ensure modules are imported using valid namespace. This test install the package and it's required packages and executes `from import *`. For e.g. `from azure.core import *`. +#### depends +The `depends` check ensures all modules in a target package can be successfully imported. Actually installing and importing will verify that all package requirements are properly set in setup.py and that the `__all__` set for the package is properly defined. This test installs the package and its required packages, then executes `from import *`. For example from `azure-core`, the following would be invoked: `from azure.core import *`. Following is the command to run this test environment locally. From 8cb6c41b46390b1f2d4e89709e21eb85a029597d Mon Sep 17 00:00:00 2001 From: Craig Treasure Date: Fri, 26 Feb 2021 15:34:30 -0800 Subject: [PATCH 19/30] Update azure-core minimum version (#16968) - This change updates the minimum version of Azure Core to 1.4.0 to make sure we get a package version that includes AzureKeyCredential to fix the nightly release builds. --- sdk/mixedreality/azure-mixedreality-authentication/setup.py | 2 +- shared_requirements.txt | 3 +-- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/sdk/mixedreality/azure-mixedreality-authentication/setup.py b/sdk/mixedreality/azure-mixedreality-authentication/setup.py index 0384e23bf7c8..592f79fb49a5 100644 --- a/sdk/mixedreality/azure-mixedreality-authentication/setup.py +++ b/sdk/mixedreality/azure-mixedreality-authentication/setup.py @@ -66,7 +66,7 @@ 'azure.mixedreality' ]), install_requires=[ - 'azure-core<2.0.0,>=1.2.2', + 'azure-core<2.0.0,>=1.4.0', 'msrest>=0.5.0' ], extras_require={ diff --git a/shared_requirements.txt b/shared_requirements.txt index a9cffd7596bc..4c5403b260e5 100644 --- a/shared_requirements.txt +++ b/shared_requirements.txt @@ -195,5 +195,4 @@ opentelemetry-sdk==0.17b0 #override azure-monitor-opentelemetry-exporter opentelemetry-sdk==1.0.0rc1 #override azure-core-tracing-opentelemetry opentelemetry-api==0.17b0 #override azure-identity six>=1.12.0 -#override azure-ai-formrecognizer -#override azure-ai-metricsadvisor +#override azure-mixedreality-authentication azure-core<2.0.0,>=1.4.0 From 818809031b073df2b1a1ddb03c4179530dd4e80c Mon Sep 17 00:00:00 2001 From: Scott Beddall <45376673+scbedd@users.noreply.github.com> Date: Fri, 26 Feb 2021 17:38:47 -0800 Subject: [PATCH 20/30] the previous filter was erroneously filtering out real files. (#16978) --- eng/pipelines/templates/stages/archetype-python-release.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/eng/pipelines/templates/stages/archetype-python-release.yml b/eng/pipelines/templates/stages/archetype-python-release.yml index 8e2a3748f908..916a0fb27a0e 100644 --- a/eng/pipelines/templates/stages/archetype-python-release.yml +++ b/eng/pipelines/templates/stages/archetype-python-release.yml @@ -286,8 +286,8 @@ stages: $packageDirectory = "${{artifact.name}}".Replace("_", "-") echo "##vso[task.setvariable variable=Package.Name]$packageDirectory" - pwsh: | - $fileCount = (Get-ChildItem $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$packageDirectory -Filter $packageDirectory-[0-9]*.[0-9]*.[0-9]*a[0-9]* | Measure-Object).Count - + $fileCount = (Get-ChildItem $(Pipeline.Workspace)/${{parameters.ArtifactName}}/$(Package.Name) | ? {$_.Name -match "-[0-9]*.[0-9]*.[0-9]*a[0-9]*" } | Measure-Object).Count + if ($fileCount -eq 0) { Write-Host "No alpha packages for ${{artifact.safeName}} to publish." exit 0 From 061b26824758451d99296bff27ab905f33c153eb Mon Sep 17 00:00:00 2001 From: Azure SDK Bot <53356347+azure-sdk@users.noreply.github.com> Date: Fri, 26 Feb 2021 18:46:43 -0800 Subject: [PATCH 21/30] Update Prepare-Release script (#16976) - Remove BuildType parameter as we can default it from package properties - Stop passing BuildType and GroupId and instead defaul them from package properties - Enable StrictMode to help identify potential errors - Start passing sdktype and isnewsdk properties to devops script - Sync latest changes with devops work item to fix a couple bugs Co-authored-by: Wes Haggard --- .../Helpers/DevOps-WorkItem-Helpers.ps1 | 68 +++++------ eng/common/scripts/Prepare-Release.ps1 | 111 ++++++++++-------- eng/common/scripts/common.ps1 | 4 +- eng/common/scripts/logging.ps1 | 7 +- 4 files changed, 95 insertions(+), 95 deletions(-) diff --git a/eng/common/scripts/Helpers/DevOps-WorkItem-Helpers.ps1 b/eng/common/scripts/Helpers/DevOps-WorkItem-Helpers.ps1 index 327366c7a917..367efb090cd8 100644 --- a/eng/common/scripts/Helpers/DevOps-WorkItem-Helpers.ps1 +++ b/eng/common/scripts/Helpers/DevOps-WorkItem-Helpers.ps1 @@ -127,7 +127,6 @@ function FindPackageWorkItem($lang, $packageName, $version, $outputCommand = $tr $fields += "ID" $fields += "State" $fields += "System.AssignedTo" - $fields += "Microsoft.VSTS.Common.StateChangeDate" $fields += "Parent" $fields += "Language" $fields += "Package" @@ -265,19 +264,6 @@ function CreateWorkItem($title, $type, $iteration, $area, $fields, $assignedTo, return $workItem } -function ResetWorkItemState($workItem, $resetState = $null, $outputCommand = $true) -{ - if (!$resetState -or $resetState -eq "New") { - $resetState = "Next Release Unknown" - } - if ($workItem.fields["System.State"] -ne $resetState) - { - Write-Verbose "Resetting state for [$($workItem.id)] from '$($workItem.fields['System.State'])' to '$resetState'" - return UpdateWorkItem $workItem.id -state $resetState -outputCommand $outputCommand - } - return $workItem -} - function UpdateWorkItem($id, $fields, $title, $state, $assignedTo, $outputCommand = $true) { $parameters = $ReleaseDevOpsCommonParameters @@ -305,6 +291,30 @@ function UpdatePackageWorkItemReleaseState($id, $state, $releaseType, $outputCom return UpdateWorkItem -id $id -state $state -fields $fields -outputCommand $outputCommand } +function FindOrCreateClonePackageWorkItem($lang, $pkg, $verMajorMinor, $outputCommand = $false) +{ + $workItem = FindPackageWorkItem -lang $lang -packageName $pkg.Package -version $verMajorMinor -includeClosed $true -outputCommand $outputCommand + + if (!$workItem) { + $latestVersionItem = FindLatestPackageWorkItem -lang $lang -packageName $pkg.Package -outputCommand $outputCommand + $assignedTo = "me" + if ($latestVersionItem) { + Write-Verbose "Copying data from latest matching [$($latestVersionItem.id)] with version $($latestVersionItem.fields["Custom.PackageVersionMajorMinor"])" + if ($latestVersionItem.fields["System.AssignedTo"]) { + $assignedTo = $latestVersionItem.fields["System.AssignedTo"]["uniqueName"] + } + $pkg.DisplayName = $latestVersionItem.fields["Custom.PackageDisplayName"] + $pkg.ServiceName = $latestVersionItem.fields["Custom.ServiceName"] + if (!$pkg.RepoPath -and $pkg.RepoPath -ne "NA" -and $pkg.fields["Custom.PackageRepoPath"]) { + $pkg.RepoPath = $pkg.fields["Custom.PackageRepoPath"] + } + } + $workItem = CreateOrUpdatePackageWorkItem $lang $pkg $verMajorMinor -existingItem $null -assignedTo $assignedTo -outputCommand $outputCommand + } + + return $workItem +} + function CreateOrUpdatePackageWorkItem($lang, $pkg, $verMajorMinor, $existingItem, $assignedTo = $null, $outputCommand = $true) { if (!$lang -or !$pkg -or !$verMajorMinor) { @@ -347,14 +357,18 @@ function CreateOrUpdatePackageWorkItem($lang, $pkg, $verMajorMinor, $existingIte Write-Host "At least field $changedField ($($existingItem.fields[$changedField])) changed so updating." } - $beforeState = $existingItem.fields["System.State"] - if ($changedField) { + $beforeState = $existingItem.fields["System.State"] + # Need to set to New to be able to update $existingItem = UpdateWorkItem -id $existingItem.id -fields $fields -title $title -state "New" -assignedTo $assignedTo -outputCommand $outputCommand Write-Host "[$($existingItem.id)]$lang - $pkgName($verMajorMinor) - Updated" + + if ($beforeState -ne $existingItem.fields['System.State']) { + Write-Verbose "Resetting state for [$($existingItem.id)] from '$($existingItem.fields['System.State'])' to '$beforeState'" + $existingItem = UpdateWorkItem $existingItem.id -state $beforeState -outputCommand $outputCommand + } } - $existingItem = ResetWorkItemState $existingItem $beforeState -outputCommand $outputCommand $newparentItem = FindOrCreatePackageGroupParent $serviceName $pkgDisplayName -outputCommand $false UpdateWorkItemParent $existingItem $newParentItem -outputCommand $outputCommand @@ -363,7 +377,6 @@ function CreateOrUpdatePackageWorkItem($lang, $pkg, $verMajorMinor, $existingIte $parentItem = FindOrCreatePackageGroupParent $serviceName $pkgDisplayName -outputCommand $false $workItem = CreateWorkItem $title "Package" "Release" "Release" $fields $assignedTo $parentItem.id -outputCommand $outputCommand - $workItem = ResetWorkItemState $workItem -outputCommand $outputCommand Write-Host "[$($workItem.id)]$lang - $pkgName($verMajorMinor) - Created" return $workItem } @@ -752,25 +765,6 @@ function UpdatePackageVersions($pkgWorkItem, $plannedVersions, $shippedVersions) "value": "$shippedPackages" } "@ - - # If we shipped a version after we set "In Release" state then reset the state to "Next Release Unknown" - if ($pkgWorkItem.fields["System.State"] -eq "In Release") - { - $lastShippedDate = [DateTime]$newShippedVersions[0].Date - $markedInReleaseDate = ([DateTime]$pkgWorkItem.fields["Microsoft.VSTS.Common.StateChangeDate"]) - - # We just shipped so lets set the state to "Next Release Unknown" - if ($markedInReleaseDate -le $lastShippedDate) - { - $fieldUpdates += @' -{ - "op": "replace", - "path": "/fields/State", - "value": "Next Release Unknown" -} -'@ - } - } } # Full merged version set diff --git a/eng/common/scripts/Prepare-Release.ps1 b/eng/common/scripts/Prepare-Release.ps1 index dded6a346343..1da047449e34 100644 --- a/eng/common/scripts/Prepare-Release.ps1 +++ b/eng/common/scripts/Prepare-Release.ps1 @@ -2,60 +2,67 @@ [CmdletBinding()] param( - [Parameter(Mandatory=$true)] - [string]$PackageName, - [string]$ServiceDirectory, - [string]$ReleaseDate, # Pass Date in the form MM/dd/yyyy" - [string]$BuildType # For Java + [Parameter(Mandatory = $true)] + [string]$PackageName, + [string]$ServiceDirectory, + [string]$ReleaseDate # Pass Date in the form MM/dd/yyyy" ) +Set-StrictMode -Version 3 . ${PSScriptRoot}\common.ps1 function Get-ReleaseDay($baseDate) { - # Find first friday - while ($baseDate.DayOfWeek -ne 5) - { - $baseDate = $baseDate.AddDays(1) - } - - # Go to Tuesday - $baseDate = $baseDate.AddDays(4) - - return $baseDate; + # Find first friday + while ($baseDate.DayOfWeek -ne 5) + { + $baseDate = $baseDate.AddDays(1) + } + + # Go to Tuesday + $baseDate = $baseDate.AddDays(4) + + return $baseDate; } $ErrorPreference = 'Stop' $packageProperties = Get-PkgProperties -PackageName $PackageName -ServiceDirectory $serviceDirectory +if (!$packageProperties) +{ + Write-Error "Could not find a package with name [ $packageName ], please verify the package name matches the exact name." + exit 1 +} + +Write-Host "Package Name [ $($packageProperties.Name) ]" Write-Host "Source directory [ $serviceDirectory ]" if (!$ReleaseDate) { - $currentDate = Get-Date - $thisMonthReleaseDate = Get-ReleaseDay((Get-Date -Day 1)); - $nextMonthReleaseDate = Get-ReleaseDay((Get-Date -Day 1).AddMonths(1)); - - if ($thisMonthReleaseDate -ge $currentDate) - { - # On track for this month release - $ParsedReleaseDate = $thisMonthReleaseDate - } - elseif ($currentDate.Day -lt 15) - { - # Catching up to this month release - $ParsedReleaseDate = $currentDate - } - else - { - # Next month release - $ParsedReleaseDate = $nextMonthReleaseDate - } + $currentDate = Get-Date + $thisMonthReleaseDate = Get-ReleaseDay((Get-Date -Day 1)); + $nextMonthReleaseDate = Get-ReleaseDay((Get-Date -Day 1).AddMonths(1)); + + if ($thisMonthReleaseDate -ge $currentDate) + { + # On track for this month release + $ParsedReleaseDate = $thisMonthReleaseDate + } + elseif ($currentDate.Day -lt 15) + { + # Catching up to this month release + $ParsedReleaseDate = $currentDate + } + else + { + # Next month release + $ParsedReleaseDate = $nextMonthReleaseDate + } } else { - $ParsedReleaseDate = [datetime]$ReleaseDate + $ParsedReleaseDate = [datetime]$ReleaseDate } $releaseDateString = $ParsedReleaseDate.ToString("MM/dd/yyyy") @@ -70,40 +77,42 @@ $newVersion = Read-Host -Prompt "Input the new version, or press Enter to use us if (!$newVersion) { - $newVersion = $currentProjectVersion; + $newVersion = $currentProjectVersion; } $newVersionParsed = [AzureEngSemanticVersion]::ParseVersionString($newVersion) if ($null -eq $newVersionParsed) { - Write-Error "Invalid version $newVersion. Version must follow standard SemVer rules, see https://aka.ms/azsdk/engsys/packageversioning" - exit 1 + Write-Error "Invalid version $newVersion. Version must follow standard SemVer rules, see https://aka.ms/azsdk/engsys/packageversioning" + exit 1 } if (Test-Path "Function:SetPackageVersion") { - SetPackageVersion -PackageName $packageProperties.Name -Version $newVersion -ServiceDirectory $serviceDirectory -ReleaseDate $releaseDateString ` - -BuildType $BuildType -GroupId $packageProperties.Group + SetPackageVersion -PackageName $packageProperties.Name -Version $newVersion -ServiceDirectory $serviceDirectory -ReleaseDate $releaseDateString ` + -PackageProperties $packageProperties } else { - LogError "The function 'SetPackageVersion' was not found.` + LogError "The function 'SetPackageVersion' was not found.` Make sure it is present in eng/scripts/Language-Settings.ps1.` See https://github.com/Azure/azure-sdk-tools/blob/master/doc/common/common_engsys.md#code-structure" - exit 1 + exit 1 } &$EngCommonScriptsDir/Update-DevOps-Release-WorkItem.ps1 ` --language $LanguageDisplayName ` --packageName $packageProperties.Name ` --version $newVersion ` --plannedDate $releaseDateString ` --packageRepoPath $packageProperties.serviceDirectory + -language $LanguageDisplayName ` + -packageName $packageProperties.Name ` + -version $newVersion ` + -plannedDate $releaseDateString ` + -packageRepoPath $packageProperties.serviceDirectory ` + -packageType $packageProperties.SDKType ` + -packageNewLibrary $packageProperties.IsNewSDK git diff -s --exit-code $packageProperties.DirectoryPath if ($LASTEXITCODE -ne 0) { - git status - Write-Host "Some changes were made to the repo source" -ForegroundColor Green - Write-Host "Submit a pull request with the necessary changes to the repo" -ForegroundColor Green -} \ No newline at end of file + git status + Write-Host "Some changes were made to the repo source" -ForegroundColor Green + Write-Host "Submit a pull request with the necessary changes to the repo" -ForegroundColor Green +} diff --git a/eng/common/scripts/common.ps1 b/eng/common/scripts/common.ps1 index 8ccf27b0ba4f..52c6b9d48f41 100644 --- a/eng/common/scripts/common.ps1 +++ b/eng/common/scripts/common.ps1 @@ -25,12 +25,12 @@ if (Test-Path $EngScriptsLanguageSettings) { . $EngScriptsLanguageSettings } -if (-not $LanguageShort) +if (!(Get-Variable -Name "LangaugeShort" -ValueOnly -ErrorAction "Ignore")) { $LangaugeShort = $Language } -if (-not $LanguageDisplayName) +if (!(Get-Variable -Name "LanguageDisplayName" -ValueOnly -ErrorAction "Ignore")) { $LanguageDisplayName = $Language } diff --git a/eng/common/scripts/logging.ps1 b/eng/common/scripts/logging.ps1 index 9b327fd81c19..5266d9614d67 100644 --- a/eng/common/scripts/logging.ps1 +++ b/eng/common/scripts/logging.ps1 @@ -1,7 +1,4 @@ -if (-not $isDevOpsRun) -{ - $isDevOpsRun = ($null -ne $env:SYSTEM_TEAMPROJECTID) -} +$isDevOpsRun = ($null -ne $env:SYSTEM_TEAMPROJECTID) function LogWarning { @@ -37,4 +34,4 @@ function LogDebug { Write-Debug "$args" } -} \ No newline at end of file +} From c6580d9ca551930967f8e807becb4876338bc938 Mon Sep 17 00:00:00 2001 From: zhangyan133 <77086185+zhangyan133@users.noreply.github.com> Date: Mon, 1 Mar 2021 10:04:13 +0800 Subject: [PATCH 22/30] T2 servicefabricmanagedclusters 2021 02 26 (#16958) * CodeGen from PR 13170 in Azure/azure-rest-api-specs changetotrack2 (#13170) * changetotrack2 * new readme.python.md * some modification Co-authored-by: Yan Zhang (WICRESOFT NORTH AMERICA LTD) * test,version,CHANGELOG * modify changelog&version * modify changelog * delete repetitive usage Co-authored-by: SDKAuto Co-authored-by: Yan Zhang (WICRESOFT NORTH AMERICA LTD) --- .../CHANGELOG.md | 5 + .../MANIFEST.in | 5 + .../README.md | 28 + .../azure/__init__.py | 1 + .../azure/mgmt/__init__.py | 1 + .../servicefabricmanagedclusters/__init__.py | 19 + .../_configuration.py | 71 + .../_metadata.json | 67 + ...bric_managed_clusters_management_client.py | 99 + .../servicefabricmanagedclusters/_version.py | 9 + .../aio/__init__.py | 10 + .../aio/_configuration.py | 67 + ...bric_managed_clusters_management_client.py | 93 + .../aio/operations/__init__.py | 25 + .../_application_type_versions_operations.py | 544 +++ .../_application_types_operations.py | 453 +++ .../operations/_applications_operations.py | 517 +++ .../_managed_clusters_operations.py | 561 +++ .../aio/operations/_node_types_operations.py | 902 +++++ .../aio/operations/_operations.py | 107 + .../aio/operations/_services_operations.py | 547 +++ .../models/__init__.py | 276 ++ .../models/_models.py | 3134 +++++++++++++++ .../models/_models_py3.py | 3442 +++++++++++++++++ ...anaged_clusters_management_client_enums.py | 231 ++ .../operations/__init__.py | 25 + .../_application_type_versions_operations.py | 555 +++ .../_application_types_operations.py | 463 +++ .../operations/_applications_operations.py | 528 +++ .../_managed_clusters_operations.py | 573 +++ .../operations/_node_types_operations.py | 919 +++++ .../operations/_operations.py | 112 + .../operations/_services_operations.py | 558 +++ .../servicefabricmanagedclusters/py.typed | 1 + .../sdk_packaging.toml | 8 + .../setup.cfg | 2 + .../setup.py | 91 + sdk/servicefabricmanagedclusters/ci.yml | 35 + 38 files changed, 15084 insertions(+) create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/CHANGELOG.md create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/MANIFEST.in create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/README.md create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_configuration.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_metadata.json create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_service_fabric_managed_clusters_management_client.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_version.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_configuration.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_service_fabric_managed_clusters_management_client.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_type_versions_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_types_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_applications_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_managed_clusters_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_node_types_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_services_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models_py3.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_service_fabric_managed_clusters_management_client_enums.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/__init__.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_type_versions_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_types_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_applications_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_managed_clusters_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_node_types_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_services_operations.py create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/py.typed create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/sdk_packaging.toml create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.cfg create mode 100644 sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.py create mode 100644 sdk/servicefabricmanagedclusters/ci.yml diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/CHANGELOG.md b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/CHANGELOG.md new file mode 100644 index 000000000000..f8121c11f8af --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/CHANGELOG.md @@ -0,0 +1,5 @@ +# Release History + +## 1.0.0b1 (2021-02-26) + +* Initial Release diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/MANIFEST.in b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/MANIFEST.in new file mode 100644 index 000000000000..a3cb07df8765 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/MANIFEST.in @@ -0,0 +1,5 @@ +recursive-include tests *.py *.yaml +include *.md +include azure/__init__.py +include azure/mgmt/__init__.py + diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/README.md b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/README.md new file mode 100644 index 000000000000..6f74019715d8 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/README.md @@ -0,0 +1,28 @@ +# Microsoft Azure SDK for Python + +This is the Microsoft Azure Servicefabricmanagedclusters Management Client Library. +This package has been tested with Python 2.7, 3.5, 3.6, 3.7 and 3.8. +For a more complete view of Azure libraries, see the [azure sdk python release](https://aka.ms/azsdk/python/all). + + +# Usage + + +To learn how to use this package, see the [quickstart guide](https://aka.ms/azsdk/python/mgmt) + + + +For docs and references, see [Python SDK References](https://docs.microsoft.com/python/api/overview/azure/) +Code samples for this package can be found at [Servicefabricmanagedclusters Management](https://docs.microsoft.com/samples/browse/?languages=python&term=Getting%20started%20-%20Managing&terms=Getting%20started%20-%20Managing) on docs.microsoft.com. +Additional code samples for different Azure services are available at [Samples Repo](https://aka.ms/azsdk/python/mgmt/samples) + + +# Provide Feedback + +If you encounter any bugs or have suggestions, please file an issue in the +[Issues](https://github.com/Azure/azure-sdk-for-python/issues) +section of the project. + + +![Impressions](https://azure-sdk-impressions.azurewebsites.net/api/impressions/azure-sdk-for-python%2Fazure-mgmt-servicefabricmanagedclusters%2FREADME.png) + diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/__init__.py new file mode 100644 index 000000000000..0260537a02bb --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/__init__.py @@ -0,0 +1 @@ +__path__ = __import__('pkgutil').extend_path(__path__, __name__) \ No newline at end of file diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/__init__.py new file mode 100644 index 000000000000..0260537a02bb --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/__init__.py @@ -0,0 +1 @@ +__path__ = __import__('pkgutil').extend_path(__path__, __name__) \ No newline at end of file diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/__init__.py new file mode 100644 index 000000000000..9a2945417823 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/__init__.py @@ -0,0 +1,19 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._service_fabric_managed_clusters_management_client import ServiceFabricManagedClustersManagementClient +from ._version import VERSION + +__version__ = VERSION +__all__ = ['ServiceFabricManagedClustersManagementClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_configuration.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_configuration.py new file mode 100644 index 000000000000..975f57d040a5 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_configuration.py @@ -0,0 +1,71 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +from ._version import VERSION + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + + from azure.core.credentials import TokenCredential + + +class ServiceFabricManagedClustersManagementClientConfiguration(Configuration): + """Configuration for ServiceFabricManagedClustersManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The customer subscription identifier. + :type subscription_id: str + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(ServiceFabricManagedClustersManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2021-01-01-preview" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-servicefabricmanagedclusters/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_metadata.json b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_metadata.json new file mode 100644 index 000000000000..b80565ec1466 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_metadata.json @@ -0,0 +1,67 @@ +{ + "chosen_version": "2021-01-01-preview", + "total_api_version_list": ["2021-01-01-preview"], + "client": { + "name": "ServiceFabricManagedClustersManagementClient", + "filename": "_service_fabric_managed_clusters_management_client", + "description": "Service Fabric Managed Clusters Management Client.", + "base_url": "\u0027https://management.azure.com\u0027", + "custom_base_url": null, + "azure_arm": true, + "has_lro_operations": true, + "client_side_validation": true + }, + "global_parameters": { + "sync": { + "credential": { + "signature": "credential, # type: \"TokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials.TokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The customer subscription identifier.", + "docstring_type": "str", + "required": true + } + }, + "async": { + "credential": { + "signature": "credential, # type: \"AsyncTokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The customer subscription identifier.", + "docstring_type": "str", + "required": true + } + }, + "constant": { + }, + "call": "credential, subscription_id" + }, + "config": { + "credential": true, + "credential_scopes": ["https://management.azure.com/.default"], + "credential_default_policy_type": "BearerTokenCredentialPolicy", + "credential_default_policy_type_has_async_version": true, + "credential_key_header_name": null + }, + "operation_groups": { + "application_types": "ApplicationTypesOperations", + "application_type_versions": "ApplicationTypeVersionsOperations", + "applications": "ApplicationsOperations", + "services": "ServicesOperations", + "managed_clusters": "ManagedClustersOperations", + "operations": "Operations", + "node_types": "NodeTypesOperations" + }, + "operation_mixins": { + }, + "sync_imports": "None", + "async_imports": "None" +} \ No newline at end of file diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_service_fabric_managed_clusters_management_client.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_service_fabric_managed_clusters_management_client.py new file mode 100644 index 000000000000..c990f1790a6d --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_service_fabric_managed_clusters_management_client.py @@ -0,0 +1,99 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.mgmt.core import ARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + + from azure.core.credentials import TokenCredential + +from ._configuration import ServiceFabricManagedClustersManagementClientConfiguration +from .operations import ApplicationTypesOperations +from .operations import ApplicationTypeVersionsOperations +from .operations import ApplicationsOperations +from .operations import ServicesOperations +from .operations import ManagedClustersOperations +from .operations import Operations +from .operations import NodeTypesOperations +from . import models + + +class ServiceFabricManagedClustersManagementClient(object): + """Service Fabric Managed Clusters Management Client. + + :ivar application_types: ApplicationTypesOperations operations + :vartype application_types: service_fabric_managed_clusters_management_client.operations.ApplicationTypesOperations + :ivar application_type_versions: ApplicationTypeVersionsOperations operations + :vartype application_type_versions: service_fabric_managed_clusters_management_client.operations.ApplicationTypeVersionsOperations + :ivar applications: ApplicationsOperations operations + :vartype applications: service_fabric_managed_clusters_management_client.operations.ApplicationsOperations + :ivar services: ServicesOperations operations + :vartype services: service_fabric_managed_clusters_management_client.operations.ServicesOperations + :ivar managed_clusters: ManagedClustersOperations operations + :vartype managed_clusters: service_fabric_managed_clusters_management_client.operations.ManagedClustersOperations + :ivar operations: Operations operations + :vartype operations: service_fabric_managed_clusters_management_client.operations.Operations + :ivar node_types: NodeTypesOperations operations + :vartype node_types: service_fabric_managed_clusters_management_client.operations.NodeTypesOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The customer subscription identifier. + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://management.azure.com' + self._config = ServiceFabricManagedClustersManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.application_types = ApplicationTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_type_versions = ApplicationTypeVersionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.applications = ApplicationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.services = ServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.managed_clusters = ManagedClustersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.node_types = NodeTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> ServiceFabricManagedClustersManagementClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_version.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_version.py new file mode 100644 index 000000000000..e5754a47ce68 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/_version.py @@ -0,0 +1,9 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +VERSION = "1.0.0b1" diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/__init__.py new file mode 100644 index 000000000000..ee979dc7fea8 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/__init__.py @@ -0,0 +1,10 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._service_fabric_managed_clusters_management_client import ServiceFabricManagedClustersManagementClient +__all__ = ['ServiceFabricManagedClustersManagementClient'] diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_configuration.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_configuration.py new file mode 100644 index 000000000000..d7add0c2634e --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_configuration.py @@ -0,0 +1,67 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +from .._version import VERSION + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + + +class ServiceFabricManagedClustersManagementClientConfiguration(Configuration): + """Configuration for ServiceFabricManagedClustersManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The customer subscription identifier. + :type subscription_id: str + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + **kwargs: Any + ) -> None: + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(ServiceFabricManagedClustersManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2021-01-01-preview" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-servicefabricmanagedclusters/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_service_fabric_managed_clusters_management_client.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_service_fabric_managed_clusters_management_client.py new file mode 100644 index 000000000000..64fd0b6c6a53 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/_service_fabric_managed_clusters_management_client.py @@ -0,0 +1,93 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional, TYPE_CHECKING + +from azure.mgmt.core import AsyncARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +from ._configuration import ServiceFabricManagedClustersManagementClientConfiguration +from .operations import ApplicationTypesOperations +from .operations import ApplicationTypeVersionsOperations +from .operations import ApplicationsOperations +from .operations import ServicesOperations +from .operations import ManagedClustersOperations +from .operations import Operations +from .operations import NodeTypesOperations +from .. import models + + +class ServiceFabricManagedClustersManagementClient(object): + """Service Fabric Managed Clusters Management Client. + + :ivar application_types: ApplicationTypesOperations operations + :vartype application_types: service_fabric_managed_clusters_management_client.aio.operations.ApplicationTypesOperations + :ivar application_type_versions: ApplicationTypeVersionsOperations operations + :vartype application_type_versions: service_fabric_managed_clusters_management_client.aio.operations.ApplicationTypeVersionsOperations + :ivar applications: ApplicationsOperations operations + :vartype applications: service_fabric_managed_clusters_management_client.aio.operations.ApplicationsOperations + :ivar services: ServicesOperations operations + :vartype services: service_fabric_managed_clusters_management_client.aio.operations.ServicesOperations + :ivar managed_clusters: ManagedClustersOperations operations + :vartype managed_clusters: service_fabric_managed_clusters_management_client.aio.operations.ManagedClustersOperations + :ivar operations: Operations operations + :vartype operations: service_fabric_managed_clusters_management_client.aio.operations.Operations + :ivar node_types: NodeTypesOperations operations + :vartype node_types: service_fabric_managed_clusters_management_client.aio.operations.NodeTypesOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The customer subscription identifier. + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://management.azure.com' + self._config = ServiceFabricManagedClustersManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.application_types = ApplicationTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.application_type_versions = ApplicationTypeVersionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.applications = ApplicationsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.services = ServicesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.managed_clusters = ManagedClustersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.node_types = NodeTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "ServiceFabricManagedClustersManagementClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/__init__.py new file mode 100644 index 000000000000..613aba52b2a2 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/__init__.py @@ -0,0 +1,25 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._application_types_operations import ApplicationTypesOperations +from ._application_type_versions_operations import ApplicationTypeVersionsOperations +from ._applications_operations import ApplicationsOperations +from ._services_operations import ServicesOperations +from ._managed_clusters_operations import ManagedClustersOperations +from ._operations import Operations +from ._node_types_operations import NodeTypesOperations + +__all__ = [ + 'ApplicationTypesOperations', + 'ApplicationTypeVersionsOperations', + 'ApplicationsOperations', + 'ServicesOperations', + 'ManagedClustersOperations', + 'Operations', + 'NodeTypesOperations', +] diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_type_versions_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_type_versions_operations.py new file mode 100644 index 000000000000..2258aa3841e6 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_type_versions_operations.py @@ -0,0 +1,544 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationTypeVersionsOperations: + """ApplicationTypeVersionsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + **kwargs + ) -> "_models.ApplicationTypeVersionResource": + """Gets a Service Fabric managed application type version resource. + + Get a Service Fabric managed application type version resource created or in the process of + being created in the Service Fabric managed application type name resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeVersionResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + parameters: "_models.ApplicationTypeVersionResource", + **kwargs + ) -> "_models.ApplicationTypeVersionResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeVersionResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + parameters: "_models.ApplicationTypeVersionResource", + **kwargs + ) -> AsyncLROPoller["_models.ApplicationTypeVersionResource"]: + """Creates or updates a Service Fabric managed application type version resource. + + Create or update a Service Fabric managed application type version resource with the specified + name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :param parameters: The application type version resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either ApplicationTypeVersionResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + version=version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + parameters: "_models.ApplicationTypeVersionUpdateParameters", + **kwargs + ) -> "_models.ApplicationTypeVersionResource": + """Updates the tags of an application type version resource of a given managed cluster. + + Updates the tags of an application type version resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :param parameters: The application type version resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeVersionResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeVersionUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + version: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric managed application type version resource. + + Delete a Service Fabric managed application type version resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + version=version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def list_by_application_types( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationTypeVersionResourceList"]: + """Gets the list of application type version resources created in the specified Service Fabric managed application type name resource. + + Gets all application type version resources created or in the process of being created in the + Service Fabric managed application type name resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationTypeVersionResourceList or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_application_types.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationTypeVersionResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_application_types.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_types_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_types_operations.py new file mode 100644 index 000000000000..0696e474977d --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_application_types_operations.py @@ -0,0 +1,453 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationTypesOperations: + """ApplicationTypesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + **kwargs + ) -> "_models.ApplicationTypeResource": + """Gets a Service Fabric managed application type name resource. + + Get a Service Fabric application type name resource created or in the process of being created + in the Service Fabric managed cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + parameters: "_models.ApplicationTypeResource", + **kwargs + ) -> "_models.ApplicationTypeResource": + """Creates or updates a Service Fabric managed application type name resource. + + Create or update a Service Fabric managed application type name resource with the specified + name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param parameters: The application type name resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + parameters: "_models.ApplicationTypeUpdateParameters", + **kwargs + ) -> "_models.ApplicationTypeResource": + """Updates the tags of an application type resource of a given managed cluster. + + Updates the tags of an application type resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param parameters: The application type resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + application_type_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric managed application type name resource. + + Delete a Service Fabric managed application type name resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def list( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationTypeResourceList"]: + """Gets the list of application type name resources created in the specified Service Fabric managed cluster resource. + + Gets all application type name resources created or in the process of being created in the + Service Fabric managed cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationTypeResourceList or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationTypeResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationTypeResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_applications_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_applications_operations.py new file mode 100644 index 000000000000..91e76a80f46b --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_applications_operations.py @@ -0,0 +1,517 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationsOperations: + """ApplicationsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + **kwargs + ) -> "_models.ApplicationResource": + """Gets a Service Fabric managed application resource. + + Get a Service Fabric managed application resource created or in the process of being created in + the Service Fabric cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + parameters: "_models.ApplicationResource", + **kwargs + ) -> "_models.ApplicationResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + parameters: "_models.ApplicationResource", + **kwargs + ) -> AsyncLROPoller["_models.ApplicationResource"]: + """Creates or updates a Service Fabric managed application resource. + + Create or update a Service Fabric managed application resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param parameters: The application resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either ApplicationResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~service_fabric_managed_clusters_management_client.models.ApplicationResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + parameters: "_models.ApplicationUpdateParameters", + **kwargs + ) -> "_models.ApplicationResource": + """Updates the tags of an application resource of a given managed cluster. + + Updates the tags of an application resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param parameters: The application resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric managed application resource. + + Delete a Service Fabric managed application resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def list( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> AsyncIterable["_models.ApplicationResourceList"]: + """Gets the list of managed application resources created in the specified Service Fabric cluster resource. + + Gets all managed application resources created or in the process of being created in the + Service Fabric cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationResourceList or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_managed_clusters_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_managed_clusters_operations.py new file mode 100644 index 000000000000..0af10812c863 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_managed_clusters_operations.py @@ -0,0 +1,561 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ManagedClustersOperations: + """ManagedClustersOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_resource_group( + self, + resource_group_name: str, + **kwargs + ) -> AsyncIterable["_models.ManagedClusterListResult"]: + """Gets the list of Service Fabric cluster resources created in the specified resource group. + + Gets all Service Fabric cluster resources created or in the process of being created in the + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ManagedClusterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ManagedClusterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedClusterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ManagedClusterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters'} # type: ignore + + def list_by_subscription( + self, + **kwargs + ) -> AsyncIterable["_models.ManagedClusterListResult"]: + """Gets the list of Service Fabric cluster resources created in the specified subscription. + + Gets all Service Fabric cluster resources created or in the process of being created in the + subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ManagedClusterListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ManagedClusterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedClusterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ManagedClusterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.ServiceFabric/managedClusters'} # type: ignore + + async def get( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> "_models.ManagedCluster": + """Gets a Service Fabric managed cluster resource. + + Get a Service Fabric managed cluster resource created or in the process of being created in the + specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ManagedCluster, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cluster_name: str, + parameters: "_models.ManagedCluster", + **kwargs + ) -> "_models.ManagedCluster": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ManagedCluster') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cluster_name: str, + parameters: "_models.ManagedCluster", + **kwargs + ) -> AsyncLROPoller["_models.ManagedCluster"]: + """Creates or updates a Service Fabric managed cluster resource. + + Create or update a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param parameters: The cluster resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either ManagedCluster or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~service_fabric_managed_clusters_management_client.models.ManagedCluster] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + parameters: "_models.ManagedClusterUpdateParameters", + **kwargs + ) -> "_models.ManagedCluster": + """Updates the tags of of a Service Fabric managed cluster resource. + + Update the tags of of a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param parameters: The managed cluster resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ManagedClusterUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ManagedCluster, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ManagedClusterUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric managed cluster resource. + + Delete a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_node_types_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_node_types_operations.py new file mode 100644 index 000000000000..6b01591baf03 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_node_types_operations.py @@ -0,0 +1,902 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class NodeTypesOperations: + """NodeTypesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_managed_clusters( + self, + resource_group_name: str, + cluster_name: str, + **kwargs + ) -> AsyncIterable["_models.NodeTypeListResult"]: + """Gets the list of Node types of the specified managed cluster. + + Gets all Node types of the specified managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NodeTypeListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.NodeTypeListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeTypeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_managed_clusters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('NodeTypeListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_managed_clusters.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes'} # type: ignore + + async def _restart_initial( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restart_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restart_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/restart'} # type: ignore + + async def begin_restart( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> AsyncLROPoller[None]: + """Restarts one or more nodes on the node type. + + Restarts one or more nodes on the node type. It will disable the fabric nodes, trigger a + restart on the VMs and activate the nodes back again. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for restart action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._restart_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/restart'} # type: ignore + + async def _reimage_initial( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._reimage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _reimage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/reimage'} # type: ignore + + async def begin_reimage( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> AsyncLROPoller[None]: + """Reimages one or more nodes on the node type. + + Reimages one or more nodes on the node type. It will disable the fabric nodes, trigger a + reimage on the VMs and activate the nodes back again. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for reimage action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._reimage_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_reimage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/reimage'} # type: ignore + + async def _delete_node_initial( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._delete_node_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_node_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/deleteNode'} # type: ignore + + async def begin_delete_node( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeActionParameters", + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes one or more nodes on the node type. + + Deletes one or more nodes on the node type. It will disable the fabric nodes, trigger a delete + on the VMs and removes the state from the cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for delete action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_node_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_node.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/deleteNode'} # type: ignore + + async def get( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + **kwargs + ) -> "_models.NodeType": + """Gets a Service Fabric node type. + + Get a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NodeType, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.NodeType + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeType", + **kwargs + ) -> "_models.NodeType": + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeType') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NodeType', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeType", + **kwargs + ) -> AsyncLROPoller["_models.NodeType"]: + """Creates or updates a Service Fabric node type. + + Create or update a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: The node type resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeType + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either NodeType or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~service_fabric_managed_clusters_management_client.models.NodeType] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + parameters: "_models.NodeTypeUpdateParameters", + **kwargs + ) -> "_models.NodeType": + """Update the tags of a node type resource of a given managed cluster. + + Update the configuration of a node type of a given managed cluster, only updating tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: The parameters to update the node type configuration. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NodeType, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.NodeType + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + node_type_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric node type. + + Delete a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_operations.py new file mode 100644 index 000000000000..5cf43c5c972a --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_operations.py @@ -0,0 +1,107 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class Operations: + """Operations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.OperationListResult"]: + """Lists all of the available Service Fabric resource provider API operations. + + Get the list of available Service Fabric resource provider API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.ServiceFabric/operations'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_services_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_services_operations.py new file mode 100644 index 000000000000..eabcaf551deb --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/aio/operations/_services_operations.py @@ -0,0 +1,547 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ServicesOperations: + """ServicesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + **kwargs + ) -> "_models.ServiceResource": + """Gets a Service Fabric managed service resource. + + Get a Service Fabric service resource created or in the process of being created in the Service + Fabric managed application resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + parameters: "_models.ServiceResource", + **kwargs + ) -> "_models.ServiceResource": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ServiceResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + parameters: "_models.ServiceResource", + **kwargs + ) -> AsyncLROPoller["_models.ServiceResource"]: + """Creates or updates a Service Fabric managed service resource. + + Create or update a Service Fabric managed service resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :param parameters: The service resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either ServiceResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~service_fabric_managed_clusters_management_client.models.ServiceResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + service_name=service_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + parameters: "_models.ServiceUpdateParameters", + **kwargs + ) -> "_models.ServiceResource": + """Updates the tags of a service resource of a given managed cluster. + + Updates the tags of a service resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :param parameters: The service resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ServiceUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ServiceUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + service_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a Service Fabric managed service resource. + + Delete a Service Fabric managed service resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + service_name=service_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def list_by_applications( + self, + resource_group_name: str, + cluster_name: str, + application_name: str, + **kwargs + ) -> AsyncIterable["_models.ServiceResourceList"]: + """Gets the list of service resources created in the specified Service Fabric managed application resource. + + Gets all service resources created or in the process of being created in the Service Fabric + managed application resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ServiceResourceList or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~service_fabric_managed_clusters_management_client.models.ServiceResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_applications.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ServiceResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_applications.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/__init__.py new file mode 100644 index 000000000000..bc02491d4d47 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/__init__.py @@ -0,0 +1,276 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import AddRemoveIncrementalNamedPartitionScalingMechanism + from ._models_py3 import ApplicationHealthPolicy + from ._models_py3 import ApplicationResource + from ._models_py3 import ApplicationResourceList + from ._models_py3 import ApplicationTypeResource + from ._models_py3 import ApplicationTypeResourceList + from ._models_py3 import ApplicationTypeUpdateParameters + from ._models_py3 import ApplicationTypeVersionResource + from ._models_py3 import ApplicationTypeVersionResourceList + from ._models_py3 import ApplicationTypeVersionUpdateParameters + from ._models_py3 import ApplicationTypeVersionsCleanupPolicy + from ._models_py3 import ApplicationUpdateParameters + from ._models_py3 import ApplicationUpgradePolicy + from ._models_py3 import ApplicationUserAssignedIdentity + from ._models_py3 import AvailableOperationDisplay + from ._models_py3 import AveragePartitionLoadScalingTrigger + from ._models_py3 import AverageServiceLoadScalingTrigger + from ._models_py3 import AzureActiveDirectory + from ._models_py3 import ClientCertificate + from ._models_py3 import EndpointRangeDescription + from ._models_py3 import ErrorModel + from ._models_py3 import ErrorModelError + from ._models_py3 import LoadBalancingRule + from ._models_py3 import ManagedCluster + from ._models_py3 import ManagedClusterListResult + from ._models_py3 import ManagedClusterUpdateParameters + from ._models_py3 import ManagedIdentity + from ._models_py3 import ManagedProxyResource + from ._models_py3 import NamedPartitionScheme + from ._models_py3 import NetworkSecurityRule + from ._models_py3 import NodeType + from ._models_py3 import NodeTypeActionParameters + from ._models_py3 import NodeTypeListResult + from ._models_py3 import NodeTypeUpdateParameters + from ._models_py3 import OperationListResult + from ._models_py3 import OperationResult + from ._models_py3 import Partition + from ._models_py3 import PartitionInstanceCountScaleMechanism + from ._models_py3 import ProxyResource + from ._models_py3 import Resource + from ._models_py3 import RollingUpgradeMonitoringPolicy + from ._models_py3 import ScalingMechanism + from ._models_py3 import ScalingPolicy + from ._models_py3 import ScalingTrigger + from ._models_py3 import ServiceCorrelation + from ._models_py3 import ServiceLoadMetric + from ._models_py3 import ServicePlacementInvalidDomainPolicy + from ._models_py3 import ServicePlacementNonPartiallyPlaceServicePolicy + from ._models_py3 import ServicePlacementPolicy + from ._models_py3 import ServicePlacementPreferPrimaryDomainPolicy + from ._models_py3 import ServicePlacementRequireDomainDistributionPolicy + from ._models_py3 import ServicePlacementRequiredDomainPolicy + from ._models_py3 import ServiceResource + from ._models_py3 import ServiceResourceList + from ._models_py3 import ServiceResourceProperties + from ._models_py3 import ServiceResourcePropertiesBase + from ._models_py3 import ServiceTypeHealthPolicy + from ._models_py3 import ServiceUpdateParameters + from ._models_py3 import SettingsParameterDescription + from ._models_py3 import SettingsSectionDescription + from ._models_py3 import SingletonPartitionScheme + from ._models_py3 import Sku + from ._models_py3 import StatefulServiceProperties + from ._models_py3 import StatelessServiceProperties + from ._models_py3 import SubResource + from ._models_py3 import SystemData + from ._models_py3 import UniformInt64RangePartitionScheme + from ._models_py3 import UserAssignedIdentity + from ._models_py3 import VMSSExtension + from ._models_py3 import VaultCertificate + from ._models_py3 import VaultSecretGroup + from ._models_py3 import VmManagedIdentity +except (SyntaxError, ImportError): + from ._models import AddRemoveIncrementalNamedPartitionScalingMechanism # type: ignore + from ._models import ApplicationHealthPolicy # type: ignore + from ._models import ApplicationResource # type: ignore + from ._models import ApplicationResourceList # type: ignore + from ._models import ApplicationTypeResource # type: ignore + from ._models import ApplicationTypeResourceList # type: ignore + from ._models import ApplicationTypeUpdateParameters # type: ignore + from ._models import ApplicationTypeVersionResource # type: ignore + from ._models import ApplicationTypeVersionResourceList # type: ignore + from ._models import ApplicationTypeVersionUpdateParameters # type: ignore + from ._models import ApplicationTypeVersionsCleanupPolicy # type: ignore + from ._models import ApplicationUpdateParameters # type: ignore + from ._models import ApplicationUpgradePolicy # type: ignore + from ._models import ApplicationUserAssignedIdentity # type: ignore + from ._models import AvailableOperationDisplay # type: ignore + from ._models import AveragePartitionLoadScalingTrigger # type: ignore + from ._models import AverageServiceLoadScalingTrigger # type: ignore + from ._models import AzureActiveDirectory # type: ignore + from ._models import ClientCertificate # type: ignore + from ._models import EndpointRangeDescription # type: ignore + from ._models import ErrorModel # type: ignore + from ._models import ErrorModelError # type: ignore + from ._models import LoadBalancingRule # type: ignore + from ._models import ManagedCluster # type: ignore + from ._models import ManagedClusterListResult # type: ignore + from ._models import ManagedClusterUpdateParameters # type: ignore + from ._models import ManagedIdentity # type: ignore + from ._models import ManagedProxyResource # type: ignore + from ._models import NamedPartitionScheme # type: ignore + from ._models import NetworkSecurityRule # type: ignore + from ._models import NodeType # type: ignore + from ._models import NodeTypeActionParameters # type: ignore + from ._models import NodeTypeListResult # type: ignore + from ._models import NodeTypeUpdateParameters # type: ignore + from ._models import OperationListResult # type: ignore + from ._models import OperationResult # type: ignore + from ._models import Partition # type: ignore + from ._models import PartitionInstanceCountScaleMechanism # type: ignore + from ._models import ProxyResource # type: ignore + from ._models import Resource # type: ignore + from ._models import RollingUpgradeMonitoringPolicy # type: ignore + from ._models import ScalingMechanism # type: ignore + from ._models import ScalingPolicy # type: ignore + from ._models import ScalingTrigger # type: ignore + from ._models import ServiceCorrelation # type: ignore + from ._models import ServiceLoadMetric # type: ignore + from ._models import ServicePlacementInvalidDomainPolicy # type: ignore + from ._models import ServicePlacementNonPartiallyPlaceServicePolicy # type: ignore + from ._models import ServicePlacementPolicy # type: ignore + from ._models import ServicePlacementPreferPrimaryDomainPolicy # type: ignore + from ._models import ServicePlacementRequireDomainDistributionPolicy # type: ignore + from ._models import ServicePlacementRequiredDomainPolicy # type: ignore + from ._models import ServiceResource # type: ignore + from ._models import ServiceResourceList # type: ignore + from ._models import ServiceResourceProperties # type: ignore + from ._models import ServiceResourcePropertiesBase # type: ignore + from ._models import ServiceTypeHealthPolicy # type: ignore + from ._models import ServiceUpdateParameters # type: ignore + from ._models import SettingsParameterDescription # type: ignore + from ._models import SettingsSectionDescription # type: ignore + from ._models import SingletonPartitionScheme # type: ignore + from ._models import Sku # type: ignore + from ._models import StatefulServiceProperties # type: ignore + from ._models import StatelessServiceProperties # type: ignore + from ._models import SubResource # type: ignore + from ._models import SystemData # type: ignore + from ._models import UniformInt64RangePartitionScheme # type: ignore + from ._models import UserAssignedIdentity # type: ignore + from ._models import VMSSExtension # type: ignore + from ._models import VaultCertificate # type: ignore + from ._models import VaultSecretGroup # type: ignore + from ._models import VmManagedIdentity # type: ignore + +from ._service_fabric_managed_clusters_management_client_enums import ( + Access, + ClusterState, + ClusterUpgradeCadence, + Direction, + FailureAction, + ManagedClusterAddOnFeature, + ManagedIdentityType, + ManagedResourceProvisioningState, + MoveCost, + NsgProtocol, + PartitionScheme, + ProbeProtocol, + Protocol, + RollingUpgradeMode, + ServiceCorrelationScheme, + ServiceKind, + ServiceLoadMetricWeight, + ServicePackageActivationMode, + ServicePlacementPolicyType, + ServiceScalingMechanismKind, + ServiceScalingTriggerKind, + SkuName, +) + +__all__ = [ + 'AddRemoveIncrementalNamedPartitionScalingMechanism', + 'ApplicationHealthPolicy', + 'ApplicationResource', + 'ApplicationResourceList', + 'ApplicationTypeResource', + 'ApplicationTypeResourceList', + 'ApplicationTypeUpdateParameters', + 'ApplicationTypeVersionResource', + 'ApplicationTypeVersionResourceList', + 'ApplicationTypeVersionUpdateParameters', + 'ApplicationTypeVersionsCleanupPolicy', + 'ApplicationUpdateParameters', + 'ApplicationUpgradePolicy', + 'ApplicationUserAssignedIdentity', + 'AvailableOperationDisplay', + 'AveragePartitionLoadScalingTrigger', + 'AverageServiceLoadScalingTrigger', + 'AzureActiveDirectory', + 'ClientCertificate', + 'EndpointRangeDescription', + 'ErrorModel', + 'ErrorModelError', + 'LoadBalancingRule', + 'ManagedCluster', + 'ManagedClusterListResult', + 'ManagedClusterUpdateParameters', + 'ManagedIdentity', + 'ManagedProxyResource', + 'NamedPartitionScheme', + 'NetworkSecurityRule', + 'NodeType', + 'NodeTypeActionParameters', + 'NodeTypeListResult', + 'NodeTypeUpdateParameters', + 'OperationListResult', + 'OperationResult', + 'Partition', + 'PartitionInstanceCountScaleMechanism', + 'ProxyResource', + 'Resource', + 'RollingUpgradeMonitoringPolicy', + 'ScalingMechanism', + 'ScalingPolicy', + 'ScalingTrigger', + 'ServiceCorrelation', + 'ServiceLoadMetric', + 'ServicePlacementInvalidDomainPolicy', + 'ServicePlacementNonPartiallyPlaceServicePolicy', + 'ServicePlacementPolicy', + 'ServicePlacementPreferPrimaryDomainPolicy', + 'ServicePlacementRequireDomainDistributionPolicy', + 'ServicePlacementRequiredDomainPolicy', + 'ServiceResource', + 'ServiceResourceList', + 'ServiceResourceProperties', + 'ServiceResourcePropertiesBase', + 'ServiceTypeHealthPolicy', + 'ServiceUpdateParameters', + 'SettingsParameterDescription', + 'SettingsSectionDescription', + 'SingletonPartitionScheme', + 'Sku', + 'StatefulServiceProperties', + 'StatelessServiceProperties', + 'SubResource', + 'SystemData', + 'UniformInt64RangePartitionScheme', + 'UserAssignedIdentity', + 'VMSSExtension', + 'VaultCertificate', + 'VaultSecretGroup', + 'VmManagedIdentity', + 'Access', + 'ClusterState', + 'ClusterUpgradeCadence', + 'Direction', + 'FailureAction', + 'ManagedClusterAddOnFeature', + 'ManagedIdentityType', + 'ManagedResourceProvisioningState', + 'MoveCost', + 'NsgProtocol', + 'PartitionScheme', + 'ProbeProtocol', + 'Protocol', + 'RollingUpgradeMode', + 'ServiceCorrelationScheme', + 'ServiceKind', + 'ServiceLoadMetricWeight', + 'ServicePackageActivationMode', + 'ServicePlacementPolicyType', + 'ServiceScalingMechanismKind', + 'ServiceScalingTriggerKind', + 'SkuName', +] diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models.py new file mode 100644 index 000000000000..cba99fcf4e05 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models.py @@ -0,0 +1,3134 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + + +class ScalingMechanism(msrest.serialization.Model): + """Describes the mechanism for performing a scaling operation. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: AddRemoveIncrementalNamedPartitionScalingMechanism, PartitionInstanceCountScaleMechanism. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + """ + + _validation = { + 'kind': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + } + + _subtype_map = { + 'kind': {'AddRemoveIncrementalNamedPartition': 'AddRemoveIncrementalNamedPartitionScalingMechanism', 'ScalePartitionInstanceCount': 'PartitionInstanceCountScaleMechanism'} + } + + def __init__( + self, + **kwargs + ): + super(ScalingMechanism, self).__init__(**kwargs) + self.kind = None # type: Optional[str] + + +class AddRemoveIncrementalNamedPartitionScalingMechanism(ScalingMechanism): + """Represents a scaling mechanism for adding or removing named partitions of a stateless service. Partition names are in the format '0','1'...'N-1'. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + :param min_partition_count: Required. Minimum number of named partitions of the service. + :type min_partition_count: int + :param max_partition_count: Required. Maximum number of named partitions of the service. + :type max_partition_count: int + :param scale_increment: Required. The number of instances to add or remove during a scaling + operation. + :type scale_increment: int + """ + + _validation = { + 'kind': {'required': True}, + 'min_partition_count': {'required': True}, + 'max_partition_count': {'required': True}, + 'scale_increment': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'min_partition_count': {'key': 'minPartitionCount', 'type': 'int'}, + 'max_partition_count': {'key': 'maxPartitionCount', 'type': 'int'}, + 'scale_increment': {'key': 'scaleIncrement', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(AddRemoveIncrementalNamedPartitionScalingMechanism, self).__init__(**kwargs) + self.kind = 'AddRemoveIncrementalNamedPartition' # type: str + self.min_partition_count = kwargs['min_partition_count'] + self.max_partition_count = kwargs['max_partition_count'] + self.scale_increment = kwargs['scale_increment'] + + +class ApplicationHealthPolicy(msrest.serialization.Model): + """Defines a health policy used to evaluate the health of an application or one of its children entities. + + All required parameters must be populated in order to send to Azure. + + :param consider_warning_as_error: Required. Indicates whether warnings are treated with the + same severity as errors. + :type consider_warning_as_error: bool + :param max_percent_unhealthy_deployed_applications: Required. The maximum allowed percentage of + unhealthy deployed applications. Allowed values are Byte values from zero to 100. + The percentage represents the maximum tolerated percentage of deployed applications that can + be unhealthy before the application is considered in error. + This is calculated by dividing the number of unhealthy deployed applications over the number + of nodes where the application is currently deployed on in the cluster. + The computation rounds up to tolerate one failure on small numbers of nodes. Default + percentage is zero. + :type max_percent_unhealthy_deployed_applications: int + :param default_service_type_health_policy: The health policy used by default to evaluate the + health of a service type. + :type default_service_type_health_policy: + ~service_fabric_managed_clusters_management_client.models.ServiceTypeHealthPolicy + :param service_type_health_policy_map: The map with service type health policy per service type + name. The map is empty by default. + :type service_type_health_policy_map: dict[str, + ~service_fabric_managed_clusters_management_client.models.ServiceTypeHealthPolicy] + """ + + _validation = { + 'consider_warning_as_error': {'required': True}, + 'max_percent_unhealthy_deployed_applications': {'required': True}, + } + + _attribute_map = { + 'consider_warning_as_error': {'key': 'considerWarningAsError', 'type': 'bool'}, + 'max_percent_unhealthy_deployed_applications': {'key': 'maxPercentUnhealthyDeployedApplications', 'type': 'int'}, + 'default_service_type_health_policy': {'key': 'defaultServiceTypeHealthPolicy', 'type': 'ServiceTypeHealthPolicy'}, + 'service_type_health_policy_map': {'key': 'serviceTypeHealthPolicyMap', 'type': '{ServiceTypeHealthPolicy}'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationHealthPolicy, self).__init__(**kwargs) + self.consider_warning_as_error = kwargs['consider_warning_as_error'] + self.max_percent_unhealthy_deployed_applications = kwargs['max_percent_unhealthy_deployed_applications'] + self.default_service_type_health_policy = kwargs.get('default_service_type_health_policy', None) + self.service_type_health_policy_map = kwargs.get('service_type_health_policy_map', None) + + +class ProxyResource(msrest.serialization.Model): + """The resource model definition for proxy-only resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + **kwargs + ): + super(ProxyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = kwargs.get('location', None) + self.tags = kwargs.get('tags', None) + self.system_data = None + + +class ApplicationResource(ProxyResource): + """The application resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param identity: Describes the managed identities for an Azure resource. + :type identity: ~service_fabric_managed_clusters_management_client.models.ManagedIdentity + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param version: The version of the application type as defined in the application manifest. + This name must be the full Arm Resource ID for the referenced application type version. + :type version: str + :param parameters: List of application parameters with overridden values from their default + values specified in the application manifest. + :type parameters: dict[str, str] + :param upgrade_policy: Describes the policy for a monitored application upgrade. + :type upgrade_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationUpgradePolicy + :param managed_identities: List of user assigned identities for the application, each mapped to + a friendly name. + :type managed_identities: + list[~service_fabric_managed_clusters_management_client.models.ApplicationUserAssignedIdentity] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedIdentity'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'parameters': {'key': 'properties.parameters', 'type': '{str}'}, + 'upgrade_policy': {'key': 'properties.upgradePolicy', 'type': 'ApplicationUpgradePolicy'}, + 'managed_identities': {'key': 'properties.managedIdentities', 'type': '[ApplicationUserAssignedIdentity]'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationResource, self).__init__(**kwargs) + self.identity = kwargs.get('identity', None) + self.provisioning_state = None + self.version = kwargs.get('version', None) + self.parameters = kwargs.get('parameters', None) + self.upgrade_policy = kwargs.get('upgrade_policy', None) + self.managed_identities = kwargs.get('managed_identities', None) + + +class ApplicationResourceList(msrest.serialization.Model): + """The list of application resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationResource] + :ivar next_link: URL to get the next set of application list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationResourceList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ApplicationTypeResource(ProxyResource): + """The application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeResource, self).__init__(**kwargs) + self.provisioning_state = None + + +class ApplicationTypeResourceList(msrest.serialization.Model): + """The list of application type names. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource] + :ivar next_link: URL to get the next set of application type list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationTypeResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeResourceList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ApplicationTypeUpdateParameters(msrest.serialization.Model): + """Application type update request. + + :param tags: A set of tags. Application type update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class ApplicationTypeVersionResource(ProxyResource): + """An application type version resource for the specified application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param app_package_url: The URL to the application package. + :type app_package_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'app_package_url': {'key': 'properties.appPackageUrl', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeVersionResource, self).__init__(**kwargs) + self.provisioning_state = None + self.app_package_url = kwargs.get('app_package_url', None) + + +class ApplicationTypeVersionResourceList(msrest.serialization.Model): + """The list of application type version resources for the specified application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource] + :ivar next_link: URL to get the next set of application type version list results if there are + any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationTypeVersionResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeVersionResourceList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ApplicationTypeVersionsCleanupPolicy(msrest.serialization.Model): + """The policy used to clean up unused versions. + + All required parameters must be populated in order to send to Azure. + + :param max_unused_versions_to_keep: Required. Number of unused versions per application type to + keep. + :type max_unused_versions_to_keep: int + """ + + _validation = { + 'max_unused_versions_to_keep': {'required': True, 'minimum': 0}, + } + + _attribute_map = { + 'max_unused_versions_to_keep': {'key': 'maxUnusedVersionsToKeep', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeVersionsCleanupPolicy, self).__init__(**kwargs) + self.max_unused_versions_to_keep = kwargs['max_unused_versions_to_keep'] + + +class ApplicationTypeVersionUpdateParameters(msrest.serialization.Model): + """Application type version update request. + + :param tags: A set of tags. Application type version update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationTypeVersionUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class ApplicationUpdateParameters(msrest.serialization.Model): + """Application update request. + + :param tags: A set of tags. Application update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class ApplicationUpgradePolicy(msrest.serialization.Model): + """Describes the policy for a monitored application upgrade. + + :param application_health_policy: Defines a health policy used to evaluate the health of an + application or one of its children entities. + :type application_health_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationHealthPolicy + :param force_restart: If true, then processes are forcefully restarted during upgrade even when + the code version has not changed (the upgrade only changes configuration or data). + :type force_restart: bool + :param rolling_upgrade_monitoring_policy: The policy used for monitoring the application + upgrade. + :type rolling_upgrade_monitoring_policy: + ~service_fabric_managed_clusters_management_client.models.RollingUpgradeMonitoringPolicy + :param instance_close_delay_duration: Duration in seconds, to wait before a stateless instance + is closed, to allow the active requests to drain gracefully. This would be effective when the + instance is closing during the application/cluster upgrade, only for those instances which have + a non-zero delay duration configured in the service description. See + InstanceCloseDelayDurationSeconds property in StatelessServiceDescription for details. Note, + the default value of InstanceCloseDelayDurationInSeconds is 4294967295, which indicates that + the behavior will entirely depend on the delay configured in the stateless service description. + :type instance_close_delay_duration: long + :param upgrade_mode: The mode used to monitor health during a rolling upgrade. The values are + Monitored, and UnmonitoredAuto. Possible values include: "Monitored", "UnmonitoredAuto". + :type upgrade_mode: str or + ~service_fabric_managed_clusters_management_client.models.RollingUpgradeMode + :param upgrade_replica_set_check_timeout: The maximum amount of time to block processing of an + upgrade domain and prevent loss of availability when there are unexpected issues. When this + timeout expires, processing of the upgrade domain will proceed regardless of availability loss + issues. The timeout is reset at the start of each upgrade domain. Valid values are between 0 + and 42949672925 inclusive. (unsigned 32-bit integer). + :type upgrade_replica_set_check_timeout: long + :param recreate_application: Determines whether the application should be recreated on update. + If value=true, the rest of the upgrade policy parameters are not allowed. + :type recreate_application: bool + """ + + _attribute_map = { + 'application_health_policy': {'key': 'applicationHealthPolicy', 'type': 'ApplicationHealthPolicy'}, + 'force_restart': {'key': 'forceRestart', 'type': 'bool'}, + 'rolling_upgrade_monitoring_policy': {'key': 'rollingUpgradeMonitoringPolicy', 'type': 'RollingUpgradeMonitoringPolicy'}, + 'instance_close_delay_duration': {'key': 'instanceCloseDelayDuration', 'type': 'long'}, + 'upgrade_mode': {'key': 'upgradeMode', 'type': 'str'}, + 'upgrade_replica_set_check_timeout': {'key': 'upgradeReplicaSetCheckTimeout', 'type': 'long'}, + 'recreate_application': {'key': 'recreateApplication', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationUpgradePolicy, self).__init__(**kwargs) + self.application_health_policy = kwargs.get('application_health_policy', None) + self.force_restart = kwargs.get('force_restart', False) + self.rolling_upgrade_monitoring_policy = kwargs.get('rolling_upgrade_monitoring_policy', None) + self.instance_close_delay_duration = kwargs.get('instance_close_delay_duration', None) + self.upgrade_mode = kwargs.get('upgrade_mode', None) + self.upgrade_replica_set_check_timeout = kwargs.get('upgrade_replica_set_check_timeout', None) + self.recreate_application = kwargs.get('recreate_application', None) + + +class ApplicationUserAssignedIdentity(msrest.serialization.Model): + """ApplicationUserAssignedIdentity. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The friendly name of user assigned identity. + :type name: str + :param principal_id: Required. The principal id of user assigned identity. + :type principal_id: str + """ + + _validation = { + 'name': {'required': True}, + 'principal_id': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApplicationUserAssignedIdentity, self).__init__(**kwargs) + self.name = kwargs['name'] + self.principal_id = kwargs['principal_id'] + + +class AvailableOperationDisplay(msrest.serialization.Model): + """Operation supported by the Service Fabric resource provider. + + :param provider: The name of the provider. + :type provider: str + :param resource: The resource on which the operation is performed. + :type resource: str + :param operation: The operation that can be performed. + :type operation: str + :param description: Operation description. + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AvailableOperationDisplay, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + self.description = kwargs.get('description', None) + + +class ScalingTrigger(msrest.serialization.Model): + """Describes the trigger for performing a scaling operation. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: AveragePartitionLoadScalingTrigger, AverageServiceLoadScalingTrigger. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + """ + + _validation = { + 'kind': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + } + + _subtype_map = { + 'kind': {'AveragePartitionLoadTrigger': 'AveragePartitionLoadScalingTrigger', 'AverageServiceLoadTrigger': 'AverageServiceLoadScalingTrigger'} + } + + def __init__( + self, + **kwargs + ): + super(ScalingTrigger, self).__init__(**kwargs) + self.kind = None # type: Optional[str] + + +class AveragePartitionLoadScalingTrigger(ScalingTrigger): + """Represents a scaling trigger related to an average load of a metric/resource of a partition. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + :param metric_name: Required. The name of the metric for which usage should be tracked. + :type metric_name: str + :param lower_load_threshold: Required. The lower limit of the load below which a scale in + operation should be performed. + :type lower_load_threshold: float + :param upper_load_threshold: Required. The upper limit of the load beyond which a scale out + operation should be performed. + :type upper_load_threshold: float + :param scale_interval: Required. The period in seconds on which a decision is made whether to + scale or not. This property should come in ISO 8601 format "hh:mm:ss". + :type scale_interval: str + """ + + _validation = { + 'kind': {'required': True}, + 'metric_name': {'required': True}, + 'lower_load_threshold': {'required': True}, + 'upper_load_threshold': {'required': True}, + 'scale_interval': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'metric_name': {'key': 'metricName', 'type': 'str'}, + 'lower_load_threshold': {'key': 'lowerLoadThreshold', 'type': 'float'}, + 'upper_load_threshold': {'key': 'upperLoadThreshold', 'type': 'float'}, + 'scale_interval': {'key': 'scaleInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AveragePartitionLoadScalingTrigger, self).__init__(**kwargs) + self.kind = 'AveragePartitionLoadTrigger' # type: str + self.metric_name = kwargs['metric_name'] + self.lower_load_threshold = kwargs['lower_load_threshold'] + self.upper_load_threshold = kwargs['upper_load_threshold'] + self.scale_interval = kwargs['scale_interval'] + + +class AverageServiceLoadScalingTrigger(ScalingTrigger): + """Represents a scaling policy related to an average load of a metric/resource of a service. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + :param metric_name: Required. The name of the metric for which usage should be tracked. + :type metric_name: str + :param lower_load_threshold: Required. The lower limit of the load below which a scale in + operation should be performed. + :type lower_load_threshold: float + :param upper_load_threshold: Required. The upper limit of the load beyond which a scale out + operation should be performed. + :type upper_load_threshold: float + :param scale_interval: Required. The period in seconds on which a decision is made whether to + scale or not. This property should come in ISO 8601 format "hh:mm:ss". + :type scale_interval: str + """ + + _validation = { + 'kind': {'required': True}, + 'metric_name': {'required': True}, + 'lower_load_threshold': {'required': True}, + 'upper_load_threshold': {'required': True}, + 'scale_interval': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'metric_name': {'key': 'metricName', 'type': 'str'}, + 'lower_load_threshold': {'key': 'lowerLoadThreshold', 'type': 'float'}, + 'upper_load_threshold': {'key': 'upperLoadThreshold', 'type': 'float'}, + 'scale_interval': {'key': 'scaleInterval', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AverageServiceLoadScalingTrigger, self).__init__(**kwargs) + self.kind = 'AverageServiceLoadTrigger' # type: str + self.metric_name = kwargs['metric_name'] + self.lower_load_threshold = kwargs['lower_load_threshold'] + self.upper_load_threshold = kwargs['upper_load_threshold'] + self.scale_interval = kwargs['scale_interval'] + + +class AzureActiveDirectory(msrest.serialization.Model): + """The settings to enable AAD authentication on the cluster. + + :param tenant_id: Azure active directory tenant id. + :type tenant_id: str + :param cluster_application: Azure active directory cluster application id. + :type cluster_application: str + :param client_application: Azure active directory client application id. + :type client_application: str + """ + + _attribute_map = { + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'cluster_application': {'key': 'clusterApplication', 'type': 'str'}, + 'client_application': {'key': 'clientApplication', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(**kwargs) + self.tenant_id = kwargs.get('tenant_id', None) + self.cluster_application = kwargs.get('cluster_application', None) + self.client_application = kwargs.get('client_application', None) + + +class ClientCertificate(msrest.serialization.Model): + """Client certificate definition. + + All required parameters must be populated in order to send to Azure. + + :param is_admin: Required. Indicates if the client certificate has admin access to the cluster. + Non admin clients can perform only read only operations on the cluster. + :type is_admin: bool + :param thumbprint: Certificate thumbprint. + :type thumbprint: str + :param common_name: Certificate common name. + :type common_name: str + :param issuer_thumbprint: Issuer thumbprint for the certificate. Only used together with + CommonName. + :type issuer_thumbprint: str + """ + + _validation = { + 'is_admin': {'required': True}, + } + + _attribute_map = { + 'is_admin': {'key': 'isAdmin', 'type': 'bool'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'common_name': {'key': 'commonName', 'type': 'str'}, + 'issuer_thumbprint': {'key': 'issuerThumbprint', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ClientCertificate, self).__init__(**kwargs) + self.is_admin = kwargs['is_admin'] + self.thumbprint = kwargs.get('thumbprint', None) + self.common_name = kwargs.get('common_name', None) + self.issuer_thumbprint = kwargs.get('issuer_thumbprint', None) + + +class EndpointRangeDescription(msrest.serialization.Model): + """Port range details. + + All required parameters must be populated in order to send to Azure. + + :param start_port: Required. Starting port of a range of ports. + :type start_port: int + :param end_port: Required. End port of a range of ports. + :type end_port: int + """ + + _validation = { + 'start_port': {'required': True}, + 'end_port': {'required': True}, + } + + _attribute_map = { + 'start_port': {'key': 'startPort', 'type': 'int'}, + 'end_port': {'key': 'endPort', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(EndpointRangeDescription, self).__init__(**kwargs) + self.start_port = kwargs['start_port'] + self.end_port = kwargs['end_port'] + + +class ErrorModel(msrest.serialization.Model): + """The structure of the error. + + :param error: The error details. + :type error: ~service_fabric_managed_clusters_management_client.models.ErrorModelError + """ + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorModelError'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorModel, self).__init__(**kwargs) + self.error = kwargs.get('error', None) + + +class ErrorModelError(msrest.serialization.Model): + """The error details. + + :param code: The error code. + :type code: str + :param message: The error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorModelError, self).__init__(**kwargs) + self.code = kwargs.get('code', None) + self.message = kwargs.get('message', None) + + +class LoadBalancingRule(msrest.serialization.Model): + """Describes a load balancing rule. + + All required parameters must be populated in order to send to Azure. + + :param frontend_port: Required. The port for the external endpoint. Port numbers for each rule + must be unique within the Load Balancer. Acceptable values are between 1 and 65534. + :type frontend_port: int + :param backend_port: Required. The port used for internal connections on the endpoint. + Acceptable values are between 1 and 65535. + :type backend_port: int + :param protocol: Required. The reference to the transport protocol used by the load balancing + rule. Possible values include: "tcp", "udp". + :type protocol: str or ~service_fabric_managed_clusters_management_client.models.Protocol + :param probe_protocol: Required. the reference to the load balancer probe used by the load + balancing rule. Possible values include: "tcp", "http", "https". + :type probe_protocol: str or + ~service_fabric_managed_clusters_management_client.models.ProbeProtocol + :param probe_request_path: The probe request path. Only supported for HTTP/HTTPS probes. + :type probe_request_path: str + """ + + _validation = { + 'frontend_port': {'required': True, 'maximum': 65534, 'minimum': 1}, + 'backend_port': {'required': True, 'maximum': 65534, 'minimum': 1}, + 'protocol': {'required': True}, + 'probe_protocol': {'required': True}, + } + + _attribute_map = { + 'frontend_port': {'key': 'frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'backendPort', 'type': 'int'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'probe_protocol': {'key': 'probeProtocol', 'type': 'str'}, + 'probe_request_path': {'key': 'probeRequestPath', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(LoadBalancingRule, self).__init__(**kwargs) + self.frontend_port = kwargs['frontend_port'] + self.backend_port = kwargs['backend_port'] + self.protocol = kwargs['protocol'] + self.probe_protocol = kwargs['probe_protocol'] + self.probe_request_path = kwargs.get('probe_request_path', None) + + +class Resource(msrest.serialization.Model): + """The resource model definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Required. Azure resource location. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar etag: Azure resource etag. + :vartype etag: str + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + 'etag': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = kwargs['location'] + self.tags = kwargs.get('tags', None) + self.etag = None + self.system_data = None + + +class ManagedCluster(Resource): + """The manged cluster resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Required. Azure resource location. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar etag: Azure resource etag. + :vartype etag: str + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param sku: The sku of the managed cluster. + :type sku: ~service_fabric_managed_clusters_management_client.models.Sku + :param dns_name: The cluster dns name. + :type dns_name: str + :ivar fqdn: The fully qualified domain name associated with the public load balancer of the + cluster. + :vartype fqdn: str + :ivar ipv4_address: The IPv4 address associated with the public load balancer of the cluster. + :vartype ipv4_address: str + :ivar cluster_id: A service generated unique identifier for the cluster resource. + :vartype cluster_id: str + :ivar cluster_state: The current state of the cluster. Possible values include: + "WaitingForNodes", "Deploying", "BaselineUpgrade", "Upgrading", "UpgradeFailed", "Ready". + :vartype cluster_state: str or + ~service_fabric_managed_clusters_management_client.models.ClusterState + :ivar cluster_certificate_thumbprints: List of thumbprints of the cluster certificates. + :vartype cluster_certificate_thumbprints: list[str] + :param client_connection_port: The port used for client connections to the cluster. + :type client_connection_port: int + :param http_gateway_connection_port: The port used for HTTP connections to the cluster. + :type http_gateway_connection_port: int + :param admin_user_name: VM admin user name. + :type admin_user_name: str + :param admin_password: VM admin user password. + :type admin_password: str + :param load_balancing_rules: Load balancing rules that are applied to the public load balancer + of the cluster. + :type load_balancing_rules: + list[~service_fabric_managed_clusters_management_client.models.LoadBalancingRule] + :param allow_rdp_access: Setting this to true enables RDP access to the VM. The default NSG + rule opens RDP port to internet which can be overridden with custom Network Security Rules. The + default value for this setting is false. + :type allow_rdp_access: bool + :param network_security_rules: Custom Network Security Rules that are applied to the virtual + network of the cluster. + :type network_security_rules: + list[~service_fabric_managed_clusters_management_client.models.NetworkSecurityRule] + :param clients: Client certificates that are allowed to manage the cluster. + :type clients: + list[~service_fabric_managed_clusters_management_client.models.ClientCertificate] + :param azure_active_directory: The AAD authentication settings of the cluster. + :type azure_active_directory: + ~service_fabric_managed_clusters_management_client.models.AzureActiveDirectory + :param fabric_settings: The list of custom fabric settings to configure the cluster. + :type fabric_settings: + list[~service_fabric_managed_clusters_management_client.models.SettingsSectionDescription] + :ivar provisioning_state: The provisioning state of the managed cluster resource. Possible + values include: "None", "Creating", "Created", "Updating", "Succeeded", "Failed", "Canceled", + "Deleting", "Deleted", "Other". + :vartype provisioning_state: str or + ~service_fabric_managed_clusters_management_client.models.ManagedResourceProvisioningState + :param cluster_code_version: The Service Fabric runtime version of the cluster. This property + can only by set the user when **upgradeMode** is set to 'Manual'. To get list of available + Service Fabric versions for new clusters use `ClusterVersion API <./ClusterVersion.md>`_. To + get the list of available version for existing clusters use **availableClusterVersions**. + :type cluster_code_version: str + :param cluster_upgrade_cadence: Indicates when new cluster runtime version upgrades will be + applied after they are released. By default is Wave0. Possible values include: "Wave0", + "Wave1", "Wave2". + :type cluster_upgrade_cadence: str or + ~service_fabric_managed_clusters_management_client.models.ClusterUpgradeCadence + :param addon_features: List of add-on features to enable on the cluster. + :type addon_features: list[str or + ~service_fabric_managed_clusters_management_client.models.ManagedClusterAddOnFeature] + :param enable_auto_os_upgrade: Setting this to true enables automatic OS upgrade for the node + types that are created using any platform OS image with version 'latest'. The default value for + this setting is false. + :type enable_auto_os_upgrade: bool + :param application_type_versions_cleanup_policy: The policy used to clean up unused versions. + :type application_type_versions_cleanup_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionsCleanupPolicy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + 'etag': {'readonly': True}, + 'system_data': {'readonly': True}, + 'fqdn': {'readonly': True}, + 'ipv4_address': {'readonly': True}, + 'cluster_id': {'readonly': True}, + 'cluster_state': {'readonly': True}, + 'cluster_certificate_thumbprints': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'dns_name': {'key': 'properties.dnsName', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'ipv4_address': {'key': 'properties.ipv4Address', 'type': 'str'}, + 'cluster_id': {'key': 'properties.clusterId', 'type': 'str'}, + 'cluster_state': {'key': 'properties.clusterState', 'type': 'str'}, + 'cluster_certificate_thumbprints': {'key': 'properties.clusterCertificateThumbprints', 'type': '[str]'}, + 'client_connection_port': {'key': 'properties.clientConnectionPort', 'type': 'int'}, + 'http_gateway_connection_port': {'key': 'properties.httpGatewayConnectionPort', 'type': 'int'}, + 'admin_user_name': {'key': 'properties.adminUserName', 'type': 'str'}, + 'admin_password': {'key': 'properties.adminPassword', 'type': 'str'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[LoadBalancingRule]'}, + 'allow_rdp_access': {'key': 'properties.allowRdpAccess', 'type': 'bool'}, + 'network_security_rules': {'key': 'properties.networkSecurityRules', 'type': '[NetworkSecurityRule]'}, + 'clients': {'key': 'properties.clients', 'type': '[ClientCertificate]'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'fabric_settings': {'key': 'properties.fabricSettings', 'type': '[SettingsSectionDescription]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'cluster_code_version': {'key': 'properties.clusterCodeVersion', 'type': 'str'}, + 'cluster_upgrade_cadence': {'key': 'properties.clusterUpgradeCadence', 'type': 'str'}, + 'addon_features': {'key': 'properties.addonFeatures', 'type': '[str]'}, + 'enable_auto_os_upgrade': {'key': 'properties.enableAutoOSUpgrade', 'type': 'bool'}, + 'application_type_versions_cleanup_policy': {'key': 'properties.applicationTypeVersionsCleanupPolicy', 'type': 'ApplicationTypeVersionsCleanupPolicy'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedCluster, self).__init__(**kwargs) + self.sku = kwargs.get('sku', None) + self.dns_name = kwargs.get('dns_name', None) + self.fqdn = None + self.ipv4_address = None + self.cluster_id = None + self.cluster_state = None + self.cluster_certificate_thumbprints = None + self.client_connection_port = kwargs.get('client_connection_port', 19000) + self.http_gateway_connection_port = kwargs.get('http_gateway_connection_port', 19080) + self.admin_user_name = kwargs.get('admin_user_name', None) + self.admin_password = kwargs.get('admin_password', None) + self.load_balancing_rules = kwargs.get('load_balancing_rules', None) + self.allow_rdp_access = kwargs.get('allow_rdp_access', None) + self.network_security_rules = kwargs.get('network_security_rules', None) + self.clients = kwargs.get('clients', None) + self.azure_active_directory = kwargs.get('azure_active_directory', None) + self.fabric_settings = kwargs.get('fabric_settings', None) + self.provisioning_state = None + self.cluster_code_version = kwargs.get('cluster_code_version', None) + self.cluster_upgrade_cadence = kwargs.get('cluster_upgrade_cadence', None) + self.addon_features = kwargs.get('addon_features', None) + self.enable_auto_os_upgrade = kwargs.get('enable_auto_os_upgrade', None) + self.application_type_versions_cleanup_policy = kwargs.get('application_type_versions_cleanup_policy', None) + + +class ManagedClusterListResult(msrest.serialization.Model): + """Managed Cluster list results. + + :param value: + :type value: list[~service_fabric_managed_clusters_management_client.models.ManagedCluster] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ManagedCluster]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedClusterListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ManagedClusterUpdateParameters(msrest.serialization.Model): + """Managed cluster update request. + + :param tags: A set of tags. Managed cluster update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedClusterUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class ManagedIdentity(msrest.serialization.Model): + """Describes the managed identities for an Azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of the managed identity. This property will only be + provided for a system assigned identity. + :vartype principal_id: str + :ivar tenant_id: The tenant id of the managed identity. This property will only be provided for + a system assigned identity. + :vartype tenant_id: str + :param type: The type of managed identity for the resource. Possible values include: "None", + "SystemAssigned", "UserAssigned", "SystemAssigned, UserAssigned". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ManagedIdentityType + :param user_assigned_identities: The list of user identities associated with the resource. The + user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: dict[str, + ~service_fabric_managed_clusters_management_client.models.UserAssignedIdentity] + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{UserAssignedIdentity}'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedIdentity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = kwargs.get('type', None) + self.user_assigned_identities = kwargs.get('user_assigned_identities', None) + + +class ManagedProxyResource(msrest.serialization.Model): + """The resource model definition for proxy-only resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + **kwargs + ): + super(ManagedProxyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.tags = kwargs.get('tags', None) + self.system_data = None + + +class Partition(msrest.serialization.Model): + """Describes how the service is partitioned. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: NamedPartitionScheme, SingletonPartitionScheme, UniformInt64RangePartitionScheme. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + """ + + _validation = { + 'partition_scheme': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + } + + _subtype_map = { + 'partition_scheme': {'Named': 'NamedPartitionScheme', 'Singleton': 'SingletonPartitionScheme', 'UniformInt64Range': 'UniformInt64RangePartitionScheme'} + } + + def __init__( + self, + **kwargs + ): + super(Partition, self).__init__(**kwargs) + self.partition_scheme = None # type: Optional[str] + + +class NamedPartitionScheme(Partition): + """Describes the named partition scheme of the service. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + :param names: Required. Array for the names of the partitions. + :type names: list[str] + """ + + _validation = { + 'partition_scheme': {'required': True}, + 'names': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + 'names': {'key': 'names', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(NamedPartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'Named' # type: str + self.names = kwargs['names'] + + +class NetworkSecurityRule(msrest.serialization.Model): + """Describes a network security rule. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Network security rule name. + :type name: str + :param description: Network security rule description. + :type description: str + :param protocol: Required. Network protocol this rule applies to. Possible values include: + "http", "https", "tcp", "udp", "icmp", "ah", "esp". + :type protocol: str or ~service_fabric_managed_clusters_management_client.models.NsgProtocol + :param source_address_prefixes: The CIDR or source IP ranges. + :type source_address_prefixes: list[str] + :param destination_address_prefixes: The destination address prefixes. CIDR or destination IP + ranges. + :type destination_address_prefixes: list[str] + :param source_port_ranges: The source port ranges. + :type source_port_ranges: list[str] + :param destination_port_ranges: The destination port ranges. + :type destination_port_ranges: list[str] + :param access: Required. The network traffic is allowed or denied. Possible values include: + "allow", "deny". + :type access: str or ~service_fabric_managed_clusters_management_client.models.Access + :param priority: Required. The priority of the rule. The value can be in the range 1000 to + 3000. Values outside this range are reserved for Service Fabric ManagerCluster Resource + Provider. The priority number must be unique for each rule in the collection. The lower the + priority number, the higher the priority of the rule. + :type priority: int + :param direction: Required. Network security rule direction. Possible values include: + "inbound", "outbound". + :type direction: str or ~service_fabric_managed_clusters_management_client.models.Direction + """ + + _validation = { + 'name': {'required': True}, + 'protocol': {'required': True}, + 'access': {'required': True}, + 'priority': {'required': True, 'maximum': 3000, 'minimum': 1000}, + 'direction': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_address_prefixes': {'key': 'sourceAddressPrefixes', 'type': '[str]'}, + 'destination_address_prefixes': {'key': 'destinationAddressPrefixes', 'type': '[str]'}, + 'source_port_ranges': {'key': 'sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'destinationPortRanges', 'type': '[str]'}, + 'access': {'key': 'access', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'direction': {'key': 'direction', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NetworkSecurityRule, self).__init__(**kwargs) + self.name = kwargs['name'] + self.description = kwargs.get('description', None) + self.protocol = kwargs['protocol'] + self.source_address_prefixes = kwargs.get('source_address_prefixes', None) + self.destination_address_prefixes = kwargs.get('destination_address_prefixes', None) + self.source_port_ranges = kwargs.get('source_port_ranges', None) + self.destination_port_ranges = kwargs.get('destination_port_ranges', None) + self.access = kwargs['access'] + self.priority = kwargs['priority'] + self.direction = kwargs['direction'] + + +class NodeType(ManagedProxyResource): + """Describes a node type in the cluster, each node type represents sub set of nodes in the cluster. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param is_primary: The node type on which system services will run. Only one node type should + be marked as primary. Primary node type cannot be deleted or changed for existing clusters. + :type is_primary: bool + :param vm_instance_count: The number of nodes in the node type. + :type vm_instance_count: int + :param data_disk_size_gb: Disk size for each vm in the node type in GBs. + :type data_disk_size_gb: int + :param placement_properties: The placement tags applied to nodes in the node type, which can be + used to indicate where certain services (workload) should run. + :type placement_properties: dict[str, str] + :param capacities: The capacity tags applied to the nodes in the node type, the cluster + resource manager uses these tags to understand how much resource a node has. + :type capacities: dict[str, str] + :param application_ports: The range of ports from which cluster assigned port to Service Fabric + applications. + :type application_ports: + ~service_fabric_managed_clusters_management_client.models.EndpointRangeDescription + :param ephemeral_ports: The range of ephemeral ports that nodes in this node type should be + configured with. + :type ephemeral_ports: + ~service_fabric_managed_clusters_management_client.models.EndpointRangeDescription + :param vm_size: The size of virtual machines in the pool. All virtual machines in a pool are + the same size. For example, Standard_D3. + :type vm_size: str + :param vm_image_publisher: The publisher of the Azure Virtual Machines Marketplace image. For + example, Canonical or MicrosoftWindowsServer. + :type vm_image_publisher: str + :param vm_image_offer: The offer type of the Azure Virtual Machines Marketplace image. For + example, UbuntuServer or WindowsServer. + :type vm_image_offer: str + :param vm_image_sku: The SKU of the Azure Virtual Machines Marketplace image. For example, + 14.04.0-LTS or 2012-R2-Datacenter. + :type vm_image_sku: str + :param vm_image_version: The version of the Azure Virtual Machines Marketplace image. A value + of 'latest' can be specified to select the latest version of an image. If omitted, the default + is 'latest'. + :type vm_image_version: str + :param vm_secrets: The secrets to install in the virtual machines. + :type vm_secrets: + list[~service_fabric_managed_clusters_management_client.models.VaultSecretGroup] + :param vm_extensions: Set of extensions that should be installed onto the virtual machines. + :type vm_extensions: + list[~service_fabric_managed_clusters_management_client.models.VMSSExtension] + :param vm_managed_identity: Identities for the virtual machine scale set under the node type. + :type vm_managed_identity: + ~service_fabric_managed_clusters_management_client.models.VmManagedIdentity + :ivar provisioning_state: The provisioning state of the managed cluster resource. Possible + values include: "None", "Creating", "Created", "Updating", "Succeeded", "Failed", "Canceled", + "Deleting", "Deleted", "Other". + :vartype provisioning_state: str or + ~service_fabric_managed_clusters_management_client.models.ManagedResourceProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'vm_instance_count': {'maximum': 2147483647, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_primary': {'key': 'properties.isPrimary', 'type': 'bool'}, + 'vm_instance_count': {'key': 'properties.vmInstanceCount', 'type': 'int'}, + 'data_disk_size_gb': {'key': 'properties.dataDiskSizeGB', 'type': 'int'}, + 'placement_properties': {'key': 'properties.placementProperties', 'type': '{str}'}, + 'capacities': {'key': 'properties.capacities', 'type': '{str}'}, + 'application_ports': {'key': 'properties.applicationPorts', 'type': 'EndpointRangeDescription'}, + 'ephemeral_ports': {'key': 'properties.ephemeralPorts', 'type': 'EndpointRangeDescription'}, + 'vm_size': {'key': 'properties.vmSize', 'type': 'str'}, + 'vm_image_publisher': {'key': 'properties.vmImagePublisher', 'type': 'str'}, + 'vm_image_offer': {'key': 'properties.vmImageOffer', 'type': 'str'}, + 'vm_image_sku': {'key': 'properties.vmImageSku', 'type': 'str'}, + 'vm_image_version': {'key': 'properties.vmImageVersion', 'type': 'str'}, + 'vm_secrets': {'key': 'properties.vmSecrets', 'type': '[VaultSecretGroup]'}, + 'vm_extensions': {'key': 'properties.vmExtensions', 'type': '[VMSSExtension]'}, + 'vm_managed_identity': {'key': 'properties.vmManagedIdentity', 'type': 'VmManagedIdentity'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NodeType, self).__init__(**kwargs) + self.is_primary = kwargs.get('is_primary', None) + self.vm_instance_count = kwargs.get('vm_instance_count', None) + self.data_disk_size_gb = kwargs.get('data_disk_size_gb', None) + self.placement_properties = kwargs.get('placement_properties', None) + self.capacities = kwargs.get('capacities', None) + self.application_ports = kwargs.get('application_ports', None) + self.ephemeral_ports = kwargs.get('ephemeral_ports', None) + self.vm_size = kwargs.get('vm_size', None) + self.vm_image_publisher = kwargs.get('vm_image_publisher', None) + self.vm_image_offer = kwargs.get('vm_image_offer', None) + self.vm_image_sku = kwargs.get('vm_image_sku', None) + self.vm_image_version = kwargs.get('vm_image_version', None) + self.vm_secrets = kwargs.get('vm_secrets', None) + self.vm_extensions = kwargs.get('vm_extensions', None) + self.vm_managed_identity = kwargs.get('vm_managed_identity', None) + self.provisioning_state = None + + +class NodeTypeActionParameters(msrest.serialization.Model): + """Parameters for Node type action. + + All required parameters must be populated in order to send to Azure. + + :param nodes: Required. List of node names from the node type. + :type nodes: list[str] + :param force: Force the action to go through. + :type force: bool + """ + + _validation = { + 'nodes': {'required': True}, + } + + _attribute_map = { + 'nodes': {'key': 'nodes', 'type': '[str]'}, + 'force': {'key': 'force', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(NodeTypeActionParameters, self).__init__(**kwargs) + self.nodes = kwargs['nodes'] + self.force = kwargs.get('force', None) + + +class NodeTypeListResult(msrest.serialization.Model): + """Node type list results. + + :param value: The list of node types. + :type value: list[~service_fabric_managed_clusters_management_client.models.NodeType] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NodeType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NodeTypeListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class NodeTypeUpdateParameters(msrest.serialization.Model): + """Node type update request. + + :param tags: A set of tags. Node type update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(NodeTypeUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class OperationListResult(msrest.serialization.Model): + """Describes the result of the request to list Service Fabric resource provider operations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: List of operations supported by the Service Fabric resource provider. + :type value: list[~service_fabric_managed_clusters_management_client.models.OperationResult] + :ivar next_link: URL to get the next set of operation list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OperationResult]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class OperationResult(msrest.serialization.Model): + """Available operation list result. + + :param name: The name of the operation. + :type name: str + :param is_data_action: Indicates whether the operation is a data action. + :type is_data_action: bool + :param display: The object that represents the operation. + :type display: + ~service_fabric_managed_clusters_management_client.models.AvailableOperationDisplay + :param origin: Origin result. + :type origin: str + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'is_data_action': {'key': 'isDataAction', 'type': 'bool'}, + 'display': {'key': 'display', 'type': 'AvailableOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationResult, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.is_data_action = kwargs.get('is_data_action', None) + self.display = kwargs.get('display', None) + self.origin = kwargs.get('origin', None) + self.next_link = kwargs.get('next_link', None) + + +class PartitionInstanceCountScaleMechanism(ScalingMechanism): + """Represents a scaling mechanism for adding or removing instances of stateless service partition. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + :param min_instance_count: Required. Minimum number of instances of the partition. + :type min_instance_count: int + :param max_instance_count: Required. Maximum number of instances of the partition. + :type max_instance_count: int + :param scale_increment: Required. The number of instances to add or remove during a scaling + operation. + :type scale_increment: int + """ + + _validation = { + 'kind': {'required': True}, + 'min_instance_count': {'required': True}, + 'max_instance_count': {'required': True}, + 'scale_increment': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'min_instance_count': {'key': 'minInstanceCount', 'type': 'int'}, + 'max_instance_count': {'key': 'maxInstanceCount', 'type': 'int'}, + 'scale_increment': {'key': 'scaleIncrement', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(PartitionInstanceCountScaleMechanism, self).__init__(**kwargs) + self.kind = 'ScalePartitionInstanceCount' # type: str + self.min_instance_count = kwargs['min_instance_count'] + self.max_instance_count = kwargs['max_instance_count'] + self.scale_increment = kwargs['scale_increment'] + + +class RollingUpgradeMonitoringPolicy(msrest.serialization.Model): + """The policy used for monitoring the application upgrade. + + All required parameters must be populated in order to send to Azure. + + :param failure_action: Required. The compensating action to perform when a Monitored upgrade + encounters monitoring policy or health policy violations. Invalid indicates the failure action + is invalid. Rollback specifies that the upgrade will start rolling back automatically. Manual + indicates that the upgrade will switch to UnmonitoredManual upgrade mode. Possible values + include: "Rollback", "Manual". + :type failure_action: str or + ~service_fabric_managed_clusters_management_client.models.FailureAction + :param health_check_wait_duration: Required. The amount of time to wait after completing an + upgrade domain before applying health policies. It is interpreted as a string representing an + ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_wait_duration: str + :param health_check_stable_duration: Required. The amount of time that the application or + cluster must remain healthy before the upgrade proceeds to the next upgrade domain. It is + interpreted as a string representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_stable_duration: str + :param health_check_retry_timeout: Required. The amount of time to retry health evaluation when + the application or cluster is unhealthy before FailureAction is executed. It is interpreted as + a string representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_retry_timeout: str + :param upgrade_timeout: Required. The amount of time the overall upgrade has to complete before + FailureAction is executed. Cannot be larger than 12 hours. It is interpreted as a string + representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type upgrade_timeout: str + :param upgrade_domain_timeout: Required. The amount of time each upgrade domain has to complete + before FailureAction is executed. Cannot be larger than 12 hours. It is interpreted as a string + representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type upgrade_domain_timeout: str + """ + + _validation = { + 'failure_action': {'required': True}, + 'health_check_wait_duration': {'required': True}, + 'health_check_stable_duration': {'required': True}, + 'health_check_retry_timeout': {'required': True}, + 'upgrade_timeout': {'required': True}, + 'upgrade_domain_timeout': {'required': True}, + } + + _attribute_map = { + 'failure_action': {'key': 'failureAction', 'type': 'str'}, + 'health_check_wait_duration': {'key': 'healthCheckWaitDuration', 'type': 'str'}, + 'health_check_stable_duration': {'key': 'healthCheckStableDuration', 'type': 'str'}, + 'health_check_retry_timeout': {'key': 'healthCheckRetryTimeout', 'type': 'str'}, + 'upgrade_timeout': {'key': 'upgradeTimeout', 'type': 'str'}, + 'upgrade_domain_timeout': {'key': 'upgradeDomainTimeout', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(RollingUpgradeMonitoringPolicy, self).__init__(**kwargs) + self.failure_action = kwargs['failure_action'] + self.health_check_wait_duration = kwargs['health_check_wait_duration'] + self.health_check_stable_duration = kwargs['health_check_stable_duration'] + self.health_check_retry_timeout = kwargs['health_check_retry_timeout'] + self.upgrade_timeout = kwargs['upgrade_timeout'] + self.upgrade_domain_timeout = kwargs['upgrade_domain_timeout'] + + +class ScalingPolicy(msrest.serialization.Model): + """Specifies a metric to load balance a service during runtime. + + All required parameters must be populated in order to send to Azure. + + :param scaling_mechanism: Required. Specifies the mechanism associated with this scaling + policy. + :type scaling_mechanism: + ~service_fabric_managed_clusters_management_client.models.ScalingMechanism + :param scaling_trigger: Required. Specifies the trigger associated with this scaling policy. + :type scaling_trigger: ~service_fabric_managed_clusters_management_client.models.ScalingTrigger + """ + + _validation = { + 'scaling_mechanism': {'required': True}, + 'scaling_trigger': {'required': True}, + } + + _attribute_map = { + 'scaling_mechanism': {'key': 'scalingMechanism', 'type': 'ScalingMechanism'}, + 'scaling_trigger': {'key': 'scalingTrigger', 'type': 'ScalingTrigger'}, + } + + def __init__( + self, + **kwargs + ): + super(ScalingPolicy, self).__init__(**kwargs) + self.scaling_mechanism = kwargs['scaling_mechanism'] + self.scaling_trigger = kwargs['scaling_trigger'] + + +class ServiceCorrelation(msrest.serialization.Model): + """Creates a particular correlation between services. + + All required parameters must be populated in order to send to Azure. + + :param scheme: Required. The ServiceCorrelationScheme which describes the relationship between + this service and the service specified via ServiceName. Possible values include: + "AlignedAffinity", "NonAlignedAffinity". + :type scheme: str or + ~service_fabric_managed_clusters_management_client.models.ServiceCorrelationScheme + :param service_name: Required. The Arm Resource ID of the service that the correlation + relationship is established with. + :type service_name: str + """ + + _validation = { + 'scheme': {'required': True}, + 'service_name': {'required': True}, + } + + _attribute_map = { + 'scheme': {'key': 'scheme', 'type': 'str'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceCorrelation, self).__init__(**kwargs) + self.scheme = kwargs['scheme'] + self.service_name = kwargs['service_name'] + + +class ServiceLoadMetric(msrest.serialization.Model): + """Specifies a metric to load balance a service during runtime. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the metric. If the service chooses to report load during + runtime, the load metric name should match the name that is specified in Name exactly. Note + that metric names are case sensitive. + :type name: str + :param weight: The service load metric relative weight, compared to other metrics configured + for this service, as a number. Possible values include: "Zero", "Low", "Medium", "High". + :type weight: str or + ~service_fabric_managed_clusters_management_client.models.ServiceLoadMetricWeight + :param primary_default_load: Used only for Stateful services. The default amount of load, as a + number, that this service creates for this metric when it is a Primary replica. + :type primary_default_load: int + :param secondary_default_load: Used only for Stateful services. The default amount of load, as + a number, that this service creates for this metric when it is a Secondary replica. + :type secondary_default_load: int + :param default_load: Used only for Stateless services. The default amount of load, as a number, + that this service creates for this metric. + :type default_load: int + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'str'}, + 'primary_default_load': {'key': 'primaryDefaultLoad', 'type': 'int'}, + 'secondary_default_load': {'key': 'secondaryDefaultLoad', 'type': 'int'}, + 'default_load': {'key': 'defaultLoad', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceLoadMetric, self).__init__(**kwargs) + self.name = kwargs['name'] + self.weight = kwargs.get('weight', None) + self.primary_default_load = kwargs.get('primary_default_load', None) + self.secondary_default_load = kwargs.get('secondary_default_load', None) + self.default_load = kwargs.get('default_load', None) + + +class ServicePlacementPolicy(msrest.serialization.Model): + """Describes the policy to be used for placement of a Service Fabric service. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: ServicePlacementInvalidDomainPolicy, ServicePlacementNonPartiallyPlaceServicePolicy, ServicePlacementPreferPrimaryDomainPolicy, ServicePlacementRequiredDomainPolicy, ServicePlacementRequireDomainDistributionPolicy. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + """ + + _validation = { + 'type': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + _subtype_map = { + 'type': {'InvalidDomain': 'ServicePlacementInvalidDomainPolicy', 'NonPartiallyPlaceService': 'ServicePlacementNonPartiallyPlaceServicePolicy', 'PreferredPrimaryDomain': 'ServicePlacementPreferPrimaryDomainPolicy', 'RequiredDomain': 'ServicePlacementRequiredDomainPolicy', 'RequiredDomainDistribution': 'ServicePlacementRequireDomainDistributionPolicy'} + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementPolicy, self).__init__(**kwargs) + self.type = None # type: Optional[str] + + +class ServicePlacementInvalidDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where a particular fault or upgrade domain should not be used for placement of the instances or replicas of that service. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should not be used for placement. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementInvalidDomainPolicy, self).__init__(**kwargs) + self.type = 'InvalidDomain' # type: str + self.domain_name = kwargs['domain_name'] + + +class ServicePlacementNonPartiallyPlaceServicePolicy(ServicePlacementPolicy): + """ServicePlacementNonPartiallyPlaceServicePolicy. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + """ + + _validation = { + 'type': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementNonPartiallyPlaceServicePolicy, self).__init__(**kwargs) + self.type = 'NonPartiallyPlaceService' # type: str + + +class ServicePlacementPreferPrimaryDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where the service's +Primary replicas should optimally be placed in a particular domain. + +This placement policy is usually used with fault domains in scenarios where the Service Fabric +cluster is geographically distributed in order to indicate that a service's primary replica should +be located in a particular fault domain, which in geo-distributed scenarios usually aligns with regional +or datacenter boundaries. Note that since this is an optimization it is possible that the Primary replica +may not end up located in this domain due to failures, capacity limits, or other constraints. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementPreferPrimaryDomainPolicy, self).__init__(**kwargs) + self.type = 'PreferredPrimaryDomain' # type: str + self.domain_name = kwargs['domain_name'] + + +class ServicePlacementRequiredDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where the instances or replicas of that service must be placed in a particular domain. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementRequiredDomainPolicy, self).__init__(**kwargs) + self.type = 'RequiredDomain' # type: str + self.domain_name = kwargs['domain_name'] + + +class ServicePlacementRequireDomainDistributionPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where two replicas +from the same partition should never be placed in the same fault or upgrade domain. + +While this is not common it can expose the service to an increased risk of concurrent failures +due to unplanned outages or other cases of subsequent/concurrent failures. As an example, consider +a case where replicas are deployed across different data center, with one replica per location. +In the event that one of the datacenters goes offline, normally the replica that was placed in that +datacenter will be packed into one of the remaining datacenters. If this is not desirable then this +policy should be set. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementRequireDomainDistributionPolicy, self).__init__(**kwargs) + self.type = 'RequiredDomainDistribution' # type: str + self.domain_name = kwargs['domain_name'] + + +class ServiceResource(ProxyResource): + """The service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param properties: The service resource properties. + :type properties: + ~service_fabric_managed_clusters_management_client.models.ServiceResourceProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': 'ServiceResourceProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceResource, self).__init__(**kwargs) + self.properties = kwargs.get('properties', None) + + +class ServiceResourceList(msrest.serialization.Model): + """The list of service resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: list[~service_fabric_managed_clusters_management_client.models.ServiceResource] + :ivar next_link: URL to get the next set of service list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceResourceList, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ServiceResourcePropertiesBase(msrest.serialization.Model): + """The common service resource properties. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + """ + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceResourcePropertiesBase, self).__init__(**kwargs) + self.placement_constraints = kwargs.get('placement_constraints', None) + self.correlation_scheme = kwargs.get('correlation_scheme', None) + self.service_load_metrics = kwargs.get('service_load_metrics', None) + self.service_placement_policies = kwargs.get('service_placement_policies', None) + self.default_move_cost = kwargs.get('default_move_cost', None) + self.scaling_policies = kwargs.get('scaling_policies', None) + + +class ServiceResourceProperties(ServiceResourcePropertiesBase): + """The service resource properties. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: StatefulServiceProperties, StatelessServiceProperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + } + + _subtype_map = { + 'service_kind': {'Stateful': 'StatefulServiceProperties', 'Stateless': 'StatelessServiceProperties'} + } + + def __init__( + self, + **kwargs + ): + super(ServiceResourceProperties, self).__init__(**kwargs) + self.provisioning_state = None + self.service_kind = 'ServiceResourceProperties' # type: str + self.service_type_name = kwargs['service_type_name'] + self.partition_description = kwargs['partition_description'] + self.service_package_activation_mode = kwargs.get('service_package_activation_mode', None) + self.service_dns_name = kwargs.get('service_dns_name', None) + + +class ServiceTypeHealthPolicy(msrest.serialization.Model): + """Represents the health policy used to evaluate the health of services belonging to a service type. + + All required parameters must be populated in order to send to Azure. + + :param max_percent_unhealthy_services: Required. The maximum allowed percentage of unhealthy + services. + + The percentage represents the maximum tolerated percentage of services that can be unhealthy + before the application is considered in error. + If the percentage is respected but there is at least one unhealthy service, the health is + evaluated as Warning. + This is calculated by dividing the number of unhealthy services of the specific service type + over the total number of services of the specific service type. + The computation rounds up to tolerate one failure on small numbers of services. + :type max_percent_unhealthy_services: int + :param max_percent_unhealthy_partitions_per_service: Required. The maximum allowed percentage + of unhealthy partitions per service. + + The percentage represents the maximum tolerated percentage of partitions that can be unhealthy + before the service is considered in error. + If the percentage is respected but there is at least one unhealthy partition, the health is + evaluated as Warning. + The percentage is calculated by dividing the number of unhealthy partitions over the total + number of partitions in the service. + The computation rounds up to tolerate one failure on small numbers of partitions. + :type max_percent_unhealthy_partitions_per_service: int + :param max_percent_unhealthy_replicas_per_partition: Required. The maximum allowed percentage + of unhealthy replicas per partition. + + The percentage represents the maximum tolerated percentage of replicas that can be unhealthy + before the partition is considered in error. + If the percentage is respected but there is at least one unhealthy replica, the health is + evaluated as Warning. + The percentage is calculated by dividing the number of unhealthy replicas over the total + number of replicas in the partition. + The computation rounds up to tolerate one failure on small numbers of replicas. + :type max_percent_unhealthy_replicas_per_partition: int + """ + + _validation = { + 'max_percent_unhealthy_services': {'required': True, 'maximum': 100, 'minimum': 0}, + 'max_percent_unhealthy_partitions_per_service': {'required': True, 'maximum': 100, 'minimum': 0}, + 'max_percent_unhealthy_replicas_per_partition': {'required': True, 'maximum': 100, 'minimum': 0}, + } + + _attribute_map = { + 'max_percent_unhealthy_services': {'key': 'maxPercentUnhealthyServices', 'type': 'int'}, + 'max_percent_unhealthy_partitions_per_service': {'key': 'maxPercentUnhealthyPartitionsPerService', 'type': 'int'}, + 'max_percent_unhealthy_replicas_per_partition': {'key': 'maxPercentUnhealthyReplicasPerPartition', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceTypeHealthPolicy, self).__init__(**kwargs) + self.max_percent_unhealthy_services = kwargs['max_percent_unhealthy_services'] + self.max_percent_unhealthy_partitions_per_service = kwargs['max_percent_unhealthy_partitions_per_service'] + self.max_percent_unhealthy_replicas_per_partition = kwargs['max_percent_unhealthy_replicas_per_partition'] + + +class ServiceUpdateParameters(msrest.serialization.Model): + """Service update request. + + :param tags: A set of tags. Service update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ServiceUpdateParameters, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class SettingsParameterDescription(msrest.serialization.Model): + """Describes a parameter in fabric settings of the cluster. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The parameter name of fabric setting. + :type name: str + :param value: Required. The parameter value of fabric setting. + :type value: str + """ + + _validation = { + 'name': {'required': True}, + 'value': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SettingsParameterDescription, self).__init__(**kwargs) + self.name = kwargs['name'] + self.value = kwargs['value'] + + +class SettingsSectionDescription(msrest.serialization.Model): + """Describes a section in the fabric settings of the cluster. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The section name of the fabric settings. + :type name: str + :param parameters: Required. The collection of parameters in the section. + :type parameters: + list[~service_fabric_managed_clusters_management_client.models.SettingsParameterDescription] + """ + + _validation = { + 'name': {'required': True}, + 'parameters': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[SettingsParameterDescription]'}, + } + + def __init__( + self, + **kwargs + ): + super(SettingsSectionDescription, self).__init__(**kwargs) + self.name = kwargs['name'] + self.parameters = kwargs['parameters'] + + +class SingletonPartitionScheme(Partition): + """SingletonPartitionScheme. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + """ + + _validation = { + 'partition_scheme': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SingletonPartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'Singleton' # type: str + + +class Sku(msrest.serialization.Model): + """Service Fabric managed cluster Sku definition. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Sku Name. Possible values include: "Basic", "Standard". + :type name: str or ~service_fabric_managed_clusters_management_client.models.SkuName + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Sku, self).__init__(**kwargs) + self.name = kwargs['name'] + + +class StatefulServiceProperties(ServiceResourceProperties): + """The properties of a stateful service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + :param has_persisted_state: A flag indicating whether this is a persistent service which stores + states on the local disk. If it is then the value of this property is true, if not it is false. + :type has_persisted_state: bool + :param target_replica_set_size: The target replica set size as a number. + :type target_replica_set_size: int + :param min_replica_set_size: The minimum replica set size as a number. + :type min_replica_set_size: int + :param replica_restart_wait_duration: The duration between when a replica goes down and when a + new replica is created, represented in ISO 8601 format "hh:mm:ss". + :type replica_restart_wait_duration: str + :param quorum_loss_wait_duration: The maximum duration for which a partition is allowed to be + in a state of quorum loss, represented in ISO 8601 format "hh:mm:ss". + :type quorum_loss_wait_duration: str + :param stand_by_replica_keep_duration: The definition on how long StandBy replicas should be + maintained before being removed, represented in ISO 8601 format "hh:mm:ss". + :type stand_by_replica_keep_duration: str + :param service_placement_time_limit: The duration for which replicas can stay InBuild before + reporting that build is stuck, represented in ISO 8601 format "hh:mm:ss". + :type service_placement_time_limit: str + :param drop_source_replica_on_move: Indicates whether to drop source Secondary replica even if + the target replica has not finished build. If desired behavior is to drop it as soon as + possible the value of this property is true, if not it is false. + :type drop_source_replica_on_move: bool + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + 'target_replica_set_size': {'minimum': 1}, + 'min_replica_set_size': {'minimum': 1}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + 'has_persisted_state': {'key': 'hasPersistedState', 'type': 'bool'}, + 'target_replica_set_size': {'key': 'targetReplicaSetSize', 'type': 'int'}, + 'min_replica_set_size': {'key': 'minReplicaSetSize', 'type': 'int'}, + 'replica_restart_wait_duration': {'key': 'replicaRestartWaitDuration', 'type': 'str'}, + 'quorum_loss_wait_duration': {'key': 'quorumLossWaitDuration', 'type': 'str'}, + 'stand_by_replica_keep_duration': {'key': 'standByReplicaKeepDuration', 'type': 'str'}, + 'service_placement_time_limit': {'key': 'servicePlacementTimeLimit', 'type': 'str'}, + 'drop_source_replica_on_move': {'key': 'dropSourceReplicaOnMove', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(StatefulServiceProperties, self).__init__(**kwargs) + self.service_kind = 'Stateful' # type: str + self.has_persisted_state = kwargs.get('has_persisted_state', None) + self.target_replica_set_size = kwargs.get('target_replica_set_size', None) + self.min_replica_set_size = kwargs.get('min_replica_set_size', None) + self.replica_restart_wait_duration = kwargs.get('replica_restart_wait_duration', None) + self.quorum_loss_wait_duration = kwargs.get('quorum_loss_wait_duration', None) + self.stand_by_replica_keep_duration = kwargs.get('stand_by_replica_keep_duration', None) + self.service_placement_time_limit = kwargs.get('service_placement_time_limit', None) + self.drop_source_replica_on_move = kwargs.get('drop_source_replica_on_move', None) + + +class StatelessServiceProperties(ServiceResourceProperties): + """The properties of a stateless service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + :param instance_count: Required. The instance count. + :type instance_count: int + :param min_instance_count: MinInstanceCount is the minimum number of instances that must be up + to meet the EnsureAvailability safety check during operations like upgrade or deactivate node. + The actual number that is used is max( MinInstanceCount, ceil( MinInstancePercentage/100.0 * + InstanceCount) ). Note, if InstanceCount is set to -1, during MinInstanceCount computation -1 + is first converted into the number of nodes on which the instances are allowed to be placed + according to the placement constraints on the service. + :type min_instance_count: int + :param min_instance_percentage: MinInstancePercentage is the minimum percentage of + InstanceCount that must be up to meet the EnsureAvailability safety check during operations + like upgrade or deactivate node. The actual number that is used is max( MinInstanceCount, ceil( + MinInstancePercentage/100.0 * InstanceCount) ). Note, if InstanceCount is set to -1, during + MinInstancePercentage computation, -1 is first converted into the number of nodes on which the + instances are allowed to be placed according to the placement constraints on the service. + :type min_instance_percentage: int + :param instance_close_delay_duration: Duration represented in ISO 8601 format "hh:mm:ss", to + wait before a stateless instance is closed, to allow the active requests to drain gracefully. + This would be effective when the instance is closing during the application/cluster upgrade and + disabling node. The endpoint exposed on this instance is removed prior to starting the delay, + which prevents new connections to this instance. In addition, clients that have subscribed to + service endpoint change + events(https://docs.microsoft.com/dotnet/api/system.fabric.fabricclient.servicemanagementclient.registerservicenotificationfilterasync), + can do the following upon receiving the endpoint removal notification: - Stop sending new + requests to this instance. - Close existing connections after in-flight requests have + completed. - Connect to a different instance of the service partition for future requests. + Note, the default value of InstanceCloseDelayDuration is 0, which indicates that there won't be + any delay or removal of the endpoint prior to closing the instance. + :type instance_close_delay_duration: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + 'instance_count': {'required': True, 'minimum': -1}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + 'instance_count': {'key': 'instanceCount', 'type': 'int'}, + 'min_instance_count': {'key': 'minInstanceCount', 'type': 'int'}, + 'min_instance_percentage': {'key': 'minInstancePercentage', 'type': 'int'}, + 'instance_close_delay_duration': {'key': 'instanceCloseDelayDuration', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(StatelessServiceProperties, self).__init__(**kwargs) + self.service_kind = 'Stateless' # type: str + self.instance_count = kwargs['instance_count'] + self.min_instance_count = kwargs.get('min_instance_count', None) + self.min_instance_percentage = kwargs.get('min_instance_percentage', None) + self.instance_close_delay_duration = kwargs.get('instance_close_delay_duration', "0") + + +class SubResource(msrest.serialization.Model): + """Azure resource identifier. + + :param id: Azure resource identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SubResource, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. + :type created_by_type: str + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. + :type last_modified_by_type: str + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = kwargs.get('created_by', None) + self.created_by_type = kwargs.get('created_by_type', None) + self.created_at = kwargs.get('created_at', None) + self.last_modified_by = kwargs.get('last_modified_by', None) + self.last_modified_by_type = kwargs.get('last_modified_by_type', None) + self.last_modified_at = kwargs.get('last_modified_at', None) + + +class UniformInt64RangePartitionScheme(Partition): + """Describes a partitioning scheme where an integer range is allocated evenly across a number of partitions. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + :param count: Required. The number of partitions. + :type count: int + :param low_key: Required. The lower bound of the partition key range that + should be split between the partition ‘Count’. + :type low_key: long + :param high_key: Required. The upper bound of the partition key range that + should be split between the partition ‘Count’. + :type high_key: long + """ + + _validation = { + 'partition_scheme': {'required': True}, + 'count': {'required': True}, + 'low_key': {'required': True}, + 'high_key': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'low_key': {'key': 'lowKey', 'type': 'long'}, + 'high_key': {'key': 'highKey', 'type': 'long'}, + } + + def __init__( + self, + **kwargs + ): + super(UniformInt64RangePartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'UniformInt64Range' # type: str + self.count = kwargs['count'] + self.low_key = kwargs['low_key'] + self.high_key = kwargs['high_key'] + + +class UserAssignedIdentity(msrest.serialization.Model): + """UserAssignedIdentity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of user assigned identity. + :vartype principal_id: str + :ivar client_id: The client id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UserAssignedIdentity, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class VaultCertificate(msrest.serialization.Model): + """Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. + + All required parameters must be populated in order to send to Azure. + + :param certificate_url: Required. This is the URL of a certificate that has been uploaded to + Key Vault as a secret. For adding a secret to the Key Vault, see `Add a key or secret to the + key vault `_. In this + case, your certificate needs to be It is the Base64 encoding of the following JSON Object which + is encoded in UTF-8: :code:`
`:code:`
` {:code:`
` "data":":code:``",:code:`
` "dataType":"pfx",:code:`
` "password":":code:``":code:`
`}. + :type certificate_url: str + :param certificate_store: Required. For Windows VMs, specifies the certificate store on the + Virtual Machine to which the certificate should be added. The specified certificate store is + implicitly in the LocalMachine account. :code:`
`:code:`
`For Linux VMs, the certificate + file is placed under the /var/lib/waagent directory, with the file name + :code:``.crt for the X509 certificate file and + :code:``.prv for private key. Both of these files are .pem formatted. + :type certificate_store: str + """ + + _validation = { + 'certificate_url': {'required': True}, + 'certificate_store': {'required': True}, + } + + _attribute_map = { + 'certificate_url': {'key': 'certificateUrl', 'type': 'str'}, + 'certificate_store': {'key': 'certificateStore', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VaultCertificate, self).__init__(**kwargs) + self.certificate_url = kwargs['certificate_url'] + self.certificate_store = kwargs['certificate_store'] + + +class VaultSecretGroup(msrest.serialization.Model): + """Specifies set of certificates that should be installed onto the virtual machines. + + All required parameters must be populated in order to send to Azure. + + :param source_vault: Required. The relative URL of the Key Vault containing all of the + certificates in VaultCertificates. + :type source_vault: ~service_fabric_managed_clusters_management_client.models.SubResource + :param vault_certificates: Required. The list of key vault references in SourceVault which + contain certificates. + :type vault_certificates: + list[~service_fabric_managed_clusters_management_client.models.VaultCertificate] + """ + + _validation = { + 'source_vault': {'required': True}, + 'vault_certificates': {'required': True}, + } + + _attribute_map = { + 'source_vault': {'key': 'sourceVault', 'type': 'SubResource'}, + 'vault_certificates': {'key': 'vaultCertificates', 'type': '[VaultCertificate]'}, + } + + def __init__( + self, + **kwargs + ): + super(VaultSecretGroup, self).__init__(**kwargs) + self.source_vault = kwargs['source_vault'] + self.vault_certificates = kwargs['vault_certificates'] + + +class VmManagedIdentity(msrest.serialization.Model): + """Identities for the virtual machine scale set under the node type. + + :param user_assigned_identities: The list of user identities associated with the virtual + machine scale set under the node type. Each entry will be an ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: list[str] + """ + + _attribute_map = { + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(VmManagedIdentity, self).__init__(**kwargs) + self.user_assigned_identities = kwargs.get('user_assigned_identities', None) + + +class VMSSExtension(msrest.serialization.Model): + """Specifies set of extensions that should be installed onto the virtual machines. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the extension. + :type name: str + :param publisher: Required. The name of the extension handler publisher. + :type publisher: str + :param type: Required. Specifies the type of the extension; an example is + "CustomScriptExtension". + :type type: str + :param type_handler_version: Required. Specifies the version of the script handler. + :type type_handler_version: str + :param auto_upgrade_minor_version: Indicates whether the extension should use a newer minor + version if one is available at deployment time. Once deployed, however, the extension will not + upgrade minor versions unless redeployed, even with this property set to true. + :type auto_upgrade_minor_version: bool + :param settings: Json formatted public settings for the extension. + :type settings: object + :param protected_settings: The extension can contain either protectedSettings or + protectedSettingsFromKeyVault or no protected settings at all. + :type protected_settings: object + :param force_update_tag: If a value is provided and is different from the previous value, the + extension handler will be forced to update even if the extension configuration has not changed. + :type force_update_tag: str + :param provision_after_extensions: Collection of extension names after which this extension + needs to be provisioned. + :type provision_after_extensions: list[str] + :ivar provisioning_state: The provisioning state, which only appears in the response. + :vartype provisioning_state: str + """ + + _validation = { + 'name': {'required': True}, + 'publisher': {'required': True}, + 'type': {'required': True}, + 'type_handler_version': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'publisher': {'key': 'properties.publisher', 'type': 'str'}, + 'type': {'key': 'properties.type', 'type': 'str'}, + 'type_handler_version': {'key': 'properties.typeHandlerVersion', 'type': 'str'}, + 'auto_upgrade_minor_version': {'key': 'properties.autoUpgradeMinorVersion', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': 'object'}, + 'protected_settings': {'key': 'properties.protectedSettings', 'type': 'object'}, + 'force_update_tag': {'key': 'properties.forceUpdateTag', 'type': 'str'}, + 'provision_after_extensions': {'key': 'properties.provisionAfterExtensions', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(VMSSExtension, self).__init__(**kwargs) + self.name = kwargs['name'] + self.publisher = kwargs['publisher'] + self.type = kwargs['type'] + self.type_handler_version = kwargs['type_handler_version'] + self.auto_upgrade_minor_version = kwargs.get('auto_upgrade_minor_version', None) + self.settings = kwargs.get('settings', None) + self.protected_settings = kwargs.get('protected_settings', None) + self.force_update_tag = kwargs.get('force_update_tag', None) + self.provision_after_extensions = kwargs.get('provision_after_extensions', None) + self.provisioning_state = None diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models_py3.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models_py3.py new file mode 100644 index 000000000000..7cc55bc46409 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_models_py3.py @@ -0,0 +1,3442 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import datetime +from typing import Dict, List, Optional, Union + +from azure.core.exceptions import HttpResponseError +import msrest.serialization + +from ._service_fabric_managed_clusters_management_client_enums import * + + +class ScalingMechanism(msrest.serialization.Model): + """Describes the mechanism for performing a scaling operation. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: AddRemoveIncrementalNamedPartitionScalingMechanism, PartitionInstanceCountScaleMechanism. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + """ + + _validation = { + 'kind': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + } + + _subtype_map = { + 'kind': {'AddRemoveIncrementalNamedPartition': 'AddRemoveIncrementalNamedPartitionScalingMechanism', 'ScalePartitionInstanceCount': 'PartitionInstanceCountScaleMechanism'} + } + + def __init__( + self, + **kwargs + ): + super(ScalingMechanism, self).__init__(**kwargs) + self.kind = None # type: Optional[str] + + +class AddRemoveIncrementalNamedPartitionScalingMechanism(ScalingMechanism): + """Represents a scaling mechanism for adding or removing named partitions of a stateless service. Partition names are in the format '0','1'...'N-1'. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + :param min_partition_count: Required. Minimum number of named partitions of the service. + :type min_partition_count: int + :param max_partition_count: Required. Maximum number of named partitions of the service. + :type max_partition_count: int + :param scale_increment: Required. The number of instances to add or remove during a scaling + operation. + :type scale_increment: int + """ + + _validation = { + 'kind': {'required': True}, + 'min_partition_count': {'required': True}, + 'max_partition_count': {'required': True}, + 'scale_increment': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'min_partition_count': {'key': 'minPartitionCount', 'type': 'int'}, + 'max_partition_count': {'key': 'maxPartitionCount', 'type': 'int'}, + 'scale_increment': {'key': 'scaleIncrement', 'type': 'int'}, + } + + def __init__( + self, + *, + min_partition_count: int, + max_partition_count: int, + scale_increment: int, + **kwargs + ): + super(AddRemoveIncrementalNamedPartitionScalingMechanism, self).__init__(**kwargs) + self.kind = 'AddRemoveIncrementalNamedPartition' # type: str + self.min_partition_count = min_partition_count + self.max_partition_count = max_partition_count + self.scale_increment = scale_increment + + +class ApplicationHealthPolicy(msrest.serialization.Model): + """Defines a health policy used to evaluate the health of an application or one of its children entities. + + All required parameters must be populated in order to send to Azure. + + :param consider_warning_as_error: Required. Indicates whether warnings are treated with the + same severity as errors. + :type consider_warning_as_error: bool + :param max_percent_unhealthy_deployed_applications: Required. The maximum allowed percentage of + unhealthy deployed applications. Allowed values are Byte values from zero to 100. + The percentage represents the maximum tolerated percentage of deployed applications that can + be unhealthy before the application is considered in error. + This is calculated by dividing the number of unhealthy deployed applications over the number + of nodes where the application is currently deployed on in the cluster. + The computation rounds up to tolerate one failure on small numbers of nodes. Default + percentage is zero. + :type max_percent_unhealthy_deployed_applications: int + :param default_service_type_health_policy: The health policy used by default to evaluate the + health of a service type. + :type default_service_type_health_policy: + ~service_fabric_managed_clusters_management_client.models.ServiceTypeHealthPolicy + :param service_type_health_policy_map: The map with service type health policy per service type + name. The map is empty by default. + :type service_type_health_policy_map: dict[str, + ~service_fabric_managed_clusters_management_client.models.ServiceTypeHealthPolicy] + """ + + _validation = { + 'consider_warning_as_error': {'required': True}, + 'max_percent_unhealthy_deployed_applications': {'required': True}, + } + + _attribute_map = { + 'consider_warning_as_error': {'key': 'considerWarningAsError', 'type': 'bool'}, + 'max_percent_unhealthy_deployed_applications': {'key': 'maxPercentUnhealthyDeployedApplications', 'type': 'int'}, + 'default_service_type_health_policy': {'key': 'defaultServiceTypeHealthPolicy', 'type': 'ServiceTypeHealthPolicy'}, + 'service_type_health_policy_map': {'key': 'serviceTypeHealthPolicyMap', 'type': '{ServiceTypeHealthPolicy}'}, + } + + def __init__( + self, + *, + consider_warning_as_error: bool, + max_percent_unhealthy_deployed_applications: int, + default_service_type_health_policy: Optional["ServiceTypeHealthPolicy"] = None, + service_type_health_policy_map: Optional[Dict[str, "ServiceTypeHealthPolicy"]] = None, + **kwargs + ): + super(ApplicationHealthPolicy, self).__init__(**kwargs) + self.consider_warning_as_error = consider_warning_as_error + self.max_percent_unhealthy_deployed_applications = max_percent_unhealthy_deployed_applications + self.default_service_type_health_policy = default_service_type_health_policy + self.service_type_health_policy_map = service_type_health_policy_map + + +class ProxyResource(msrest.serialization.Model): + """The resource model definition for proxy-only resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ProxyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = location + self.tags = tags + self.system_data = None + + +class ApplicationResource(ProxyResource): + """The application resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param identity: Describes the managed identities for an Azure resource. + :type identity: ~service_fabric_managed_clusters_management_client.models.ManagedIdentity + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param version: The version of the application type as defined in the application manifest. + This name must be the full Arm Resource ID for the referenced application type version. + :type version: str + :param parameters: List of application parameters with overridden values from their default + values specified in the application manifest. + :type parameters: dict[str, str] + :param upgrade_policy: Describes the policy for a monitored application upgrade. + :type upgrade_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationUpgradePolicy + :param managed_identities: List of user assigned identities for the application, each mapped to + a friendly name. + :type managed_identities: + list[~service_fabric_managed_clusters_management_client.models.ApplicationUserAssignedIdentity] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'identity': {'key': 'identity', 'type': 'ManagedIdentity'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'version': {'key': 'properties.version', 'type': 'str'}, + 'parameters': {'key': 'properties.parameters', 'type': '{str}'}, + 'upgrade_policy': {'key': 'properties.upgradePolicy', 'type': 'ApplicationUpgradePolicy'}, + 'managed_identities': {'key': 'properties.managedIdentities', 'type': '[ApplicationUserAssignedIdentity]'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + identity: Optional["ManagedIdentity"] = None, + version: Optional[str] = None, + parameters: Optional[Dict[str, str]] = None, + upgrade_policy: Optional["ApplicationUpgradePolicy"] = None, + managed_identities: Optional[List["ApplicationUserAssignedIdentity"]] = None, + **kwargs + ): + super(ApplicationResource, self).__init__(location=location, tags=tags, **kwargs) + self.identity = identity + self.provisioning_state = None + self.version = version + self.parameters = parameters + self.upgrade_policy = upgrade_policy + self.managed_identities = managed_identities + + +class ApplicationResourceList(msrest.serialization.Model): + """The list of application resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationResource] + :ivar next_link: URL to get the next set of application list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationResource"]] = None, + **kwargs + ): + super(ApplicationResourceList, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ApplicationTypeResource(ProxyResource): + """The application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ApplicationTypeResource, self).__init__(location=location, tags=tags, **kwargs) + self.provisioning_state = None + + +class ApplicationTypeResourceList(msrest.serialization.Model): + """The list of application type names. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource] + :ivar next_link: URL to get the next set of application type list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationTypeResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationTypeResource"]] = None, + **kwargs + ): + super(ApplicationTypeResourceList, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ApplicationTypeUpdateParameters(msrest.serialization.Model): + """Application type update request. + + :param tags: A set of tags. Application type update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ApplicationTypeUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class ApplicationTypeVersionResource(ProxyResource): + """An application type version resource for the specified application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param app_package_url: The URL to the application package. + :type app_package_url: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'app_package_url': {'key': 'properties.appPackageUrl', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + app_package_url: Optional[str] = None, + **kwargs + ): + super(ApplicationTypeVersionResource, self).__init__(location=location, tags=tags, **kwargs) + self.provisioning_state = None + self.app_package_url = app_package_url + + +class ApplicationTypeVersionResourceList(msrest.serialization.Model): + """The list of application type version resources for the specified application type name resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: + list[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource] + :ivar next_link: URL to get the next set of application type version list results if there are + any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ApplicationTypeVersionResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ApplicationTypeVersionResource"]] = None, + **kwargs + ): + super(ApplicationTypeVersionResourceList, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ApplicationTypeVersionsCleanupPolicy(msrest.serialization.Model): + """The policy used to clean up unused versions. + + All required parameters must be populated in order to send to Azure. + + :param max_unused_versions_to_keep: Required. Number of unused versions per application type to + keep. + :type max_unused_versions_to_keep: int + """ + + _validation = { + 'max_unused_versions_to_keep': {'required': True, 'minimum': 0}, + } + + _attribute_map = { + 'max_unused_versions_to_keep': {'key': 'maxUnusedVersionsToKeep', 'type': 'int'}, + } + + def __init__( + self, + *, + max_unused_versions_to_keep: int, + **kwargs + ): + super(ApplicationTypeVersionsCleanupPolicy, self).__init__(**kwargs) + self.max_unused_versions_to_keep = max_unused_versions_to_keep + + +class ApplicationTypeVersionUpdateParameters(msrest.serialization.Model): + """Application type version update request. + + :param tags: A set of tags. Application type version update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ApplicationTypeVersionUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class ApplicationUpdateParameters(msrest.serialization.Model): + """Application update request. + + :param tags: A set of tags. Application update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ApplicationUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class ApplicationUpgradePolicy(msrest.serialization.Model): + """Describes the policy for a monitored application upgrade. + + :param application_health_policy: Defines a health policy used to evaluate the health of an + application or one of its children entities. + :type application_health_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationHealthPolicy + :param force_restart: If true, then processes are forcefully restarted during upgrade even when + the code version has not changed (the upgrade only changes configuration or data). + :type force_restart: bool + :param rolling_upgrade_monitoring_policy: The policy used for monitoring the application + upgrade. + :type rolling_upgrade_monitoring_policy: + ~service_fabric_managed_clusters_management_client.models.RollingUpgradeMonitoringPolicy + :param instance_close_delay_duration: Duration in seconds, to wait before a stateless instance + is closed, to allow the active requests to drain gracefully. This would be effective when the + instance is closing during the application/cluster upgrade, only for those instances which have + a non-zero delay duration configured in the service description. See + InstanceCloseDelayDurationSeconds property in StatelessServiceDescription for details. Note, + the default value of InstanceCloseDelayDurationInSeconds is 4294967295, which indicates that + the behavior will entirely depend on the delay configured in the stateless service description. + :type instance_close_delay_duration: long + :param upgrade_mode: The mode used to monitor health during a rolling upgrade. The values are + Monitored, and UnmonitoredAuto. Possible values include: "Monitored", "UnmonitoredAuto". + :type upgrade_mode: str or + ~service_fabric_managed_clusters_management_client.models.RollingUpgradeMode + :param upgrade_replica_set_check_timeout: The maximum amount of time to block processing of an + upgrade domain and prevent loss of availability when there are unexpected issues. When this + timeout expires, processing of the upgrade domain will proceed regardless of availability loss + issues. The timeout is reset at the start of each upgrade domain. Valid values are between 0 + and 42949672925 inclusive. (unsigned 32-bit integer). + :type upgrade_replica_set_check_timeout: long + :param recreate_application: Determines whether the application should be recreated on update. + If value=true, the rest of the upgrade policy parameters are not allowed. + :type recreate_application: bool + """ + + _attribute_map = { + 'application_health_policy': {'key': 'applicationHealthPolicy', 'type': 'ApplicationHealthPolicy'}, + 'force_restart': {'key': 'forceRestart', 'type': 'bool'}, + 'rolling_upgrade_monitoring_policy': {'key': 'rollingUpgradeMonitoringPolicy', 'type': 'RollingUpgradeMonitoringPolicy'}, + 'instance_close_delay_duration': {'key': 'instanceCloseDelayDuration', 'type': 'long'}, + 'upgrade_mode': {'key': 'upgradeMode', 'type': 'str'}, + 'upgrade_replica_set_check_timeout': {'key': 'upgradeReplicaSetCheckTimeout', 'type': 'long'}, + 'recreate_application': {'key': 'recreateApplication', 'type': 'bool'}, + } + + def __init__( + self, + *, + application_health_policy: Optional["ApplicationHealthPolicy"] = None, + force_restart: Optional[bool] = False, + rolling_upgrade_monitoring_policy: Optional["RollingUpgradeMonitoringPolicy"] = None, + instance_close_delay_duration: Optional[int] = None, + upgrade_mode: Optional[Union[str, "RollingUpgradeMode"]] = None, + upgrade_replica_set_check_timeout: Optional[int] = None, + recreate_application: Optional[bool] = None, + **kwargs + ): + super(ApplicationUpgradePolicy, self).__init__(**kwargs) + self.application_health_policy = application_health_policy + self.force_restart = force_restart + self.rolling_upgrade_monitoring_policy = rolling_upgrade_monitoring_policy + self.instance_close_delay_duration = instance_close_delay_duration + self.upgrade_mode = upgrade_mode + self.upgrade_replica_set_check_timeout = upgrade_replica_set_check_timeout + self.recreate_application = recreate_application + + +class ApplicationUserAssignedIdentity(msrest.serialization.Model): + """ApplicationUserAssignedIdentity. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The friendly name of user assigned identity. + :type name: str + :param principal_id: Required. The principal id of user assigned identity. + :type principal_id: str + """ + + _validation = { + 'name': {'required': True}, + 'principal_id': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'principal_id': {'key': 'principalId', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + principal_id: str, + **kwargs + ): + super(ApplicationUserAssignedIdentity, self).__init__(**kwargs) + self.name = name + self.principal_id = principal_id + + +class AvailableOperationDisplay(msrest.serialization.Model): + """Operation supported by the Service Fabric resource provider. + + :param provider: The name of the provider. + :type provider: str + :param resource: The resource on which the operation is performed. + :type resource: str + :param operation: The operation that can be performed. + :type operation: str + :param description: Operation description. + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(AvailableOperationDisplay, self).__init__(**kwargs) + self.provider = provider + self.resource = resource + self.operation = operation + self.description = description + + +class ScalingTrigger(msrest.serialization.Model): + """Describes the trigger for performing a scaling operation. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: AveragePartitionLoadScalingTrigger, AverageServiceLoadScalingTrigger. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + """ + + _validation = { + 'kind': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + } + + _subtype_map = { + 'kind': {'AveragePartitionLoadTrigger': 'AveragePartitionLoadScalingTrigger', 'AverageServiceLoadTrigger': 'AverageServiceLoadScalingTrigger'} + } + + def __init__( + self, + **kwargs + ): + super(ScalingTrigger, self).__init__(**kwargs) + self.kind = None # type: Optional[str] + + +class AveragePartitionLoadScalingTrigger(ScalingTrigger): + """Represents a scaling trigger related to an average load of a metric/resource of a partition. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + :param metric_name: Required. The name of the metric for which usage should be tracked. + :type metric_name: str + :param lower_load_threshold: Required. The lower limit of the load below which a scale in + operation should be performed. + :type lower_load_threshold: float + :param upper_load_threshold: Required. The upper limit of the load beyond which a scale out + operation should be performed. + :type upper_load_threshold: float + :param scale_interval: Required. The period in seconds on which a decision is made whether to + scale or not. This property should come in ISO 8601 format "hh:mm:ss". + :type scale_interval: str + """ + + _validation = { + 'kind': {'required': True}, + 'metric_name': {'required': True}, + 'lower_load_threshold': {'required': True}, + 'upper_load_threshold': {'required': True}, + 'scale_interval': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'metric_name': {'key': 'metricName', 'type': 'str'}, + 'lower_load_threshold': {'key': 'lowerLoadThreshold', 'type': 'float'}, + 'upper_load_threshold': {'key': 'upperLoadThreshold', 'type': 'float'}, + 'scale_interval': {'key': 'scaleInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + metric_name: str, + lower_load_threshold: float, + upper_load_threshold: float, + scale_interval: str, + **kwargs + ): + super(AveragePartitionLoadScalingTrigger, self).__init__(**kwargs) + self.kind = 'AveragePartitionLoadTrigger' # type: str + self.metric_name = metric_name + self.lower_load_threshold = lower_load_threshold + self.upper_load_threshold = upper_load_threshold + self.scale_interval = scale_interval + + +class AverageServiceLoadScalingTrigger(ScalingTrigger): + """Represents a scaling policy related to an average load of a metric/resource of a service. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the trigger associated with this scaling policy.Constant + filled by server. Possible values include: "AveragePartitionLoad", "AverageServiceLoad". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingTriggerKind + :param metric_name: Required. The name of the metric for which usage should be tracked. + :type metric_name: str + :param lower_load_threshold: Required. The lower limit of the load below which a scale in + operation should be performed. + :type lower_load_threshold: float + :param upper_load_threshold: Required. The upper limit of the load beyond which a scale out + operation should be performed. + :type upper_load_threshold: float + :param scale_interval: Required. The period in seconds on which a decision is made whether to + scale or not. This property should come in ISO 8601 format "hh:mm:ss". + :type scale_interval: str + """ + + _validation = { + 'kind': {'required': True}, + 'metric_name': {'required': True}, + 'lower_load_threshold': {'required': True}, + 'upper_load_threshold': {'required': True}, + 'scale_interval': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'metric_name': {'key': 'metricName', 'type': 'str'}, + 'lower_load_threshold': {'key': 'lowerLoadThreshold', 'type': 'float'}, + 'upper_load_threshold': {'key': 'upperLoadThreshold', 'type': 'float'}, + 'scale_interval': {'key': 'scaleInterval', 'type': 'str'}, + } + + def __init__( + self, + *, + metric_name: str, + lower_load_threshold: float, + upper_load_threshold: float, + scale_interval: str, + **kwargs + ): + super(AverageServiceLoadScalingTrigger, self).__init__(**kwargs) + self.kind = 'AverageServiceLoadTrigger' # type: str + self.metric_name = metric_name + self.lower_load_threshold = lower_load_threshold + self.upper_load_threshold = upper_load_threshold + self.scale_interval = scale_interval + + +class AzureActiveDirectory(msrest.serialization.Model): + """The settings to enable AAD authentication on the cluster. + + :param tenant_id: Azure active directory tenant id. + :type tenant_id: str + :param cluster_application: Azure active directory cluster application id. + :type cluster_application: str + :param client_application: Azure active directory client application id. + :type client_application: str + """ + + _attribute_map = { + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'cluster_application': {'key': 'clusterApplication', 'type': 'str'}, + 'client_application': {'key': 'clientApplication', 'type': 'str'}, + } + + def __init__( + self, + *, + tenant_id: Optional[str] = None, + cluster_application: Optional[str] = None, + client_application: Optional[str] = None, + **kwargs + ): + super(AzureActiveDirectory, self).__init__(**kwargs) + self.tenant_id = tenant_id + self.cluster_application = cluster_application + self.client_application = client_application + + +class ClientCertificate(msrest.serialization.Model): + """Client certificate definition. + + All required parameters must be populated in order to send to Azure. + + :param is_admin: Required. Indicates if the client certificate has admin access to the cluster. + Non admin clients can perform only read only operations on the cluster. + :type is_admin: bool + :param thumbprint: Certificate thumbprint. + :type thumbprint: str + :param common_name: Certificate common name. + :type common_name: str + :param issuer_thumbprint: Issuer thumbprint for the certificate. Only used together with + CommonName. + :type issuer_thumbprint: str + """ + + _validation = { + 'is_admin': {'required': True}, + } + + _attribute_map = { + 'is_admin': {'key': 'isAdmin', 'type': 'bool'}, + 'thumbprint': {'key': 'thumbprint', 'type': 'str'}, + 'common_name': {'key': 'commonName', 'type': 'str'}, + 'issuer_thumbprint': {'key': 'issuerThumbprint', 'type': 'str'}, + } + + def __init__( + self, + *, + is_admin: bool, + thumbprint: Optional[str] = None, + common_name: Optional[str] = None, + issuer_thumbprint: Optional[str] = None, + **kwargs + ): + super(ClientCertificate, self).__init__(**kwargs) + self.is_admin = is_admin + self.thumbprint = thumbprint + self.common_name = common_name + self.issuer_thumbprint = issuer_thumbprint + + +class EndpointRangeDescription(msrest.serialization.Model): + """Port range details. + + All required parameters must be populated in order to send to Azure. + + :param start_port: Required. Starting port of a range of ports. + :type start_port: int + :param end_port: Required. End port of a range of ports. + :type end_port: int + """ + + _validation = { + 'start_port': {'required': True}, + 'end_port': {'required': True}, + } + + _attribute_map = { + 'start_port': {'key': 'startPort', 'type': 'int'}, + 'end_port': {'key': 'endPort', 'type': 'int'}, + } + + def __init__( + self, + *, + start_port: int, + end_port: int, + **kwargs + ): + super(EndpointRangeDescription, self).__init__(**kwargs) + self.start_port = start_port + self.end_port = end_port + + +class ErrorModel(msrest.serialization.Model): + """The structure of the error. + + :param error: The error details. + :type error: ~service_fabric_managed_clusters_management_client.models.ErrorModelError + """ + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorModelError'}, + } + + def __init__( + self, + *, + error: Optional["ErrorModelError"] = None, + **kwargs + ): + super(ErrorModel, self).__init__(**kwargs) + self.error = error + + +class ErrorModelError(msrest.serialization.Model): + """The error details. + + :param code: The error code. + :type code: str + :param message: The error message. + :type message: str + """ + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + } + + def __init__( + self, + *, + code: Optional[str] = None, + message: Optional[str] = None, + **kwargs + ): + super(ErrorModelError, self).__init__(**kwargs) + self.code = code + self.message = message + + +class LoadBalancingRule(msrest.serialization.Model): + """Describes a load balancing rule. + + All required parameters must be populated in order to send to Azure. + + :param frontend_port: Required. The port for the external endpoint. Port numbers for each rule + must be unique within the Load Balancer. Acceptable values are between 1 and 65534. + :type frontend_port: int + :param backend_port: Required. The port used for internal connections on the endpoint. + Acceptable values are between 1 and 65535. + :type backend_port: int + :param protocol: Required. The reference to the transport protocol used by the load balancing + rule. Possible values include: "tcp", "udp". + :type protocol: str or ~service_fabric_managed_clusters_management_client.models.Protocol + :param probe_protocol: Required. the reference to the load balancer probe used by the load + balancing rule. Possible values include: "tcp", "http", "https". + :type probe_protocol: str or + ~service_fabric_managed_clusters_management_client.models.ProbeProtocol + :param probe_request_path: The probe request path. Only supported for HTTP/HTTPS probes. + :type probe_request_path: str + """ + + _validation = { + 'frontend_port': {'required': True, 'maximum': 65534, 'minimum': 1}, + 'backend_port': {'required': True, 'maximum': 65534, 'minimum': 1}, + 'protocol': {'required': True}, + 'probe_protocol': {'required': True}, + } + + _attribute_map = { + 'frontend_port': {'key': 'frontendPort', 'type': 'int'}, + 'backend_port': {'key': 'backendPort', 'type': 'int'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'probe_protocol': {'key': 'probeProtocol', 'type': 'str'}, + 'probe_request_path': {'key': 'probeRequestPath', 'type': 'str'}, + } + + def __init__( + self, + *, + frontend_port: int, + backend_port: int, + protocol: Union[str, "Protocol"], + probe_protocol: Union[str, "ProbeProtocol"], + probe_request_path: Optional[str] = None, + **kwargs + ): + super(LoadBalancingRule, self).__init__(**kwargs) + self.frontend_port = frontend_port + self.backend_port = backend_port + self.protocol = protocol + self.probe_protocol = probe_protocol + self.probe_request_path = probe_request_path + + +class Resource(msrest.serialization.Model): + """The resource model definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Required. Azure resource location. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar etag: Azure resource etag. + :vartype etag: str + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + 'etag': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + *, + location: str, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = location + self.tags = tags + self.etag = None + self.system_data = None + + +class ManagedCluster(Resource): + """The manged cluster resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Required. Azure resource location. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar etag: Azure resource etag. + :vartype etag: str + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param sku: The sku of the managed cluster. + :type sku: ~service_fabric_managed_clusters_management_client.models.Sku + :param dns_name: The cluster dns name. + :type dns_name: str + :ivar fqdn: The fully qualified domain name associated with the public load balancer of the + cluster. + :vartype fqdn: str + :ivar ipv4_address: The IPv4 address associated with the public load balancer of the cluster. + :vartype ipv4_address: str + :ivar cluster_id: A service generated unique identifier for the cluster resource. + :vartype cluster_id: str + :ivar cluster_state: The current state of the cluster. Possible values include: + "WaitingForNodes", "Deploying", "BaselineUpgrade", "Upgrading", "UpgradeFailed", "Ready". + :vartype cluster_state: str or + ~service_fabric_managed_clusters_management_client.models.ClusterState + :ivar cluster_certificate_thumbprints: List of thumbprints of the cluster certificates. + :vartype cluster_certificate_thumbprints: list[str] + :param client_connection_port: The port used for client connections to the cluster. + :type client_connection_port: int + :param http_gateway_connection_port: The port used for HTTP connections to the cluster. + :type http_gateway_connection_port: int + :param admin_user_name: VM admin user name. + :type admin_user_name: str + :param admin_password: VM admin user password. + :type admin_password: str + :param load_balancing_rules: Load balancing rules that are applied to the public load balancer + of the cluster. + :type load_balancing_rules: + list[~service_fabric_managed_clusters_management_client.models.LoadBalancingRule] + :param allow_rdp_access: Setting this to true enables RDP access to the VM. The default NSG + rule opens RDP port to internet which can be overridden with custom Network Security Rules. The + default value for this setting is false. + :type allow_rdp_access: bool + :param network_security_rules: Custom Network Security Rules that are applied to the virtual + network of the cluster. + :type network_security_rules: + list[~service_fabric_managed_clusters_management_client.models.NetworkSecurityRule] + :param clients: Client certificates that are allowed to manage the cluster. + :type clients: + list[~service_fabric_managed_clusters_management_client.models.ClientCertificate] + :param azure_active_directory: The AAD authentication settings of the cluster. + :type azure_active_directory: + ~service_fabric_managed_clusters_management_client.models.AzureActiveDirectory + :param fabric_settings: The list of custom fabric settings to configure the cluster. + :type fabric_settings: + list[~service_fabric_managed_clusters_management_client.models.SettingsSectionDescription] + :ivar provisioning_state: The provisioning state of the managed cluster resource. Possible + values include: "None", "Creating", "Created", "Updating", "Succeeded", "Failed", "Canceled", + "Deleting", "Deleted", "Other". + :vartype provisioning_state: str or + ~service_fabric_managed_clusters_management_client.models.ManagedResourceProvisioningState + :param cluster_code_version: The Service Fabric runtime version of the cluster. This property + can only by set the user when **upgradeMode** is set to 'Manual'. To get list of available + Service Fabric versions for new clusters use `ClusterVersion API <./ClusterVersion.md>`_. To + get the list of available version for existing clusters use **availableClusterVersions**. + :type cluster_code_version: str + :param cluster_upgrade_cadence: Indicates when new cluster runtime version upgrades will be + applied after they are released. By default is Wave0. Possible values include: "Wave0", + "Wave1", "Wave2". + :type cluster_upgrade_cadence: str or + ~service_fabric_managed_clusters_management_client.models.ClusterUpgradeCadence + :param addon_features: List of add-on features to enable on the cluster. + :type addon_features: list[str or + ~service_fabric_managed_clusters_management_client.models.ManagedClusterAddOnFeature] + :param enable_auto_os_upgrade: Setting this to true enables automatic OS upgrade for the node + types that are created using any platform OS image with version 'latest'. The default value for + this setting is false. + :type enable_auto_os_upgrade: bool + :param application_type_versions_cleanup_policy: The policy used to clean up unused versions. + :type application_type_versions_cleanup_policy: + ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionsCleanupPolicy + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + 'etag': {'readonly': True}, + 'system_data': {'readonly': True}, + 'fqdn': {'readonly': True}, + 'ipv4_address': {'readonly': True}, + 'cluster_id': {'readonly': True}, + 'cluster_state': {'readonly': True}, + 'cluster_certificate_thumbprints': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'etag': {'key': 'etag', 'type': 'str'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'dns_name': {'key': 'properties.dnsName', 'type': 'str'}, + 'fqdn': {'key': 'properties.fqdn', 'type': 'str'}, + 'ipv4_address': {'key': 'properties.ipv4Address', 'type': 'str'}, + 'cluster_id': {'key': 'properties.clusterId', 'type': 'str'}, + 'cluster_state': {'key': 'properties.clusterState', 'type': 'str'}, + 'cluster_certificate_thumbprints': {'key': 'properties.clusterCertificateThumbprints', 'type': '[str]'}, + 'client_connection_port': {'key': 'properties.clientConnectionPort', 'type': 'int'}, + 'http_gateway_connection_port': {'key': 'properties.httpGatewayConnectionPort', 'type': 'int'}, + 'admin_user_name': {'key': 'properties.adminUserName', 'type': 'str'}, + 'admin_password': {'key': 'properties.adminPassword', 'type': 'str'}, + 'load_balancing_rules': {'key': 'properties.loadBalancingRules', 'type': '[LoadBalancingRule]'}, + 'allow_rdp_access': {'key': 'properties.allowRdpAccess', 'type': 'bool'}, + 'network_security_rules': {'key': 'properties.networkSecurityRules', 'type': '[NetworkSecurityRule]'}, + 'clients': {'key': 'properties.clients', 'type': '[ClientCertificate]'}, + 'azure_active_directory': {'key': 'properties.azureActiveDirectory', 'type': 'AzureActiveDirectory'}, + 'fabric_settings': {'key': 'properties.fabricSettings', 'type': '[SettingsSectionDescription]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + 'cluster_code_version': {'key': 'properties.clusterCodeVersion', 'type': 'str'}, + 'cluster_upgrade_cadence': {'key': 'properties.clusterUpgradeCadence', 'type': 'str'}, + 'addon_features': {'key': 'properties.addonFeatures', 'type': '[str]'}, + 'enable_auto_os_upgrade': {'key': 'properties.enableAutoOSUpgrade', 'type': 'bool'}, + 'application_type_versions_cleanup_policy': {'key': 'properties.applicationTypeVersionsCleanupPolicy', 'type': 'ApplicationTypeVersionsCleanupPolicy'}, + } + + def __init__( + self, + *, + location: str, + tags: Optional[Dict[str, str]] = None, + sku: Optional["Sku"] = None, + dns_name: Optional[str] = None, + client_connection_port: Optional[int] = 19000, + http_gateway_connection_port: Optional[int] = 19080, + admin_user_name: Optional[str] = None, + admin_password: Optional[str] = None, + load_balancing_rules: Optional[List["LoadBalancingRule"]] = None, + allow_rdp_access: Optional[bool] = None, + network_security_rules: Optional[List["NetworkSecurityRule"]] = None, + clients: Optional[List["ClientCertificate"]] = None, + azure_active_directory: Optional["AzureActiveDirectory"] = None, + fabric_settings: Optional[List["SettingsSectionDescription"]] = None, + cluster_code_version: Optional[str] = None, + cluster_upgrade_cadence: Optional[Union[str, "ClusterUpgradeCadence"]] = None, + addon_features: Optional[List[Union[str, "ManagedClusterAddOnFeature"]]] = None, + enable_auto_os_upgrade: Optional[bool] = None, + application_type_versions_cleanup_policy: Optional["ApplicationTypeVersionsCleanupPolicy"] = None, + **kwargs + ): + super(ManagedCluster, self).__init__(location=location, tags=tags, **kwargs) + self.sku = sku + self.dns_name = dns_name + self.fqdn = None + self.ipv4_address = None + self.cluster_id = None + self.cluster_state = None + self.cluster_certificate_thumbprints = None + self.client_connection_port = client_connection_port + self.http_gateway_connection_port = http_gateway_connection_port + self.admin_user_name = admin_user_name + self.admin_password = admin_password + self.load_balancing_rules = load_balancing_rules + self.allow_rdp_access = allow_rdp_access + self.network_security_rules = network_security_rules + self.clients = clients + self.azure_active_directory = azure_active_directory + self.fabric_settings = fabric_settings + self.provisioning_state = None + self.cluster_code_version = cluster_code_version + self.cluster_upgrade_cadence = cluster_upgrade_cadence + self.addon_features = addon_features + self.enable_auto_os_upgrade = enable_auto_os_upgrade + self.application_type_versions_cleanup_policy = application_type_versions_cleanup_policy + + +class ManagedClusterListResult(msrest.serialization.Model): + """Managed Cluster list results. + + :param value: + :type value: list[~service_fabric_managed_clusters_management_client.models.ManagedCluster] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ManagedCluster]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ManagedCluster"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(ManagedClusterListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ManagedClusterUpdateParameters(msrest.serialization.Model): + """Managed cluster update request. + + :param tags: A set of tags. Managed cluster update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ManagedClusterUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class ManagedIdentity(msrest.serialization.Model): + """Describes the managed identities for an Azure resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of the managed identity. This property will only be + provided for a system assigned identity. + :vartype principal_id: str + :ivar tenant_id: The tenant id of the managed identity. This property will only be provided for + a system assigned identity. + :vartype tenant_id: str + :param type: The type of managed identity for the resource. Possible values include: "None", + "SystemAssigned", "UserAssigned", "SystemAssigned, UserAssigned". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ManagedIdentityType + :param user_assigned_identities: The list of user identities associated with the resource. The + user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: dict[str, + ~service_fabric_managed_clusters_management_client.models.UserAssignedIdentity] + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{UserAssignedIdentity}'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ManagedIdentityType"]] = None, + user_assigned_identities: Optional[Dict[str, "UserAssignedIdentity"]] = None, + **kwargs + ): + super(ManagedIdentity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = type + self.user_assigned_identities = user_assigned_identities + + +class ManagedProxyResource(msrest.serialization.Model): + """The resource model definition for proxy-only resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ManagedProxyResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.tags = tags + self.system_data = None + + +class Partition(msrest.serialization.Model): + """Describes how the service is partitioned. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: NamedPartitionScheme, SingletonPartitionScheme, UniformInt64RangePartitionScheme. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + """ + + _validation = { + 'partition_scheme': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + } + + _subtype_map = { + 'partition_scheme': {'Named': 'NamedPartitionScheme', 'Singleton': 'SingletonPartitionScheme', 'UniformInt64Range': 'UniformInt64RangePartitionScheme'} + } + + def __init__( + self, + **kwargs + ): + super(Partition, self).__init__(**kwargs) + self.partition_scheme = None # type: Optional[str] + + +class NamedPartitionScheme(Partition): + """Describes the named partition scheme of the service. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + :param names: Required. Array for the names of the partitions. + :type names: list[str] + """ + + _validation = { + 'partition_scheme': {'required': True}, + 'names': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + 'names': {'key': 'names', 'type': '[str]'}, + } + + def __init__( + self, + *, + names: List[str], + **kwargs + ): + super(NamedPartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'Named' # type: str + self.names = names + + +class NetworkSecurityRule(msrest.serialization.Model): + """Describes a network security rule. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Network security rule name. + :type name: str + :param description: Network security rule description. + :type description: str + :param protocol: Required. Network protocol this rule applies to. Possible values include: + "http", "https", "tcp", "udp", "icmp", "ah", "esp". + :type protocol: str or ~service_fabric_managed_clusters_management_client.models.NsgProtocol + :param source_address_prefixes: The CIDR or source IP ranges. + :type source_address_prefixes: list[str] + :param destination_address_prefixes: The destination address prefixes. CIDR or destination IP + ranges. + :type destination_address_prefixes: list[str] + :param source_port_ranges: The source port ranges. + :type source_port_ranges: list[str] + :param destination_port_ranges: The destination port ranges. + :type destination_port_ranges: list[str] + :param access: Required. The network traffic is allowed or denied. Possible values include: + "allow", "deny". + :type access: str or ~service_fabric_managed_clusters_management_client.models.Access + :param priority: Required. The priority of the rule. The value can be in the range 1000 to + 3000. Values outside this range are reserved for Service Fabric ManagerCluster Resource + Provider. The priority number must be unique for each rule in the collection. The lower the + priority number, the higher the priority of the rule. + :type priority: int + :param direction: Required. Network security rule direction. Possible values include: + "inbound", "outbound". + :type direction: str or ~service_fabric_managed_clusters_management_client.models.Direction + """ + + _validation = { + 'name': {'required': True}, + 'protocol': {'required': True}, + 'access': {'required': True}, + 'priority': {'required': True, 'maximum': 3000, 'minimum': 1000}, + 'direction': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'protocol': {'key': 'protocol', 'type': 'str'}, + 'source_address_prefixes': {'key': 'sourceAddressPrefixes', 'type': '[str]'}, + 'destination_address_prefixes': {'key': 'destinationAddressPrefixes', 'type': '[str]'}, + 'source_port_ranges': {'key': 'sourcePortRanges', 'type': '[str]'}, + 'destination_port_ranges': {'key': 'destinationPortRanges', 'type': '[str]'}, + 'access': {'key': 'access', 'type': 'str'}, + 'priority': {'key': 'priority', 'type': 'int'}, + 'direction': {'key': 'direction', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + protocol: Union[str, "NsgProtocol"], + access: Union[str, "Access"], + priority: int, + direction: Union[str, "Direction"], + description: Optional[str] = None, + source_address_prefixes: Optional[List[str]] = None, + destination_address_prefixes: Optional[List[str]] = None, + source_port_ranges: Optional[List[str]] = None, + destination_port_ranges: Optional[List[str]] = None, + **kwargs + ): + super(NetworkSecurityRule, self).__init__(**kwargs) + self.name = name + self.description = description + self.protocol = protocol + self.source_address_prefixes = source_address_prefixes + self.destination_address_prefixes = destination_address_prefixes + self.source_port_ranges = source_port_ranges + self.destination_port_ranges = destination_port_ranges + self.access = access + self.priority = priority + self.direction = direction + + +class NodeType(ManagedProxyResource): + """Describes a node type in the cluster, each node type represents sub set of nodes in the cluster. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param is_primary: The node type on which system services will run. Only one node type should + be marked as primary. Primary node type cannot be deleted or changed for existing clusters. + :type is_primary: bool + :param vm_instance_count: The number of nodes in the node type. + :type vm_instance_count: int + :param data_disk_size_gb: Disk size for each vm in the node type in GBs. + :type data_disk_size_gb: int + :param placement_properties: The placement tags applied to nodes in the node type, which can be + used to indicate where certain services (workload) should run. + :type placement_properties: dict[str, str] + :param capacities: The capacity tags applied to the nodes in the node type, the cluster + resource manager uses these tags to understand how much resource a node has. + :type capacities: dict[str, str] + :param application_ports: The range of ports from which cluster assigned port to Service Fabric + applications. + :type application_ports: + ~service_fabric_managed_clusters_management_client.models.EndpointRangeDescription + :param ephemeral_ports: The range of ephemeral ports that nodes in this node type should be + configured with. + :type ephemeral_ports: + ~service_fabric_managed_clusters_management_client.models.EndpointRangeDescription + :param vm_size: The size of virtual machines in the pool. All virtual machines in a pool are + the same size. For example, Standard_D3. + :type vm_size: str + :param vm_image_publisher: The publisher of the Azure Virtual Machines Marketplace image. For + example, Canonical or MicrosoftWindowsServer. + :type vm_image_publisher: str + :param vm_image_offer: The offer type of the Azure Virtual Machines Marketplace image. For + example, UbuntuServer or WindowsServer. + :type vm_image_offer: str + :param vm_image_sku: The SKU of the Azure Virtual Machines Marketplace image. For example, + 14.04.0-LTS or 2012-R2-Datacenter. + :type vm_image_sku: str + :param vm_image_version: The version of the Azure Virtual Machines Marketplace image. A value + of 'latest' can be specified to select the latest version of an image. If omitted, the default + is 'latest'. + :type vm_image_version: str + :param vm_secrets: The secrets to install in the virtual machines. + :type vm_secrets: + list[~service_fabric_managed_clusters_management_client.models.VaultSecretGroup] + :param vm_extensions: Set of extensions that should be installed onto the virtual machines. + :type vm_extensions: + list[~service_fabric_managed_clusters_management_client.models.VMSSExtension] + :param vm_managed_identity: Identities for the virtual machine scale set under the node type. + :type vm_managed_identity: + ~service_fabric_managed_clusters_management_client.models.VmManagedIdentity + :ivar provisioning_state: The provisioning state of the managed cluster resource. Possible + values include: "None", "Creating", "Created", "Updating", "Succeeded", "Failed", "Canceled", + "Deleting", "Deleted", "Other". + :vartype provisioning_state: str or + ~service_fabric_managed_clusters_management_client.models.ManagedResourceProvisioningState + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + 'vm_instance_count': {'maximum': 2147483647, 'minimum': 1}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'is_primary': {'key': 'properties.isPrimary', 'type': 'bool'}, + 'vm_instance_count': {'key': 'properties.vmInstanceCount', 'type': 'int'}, + 'data_disk_size_gb': {'key': 'properties.dataDiskSizeGB', 'type': 'int'}, + 'placement_properties': {'key': 'properties.placementProperties', 'type': '{str}'}, + 'capacities': {'key': 'properties.capacities', 'type': '{str}'}, + 'application_ports': {'key': 'properties.applicationPorts', 'type': 'EndpointRangeDescription'}, + 'ephemeral_ports': {'key': 'properties.ephemeralPorts', 'type': 'EndpointRangeDescription'}, + 'vm_size': {'key': 'properties.vmSize', 'type': 'str'}, + 'vm_image_publisher': {'key': 'properties.vmImagePublisher', 'type': 'str'}, + 'vm_image_offer': {'key': 'properties.vmImageOffer', 'type': 'str'}, + 'vm_image_sku': {'key': 'properties.vmImageSku', 'type': 'str'}, + 'vm_image_version': {'key': 'properties.vmImageVersion', 'type': 'str'}, + 'vm_secrets': {'key': 'properties.vmSecrets', 'type': '[VaultSecretGroup]'}, + 'vm_extensions': {'key': 'properties.vmExtensions', 'type': '[VMSSExtension]'}, + 'vm_managed_identity': {'key': 'properties.vmManagedIdentity', 'type': 'VmManagedIdentity'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + is_primary: Optional[bool] = None, + vm_instance_count: Optional[int] = None, + data_disk_size_gb: Optional[int] = None, + placement_properties: Optional[Dict[str, str]] = None, + capacities: Optional[Dict[str, str]] = None, + application_ports: Optional["EndpointRangeDescription"] = None, + ephemeral_ports: Optional["EndpointRangeDescription"] = None, + vm_size: Optional[str] = None, + vm_image_publisher: Optional[str] = None, + vm_image_offer: Optional[str] = None, + vm_image_sku: Optional[str] = None, + vm_image_version: Optional[str] = None, + vm_secrets: Optional[List["VaultSecretGroup"]] = None, + vm_extensions: Optional[List["VMSSExtension"]] = None, + vm_managed_identity: Optional["VmManagedIdentity"] = None, + **kwargs + ): + super(NodeType, self).__init__(tags=tags, **kwargs) + self.is_primary = is_primary + self.vm_instance_count = vm_instance_count + self.data_disk_size_gb = data_disk_size_gb + self.placement_properties = placement_properties + self.capacities = capacities + self.application_ports = application_ports + self.ephemeral_ports = ephemeral_ports + self.vm_size = vm_size + self.vm_image_publisher = vm_image_publisher + self.vm_image_offer = vm_image_offer + self.vm_image_sku = vm_image_sku + self.vm_image_version = vm_image_version + self.vm_secrets = vm_secrets + self.vm_extensions = vm_extensions + self.vm_managed_identity = vm_managed_identity + self.provisioning_state = None + + +class NodeTypeActionParameters(msrest.serialization.Model): + """Parameters for Node type action. + + All required parameters must be populated in order to send to Azure. + + :param nodes: Required. List of node names from the node type. + :type nodes: list[str] + :param force: Force the action to go through. + :type force: bool + """ + + _validation = { + 'nodes': {'required': True}, + } + + _attribute_map = { + 'nodes': {'key': 'nodes', 'type': '[str]'}, + 'force': {'key': 'force', 'type': 'bool'}, + } + + def __init__( + self, + *, + nodes: List[str], + force: Optional[bool] = None, + **kwargs + ): + super(NodeTypeActionParameters, self).__init__(**kwargs) + self.nodes = nodes + self.force = force + + +class NodeTypeListResult(msrest.serialization.Model): + """Node type list results. + + :param value: The list of node types. + :type value: list[~service_fabric_managed_clusters_management_client.models.NodeType] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[NodeType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["NodeType"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(NodeTypeListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class NodeTypeUpdateParameters(msrest.serialization.Model): + """Node type update request. + + :param tags: A set of tags. Node type update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(NodeTypeUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class OperationListResult(msrest.serialization.Model): + """Describes the result of the request to list Service Fabric resource provider operations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: List of operations supported by the Service Fabric resource provider. + :type value: list[~service_fabric_managed_clusters_management_client.models.OperationResult] + :ivar next_link: URL to get the next set of operation list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[OperationResult]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["OperationResult"]] = None, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class OperationResult(msrest.serialization.Model): + """Available operation list result. + + :param name: The name of the operation. + :type name: str + :param is_data_action: Indicates whether the operation is a data action. + :type is_data_action: bool + :param display: The object that represents the operation. + :type display: + ~service_fabric_managed_clusters_management_client.models.AvailableOperationDisplay + :param origin: Origin result. + :type origin: str + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'is_data_action': {'key': 'isDataAction', 'type': 'bool'}, + 'display': {'key': 'display', 'type': 'AvailableOperationDisplay'}, + 'origin': {'key': 'origin', 'type': 'str'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + is_data_action: Optional[bool] = None, + display: Optional["AvailableOperationDisplay"] = None, + origin: Optional[str] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(OperationResult, self).__init__(**kwargs) + self.name = name + self.is_data_action = is_data_action + self.display = display + self.origin = origin + self.next_link = next_link + + +class PartitionInstanceCountScaleMechanism(ScalingMechanism): + """Represents a scaling mechanism for adding or removing instances of stateless service partition. + + All required parameters must be populated in order to send to Azure. + + :param kind: Required. Specifies the mechanism associated with this scaling policy.Constant + filled by server. Possible values include: "ScalePartitionInstanceCount", + "AddRemoveIncrementalNamedPartition". + :type kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceScalingMechanismKind + :param min_instance_count: Required. Minimum number of instances of the partition. + :type min_instance_count: int + :param max_instance_count: Required. Maximum number of instances of the partition. + :type max_instance_count: int + :param scale_increment: Required. The number of instances to add or remove during a scaling + operation. + :type scale_increment: int + """ + + _validation = { + 'kind': {'required': True}, + 'min_instance_count': {'required': True}, + 'max_instance_count': {'required': True}, + 'scale_increment': {'required': True}, + } + + _attribute_map = { + 'kind': {'key': 'kind', 'type': 'str'}, + 'min_instance_count': {'key': 'minInstanceCount', 'type': 'int'}, + 'max_instance_count': {'key': 'maxInstanceCount', 'type': 'int'}, + 'scale_increment': {'key': 'scaleIncrement', 'type': 'int'}, + } + + def __init__( + self, + *, + min_instance_count: int, + max_instance_count: int, + scale_increment: int, + **kwargs + ): + super(PartitionInstanceCountScaleMechanism, self).__init__(**kwargs) + self.kind = 'ScalePartitionInstanceCount' # type: str + self.min_instance_count = min_instance_count + self.max_instance_count = max_instance_count + self.scale_increment = scale_increment + + +class RollingUpgradeMonitoringPolicy(msrest.serialization.Model): + """The policy used for monitoring the application upgrade. + + All required parameters must be populated in order to send to Azure. + + :param failure_action: Required. The compensating action to perform when a Monitored upgrade + encounters monitoring policy or health policy violations. Invalid indicates the failure action + is invalid. Rollback specifies that the upgrade will start rolling back automatically. Manual + indicates that the upgrade will switch to UnmonitoredManual upgrade mode. Possible values + include: "Rollback", "Manual". + :type failure_action: str or + ~service_fabric_managed_clusters_management_client.models.FailureAction + :param health_check_wait_duration: Required. The amount of time to wait after completing an + upgrade domain before applying health policies. It is interpreted as a string representing an + ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_wait_duration: str + :param health_check_stable_duration: Required. The amount of time that the application or + cluster must remain healthy before the upgrade proceeds to the next upgrade domain. It is + interpreted as a string representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_stable_duration: str + :param health_check_retry_timeout: Required. The amount of time to retry health evaluation when + the application or cluster is unhealthy before FailureAction is executed. It is interpreted as + a string representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type health_check_retry_timeout: str + :param upgrade_timeout: Required. The amount of time the overall upgrade has to complete before + FailureAction is executed. Cannot be larger than 12 hours. It is interpreted as a string + representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type upgrade_timeout: str + :param upgrade_domain_timeout: Required. The amount of time each upgrade domain has to complete + before FailureAction is executed. Cannot be larger than 12 hours. It is interpreted as a string + representing an ISO 8601 duration with following format "hh:mm:ss.fff". + :type upgrade_domain_timeout: str + """ + + _validation = { + 'failure_action': {'required': True}, + 'health_check_wait_duration': {'required': True}, + 'health_check_stable_duration': {'required': True}, + 'health_check_retry_timeout': {'required': True}, + 'upgrade_timeout': {'required': True}, + 'upgrade_domain_timeout': {'required': True}, + } + + _attribute_map = { + 'failure_action': {'key': 'failureAction', 'type': 'str'}, + 'health_check_wait_duration': {'key': 'healthCheckWaitDuration', 'type': 'str'}, + 'health_check_stable_duration': {'key': 'healthCheckStableDuration', 'type': 'str'}, + 'health_check_retry_timeout': {'key': 'healthCheckRetryTimeout', 'type': 'str'}, + 'upgrade_timeout': {'key': 'upgradeTimeout', 'type': 'str'}, + 'upgrade_domain_timeout': {'key': 'upgradeDomainTimeout', 'type': 'str'}, + } + + def __init__( + self, + *, + failure_action: Union[str, "FailureAction"], + health_check_wait_duration: str, + health_check_stable_duration: str, + health_check_retry_timeout: str, + upgrade_timeout: str, + upgrade_domain_timeout: str, + **kwargs + ): + super(RollingUpgradeMonitoringPolicy, self).__init__(**kwargs) + self.failure_action = failure_action + self.health_check_wait_duration = health_check_wait_duration + self.health_check_stable_duration = health_check_stable_duration + self.health_check_retry_timeout = health_check_retry_timeout + self.upgrade_timeout = upgrade_timeout + self.upgrade_domain_timeout = upgrade_domain_timeout + + +class ScalingPolicy(msrest.serialization.Model): + """Specifies a metric to load balance a service during runtime. + + All required parameters must be populated in order to send to Azure. + + :param scaling_mechanism: Required. Specifies the mechanism associated with this scaling + policy. + :type scaling_mechanism: + ~service_fabric_managed_clusters_management_client.models.ScalingMechanism + :param scaling_trigger: Required. Specifies the trigger associated with this scaling policy. + :type scaling_trigger: ~service_fabric_managed_clusters_management_client.models.ScalingTrigger + """ + + _validation = { + 'scaling_mechanism': {'required': True}, + 'scaling_trigger': {'required': True}, + } + + _attribute_map = { + 'scaling_mechanism': {'key': 'scalingMechanism', 'type': 'ScalingMechanism'}, + 'scaling_trigger': {'key': 'scalingTrigger', 'type': 'ScalingTrigger'}, + } + + def __init__( + self, + *, + scaling_mechanism: "ScalingMechanism", + scaling_trigger: "ScalingTrigger", + **kwargs + ): + super(ScalingPolicy, self).__init__(**kwargs) + self.scaling_mechanism = scaling_mechanism + self.scaling_trigger = scaling_trigger + + +class ServiceCorrelation(msrest.serialization.Model): + """Creates a particular correlation between services. + + All required parameters must be populated in order to send to Azure. + + :param scheme: Required. The ServiceCorrelationScheme which describes the relationship between + this service and the service specified via ServiceName. Possible values include: + "AlignedAffinity", "NonAlignedAffinity". + :type scheme: str or + ~service_fabric_managed_clusters_management_client.models.ServiceCorrelationScheme + :param service_name: Required. The Arm Resource ID of the service that the correlation + relationship is established with. + :type service_name: str + """ + + _validation = { + 'scheme': {'required': True}, + 'service_name': {'required': True}, + } + + _attribute_map = { + 'scheme': {'key': 'scheme', 'type': 'str'}, + 'service_name': {'key': 'serviceName', 'type': 'str'}, + } + + def __init__( + self, + *, + scheme: Union[str, "ServiceCorrelationScheme"], + service_name: str, + **kwargs + ): + super(ServiceCorrelation, self).__init__(**kwargs) + self.scheme = scheme + self.service_name = service_name + + +class ServiceLoadMetric(msrest.serialization.Model): + """Specifies a metric to load balance a service during runtime. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the metric. If the service chooses to report load during + runtime, the load metric name should match the name that is specified in Name exactly. Note + that metric names are case sensitive. + :type name: str + :param weight: The service load metric relative weight, compared to other metrics configured + for this service, as a number. Possible values include: "Zero", "Low", "Medium", "High". + :type weight: str or + ~service_fabric_managed_clusters_management_client.models.ServiceLoadMetricWeight + :param primary_default_load: Used only for Stateful services. The default amount of load, as a + number, that this service creates for this metric when it is a Primary replica. + :type primary_default_load: int + :param secondary_default_load: Used only for Stateful services. The default amount of load, as + a number, that this service creates for this metric when it is a Secondary replica. + :type secondary_default_load: int + :param default_load: Used only for Stateless services. The default amount of load, as a number, + that this service creates for this metric. + :type default_load: int + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'weight': {'key': 'weight', 'type': 'str'}, + 'primary_default_load': {'key': 'primaryDefaultLoad', 'type': 'int'}, + 'secondary_default_load': {'key': 'secondaryDefaultLoad', 'type': 'int'}, + 'default_load': {'key': 'defaultLoad', 'type': 'int'}, + } + + def __init__( + self, + *, + name: str, + weight: Optional[Union[str, "ServiceLoadMetricWeight"]] = None, + primary_default_load: Optional[int] = None, + secondary_default_load: Optional[int] = None, + default_load: Optional[int] = None, + **kwargs + ): + super(ServiceLoadMetric, self).__init__(**kwargs) + self.name = name + self.weight = weight + self.primary_default_load = primary_default_load + self.secondary_default_load = secondary_default_load + self.default_load = default_load + + +class ServicePlacementPolicy(msrest.serialization.Model): + """Describes the policy to be used for placement of a Service Fabric service. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: ServicePlacementInvalidDomainPolicy, ServicePlacementNonPartiallyPlaceServicePolicy, ServicePlacementPreferPrimaryDomainPolicy, ServicePlacementRequiredDomainPolicy, ServicePlacementRequireDomainDistributionPolicy. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + """ + + _validation = { + 'type': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + _subtype_map = { + 'type': {'InvalidDomain': 'ServicePlacementInvalidDomainPolicy', 'NonPartiallyPlaceService': 'ServicePlacementNonPartiallyPlaceServicePolicy', 'PreferredPrimaryDomain': 'ServicePlacementPreferPrimaryDomainPolicy', 'RequiredDomain': 'ServicePlacementRequiredDomainPolicy', 'RequiredDomainDistribution': 'ServicePlacementRequireDomainDistributionPolicy'} + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementPolicy, self).__init__(**kwargs) + self.type = None # type: Optional[str] + + +class ServicePlacementInvalidDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where a particular fault or upgrade domain should not be used for placement of the instances or replicas of that service. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should not be used for placement. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + *, + domain_name: str, + **kwargs + ): + super(ServicePlacementInvalidDomainPolicy, self).__init__(**kwargs) + self.type = 'InvalidDomain' # type: str + self.domain_name = domain_name + + +class ServicePlacementNonPartiallyPlaceServicePolicy(ServicePlacementPolicy): + """ServicePlacementNonPartiallyPlaceServicePolicy. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + """ + + _validation = { + 'type': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ServicePlacementNonPartiallyPlaceServicePolicy, self).__init__(**kwargs) + self.type = 'NonPartiallyPlaceService' # type: str + + +class ServicePlacementPreferPrimaryDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where the service's +Primary replicas should optimally be placed in a particular domain. + +This placement policy is usually used with fault domains in scenarios where the Service Fabric +cluster is geographically distributed in order to indicate that a service's primary replica should +be located in a particular fault domain, which in geo-distributed scenarios usually aligns with regional +or datacenter boundaries. Note that since this is an optimization it is possible that the Primary replica +may not end up located in this domain due to failures, capacity limits, or other constraints. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + *, + domain_name: str, + **kwargs + ): + super(ServicePlacementPreferPrimaryDomainPolicy, self).__init__(**kwargs) + self.type = 'PreferredPrimaryDomain' # type: str + self.domain_name = domain_name + + +class ServicePlacementRequiredDomainPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where the instances or replicas of that service must be placed in a particular domain. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + *, + domain_name: str, + **kwargs + ): + super(ServicePlacementRequiredDomainPolicy, self).__init__(**kwargs) + self.type = 'RequiredDomain' # type: str + self.domain_name = domain_name + + +class ServicePlacementRequireDomainDistributionPolicy(ServicePlacementPolicy): + """Describes the policy to be used for placement of a Service Fabric service where two replicas +from the same partition should never be placed in the same fault or upgrade domain. + +While this is not common it can expose the service to an increased risk of concurrent failures +due to unplanned outages or other cases of subsequent/concurrent failures. As an example, consider +a case where replicas are deployed across different data center, with one replica per location. +In the event that one of the datacenters goes offline, normally the replica that was placed in that +datacenter will be packed into one of the remaining datacenters. If this is not desirable then this +policy should be set. + + All required parameters must be populated in order to send to Azure. + + :param type: Required. The type of placement policy for a service fabric service. Following are + the possible values.Constant filled by server. Possible values include: "InvalidDomain", + "RequiredDomain", "PreferredPrimaryDomain", "RequiredDomainDistribution", + "NonPartiallyPlaceService". + :type type: str or + ~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicyType + :param domain_name: Required. The name of the domain that should used for placement as per this + policy. + :type domain_name: str + """ + + _validation = { + 'type': {'required': True}, + 'domain_name': {'required': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'domain_name': {'key': 'domainName', 'type': 'str'}, + } + + def __init__( + self, + *, + domain_name: str, + **kwargs + ): + super(ServicePlacementRequireDomainDistributionPolicy, self).__init__(**kwargs) + self.type = 'RequiredDomainDistribution' # type: str + self.domain_name = domain_name + + +class ServiceResource(ProxyResource): + """The service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Azure resource identifier. + :vartype id: str + :ivar name: Azure resource name. + :vartype name: str + :ivar type: Azure resource type. + :vartype type: str + :param location: Resource location depends on the parent resource. + :type location: str + :param tags: A set of tags. Azure resource tags. + :type tags: dict[str, str] + :ivar system_data: Metadata pertaining to creation and last modification of the resource. + :vartype system_data: ~service_fabric_managed_clusters_management_client.models.SystemData + :param properties: The service resource properties. + :type properties: + ~service_fabric_managed_clusters_management_client.models.ServiceResourceProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'system_data': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'properties': {'key': 'properties', 'type': 'ServiceResourceProperties'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + properties: Optional["ServiceResourceProperties"] = None, + **kwargs + ): + super(ServiceResource, self).__init__(location=location, tags=tags, **kwargs) + self.properties = properties + + +class ServiceResourceList(msrest.serialization.Model): + """The list of service resources. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: + :type value: list[~service_fabric_managed_clusters_management_client.models.ServiceResource] + :ivar next_link: URL to get the next set of service list results if there are any. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ServiceResource]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ServiceResource"]] = None, + **kwargs + ): + super(ServiceResourceList, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ServiceResourcePropertiesBase(msrest.serialization.Model): + """The common service resource properties. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + """ + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + } + + def __init__( + self, + *, + placement_constraints: Optional[str] = None, + correlation_scheme: Optional[List["ServiceCorrelation"]] = None, + service_load_metrics: Optional[List["ServiceLoadMetric"]] = None, + service_placement_policies: Optional[List["ServicePlacementPolicy"]] = None, + default_move_cost: Optional[Union[str, "MoveCost"]] = None, + scaling_policies: Optional[List["ScalingPolicy"]] = None, + **kwargs + ): + super(ServiceResourcePropertiesBase, self).__init__(**kwargs) + self.placement_constraints = placement_constraints + self.correlation_scheme = correlation_scheme + self.service_load_metrics = service_load_metrics + self.service_placement_policies = service_placement_policies + self.default_move_cost = default_move_cost + self.scaling_policies = scaling_policies + + +class ServiceResourceProperties(ServiceResourcePropertiesBase): + """The service resource properties. + + You probably want to use the sub-classes and not this class directly. Known + sub-classes are: StatefulServiceProperties, StatelessServiceProperties. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + } + + _subtype_map = { + 'service_kind': {'Stateful': 'StatefulServiceProperties', 'Stateless': 'StatelessServiceProperties'} + } + + def __init__( + self, + *, + service_type_name: str, + partition_description: "Partition", + placement_constraints: Optional[str] = None, + correlation_scheme: Optional[List["ServiceCorrelation"]] = None, + service_load_metrics: Optional[List["ServiceLoadMetric"]] = None, + service_placement_policies: Optional[List["ServicePlacementPolicy"]] = None, + default_move_cost: Optional[Union[str, "MoveCost"]] = None, + scaling_policies: Optional[List["ScalingPolicy"]] = None, + service_package_activation_mode: Optional[Union[str, "ServicePackageActivationMode"]] = None, + service_dns_name: Optional[str] = None, + **kwargs + ): + super(ServiceResourceProperties, self).__init__(placement_constraints=placement_constraints, correlation_scheme=correlation_scheme, service_load_metrics=service_load_metrics, service_placement_policies=service_placement_policies, default_move_cost=default_move_cost, scaling_policies=scaling_policies, **kwargs) + self.provisioning_state = None + self.service_kind = 'ServiceResourceProperties' # type: str + self.service_type_name = service_type_name + self.partition_description = partition_description + self.service_package_activation_mode = service_package_activation_mode + self.service_dns_name = service_dns_name + + +class ServiceTypeHealthPolicy(msrest.serialization.Model): + """Represents the health policy used to evaluate the health of services belonging to a service type. + + All required parameters must be populated in order to send to Azure. + + :param max_percent_unhealthy_services: Required. The maximum allowed percentage of unhealthy + services. + + The percentage represents the maximum tolerated percentage of services that can be unhealthy + before the application is considered in error. + If the percentage is respected but there is at least one unhealthy service, the health is + evaluated as Warning. + This is calculated by dividing the number of unhealthy services of the specific service type + over the total number of services of the specific service type. + The computation rounds up to tolerate one failure on small numbers of services. + :type max_percent_unhealthy_services: int + :param max_percent_unhealthy_partitions_per_service: Required. The maximum allowed percentage + of unhealthy partitions per service. + + The percentage represents the maximum tolerated percentage of partitions that can be unhealthy + before the service is considered in error. + If the percentage is respected but there is at least one unhealthy partition, the health is + evaluated as Warning. + The percentage is calculated by dividing the number of unhealthy partitions over the total + number of partitions in the service. + The computation rounds up to tolerate one failure on small numbers of partitions. + :type max_percent_unhealthy_partitions_per_service: int + :param max_percent_unhealthy_replicas_per_partition: Required. The maximum allowed percentage + of unhealthy replicas per partition. + + The percentage represents the maximum tolerated percentage of replicas that can be unhealthy + before the partition is considered in error. + If the percentage is respected but there is at least one unhealthy replica, the health is + evaluated as Warning. + The percentage is calculated by dividing the number of unhealthy replicas over the total + number of replicas in the partition. + The computation rounds up to tolerate one failure on small numbers of replicas. + :type max_percent_unhealthy_replicas_per_partition: int + """ + + _validation = { + 'max_percent_unhealthy_services': {'required': True, 'maximum': 100, 'minimum': 0}, + 'max_percent_unhealthy_partitions_per_service': {'required': True, 'maximum': 100, 'minimum': 0}, + 'max_percent_unhealthy_replicas_per_partition': {'required': True, 'maximum': 100, 'minimum': 0}, + } + + _attribute_map = { + 'max_percent_unhealthy_services': {'key': 'maxPercentUnhealthyServices', 'type': 'int'}, + 'max_percent_unhealthy_partitions_per_service': {'key': 'maxPercentUnhealthyPartitionsPerService', 'type': 'int'}, + 'max_percent_unhealthy_replicas_per_partition': {'key': 'maxPercentUnhealthyReplicasPerPartition', 'type': 'int'}, + } + + def __init__( + self, + *, + max_percent_unhealthy_services: int, + max_percent_unhealthy_partitions_per_service: int, + max_percent_unhealthy_replicas_per_partition: int, + **kwargs + ): + super(ServiceTypeHealthPolicy, self).__init__(**kwargs) + self.max_percent_unhealthy_services = max_percent_unhealthy_services + self.max_percent_unhealthy_partitions_per_service = max_percent_unhealthy_partitions_per_service + self.max_percent_unhealthy_replicas_per_partition = max_percent_unhealthy_replicas_per_partition + + +class ServiceUpdateParameters(msrest.serialization.Model): + """Service update request. + + :param tags: A set of tags. Service update parameters. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ServiceUpdateParameters, self).__init__(**kwargs) + self.tags = tags + + +class SettingsParameterDescription(msrest.serialization.Model): + """Describes a parameter in fabric settings of the cluster. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The parameter name of fabric setting. + :type name: str + :param value: Required. The parameter value of fabric setting. + :type value: str + """ + + _validation = { + 'name': {'required': True}, + 'value': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + value: str, + **kwargs + ): + super(SettingsParameterDescription, self).__init__(**kwargs) + self.name = name + self.value = value + + +class SettingsSectionDescription(msrest.serialization.Model): + """Describes a section in the fabric settings of the cluster. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The section name of the fabric settings. + :type name: str + :param parameters: Required. The collection of parameters in the section. + :type parameters: + list[~service_fabric_managed_clusters_management_client.models.SettingsParameterDescription] + """ + + _validation = { + 'name': {'required': True}, + 'parameters': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '[SettingsParameterDescription]'}, + } + + def __init__( + self, + *, + name: str, + parameters: List["SettingsParameterDescription"], + **kwargs + ): + super(SettingsSectionDescription, self).__init__(**kwargs) + self.name = name + self.parameters = parameters + + +class SingletonPartitionScheme(Partition): + """SingletonPartitionScheme. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + """ + + _validation = { + 'partition_scheme': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SingletonPartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'Singleton' # type: str + + +class Sku(msrest.serialization.Model): + """Service Fabric managed cluster Sku definition. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. Sku Name. Possible values include: "Basic", "Standard". + :type name: str or ~service_fabric_managed_clusters_management_client.models.SkuName + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Union[str, "SkuName"], + **kwargs + ): + super(Sku, self).__init__(**kwargs) + self.name = name + + +class StatefulServiceProperties(ServiceResourceProperties): + """The properties of a stateful service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + :param has_persisted_state: A flag indicating whether this is a persistent service which stores + states on the local disk. If it is then the value of this property is true, if not it is false. + :type has_persisted_state: bool + :param target_replica_set_size: The target replica set size as a number. + :type target_replica_set_size: int + :param min_replica_set_size: The minimum replica set size as a number. + :type min_replica_set_size: int + :param replica_restart_wait_duration: The duration between when a replica goes down and when a + new replica is created, represented in ISO 8601 format "hh:mm:ss". + :type replica_restart_wait_duration: str + :param quorum_loss_wait_duration: The maximum duration for which a partition is allowed to be + in a state of quorum loss, represented in ISO 8601 format "hh:mm:ss". + :type quorum_loss_wait_duration: str + :param stand_by_replica_keep_duration: The definition on how long StandBy replicas should be + maintained before being removed, represented in ISO 8601 format "hh:mm:ss". + :type stand_by_replica_keep_duration: str + :param service_placement_time_limit: The duration for which replicas can stay InBuild before + reporting that build is stuck, represented in ISO 8601 format "hh:mm:ss". + :type service_placement_time_limit: str + :param drop_source_replica_on_move: Indicates whether to drop source Secondary replica even if + the target replica has not finished build. If desired behavior is to drop it as soon as + possible the value of this property is true, if not it is false. + :type drop_source_replica_on_move: bool + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + 'target_replica_set_size': {'minimum': 1}, + 'min_replica_set_size': {'minimum': 1}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + 'has_persisted_state': {'key': 'hasPersistedState', 'type': 'bool'}, + 'target_replica_set_size': {'key': 'targetReplicaSetSize', 'type': 'int'}, + 'min_replica_set_size': {'key': 'minReplicaSetSize', 'type': 'int'}, + 'replica_restart_wait_duration': {'key': 'replicaRestartWaitDuration', 'type': 'str'}, + 'quorum_loss_wait_duration': {'key': 'quorumLossWaitDuration', 'type': 'str'}, + 'stand_by_replica_keep_duration': {'key': 'standByReplicaKeepDuration', 'type': 'str'}, + 'service_placement_time_limit': {'key': 'servicePlacementTimeLimit', 'type': 'str'}, + 'drop_source_replica_on_move': {'key': 'dropSourceReplicaOnMove', 'type': 'bool'}, + } + + def __init__( + self, + *, + service_type_name: str, + partition_description: "Partition", + placement_constraints: Optional[str] = None, + correlation_scheme: Optional[List["ServiceCorrelation"]] = None, + service_load_metrics: Optional[List["ServiceLoadMetric"]] = None, + service_placement_policies: Optional[List["ServicePlacementPolicy"]] = None, + default_move_cost: Optional[Union[str, "MoveCost"]] = None, + scaling_policies: Optional[List["ScalingPolicy"]] = None, + service_package_activation_mode: Optional[Union[str, "ServicePackageActivationMode"]] = None, + service_dns_name: Optional[str] = None, + has_persisted_state: Optional[bool] = None, + target_replica_set_size: Optional[int] = None, + min_replica_set_size: Optional[int] = None, + replica_restart_wait_duration: Optional[str] = None, + quorum_loss_wait_duration: Optional[str] = None, + stand_by_replica_keep_duration: Optional[str] = None, + service_placement_time_limit: Optional[str] = None, + drop_source_replica_on_move: Optional[bool] = None, + **kwargs + ): + super(StatefulServiceProperties, self).__init__(placement_constraints=placement_constraints, correlation_scheme=correlation_scheme, service_load_metrics=service_load_metrics, service_placement_policies=service_placement_policies, default_move_cost=default_move_cost, scaling_policies=scaling_policies, service_type_name=service_type_name, partition_description=partition_description, service_package_activation_mode=service_package_activation_mode, service_dns_name=service_dns_name, **kwargs) + self.service_kind = 'Stateful' # type: str + self.has_persisted_state = has_persisted_state + self.target_replica_set_size = target_replica_set_size + self.min_replica_set_size = min_replica_set_size + self.replica_restart_wait_duration = replica_restart_wait_duration + self.quorum_loss_wait_duration = quorum_loss_wait_duration + self.stand_by_replica_keep_duration = stand_by_replica_keep_duration + self.service_placement_time_limit = service_placement_time_limit + self.drop_source_replica_on_move = drop_source_replica_on_move + + +class StatelessServiceProperties(ServiceResourceProperties): + """The properties of a stateless service resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param placement_constraints: The placement constraints as a string. Placement constraints are + boolean expressions on node properties and allow for restricting a service to particular nodes + based on the service requirements. For example, to place a service on nodes where NodeType is + blue specify the following: "NodeColor == blue)". + :type placement_constraints: str + :param correlation_scheme: A list that describes the correlation of the service with other + services. + :type correlation_scheme: + list[~service_fabric_managed_clusters_management_client.models.ServiceCorrelation] + :param service_load_metrics: The service load metrics is given as an array of ServiceLoadMetric + objects. + :type service_load_metrics: + list[~service_fabric_managed_clusters_management_client.models.ServiceLoadMetric] + :param service_placement_policies: A list that describes the correlation of the service with + other services. + :type service_placement_policies: + list[~service_fabric_managed_clusters_management_client.models.ServicePlacementPolicy] + :param default_move_cost: Specifies the move cost for the service. Possible values include: + "Zero", "Low", "Medium", "High". + :type default_move_cost: str or + ~service_fabric_managed_clusters_management_client.models.MoveCost + :param scaling_policies: Scaling policies for this service. + :type scaling_policies: + list[~service_fabric_managed_clusters_management_client.models.ScalingPolicy] + :ivar provisioning_state: The current deployment or provisioning state, which only appears in + the response. + :vartype provisioning_state: str + :param service_kind: Required. The kind of service (Stateless or Stateful).Constant filled by + server. Possible values include: "Stateless", "Stateful". + :type service_kind: str or + ~service_fabric_managed_clusters_management_client.models.ServiceKind + :param service_type_name: Required. The name of the service type. + :type service_type_name: str + :param partition_description: Required. Describes how the service is partitioned. + :type partition_description: + ~service_fabric_managed_clusters_management_client.models.Partition + :param service_package_activation_mode: The activation Mode of the service package. Possible + values include: "SharedProcess", "ExclusiveProcess". + :type service_package_activation_mode: str or + ~service_fabric_managed_clusters_management_client.models.ServicePackageActivationMode + :param service_dns_name: The DNS name of the service. It requires the DNS system service to be + enabled in Service Fabric cluster. + :type service_dns_name: str + :param instance_count: Required. The instance count. + :type instance_count: int + :param min_instance_count: MinInstanceCount is the minimum number of instances that must be up + to meet the EnsureAvailability safety check during operations like upgrade or deactivate node. + The actual number that is used is max( MinInstanceCount, ceil( MinInstancePercentage/100.0 * + InstanceCount) ). Note, if InstanceCount is set to -1, during MinInstanceCount computation -1 + is first converted into the number of nodes on which the instances are allowed to be placed + according to the placement constraints on the service. + :type min_instance_count: int + :param min_instance_percentage: MinInstancePercentage is the minimum percentage of + InstanceCount that must be up to meet the EnsureAvailability safety check during operations + like upgrade or deactivate node. The actual number that is used is max( MinInstanceCount, ceil( + MinInstancePercentage/100.0 * InstanceCount) ). Note, if InstanceCount is set to -1, during + MinInstancePercentage computation, -1 is first converted into the number of nodes on which the + instances are allowed to be placed according to the placement constraints on the service. + :type min_instance_percentage: int + :param instance_close_delay_duration: Duration represented in ISO 8601 format "hh:mm:ss", to + wait before a stateless instance is closed, to allow the active requests to drain gracefully. + This would be effective when the instance is closing during the application/cluster upgrade and + disabling node. The endpoint exposed on this instance is removed prior to starting the delay, + which prevents new connections to this instance. In addition, clients that have subscribed to + service endpoint change + events(https://docs.microsoft.com/dotnet/api/system.fabric.fabricclient.servicemanagementclient.registerservicenotificationfilterasync), + can do the following upon receiving the endpoint removal notification: - Stop sending new + requests to this instance. - Close existing connections after in-flight requests have + completed. - Connect to a different instance of the service partition for future requests. + Note, the default value of InstanceCloseDelayDuration is 0, which indicates that there won't be + any delay or removal of the endpoint prior to closing the instance. + :type instance_close_delay_duration: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'service_kind': {'required': True}, + 'service_type_name': {'required': True}, + 'partition_description': {'required': True}, + 'instance_count': {'required': True, 'minimum': -1}, + } + + _attribute_map = { + 'placement_constraints': {'key': 'placementConstraints', 'type': 'str'}, + 'correlation_scheme': {'key': 'correlationScheme', 'type': '[ServiceCorrelation]'}, + 'service_load_metrics': {'key': 'serviceLoadMetrics', 'type': '[ServiceLoadMetric]'}, + 'service_placement_policies': {'key': 'servicePlacementPolicies', 'type': '[ServicePlacementPolicy]'}, + 'default_move_cost': {'key': 'defaultMoveCost', 'type': 'str'}, + 'scaling_policies': {'key': 'scalingPolicies', 'type': '[ScalingPolicy]'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'service_kind': {'key': 'serviceKind', 'type': 'str'}, + 'service_type_name': {'key': 'serviceTypeName', 'type': 'str'}, + 'partition_description': {'key': 'partitionDescription', 'type': 'Partition'}, + 'service_package_activation_mode': {'key': 'servicePackageActivationMode', 'type': 'str'}, + 'service_dns_name': {'key': 'serviceDnsName', 'type': 'str'}, + 'instance_count': {'key': 'instanceCount', 'type': 'int'}, + 'min_instance_count': {'key': 'minInstanceCount', 'type': 'int'}, + 'min_instance_percentage': {'key': 'minInstancePercentage', 'type': 'int'}, + 'instance_close_delay_duration': {'key': 'instanceCloseDelayDuration', 'type': 'str'}, + } + + def __init__( + self, + *, + service_type_name: str, + partition_description: "Partition", + instance_count: int, + placement_constraints: Optional[str] = None, + correlation_scheme: Optional[List["ServiceCorrelation"]] = None, + service_load_metrics: Optional[List["ServiceLoadMetric"]] = None, + service_placement_policies: Optional[List["ServicePlacementPolicy"]] = None, + default_move_cost: Optional[Union[str, "MoveCost"]] = None, + scaling_policies: Optional[List["ScalingPolicy"]] = None, + service_package_activation_mode: Optional[Union[str, "ServicePackageActivationMode"]] = None, + service_dns_name: Optional[str] = None, + min_instance_count: Optional[int] = None, + min_instance_percentage: Optional[int] = None, + instance_close_delay_duration: Optional[str] = "0", + **kwargs + ): + super(StatelessServiceProperties, self).__init__(placement_constraints=placement_constraints, correlation_scheme=correlation_scheme, service_load_metrics=service_load_metrics, service_placement_policies=service_placement_policies, default_move_cost=default_move_cost, scaling_policies=scaling_policies, service_type_name=service_type_name, partition_description=partition_description, service_package_activation_mode=service_package_activation_mode, service_dns_name=service_dns_name, **kwargs) + self.service_kind = 'Stateless' # type: str + self.instance_count = instance_count + self.min_instance_count = min_instance_count + self.min_instance_percentage = min_instance_percentage + self.instance_close_delay_duration = instance_close_delay_duration + + +class SubResource(msrest.serialization.Model): + """Azure resource identifier. + + :param id: Azure resource identifier. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(SubResource, self).__init__(**kwargs) + self.id = id + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. + :type created_by_type: str + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. + :type last_modified_by_type: str + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + created_by: Optional[str] = None, + created_by_type: Optional[str] = None, + created_at: Optional[datetime.datetime] = None, + last_modified_by: Optional[str] = None, + last_modified_by_type: Optional[str] = None, + last_modified_at: Optional[datetime.datetime] = None, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = created_by + self.created_by_type = created_by_type + self.created_at = created_at + self.last_modified_by = last_modified_by + self.last_modified_by_type = last_modified_by_type + self.last_modified_at = last_modified_at + + +class UniformInt64RangePartitionScheme(Partition): + """Describes a partitioning scheme where an integer range is allocated evenly across a number of partitions. + + All required parameters must be populated in order to send to Azure. + + :param partition_scheme: Required. Specifies how the service is partitioned.Constant filled by + server. Possible values include: "Singleton", "UniformInt64Range", "Named". + :type partition_scheme: str or + ~service_fabric_managed_clusters_management_client.models.PartitionScheme + :param count: Required. The number of partitions. + :type count: int + :param low_key: Required. The lower bound of the partition key range that + should be split between the partition ‘Count’. + :type low_key: long + :param high_key: Required. The upper bound of the partition key range that + should be split between the partition ‘Count’. + :type high_key: long + """ + + _validation = { + 'partition_scheme': {'required': True}, + 'count': {'required': True}, + 'low_key': {'required': True}, + 'high_key': {'required': True}, + } + + _attribute_map = { + 'partition_scheme': {'key': 'partitionScheme', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'int'}, + 'low_key': {'key': 'lowKey', 'type': 'long'}, + 'high_key': {'key': 'highKey', 'type': 'long'}, + } + + def __init__( + self, + *, + count: int, + low_key: int, + high_key: int, + **kwargs + ): + super(UniformInt64RangePartitionScheme, self).__init__(**kwargs) + self.partition_scheme = 'UniformInt64Range' # type: str + self.count = count + self.low_key = low_key + self.high_key = high_key + + +class UserAssignedIdentity(msrest.serialization.Model): + """UserAssignedIdentity. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of user assigned identity. + :vartype principal_id: str + :ivar client_id: The client id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(UserAssignedIdentity, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class VaultCertificate(msrest.serialization.Model): + """Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. + + All required parameters must be populated in order to send to Azure. + + :param certificate_url: Required. This is the URL of a certificate that has been uploaded to + Key Vault as a secret. For adding a secret to the Key Vault, see `Add a key or secret to the + key vault `_. In this + case, your certificate needs to be It is the Base64 encoding of the following JSON Object which + is encoded in UTF-8: :code:`
`:code:`
` {:code:`
` "data":":code:``",:code:`
` "dataType":"pfx",:code:`
` "password":":code:``":code:`
`}. + :type certificate_url: str + :param certificate_store: Required. For Windows VMs, specifies the certificate store on the + Virtual Machine to which the certificate should be added. The specified certificate store is + implicitly in the LocalMachine account. :code:`
`:code:`
`For Linux VMs, the certificate + file is placed under the /var/lib/waagent directory, with the file name + :code:``.crt for the X509 certificate file and + :code:``.prv for private key. Both of these files are .pem formatted. + :type certificate_store: str + """ + + _validation = { + 'certificate_url': {'required': True}, + 'certificate_store': {'required': True}, + } + + _attribute_map = { + 'certificate_url': {'key': 'certificateUrl', 'type': 'str'}, + 'certificate_store': {'key': 'certificateStore', 'type': 'str'}, + } + + def __init__( + self, + *, + certificate_url: str, + certificate_store: str, + **kwargs + ): + super(VaultCertificate, self).__init__(**kwargs) + self.certificate_url = certificate_url + self.certificate_store = certificate_store + + +class VaultSecretGroup(msrest.serialization.Model): + """Specifies set of certificates that should be installed onto the virtual machines. + + All required parameters must be populated in order to send to Azure. + + :param source_vault: Required. The relative URL of the Key Vault containing all of the + certificates in VaultCertificates. + :type source_vault: ~service_fabric_managed_clusters_management_client.models.SubResource + :param vault_certificates: Required. The list of key vault references in SourceVault which + contain certificates. + :type vault_certificates: + list[~service_fabric_managed_clusters_management_client.models.VaultCertificate] + """ + + _validation = { + 'source_vault': {'required': True}, + 'vault_certificates': {'required': True}, + } + + _attribute_map = { + 'source_vault': {'key': 'sourceVault', 'type': 'SubResource'}, + 'vault_certificates': {'key': 'vaultCertificates', 'type': '[VaultCertificate]'}, + } + + def __init__( + self, + *, + source_vault: "SubResource", + vault_certificates: List["VaultCertificate"], + **kwargs + ): + super(VaultSecretGroup, self).__init__(**kwargs) + self.source_vault = source_vault + self.vault_certificates = vault_certificates + + +class VmManagedIdentity(msrest.serialization.Model): + """Identities for the virtual machine scale set under the node type. + + :param user_assigned_identities: The list of user identities associated with the virtual + machine scale set under the node type. Each entry will be an ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: list[str] + """ + + _attribute_map = { + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '[str]'}, + } + + def __init__( + self, + *, + user_assigned_identities: Optional[List[str]] = None, + **kwargs + ): + super(VmManagedIdentity, self).__init__(**kwargs) + self.user_assigned_identities = user_assigned_identities + + +class VMSSExtension(msrest.serialization.Model): + """Specifies set of extensions that should be installed onto the virtual machines. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the extension. + :type name: str + :param publisher: Required. The name of the extension handler publisher. + :type publisher: str + :param type: Required. Specifies the type of the extension; an example is + "CustomScriptExtension". + :type type: str + :param type_handler_version: Required. Specifies the version of the script handler. + :type type_handler_version: str + :param auto_upgrade_minor_version: Indicates whether the extension should use a newer minor + version if one is available at deployment time. Once deployed, however, the extension will not + upgrade minor versions unless redeployed, even with this property set to true. + :type auto_upgrade_minor_version: bool + :param settings: Json formatted public settings for the extension. + :type settings: object + :param protected_settings: The extension can contain either protectedSettings or + protectedSettingsFromKeyVault or no protected settings at all. + :type protected_settings: object + :param force_update_tag: If a value is provided and is different from the previous value, the + extension handler will be forced to update even if the extension configuration has not changed. + :type force_update_tag: str + :param provision_after_extensions: Collection of extension names after which this extension + needs to be provisioned. + :type provision_after_extensions: list[str] + :ivar provisioning_state: The provisioning state, which only appears in the response. + :vartype provisioning_state: str + """ + + _validation = { + 'name': {'required': True}, + 'publisher': {'required': True}, + 'type': {'required': True}, + 'type_handler_version': {'required': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'publisher': {'key': 'properties.publisher', 'type': 'str'}, + 'type': {'key': 'properties.type', 'type': 'str'}, + 'type_handler_version': {'key': 'properties.typeHandlerVersion', 'type': 'str'}, + 'auto_upgrade_minor_version': {'key': 'properties.autoUpgradeMinorVersion', 'type': 'bool'}, + 'settings': {'key': 'properties.settings', 'type': 'object'}, + 'protected_settings': {'key': 'properties.protectedSettings', 'type': 'object'}, + 'force_update_tag': {'key': 'properties.forceUpdateTag', 'type': 'str'}, + 'provision_after_extensions': {'key': 'properties.provisionAfterExtensions', 'type': '[str]'}, + 'provisioning_state': {'key': 'properties.provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + publisher: str, + type: str, + type_handler_version: str, + auto_upgrade_minor_version: Optional[bool] = None, + settings: Optional[object] = None, + protected_settings: Optional[object] = None, + force_update_tag: Optional[str] = None, + provision_after_extensions: Optional[List[str]] = None, + **kwargs + ): + super(VMSSExtension, self).__init__(**kwargs) + self.name = name + self.publisher = publisher + self.type = type + self.type_handler_version = type_handler_version + self.auto_upgrade_minor_version = auto_upgrade_minor_version + self.settings = settings + self.protected_settings = protected_settings + self.force_update_tag = force_update_tag + self.provision_after_extensions = provision_after_extensions + self.provisioning_state = None diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_service_fabric_managed_clusters_management_client_enums.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_service_fabric_managed_clusters_management_client_enums.py new file mode 100644 index 000000000000..8bd1bd636f51 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/models/_service_fabric_managed_clusters_management_client_enums.py @@ -0,0 +1,231 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from enum import Enum, EnumMeta +from six import with_metaclass + +class _CaseInsensitiveEnumMeta(EnumMeta): + def __getitem__(self, name): + return super().__getitem__(name.upper()) + + def __getattr__(cls, name): + """Return the enum member matching `name` + We use __getattr__ instead of descriptors or inserting into the enum + class' __dict__ in order to support `name` and `value` being both + properties for enum members (which live in the class' __dict__) and + enum members themselves. + """ + try: + return cls._member_map_[name.upper()] + except KeyError: + raise AttributeError(name) + + +class Access(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The network traffic is allowed or denied. + """ + + ALLOW = "allow" + DENY = "deny" + +class ClusterState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The current state of the cluster. + + + * WaitingForNodes - Indicates that the cluster resource is created and the resource provider is + waiting for Service Fabric VM extension to boot up and report to it. + * Deploying - Indicates that the Service Fabric runtime is being installed on the VMs. Cluster + resource will be in this state until the cluster boots up and system services are up. + * BaselineUpgrade - Indicates that the cluster is upgrading to establishes the cluster version. + This upgrade is automatically initiated when the cluster boots up for the first time. + * Upgrading - Indicates that the cluster is being upgraded with the user provided + configuration. + * UpgradeFailed - Indicates that the last upgrade for the cluster has failed. + * Ready - Indicates that the cluster is in a stable state. + """ + + WAITING_FOR_NODES = "WaitingForNodes" + DEPLOYING = "Deploying" + BASELINE_UPGRADE = "BaselineUpgrade" + UPGRADING = "Upgrading" + UPGRADE_FAILED = "UpgradeFailed" + READY = "Ready" + +class ClusterUpgradeCadence(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Indicates when new cluster runtime version upgrades will be applied after they are released. By + default is Wave0. + """ + + WAVE0 = "Wave0" #: Cluster upgrade starts immediately after a new version is rolled out. Recommended for Test/Dev clusters. + WAVE1 = "Wave1" #: Cluster upgrade starts 7 days after a new version is rolled out. Recommended for Pre-prod clusters. + WAVE2 = "Wave2" #: Cluster upgrade starts 14 days after a new version is rolled out. Recommended for Production clusters. + +class Direction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Network security rule direction. + """ + + INBOUND = "inbound" + OUTBOUND = "outbound" + +class FailureAction(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The compensating action to perform when a Monitored upgrade encounters monitoring policy or + health policy violations. Invalid indicates the failure action is invalid. Rollback specifies + that the upgrade will start rolling back automatically. Manual indicates that the upgrade will + switch to UnmonitoredManual upgrade mode. + """ + + ROLLBACK = "Rollback" #: Indicates that a rollback of the upgrade will be performed by Service Fabric if the upgrade fails. + MANUAL = "Manual" #: Indicates that a manual repair will need to be performed by the administrator if the upgrade fails. Service Fabric will not proceed to the next upgrade domain automatically. + +class ManagedClusterAddOnFeature(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Available cluster add-on features + """ + + DNS_SERVICE = "DnsService" + BACKUP_RESTORE_SERVICE = "BackupRestoreService" + RESOURCE_MONITOR_SERVICE = "ResourceMonitorService" + +class ManagedIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of managed identity for the resource. + """ + + NONE = "None" #: Indicates that no identity is associated with the resource. + SYSTEM_ASSIGNED = "SystemAssigned" #: Indicates that system assigned identity is associated with the resource. + USER_ASSIGNED = "UserAssigned" #: Indicates that user assigned identity is associated with the resource. + SYSTEM_ASSIGNED_USER_ASSIGNED = "SystemAssigned, UserAssigned" #: Indicates that both system assigned and user assigned identity are associated with the resource. + +class ManagedResourceProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The provisioning state of the managed resource. + """ + + NONE = "None" + CREATING = "Creating" + CREATED = "Created" + UPDATING = "Updating" + SUCCEEDED = "Succeeded" + FAILED = "Failed" + CANCELED = "Canceled" + DELETING = "Deleting" + DELETED = "Deleted" + OTHER = "Other" + +class MoveCost(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Specifies the move cost for the service. + """ + + ZERO = "Zero" #: Zero move cost. This value is zero. + LOW = "Low" #: Specifies the move cost of the service as Low. The value is 1. + MEDIUM = "Medium" #: Specifies the move cost of the service as Medium. The value is 2. + HIGH = "High" #: Specifies the move cost of the service as High. The value is 3. + +class NsgProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Network protocol this rule applies to. + """ + + HTTP = "http" + HTTPS = "https" + TCP = "tcp" + UDP = "udp" + ICMP = "icmp" + AH = "ah" + ESP = "esp" + +class PartitionScheme(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Enumerates the ways that a service can be partitioned. + """ + + SINGLETON = "Singleton" #: Indicates that the partition is based on string names, and is a SingletonPartitionScheme object, The value is 0. + UNIFORM_INT64_RANGE = "UniformInt64Range" #: Indicates that the partition is based on Int64 key ranges, and is a UniformInt64RangePartitionScheme object. The value is 1. + NAMED = "Named" #: Indicates that the partition is based on string names, and is a NamedPartitionScheme object. The value is 2. + +class ProbeProtocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """the reference to the load balancer probe used by the load balancing rule. + """ + + TCP = "tcp" + HTTP = "http" + HTTPS = "https" + +class Protocol(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The reference to the transport protocol used by the load balancing rule. + """ + + TCP = "tcp" + UDP = "udp" + +class RollingUpgradeMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The mode used to monitor health during a rolling upgrade. The values are Monitored, and + UnmonitoredAuto. + """ + + MONITORED = "Monitored" #: The upgrade will stop after completing each upgrade domain and automatically monitor health before proceeding. The value is 0. + UNMONITORED_AUTO = "UnmonitoredAuto" #: The upgrade will proceed automatically without performing any health monitoring. The value is 1. + +class ServiceCorrelationScheme(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The service correlation scheme. + """ + + ALIGNED_AFFINITY = "AlignedAffinity" #: Aligned affinity ensures that the primaries of the partitions of the affinitized services are collocated on the same nodes. This is the default and is the same as selecting the Affinity scheme. The value is 0. + NON_ALIGNED_AFFINITY = "NonAlignedAffinity" #: Non-Aligned affinity guarantees that all replicas of each service will be placed on the same nodes. Unlike Aligned Affinity, this does not guarantee that replicas of particular role will be collocated. The value is 1. + +class ServiceKind(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The kind of service (Stateless or Stateful). + """ + + STATELESS = "Stateless" #: Does not use Service Fabric to make its state highly available or reliable. The value is 0. + STATEFUL = "Stateful" #: Uses Service Fabric to make its state or part of its state highly available and reliable. The value is 1. + +class ServiceLoadMetricWeight(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Determines the metric weight relative to the other metrics that are configured for this + service. During runtime, if two metrics end up in conflict, the Cluster Resource Manager + prefers the metric with the higher weight. + """ + + ZERO = "Zero" #: Disables resource balancing for this metric. This value is zero. + LOW = "Low" #: Specifies the metric weight of the service load as Low. The value is 1. + MEDIUM = "Medium" #: Specifies the metric weight of the service load as Medium. The value is 2. + HIGH = "High" #: Specifies the metric weight of the service load as High. The value is 3. + +class ServicePackageActivationMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The activation Mode of the service package + """ + + SHARED_PROCESS = "SharedProcess" #: Indicates the application package activation mode will use shared process. + EXCLUSIVE_PROCESS = "ExclusiveProcess" #: Indicates the application package activation mode will use exclusive process. + +class ServicePlacementPolicyType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of placement policy for a service fabric service. Following are the possible values. + """ + + INVALID_DOMAIN = "InvalidDomain" #: Indicates that the ServicePlacementPolicyDescription is of type ServicePlacementInvalidDomainPolicyDescription, which indicates that a particular fault or upgrade domain cannot be used for placement of this service. The value is 0. + REQUIRED_DOMAIN = "RequiredDomain" #: Indicates that the ServicePlacementPolicyDescription is of type ServicePlacementRequireDomainDistributionPolicyDescription indicating that the replicas of the service must be placed in a specific domain. The value is 1. + PREFERRED_PRIMARY_DOMAIN = "PreferredPrimaryDomain" #: Indicates that the ServicePlacementPolicyDescription is of type ServicePlacementPreferPrimaryDomainPolicyDescription, which indicates that if possible the Primary replica for the partitions of the service should be located in a particular domain as an optimization. The value is 2. + REQUIRED_DOMAIN_DISTRIBUTION = "RequiredDomainDistribution" #: Indicates that the ServicePlacementPolicyDescription is of type ServicePlacementRequireDomainDistributionPolicyDescription, indicating that the system will disallow placement of any two replicas from the same partition in the same domain at any time. The value is 3. + NON_PARTIALLY_PLACE_SERVICE = "NonPartiallyPlaceService" #: Indicates that the ServicePlacementPolicyDescription is of type ServicePlacementNonPartiallyPlaceServicePolicyDescription, which indicates that if possible all replicas of a particular partition of the service should be placed atomically. The value is 4. + +class ServiceScalingMechanismKind(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Enumerates the ways that a service can be partitioned. + """ + + SCALE_PARTITION_INSTANCE_COUNT = "ScalePartitionInstanceCount" #: Represents a scaling mechanism for adding or removing instances of stateless service partition. The value is 0. + ADD_REMOVE_INCREMENTAL_NAMED_PARTITION = "AddRemoveIncrementalNamedPartition" #: Represents a scaling mechanism for adding or removing named partitions of a stateless service. The value is 1. + +class ServiceScalingTriggerKind(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Enumerates the ways that a service can be partitioned. + """ + + AVERAGE_PARTITION_LOAD = "AveragePartitionLoad" #: Represents a scaling trigger related to an average load of a metric/resource of a partition. The value is 0. + AVERAGE_SERVICE_LOAD = "AverageServiceLoad" #: Represents a scaling policy related to an average load of a metric/resource of a service. The value is 1. + +class SkuName(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Sku Name. Basic requires a minimum of 3 nodes and Standard a minimum of 5. Basic only allows 1 + node type. + """ + + BASIC = "Basic" + STANDARD = "Standard" diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/__init__.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/__init__.py new file mode 100644 index 000000000000..613aba52b2a2 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/__init__.py @@ -0,0 +1,25 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._application_types_operations import ApplicationTypesOperations +from ._application_type_versions_operations import ApplicationTypeVersionsOperations +from ._applications_operations import ApplicationsOperations +from ._services_operations import ServicesOperations +from ._managed_clusters_operations import ManagedClustersOperations +from ._operations import Operations +from ._node_types_operations import NodeTypesOperations + +__all__ = [ + 'ApplicationTypesOperations', + 'ApplicationTypeVersionsOperations', + 'ApplicationsOperations', + 'ServicesOperations', + 'ManagedClustersOperations', + 'Operations', + 'NodeTypesOperations', +] diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_type_versions_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_type_versions_operations.py new file mode 100644 index 000000000000..a60f4cea26a9 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_type_versions_operations.py @@ -0,0 +1,555 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationTypeVersionsOperations(object): + """ApplicationTypeVersionsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeVersionResource" + """Gets a Service Fabric managed application type version resource. + + Get a Service Fabric managed application type version resource created or in the process of + being created in the Service Fabric managed application type name resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeVersionResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + parameters, # type: "_models.ApplicationTypeVersionResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeVersionResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeVersionResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + parameters, # type: "_models.ApplicationTypeVersionResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationTypeVersionResource"] + """Creates or updates a Service Fabric managed application type version resource. + + Create or update a Service Fabric managed application type version resource with the specified + name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :param parameters: The application type version resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either ApplicationTypeVersionResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + version=version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + parameters, # type: "_models.ApplicationTypeVersionUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeVersionResource" + """Updates the tags of an application type version resource of a given managed cluster. + + Updates the tags of an application type version resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :param parameters: The application type version resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeVersionResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeVersionUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeVersionResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + version, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric managed application type version resource. + + Delete a Service Fabric managed application type version resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param version: The application type version. + :type version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + version=version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + 'version': self._serialize.url("version", version, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions/{version}'} # type: ignore + + def list_by_application_types( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationTypeVersionResourceList"] + """Gets the list of application type version resources created in the specified Service Fabric managed application type name resource. + + Gets all application type version resources created or in the process of being created in the + Service Fabric managed application type name resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationTypeVersionResourceList or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationTypeVersionResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeVersionResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_application_types.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationTypeVersionResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_application_types.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}/versions'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_types_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_types_operations.py new file mode 100644 index 000000000000..a1eee71c848f --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_application_types_operations.py @@ -0,0 +1,463 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationTypesOperations(object): + """ApplicationTypesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeResource" + """Gets a Service Fabric managed application type name resource. + + Get a Service Fabric application type name resource created or in the process of being created + in the Service Fabric managed cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + parameters, # type: "_models.ApplicationTypeResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeResource" + """Creates or updates a Service Fabric managed application type name resource. + + Create or update a Service Fabric managed application type name resource with the specified + name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param parameters: The application type name resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + parameters, # type: "_models.ApplicationTypeUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationTypeResource" + """Updates the tags of an application type resource of a given managed cluster. + + Updates the tags of an application type resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :param parameters: The application type resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationTypeResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationTypeResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationTypeUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationTypeResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric managed application type name resource. + + Delete a Service Fabric managed application type name resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_type_name: The name of the application type name resource. + :type application_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_type_name=application_type_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationTypeName': self._serialize.url("application_type_name", application_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes/{applicationTypeName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationTypeResourceList"] + """Gets the list of application type name resources created in the specified Service Fabric managed cluster resource. + + Gets all application type name resources created or in the process of being created in the + Service Fabric managed cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationTypeResourceList or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationTypeResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationTypeResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationTypeResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applicationTypes'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_applications_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_applications_operations.py new file mode 100644 index 000000000000..24d271323265 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_applications_operations.py @@ -0,0 +1,528 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationsOperations(object): + """ApplicationsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationResource" + """Gets a Service Fabric managed application resource. + + Get a Service Fabric managed application resource created or in the process of being created in + the Service Fabric cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + parameters, # type: "_models.ApplicationResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + parameters, # type: "_models.ApplicationResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ApplicationResource"] + """Creates or updates a Service Fabric managed application resource. + + Create or update a Service Fabric managed application resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param parameters: The application resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either ApplicationResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~service_fabric_managed_clusters_management_client.models.ApplicationResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + parameters, # type: "_models.ApplicationUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ApplicationResource" + """Updates the tags of an application resource of a given managed cluster. + + Updates the tags of an application resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param parameters: The application resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ApplicationUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ApplicationResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ApplicationResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ApplicationUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ApplicationResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric managed application resource. + + Delete a Service Fabric managed application resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ApplicationResourceList"] + """Gets the list of managed application resources created in the specified Service Fabric cluster resource. + + Gets all managed application resources created or in the process of being created in the + Service Fabric cluster resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ApplicationResourceList or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ApplicationResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ApplicationResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_managed_clusters_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_managed_clusters_operations.py new file mode 100644 index 000000000000..ce0d8144dd45 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_managed_clusters_operations.py @@ -0,0 +1,573 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ManagedClustersOperations(object): + """ManagedClustersOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_resource_group( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ManagedClusterListResult"] + """Gets the list of Service Fabric cluster resources created in the specified resource group. + + Gets all Service Fabric cluster resources created or in the process of being created in the + resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ManagedClusterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ManagedClusterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedClusterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ManagedClusterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters'} # type: ignore + + def list_by_subscription( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ManagedClusterListResult"] + """Gets the list of Service Fabric cluster resources created in the specified subscription. + + Gets all Service Fabric cluster resources created or in the process of being created in the + subscription. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ManagedClusterListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ManagedClusterListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedClusterListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_subscription.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ManagedClusterListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_subscription.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.ServiceFabric/managedClusters'} # type: ignore + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ManagedCluster" + """Gets a Service Fabric managed cluster resource. + + Get a Service Fabric managed cluster resource created or in the process of being created in the + specified resource group. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ManagedCluster, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + parameters, # type: "_models.ManagedCluster" + **kwargs # type: Any + ): + # type: (...) -> "_models.ManagedCluster" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ManagedCluster') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + parameters, # type: "_models.ManagedCluster" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ManagedCluster"] + """Creates or updates a Service Fabric managed cluster resource. + + Create or update a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param parameters: The cluster resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either ManagedCluster or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~service_fabric_managed_clusters_management_client.models.ManagedCluster] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + parameters, # type: "_models.ManagedClusterUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ManagedCluster" + """Updates the tags of of a Service Fabric managed cluster resource. + + Update the tags of of a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param parameters: The managed cluster resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ManagedClusterUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ManagedCluster, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ManagedCluster + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagedCluster"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ManagedClusterUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ManagedCluster', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric managed cluster resource. + + Delete a Service Fabric managed cluster resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_node_types_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_node_types_operations.py new file mode 100644 index 000000000000..51886c1585c3 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_node_types_operations.py @@ -0,0 +1,919 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class NodeTypesOperations(object): + """NodeTypesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_managed_clusters( + self, + resource_group_name, # type: str + cluster_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.NodeTypeListResult"] + """Gets the list of Node types of the specified managed cluster. + + Gets all Node types of the specified managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either NodeTypeListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.NodeTypeListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeTypeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_managed_clusters.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('NodeTypeListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_managed_clusters.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes'} # type: ignore + + def _restart_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._restart_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _restart_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/restart'} # type: ignore + + def begin_restart( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Restarts one or more nodes on the node type. + + Restarts one or more nodes on the node type. It will disable the fabric nodes, trigger a + restart on the VMs and activate the nodes back again. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for restart action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._restart_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_restart.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/restart'} # type: ignore + + def _reimage_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._reimage_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _reimage_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/reimage'} # type: ignore + + def begin_reimage( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Reimages one or more nodes on the node type. + + Reimages one or more nodes on the node type. It will disable the fabric nodes, trigger a + reimage on the VMs and activate the nodes back again. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for reimage action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._reimage_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_reimage.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/reimage'} # type: ignore + + def _delete_node_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._delete_node_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeActionParameters') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_node_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/deleteNode'} # type: ignore + + def begin_delete_node( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeActionParameters" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes one or more nodes on the node type. + + Deletes one or more nodes on the node type. It will disable the fabric nodes, trigger a delete + on the VMs and removes the state from the cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: parameters for delete action. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeActionParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_node_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_node.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}/deleteNode'} # type: ignore + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.NodeType" + """Gets a Service Fabric node type. + + Get a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NodeType, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.NodeType + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeType" + **kwargs # type: Any + ): + # type: (...) -> "_models.NodeType" + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeType') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('NodeType', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeType" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.NodeType"] + """Creates or updates a Service Fabric node type. + + Create or update a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: The node type resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeType + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either NodeType or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~service_fabric_managed_clusters_management_client.models.NodeType] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + parameters, # type: "_models.NodeTypeUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.NodeType" + """Update the tags of a node type resource of a given managed cluster. + + Update the configuration of a node type of a given managed cluster, only updating tags. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :param parameters: The parameters to update the node type configuration. + :type parameters: ~service_fabric_managed_clusters_management_client.models.NodeTypeUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: NodeType, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.NodeType + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.NodeType"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'NodeTypeUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('NodeType', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + node_type_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric node type. + + Delete a Service Fabric node type of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param node_type_name: The name of the node type. + :type node_type_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + node_type_name=node_type_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'nodeTypeName': self._serialize.url("node_type_name", node_type_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedClusters/{clusterName}/nodeTypes/{nodeTypeName}'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_operations.py new file mode 100644 index 000000000000..28f6e98854e6 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_operations.py @@ -0,0 +1,112 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class Operations(object): + """Operations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.OperationListResult"] + """Lists all of the available Service Fabric resource provider API operations. + + Get the list of available Service Fabric resource provider API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.ServiceFabric/operations'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_services_operations.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_services_operations.py new file mode 100644 index 000000000000..44b200f28312 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/operations/_services_operations.py @@ -0,0 +1,558 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ServicesOperations(object): + """ServicesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~service_fabric_managed_clusters_management_client.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceResource" + """Gets a Service Fabric managed service resource. + + Get a Service Fabric service resource created or in the process of being created in the Service + Fabric managed application resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + parameters, # type: "_models.ServiceResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceResource" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ServiceResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if response.status_code == 202: + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + parameters, # type: "_models.ServiceResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ServiceResource"] + """Creates or updates a Service Fabric managed service resource. + + Create or update a Service Fabric managed service resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :param parameters: The service resource. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either ServiceResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~service_fabric_managed_clusters_management_client.models.ServiceResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + service_name=service_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + parameters, # type: "_models.ServiceUpdateParameters" + **kwargs # type: Any + ): + # type: (...) -> "_models.ServiceResource" + """Updates the tags of a service resource of a given managed cluster. + + Updates the tags of a service resource of a given managed cluster. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :param parameters: The service resource updated tags. + :type parameters: ~service_fabric_managed_clusters_management_client.models.ServiceUpdateParameters + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ServiceResource, or the result of cls(response) + :rtype: ~service_fabric_managed_clusters_management_client.models.ServiceResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ServiceUpdateParameters') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ServiceResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + error = self._deserialize(_models.ErrorModel, response) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + service_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a Service Fabric managed service resource. + + Delete a Service Fabric managed service resource with the specified name. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :param service_name: The name of the service resource in the format of + {applicationName}~{serviceName}. + :type service_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cluster_name=cluster_name, + application_name=application_name, + service_name=service_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + 'serviceName': self._serialize.url("service_name", service_name, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services/{serviceName}'} # type: ignore + + def list_by_applications( + self, + resource_group_name, # type: str + cluster_name, # type: str + application_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ServiceResourceList"] + """Gets the list of service resources created in the specified Service Fabric managed application resource. + + Gets all service resources created or in the process of being created in the Service Fabric + managed application resource. + + :param resource_group_name: The name of the resource group. + :type resource_group_name: str + :param cluster_name: The name of the cluster resource. + :type cluster_name: str + :param application_name: The name of the application resource. + :type application_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ServiceResourceList or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~service_fabric_managed_clusters_management_client.models.ServiceResourceList] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ServiceResourceList"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2021-01-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_applications.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str'), + 'clusterName': self._serialize.url("cluster_name", cluster_name, 'str'), + 'applicationName': self._serialize.url("application_name", application_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ServiceResourceList', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + error = self._deserialize(_models.ErrorModel, response) + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_applications.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ServiceFabric/managedclusters/{clusterName}/applications/{applicationName}/services'} # type: ignore diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/py.typed b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/azure/mgmt/servicefabricmanagedclusters/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/sdk_packaging.toml b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/sdk_packaging.toml new file mode 100644 index 000000000000..997c4589873a --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/sdk_packaging.toml @@ -0,0 +1,8 @@ +[packaging] +package_name = "azure-mgmt-servicefabricmanagedclusters" +package_nspkg = "azure-mgmt-nspkg" +package_pprint_name = "Servicefabricmanagedclusters Management" +package_doc_id = "" +is_stable = false +is_arm = true +need_msrestazure = true diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.cfg b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.cfg new file mode 100644 index 000000000000..3c6e79cf31da --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.cfg @@ -0,0 +1,2 @@ +[bdist_wheel] +universal=1 diff --git a/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.py b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.py new file mode 100644 index 000000000000..7ef14fe45b86 --- /dev/null +++ b/sdk/servicefabricmanagedclusters/azure-mgmt-servicefabricmanagedclusters/setup.py @@ -0,0 +1,91 @@ +#!/usr/bin/env python + +#------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +#-------------------------------------------------------------------------- + +import re +import os.path +from io import open +from setuptools import find_packages, setup + +# Change the PACKAGE_NAME only to change folder and different name +PACKAGE_NAME = "azure-mgmt-servicefabricmanagedclusters" +PACKAGE_PPRINT_NAME = "Servicefabricmanagedclusters Management" + +# a-b-c => a/b/c +package_folder_path = PACKAGE_NAME.replace('-', '/') +# a-b-c => a.b.c +namespace_name = PACKAGE_NAME.replace('-', '.') + +# azure v0.x is not compatible with this package +# azure v0.x used to have a __version__ attribute (newer versions don't) +try: + import azure + try: + ver = azure.__version__ + raise Exception( + 'This package is incompatible with azure=={}. '.format(ver) + + 'Uninstall it with "pip uninstall azure".' + ) + except AttributeError: + pass +except ImportError: + pass + +# Version extraction inspired from 'requests' +with open(os.path.join(package_folder_path, 'version.py') + if os.path.exists(os.path.join(package_folder_path, 'version.py')) + else os.path.join(package_folder_path, '_version.py'), 'r') as fd: + version = re.search(r'^VERSION\s*=\s*[\'"]([^\'"]*)[\'"]', + fd.read(), re.MULTILINE).group(1) + +if not version: + raise RuntimeError('Cannot find version information') + +with open('README.md', encoding='utf-8') as f: + readme = f.read() +with open('CHANGELOG.md', encoding='utf-8') as f: + changelog = f.read() + +setup( + name=PACKAGE_NAME, + version=version, + description='Microsoft Azure {} Client Library for Python'.format(PACKAGE_PPRINT_NAME), + long_description=readme + '\n\n' + changelog, + long_description_content_type='text/markdown', + license='MIT License', + author='Microsoft Corporation', + author_email='azpysdkhelp@microsoft.com', + url='https://github.com/Azure/azure-sdk-for-python', + classifiers=[ + 'Development Status :: 4 - Beta', + 'Programming Language :: Python', + 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3', + 'Programming Language :: Python :: 3.5', + 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', + 'Programming Language :: Python :: 3.9', + 'License :: OSI Approved :: MIT License', + ], + zip_safe=False, + packages=find_packages(exclude=[ + 'tests', + # Exclude packages that will be covered by PEP420 or nspkg + 'azure', + 'azure.mgmt', + ]), + install_requires=[ + 'msrest>=0.5.0', + 'azure-mgmt-core>=1.2.0,<2.0.0', + 'azure-common~=1.1', + ], + extras_require={ + ":python_version<'3.0'": ['azure-mgmt-nspkg'], + } +) diff --git a/sdk/servicefabricmanagedclusters/ci.yml b/sdk/servicefabricmanagedclusters/ci.yml new file mode 100644 index 000000000000..ed826b34bc3e --- /dev/null +++ b/sdk/servicefabricmanagedclusters/ci.yml @@ -0,0 +1,35 @@ +# DO NOT EDIT THIS FILE +# This file is generated automatically and any changes will be lost. + +trigger: + branches: + include: + - master + - main + - hotfix/* + - release/* + - restapi* + paths: + include: + - sdk/servicefabricmanagedclusters/ + +pr: + branches: + include: + - master + - main + - feature/* + - hotfix/* + - release/* + - restapi* + paths: + include: + - sdk/servicefabricmanagedclusters/ + +extends: + template: ../../eng/pipelines/templates/stages/archetype-sdk-client.yml + parameters: + ServiceDirectory: servicefabricmanagedclusters + Artifacts: + - name: azure_mgmt_servicefabricmanagedclusters + safeName: azuremgmtservicefabricmanagedclusters \ No newline at end of file From 79d9f53deccc75e5c5f5f92a60209d9090b86d28 Mon Sep 17 00:00:00 2001 From: "Kaihui (Kerwin) Sun" Date: Mon, 1 Mar 2021 11:50:58 +0800 Subject: [PATCH 23/30] T2 resource 2021 02 26 (#16961) * CodeGen from PR 13128 in Azure/azure-rest-api-specs Revert "[Hub Generated] Review request for Microsoft.Resources to add version stable/2021-01-01 (#13000)" (#13128) This reverts commit 231d09443a06cedcb0b605ed08bacd77facb404e. * test,version,CHANGELOG * fix testcases Co-authored-by: SDKAuto --- .../azure-mgmt-resource/CHANGELOG.md | 38 + sdk/resources/azure-mgmt-resource/README.md | 10 + .../azure/mgmt/resource/_version.py | 2 +- .../resource/deploymentscripts/_version.py | 2 +- .../_deployment_scripts_client.py | 1 - .../v2019_10_01_preview/_metadata.json | 15 +- .../aio/_deployment_scripts_client.py | 1 - .../_deployment_scripts_operations.py | 66 +- .../v2019_10_01_preview/models/_models.py | 70 +- .../v2019_10_01_preview/models/_models_py3.py | 74 +- .../_deployment_scripts_operations.py | 66 +- .../v2020_10_01/_deployment_scripts_client.py | 1 - .../v2020_10_01/_metadata.json | 15 +- .../aio/_deployment_scripts_client.py | 1 - .../_deployment_scripts_operations.py | 66 +- .../v2020_10_01/models/_models.py | 66 +- .../v2020_10_01/models/_models_py3.py | 69 +- .../_deployment_scripts_operations.py | 66 +- .../azure/mgmt/resource/features/_version.py | 2 +- .../features/aio/_operations_mixin.py | 2 +- .../features/v2015_12_01/_feature_client.py | 1 - .../features/v2015_12_01/_metadata.json | 17 +- .../v2015_12_01/aio/_feature_client.py | 1 - .../operations/_feature_client_operations.py | 6 +- .../aio/operations/_features_operations.py | 24 +- .../operations/_feature_client_operations.py | 6 +- .../operations/_features_operations.py | 24 +- .../azure/mgmt/resource/links/_version.py | 2 +- .../v2016_09_01/_management_link_client.py | 1 - .../resource/links/v2016_09_01/_metadata.json | 15 +- .../aio/_management_link_client.py | 1 - .../v2016_09_01/aio/operations/_operations.py | 8 +- .../operations/_resource_links_operations.py | 22 +- .../v2016_09_01/operations/_operations.py | 8 +- .../operations/_resource_links_operations.py | 22 +- .../azure/mgmt/resource/locks/_version.py | 2 +- .../v2015_01_01/_management_lock_client.py | 1 - .../resource/locks/v2015_01_01/_metadata.json | 15 +- .../aio/_management_lock_client.py | 1 - .../_management_locks_operations.py | 42 +- .../_management_locks_operations.py | 42 +- .../v2016_09_01/_management_lock_client.py | 1 - .../resource/locks/v2016_09_01/_metadata.json | 15 +- .../aio/_management_lock_client.py | 1 - .../_authorization_operations_operations.py | 8 +- .../_management_locks_operations.py | 60 +- .../_authorization_operations_operations.py | 8 +- .../_management_locks_operations.py | 60 +- .../_application_client.py | 4 +- .../managedapplications/_metadata.json | 31 +- .../aio/_application_client.py | 4 +- .../aio/operations/__init__.py | 2 + .../_application_client_operations.py | 84 + .../_application_definitions_operations.py | 156 +- .../operations/_applications_operations.py | 108 +- .../managedapplications/models/__init__.py | 9 + .../managedapplications/models/_models.py | 73 + .../managedapplications/models/_models_py3.py | 83 + .../operations/__init__.py | 2 + .../_application_client_operations.py | 89 + .../_application_definitions_operations.py | 156 +- .../operations/_applications_operations.py | 108 +- .../mgmt/resource/policy/_policy_client.py | 41 +- .../azure/mgmt/resource/policy/_version.py | 2 +- .../resource/policy/aio/_policy_client.py | 41 +- .../azure/mgmt/resource/policy/models.py | 2 +- .../policy/v2015_10_01_preview/_metadata.json | 15 +- .../v2015_10_01_preview/_policy_client.py | 1 - .../v2015_10_01_preview/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 18 +- .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 18 +- .../policy/v2016_04_01/_metadata.json | 15 +- .../policy/v2016_04_01/_policy_client.py | 1 - .../policy/v2016_04_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 18 +- .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 18 +- .../policy/v2016_12_01/_metadata.json | 15 +- .../policy/v2016_12_01/_policy_client.py | 1 - .../policy/v2016_12_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 40 +- .../_policy_assignments_operations.py | 44 +- .../_policy_definitions_operations.py | 40 +- .../policy/v2017_06_01_preview/_metadata.json | 15 +- .../v2017_06_01_preview/_policy_client.py | 1 - .../v2017_06_01_preview/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../policy/v2018_03_01/_metadata.json | 15 +- .../policy/v2018_03_01/_policy_client.py | 1 - .../policy/v2018_03_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../policy/v2018_05_01/_metadata.json | 15 +- .../policy/v2018_05_01/_policy_client.py | 1 - .../policy/v2018_05_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../policy/v2019_01_01/_metadata.json | 15 +- .../policy/v2019_01_01/_policy_client.py | 1 - .../policy/v2019_01_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../policy/v2019_06_01/_metadata.json | 15 +- .../policy/v2019_06_01/_policy_client.py | 1 - .../policy/v2019_06_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../_policy_assignments_operations.py | 62 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 60 +- .../policy/v2019_09_01/_metadata.json | 15 +- .../policy/v2019_09_01/_policy_client.py | 1 - .../policy/v2019_09_01/aio/_policy_client.py | 1 - .../_policy_assignments_operations.py | 48 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 40 +- .../policy/v2019_09_01/models/_models.py | 2 +- .../policy/v2019_09_01/models/_models_py3.py | 2 +- .../_policy_assignments_operations.py | 48 +- .../_policy_definitions_operations.py | 40 +- .../_policy_set_definitions_operations.py | 40 +- .../resource/policy/v2020_09_01/__init__.py | 16 + .../policy/v2020_09_01/_configuration.py | 69 + .../policy/v2020_09_01/_metadata.json | 65 + .../policy/v2020_09_01/_policy_client.py | 88 + .../policy/v2020_09_01/aio/__init__.py | 10 + .../policy/v2020_09_01/aio/_configuration.py | 65 + .../policy/v2020_09_01/aio/_policy_client.py | 82 + .../v2020_09_01/aio/operations/__init__.py | 21 + .../_data_policy_manifests_operations.py | 173 + .../_policy_assignments_operations.py | 869 + .../_policy_definitions_operations.py | 735 + .../_policy_exemptions_operations.py | 642 + .../_policy_set_definitions_operations.py | 743 + .../policy/v2020_09_01/models/__init__.py | 117 + .../policy/v2020_09_01/models/_models.py | 1090 + .../policy/v2020_09_01/models/_models_py3.py | 1214 + .../models/_policy_client_enums.py | 114 + .../policy/v2020_09_01/operations/__init__.py | 21 + .../_data_policy_manifests_operations.py | 179 + .../_policy_assignments_operations.py | 883 + .../_policy_definitions_operations.py | 749 + .../_policy_exemptions_operations.py | 653 + .../_policy_set_definitions_operations.py | 757 + .../mgmt/resource/policy/v2020_09_01/py.typed | 1 + .../resources/_resource_management_client.py | 40 +- .../azure/mgmt/resource/resources/_version.py | 2 +- .../aio/_resource_management_client.py | 40 +- .../azure/mgmt/resource/resources/models.py | 2 +- .../resources/v2016_02_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 12 +- .../aio/operations/_deployments_operations.py | 54 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 41 +- .../aio/operations/_resources_operations.py | 52 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2016_02_01/models/_models.py | 2 +- .../v2016_02_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 12 +- .../operations/_deployments_operations.py | 54 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 41 +- .../operations/_resources_operations.py | 52 +- .../operations/_tags_operations.py | 16 +- .../resources/v2016_09_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 12 +- .../aio/operations/_deployments_operations.py | 54 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 41 +- .../aio/operations/_resources_operations.py | 126 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2016_09_01/models/_models.py | 2 +- .../v2016_09_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 12 +- .../operations/_deployments_operations.py | 54 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 41 +- .../operations/_resources_operations.py | 126 +- .../operations/_tags_operations.py | 16 +- .../resources/v2017_05_10/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 12 +- .../aio/operations/_deployments_operations.py | 54 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2017_05_10/models/_models.py | 2 +- .../v2017_05_10/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 12 +- .../operations/_deployments_operations.py | 54 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2018_02_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 12 +- .../aio/operations/_deployments_operations.py | 54 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2018_02_01/models/_models.py | 2 +- .../v2018_02_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 12 +- .../operations/_deployments_operations.py | 54 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2018_05_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 20 +- .../aio/operations/_deployments_operations.py | 98 +- .../v2018_05_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2018_05_01/models/_models.py | 2 +- .../v2018_05_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 20 +- .../operations/_deployments_operations.py | 98 +- .../v2018_05_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_03_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 20 +- .../aio/operations/_deployments_operations.py | 98 +- .../v2019_03_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2019_03_01/models/_models.py | 2 +- .../v2019_03_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 20 +- .../operations/_deployments_operations.py | 98 +- .../v2019_03_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_05_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 28 +- .../aio/operations/_deployments_operations.py | 142 +- .../v2019_05_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2019_05_01/models/_models.py | 2 +- .../v2019_05_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 28 +- .../operations/_deployments_operations.py | 142 +- .../v2019_05_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 20 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_05_10/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 28 +- .../aio/operations/_deployments_operations.py | 142 +- .../v2019_05_10/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2019_05_10/models/_models.py | 2 +- .../v2019_05_10/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 28 +- .../operations/_deployments_operations.py | 142 +- .../v2019_05_10/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_07_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 44 +- .../aio/operations/_deployments_operations.py | 267 +- .../v2019_07_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 37 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2019_07_01/models/_models.py | 2 +- .../v2019_07_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 44 +- .../operations/_deployments_operations.py | 267 +- .../v2019_07_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 37 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_08_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 44 +- .../aio/operations/_deployments_operations.py | 267 +- .../v2019_08_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 50 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 16 +- .../resources/v2019_08_01/models/_models.py | 2 +- .../v2019_08_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 44 +- .../operations/_deployments_operations.py | 267 +- .../v2019_08_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 50 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 16 +- .../resources/v2019_10_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 44 +- .../aio/operations/_deployments_operations.py | 369 +- .../v2019_10_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 50 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 32 +- .../resources/v2019_10_01/models/_models.py | 2 +- .../v2019_10_01/models/_models_py3.py | 2 +- .../_deployment_operations_operations.py | 44 +- .../operations/_deployments_operations.py | 369 +- .../v2019_10_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 28 +- .../operations/_resource_groups_operations.py | 50 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 32 +- .../resources/v2020_06_01/_metadata.json | 15 +- .../_resource_management_client.py | 1 - .../aio/_resource_management_client.py | 1 - .../_deployment_operations_operations.py | 44 +- .../aio/operations/_deployments_operations.py | 369 +- .../v2020_06_01/aio/operations/_operations.py | 8 +- .../aio/operations/_providers_operations.py | 82 +- .../operations/_resource_groups_operations.py | 59 +- .../aio/operations/_resources_operations.py | 141 +- .../aio/operations/_tags_operations.py | 32 +- .../resources/v2020_06_01/models/__init__.py | 5 + .../resources/v2020_06_01/models/_models.py | 36 +- .../v2020_06_01/models/_models_py3.py | 42 +- .../_resource_management_client_enums.py | 9 + .../_deployment_operations_operations.py | 44 +- .../operations/_deployments_operations.py | 369 +- .../v2020_06_01/operations/_operations.py | 8 +- .../operations/_providers_operations.py | 83 +- .../operations/_resource_groups_operations.py | 59 +- .../operations/_resources_operations.py | 141 +- .../operations/_tags_operations.py | 32 +- .../resources/v2020_10_01/__init__.py | 16 + .../resources/v2020_10_01/_configuration.py | 70 + .../resources/v2020_10_01/_metadata.json | 68 + .../_resource_management_client.py | 104 + .../resources/v2020_10_01/aio/__init__.py | 10 + .../v2020_10_01/aio/_configuration.py | 66 + .../aio/_resource_management_client.py | 98 + .../v2020_10_01/aio/operations/__init__.py | 27 + .../_deployment_operations_operations.py | 725 + .../aio/operations/_deployments_operations.py | 3942 ++ .../v2020_10_01/aio/operations/_operations.py | 104 + .../_provider_resource_types_operations.py | 101 + .../aio/operations/_providers_operations.py | 475 + .../operations/_resource_groups_operations.py | 589 + .../aio/operations/_resources_operations.py | 1527 + .../aio/operations/_tags_operations.py | 594 + .../resources/v2020_10_01/models/__init__.py | 263 + .../resources/v2020_10_01/models/_models.py | 2547 + .../v2020_10_01/models/_models_py3.py | 2795 + .../_resource_management_client_enums.py | 166 + .../v2020_10_01/operations/__init__.py | 27 + .../_deployment_operations_operations.py | 739 + .../operations/_deployments_operations.py | 4010 ++ .../v2020_10_01/operations/_operations.py | 109 + .../_provider_resource_types_operations.py | 106 + .../operations/_providers_operations.py | 486 + .../operations/_resource_groups_operations.py | 602 + .../operations/_resources_operations.py | 1553 + .../operations/_tags_operations.py | 607 + .../resource/resources/v2020_10_01/py.typed | 1 + .../subscriptions/_operations_mixin.py | 2 +- .../mgmt/resource/subscriptions/_version.py | 2 +- .../subscriptions/aio/_operations_mixin.py | 4 +- .../subscriptions/v2016_06_01/_metadata.json | 15 +- .../v2016_06_01/_subscription_client.py | 1 - .../v2016_06_01/aio/_subscription_client.py | 1 - .../v2016_06_01/aio/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../aio/operations/_tenants_operations.py | 8 +- .../v2016_06_01/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../operations/_tenants_operations.py | 8 +- .../subscriptions/v2018_06_01/_metadata.json | 15 +- .../v2018_06_01/_subscription_client.py | 1 - .../v2018_06_01/aio/_subscription_client.py | 1 - .../v2018_06_01/aio/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../aio/operations/_tenants_operations.py | 8 +- .../v2018_06_01/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../operations/_tenants_operations.py | 8 +- .../subscriptions/v2019_06_01/_metadata.json | 15 +- .../v2019_06_01/_subscription_client.py | 1 - .../v2019_06_01/aio/_subscription_client.py | 1 - .../v2019_06_01/aio/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../aio/operations/_tenants_operations.py | 8 +- .../v2019_06_01/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../operations/_tenants_operations.py | 8 +- .../subscriptions/v2019_11_01/_metadata.json | 15 +- .../v2019_11_01/_subscription_client.py | 1 - .../v2019_11_01/aio/_subscription_client.py | 1 - .../v2019_11_01/aio/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../aio/operations/_tenants_operations.py | 8 +- .../v2019_11_01/operations/_operations.py | 8 +- .../_subscription_client_operations.py | 10 +- .../operations/_subscriptions_operations.py | 16 +- .../operations/_tenants_operations.py | 8 +- .../mgmt/resource/templatespecs/_version.py | 2 +- .../v2019_06_01_preview/_metadata.json | 15 +- .../_template_specs_client.py | 1 - .../aio/_template_specs_client.py | 1 - .../_template_spec_versions_operations.py | 34 +- .../operations/_template_specs_operations.py | 58 +- .../v2019_06_01_preview/models/__init__.py | 5 + .../v2019_06_01_preview/models/_models.py | 49 +- .../v2019_06_01_preview/models/_models_py3.py | 49 +- .../models/_template_specs_client_enums.py | 4 + .../_template_spec_versions_operations.py | 34 +- .../operations/_template_specs_operations.py | 58 +- ....test_deployments_at_management_group.yaml | 55 - ...mt_resource.test_deployments_at_scope.yaml | 106 +- ...urce.test_deployments_at_subscription.yaml | 136 +- ..._mgmt_resource.test_deployments_basic.yaml | 126 +- ...mgmt_resource.test_provider_locations.yaml | 363 +- ...t_resource.test_provider_registration.yaml | 102 +- ...st_mgmt_resource.test_provider_tenant.yaml | 356 +- .../test_mgmt_resource.test_providers.yaml | 4108 +- ...st_mgmt_resource.test_resource_groups.yaml | 88 +- .../test_mgmt_resource.test_resources.yaml | 296 +- ...est_mgmt_resource.test_tag_operations.yaml | 73 +- ...t_resource_async.test_resource_groups.yaml | 118 +- ...yment_scripts.test_deployment_scripts.yaml | 155 +- ..._mgmt_resource_features.test_features.yaml | 20 +- .../test_mgmt_resource_links.test_links.yaml | 48 +- ...ks.test_locks_at_resource_group_level.yaml | 18 +- ...ce_locks.test_locks_at_resource_level.yaml | 32 +- ...ocks.test_locks_at_subscription_level.yaml | 20 +- ...mt_resource_locks.test_locks_by_scope.yaml | 26 +- ..._managed_application.test_application.yaml | 441 +- ...ed_application.test_application_by_id.yaml | 610 +- ...esource_policy.test_policy_definition.yaml | 56225 ++++++---------- ...policy_definition_at_management_group.yaml | 55 - ...urce_subscriptions.test_subscriptions.yaml | 17 +- ...t_resource_subscriptions.test_tenants.yaml | 4 +- .../test_mgmt_resource_deployment_scripts.py | 4 +- .../test_mgmt_resource_managed_application.py | 7 +- 509 files changed, 65346 insertions(+), 45780 deletions(-) create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_client_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_client_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_configuration.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_metadata.json create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_policy_client.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_configuration.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_policy_client.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_data_policy_manifests_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_assignments_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_definitions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_exemptions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_set_definitions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models_py3.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_policy_client_enums.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_data_policy_manifests_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_assignments_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_definitions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_exemptions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_set_definitions_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/py.typed create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_configuration.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_metadata.json create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_resource_management_client.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_configuration.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_resource_management_client.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployment_operations_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployments_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_provider_resource_types_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_providers_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resource_groups_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resources_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_tags_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models_py3.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_resource_management_client_enums.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/__init__.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployment_operations_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployments_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_provider_resource_types_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_providers_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resource_groups_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resources_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_tags_operations.py create mode 100644 sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/py.typed delete mode 100644 sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_management_group.yaml delete mode 100644 sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition_at_management_group.yaml diff --git a/sdk/resources/azure-mgmt-resource/CHANGELOG.md b/sdk/resources/azure-mgmt-resource/CHANGELOG.md index bb883e9aa8fe..7aadc8d85a94 100644 --- a/sdk/resources/azure-mgmt-resource/CHANGELOG.md +++ b/sdk/resources/azure-mgmt-resource/CHANGELOG.md @@ -1,5 +1,43 @@ # Release History +## 16.0.0 (2021-02-26) + +**Features** + + - Model ParameterDefinitionsValueMetadata has a new parameter strong_type + - Model ParameterDefinitionsValueMetadata has a new parameter assign_permissions + - Model ProviderResourceType has a new parameter location_mappings + - Model DeploymentProperties has a new parameter expression_evaluation_options + - Model PolicyAssignment has a new parameter non_compliance_messages + - Model TemplateLink has a new parameter query_string + - Model TemplateSpec has a new parameter versions + - Model DeploymentWhatIfProperties has a new parameter expression_evaluation_options + - Added operation ApplicationDefinitionsOperations.get_by_id + - Added operation ApplicationDefinitionsOperations.begin_create_or_update_by_id + - Added operation ApplicationDefinitionsOperations.begin_delete_by_id + - Added operation ProvidersOperations.register_at_management_group_scope + - Added operation PolicySetDefinitionsOperations.list_by_management_group + - Added operation PolicyDefinitionsOperations.list_by_management_group + - Added operation group ProviderResourceTypesOperations + - Added operation group DataPolicyManifestsOperations + - Added operation group ApplicationClientOperationsMixin + - Added operation group PolicyExemptionsOperations + +**Breaking changes** + + - Operation PolicyAssignmentsOperations.list has a new signature + - Operation PolicyAssignmentsOperations.list_for_management_group has a new signature + - Operation PolicyAssignmentsOperations.list_for_resource has a new signature + - Operation PolicyAssignmentsOperations.list_for_resource_group has a new signature + - Operation TemplateSpecsOperations.get has a new signature + - Operation TemplateSpecsOperations.list_by_resource_group has a new signature + - Operation TemplateSpecsOperations.list_by_subscription has a new signature + - Model PolicyAssignment no longer has parameter sku + - Operation PolicySetDefinitionsOperations.list_built_in has a new signature + - Operation PolicySetDefinitionsOperations.list has a new signature + - Operation PolicyDefinitionsOperations.list_built_in has a new signature + - Operation PolicyDefinitionsOperations.list has a new signature + ## 15.0.0 (2020-09-17) **Features** diff --git a/sdk/resources/azure-mgmt-resource/README.md b/sdk/resources/azure-mgmt-resource/README.md index 6092669e1d09..4f300428912a 100644 --- a/sdk/resources/azure-mgmt-resource/README.md +++ b/sdk/resources/azure-mgmt-resource/README.md @@ -19,3 +19,13 @@ section of the project. ![Impressions](https://azure-sdk-impressions.azurewebsites.net/api/impressions/azure-sdk-for-python%2Fazure-mgmt-resource%2FREADME.png) +# Usage + + +To learn how to use this package, see the [quickstart guide](https://aka.ms/azsdk/python/mgmt) + + + +For docs and references, see [Python SDK References](https://docs.microsoft.com/python/api/overview/azure/) +Code samples for this package can be found at [Resource Management](https://docs.microsoft.com/samples/browse/?languages=python&term=Getting%20started%20-%20Managing&terms=Getting%20started%20-%20Managing) on docs.microsoft.com. +Additional code samples for different Azure services are available at [Samples Repo](https://aka.ms/azsdk/python/mgmt/samples) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/_version.py index 0845e1285b1e..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "15.0.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_deployment_scripts_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_deployment_scripts_client.py index 28fb7d9157ff..73ff03fd516b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_deployment_scripts_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_deployment_scripts_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployment_scripts = DeploymentScriptsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_metadata.json index b2012cfe623f..f549d72b953d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/_deployment_scripts_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/_deployment_scripts_client.py index 3875393ab74d..bffabef6ba17 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/_deployment_scripts_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/_deployment_scripts_client.py @@ -47,7 +47,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployment_scripts = DeploymentScriptsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/operations/_deployment_scripts_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/operations/_deployment_scripts_operations.py index 5fa2f47af896..40ea1f2b8803 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/operations/_deployment_scripts_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/aio/operations/_deployment_scripts_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentScriptsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,10 +47,10 @@ async def _create_initial( self, resource_group_name: str, script_name: str, - deployment_script: "models.DeploymentScript", + deployment_script: "_models.DeploymentScript", **kwargs - ) -> "models.DeploymentScript": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + ) -> "_models.DeploymentScript": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -86,7 +86,7 @@ async def _create_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -105,9 +105,9 @@ async def begin_create( self, resource_group_name: str, script_name: str, - deployment_script: "models.DeploymentScript", + deployment_script: "_models.DeploymentScript", **kwargs - ) -> AsyncLROPoller["models.DeploymentScript"]: + ) -> AsyncLROPoller["_models.DeploymentScript"]: """Creates a deployment script. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -127,7 +127,7 @@ async def begin_create( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -152,7 +152,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'scriptName': self._serialize.url("script_name", script_name, 'str', max_length=90, min_length=1), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -170,9 +176,9 @@ async def update( self, resource_group_name: str, script_name: str, - deployment_script: Optional["models.DeploymentScriptUpdateParameter"] = None, + deployment_script: Optional["_models.DeploymentScriptUpdateParameter"] = None, **kwargs - ) -> "models.DeploymentScript": + ) -> "_models.DeploymentScript": """Updates deployment script tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -186,7 +192,7 @@ async def update( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +231,7 @@ async def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -241,7 +247,7 @@ async def get( resource_group_name: str, script_name: str, **kwargs - ) -> "models.DeploymentScript": + ) -> "_models.DeploymentScript": """Gets a deployment script with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -253,7 +259,7 @@ async def get( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -284,7 +290,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -344,7 +350,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -355,7 +361,7 @@ async def delete( def list_by_subscription( self, **kwargs - ) -> AsyncIterable["models.DeploymentScriptListResult"]: + ) -> AsyncIterable["_models.DeploymentScriptListResult"]: """Lists all deployment scripts for a given subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -363,7 +369,7 @@ def list_by_subscription( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -408,7 +414,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -424,7 +430,7 @@ async def get_logs( resource_group_name: str, script_name: str, **kwargs - ) -> "models.ScriptLogsList": + ) -> "_models.ScriptLogsList": """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -436,7 +442,7 @@ async def get_logs( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ScriptLogsList :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLogsList"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLogsList"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -467,7 +473,7 @@ async def get_logs( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLogsList', pipeline_response) @@ -484,7 +490,7 @@ async def get_logs_default( script_name: str, tail: Optional[int] = None, **kwargs - ) -> "models.ScriptLog": + ) -> "_models.ScriptLog": """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -500,7 +506,7 @@ async def get_logs_default( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ScriptLog :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLog"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLog"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -533,7 +539,7 @@ async def get_logs_default( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLog', pipeline_response) @@ -548,7 +554,7 @@ def list_by_resource_group( self, resource_group_name: str, **kwargs - ) -> AsyncIterable["models.DeploymentScriptListResult"]: + ) -> AsyncIterable["_models.DeploymentScriptListResult"]: """Lists deployments scripts. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -558,7 +564,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -604,7 +610,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models.py index ca59ab36c064..03171e3d3227 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models.py @@ -151,7 +151,7 @@ class AzureCliScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -183,7 +183,7 @@ class AzureCliScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_cli_version: Required. Azure CLI module version to be used. :type az_cli_version: str @@ -239,7 +239,7 @@ def __init__( self.kind = 'AzureCLI' # type: str self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -250,7 +250,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_cli_version = kwargs['az_cli_version'] @@ -279,7 +279,7 @@ class ScriptConfigurationBase(msrest.serialization.Model): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta """ @@ -311,7 +311,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") class DeploymentScriptPropertiesBase(msrest.serialization.Model): @@ -327,7 +327,7 @@ class DeploymentScriptPropertiesBase(msrest.serialization.Model): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -363,7 +363,7 @@ def __init__( super(DeploymentScriptPropertiesBase, self).__init__(**kwargs) self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -396,7 +396,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -406,7 +406,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -461,11 +461,11 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_cli_version = kwargs['az_cli_version'] self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -508,7 +508,7 @@ class AzurePowerShellScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -540,7 +540,7 @@ class AzurePowerShellScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_power_shell_version: Required. Azure PowerShell module version to be used. :type az_power_shell_version: str @@ -596,7 +596,7 @@ def __init__( self.kind = 'AzurePowerShell' # type: str self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -607,7 +607,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_power_shell_version = kwargs['az_power_shell_version'] @@ -638,7 +638,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -648,7 +648,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -703,11 +703,11 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_power_shell_version = kwargs['az_power_shell_version'] self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -779,7 +779,8 @@ def __init__( class DeploymentScriptsError(msrest.serialization.Model): """Deployment scripts error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ErrorResponse """ @@ -895,7 +896,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -947,6 +948,8 @@ class ManagedServiceIdentity(msrest.serialization.Model): :param type: Type of the managed identity. Possible values include: "UserAssigned". :type type: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ManagedServiceIdentityType + :param tenant_id: ID of the Azure Active Directory. + :type tenant_id: str :param user_assigned_identities: The list of user-assigned managed identities associated with the resource. Key is the Azure resource Id of the managed identity. :type user_assigned_identities: dict[str, @@ -955,6 +958,7 @@ class ManagedServiceIdentity(msrest.serialization.Model): _attribute_map = { 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{UserAssignedIdentity}'}, } @@ -964,6 +968,7 @@ def __init__( ): super(ManagedServiceIdentity, self).__init__(**kwargs) self.type = kwargs.get('type', None) + self.tenant_id = kwargs.get('tenant_id', None) self.user_assigned_identities = kwargs.get('user_assigned_identities', None) @@ -1112,7 +1117,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -1141,12 +1146,19 @@ def __init__( class UserAssignedIdentity(msrest.serialization.Model): """User-assigned managed identity. - :param principal_id: Azure Active Directory principal ID associated with this identity. - :type principal_id: str - :param client_id: Client App Id associated with this identity. - :type client_id: str + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Azure Active Directory principal ID associated with this identity. + :vartype principal_id: str + :ivar client_id: Client App Id associated with this identity. + :vartype client_id: str """ + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + _attribute_map = { 'principal_id': {'key': 'principalId', 'type': 'str'}, 'client_id': {'key': 'clientId', 'type': 'str'}, @@ -1157,5 +1169,5 @@ def __init__( **kwargs ): super(UserAssignedIdentity, self).__init__(**kwargs) - self.principal_id = kwargs.get('principal_id', None) - self.client_id = kwargs.get('client_id', None) + self.principal_id = None + self.client_id = None diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models_py3.py index c6a363ac7aaa..ea4af1cd0cf2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/models/_models_py3.py @@ -160,7 +160,7 @@ class AzureCliScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -192,7 +192,7 @@ class AzureCliScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_cli_version: Required. Azure CLI module version to be used. :type az_cli_version: str @@ -250,14 +250,14 @@ def __init__( tags: Optional[Dict[str, str]] = None, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", primary_script_uri: Optional[str] = None, supporting_script_uris: Optional[List[str]] = None, script_content: Optional[str] = None, arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(AzureCliScript, self).__init__(identity=identity, location=location, tags=tags, **kwargs) @@ -304,7 +304,7 @@ class ScriptConfigurationBase(msrest.serialization.Model): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta """ @@ -334,7 +334,7 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(ScriptConfigurationBase, self).__init__(**kwargs) @@ -361,7 +361,7 @@ class DeploymentScriptPropertiesBase(msrest.serialization.Model): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -395,7 +395,7 @@ def __init__( *, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(DeploymentScriptPropertiesBase, self).__init__(**kwargs) @@ -434,7 +434,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -444,7 +444,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -498,10 +498,10 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(AzureCliScriptProperties, self).__init__(container_settings=container_settings, storage_account_settings=storage_account_settings, cleanup_preference=cleanup_preference, primary_script_uri=primary_script_uri, supporting_script_uris=supporting_script_uris, script_content=script_content, arguments=arguments, environment_variables=environment_variables, force_update_tag=force_update_tag, retention_interval=retention_interval, timeout=timeout, **kwargs) @@ -559,7 +559,7 @@ class AzurePowerShellScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -591,7 +591,7 @@ class AzurePowerShellScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_power_shell_version: Required. Azure PowerShell module version to be used. :type az_power_shell_version: str @@ -649,14 +649,14 @@ def __init__( tags: Optional[Dict[str, str]] = None, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", primary_script_uri: Optional[str] = None, supporting_script_uris: Optional[List[str]] = None, script_content: Optional[str] = None, arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(AzurePowerShellScript, self).__init__(identity=identity, location=location, tags=tags, **kwargs) @@ -705,7 +705,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -715,7 +715,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -769,10 +769,10 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(AzurePowerShellScriptProperties, self).__init__(container_settings=container_settings, storage_account_settings=storage_account_settings, cleanup_preference=cleanup_preference, primary_script_uri=primary_script_uri, supporting_script_uris=supporting_script_uris, script_content=script_content, arguments=arguments, environment_variables=environment_variables, force_update_tag=force_update_tag, retention_interval=retention_interval, timeout=timeout, **kwargs) @@ -863,7 +863,8 @@ def __init__( class DeploymentScriptsError(msrest.serialization.Model): """Deployment scripts error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ErrorResponse """ @@ -987,7 +988,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -1039,6 +1040,8 @@ class ManagedServiceIdentity(msrest.serialization.Model): :param type: Type of the managed identity. Possible values include: "UserAssigned". :type type: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ManagedServiceIdentityType + :param tenant_id: ID of the Azure Active Directory. + :type tenant_id: str :param user_assigned_identities: The list of user-assigned managed identities associated with the resource. Key is the Azure resource Id of the managed identity. :type user_assigned_identities: dict[str, @@ -1047,6 +1050,7 @@ class ManagedServiceIdentity(msrest.serialization.Model): _attribute_map = { 'type': {'key': 'type', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{UserAssignedIdentity}'}, } @@ -1054,11 +1058,13 @@ def __init__( self, *, type: Optional[Union[str, "ManagedServiceIdentityType"]] = None, + tenant_id: Optional[str] = None, user_assigned_identities: Optional[Dict[str, "UserAssignedIdentity"]] = None, **kwargs ): super(ManagedServiceIdentity, self).__init__(**kwargs) self.type = type + self.tenant_id = tenant_id self.user_assigned_identities = user_assigned_identities @@ -1214,7 +1220,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -1250,12 +1256,19 @@ def __init__( class UserAssignedIdentity(msrest.serialization.Model): """User-assigned managed identity. - :param principal_id: Azure Active Directory principal ID associated with this identity. - :type principal_id: str - :param client_id: Client App Id associated with this identity. - :type client_id: str + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Azure Active Directory principal ID associated with this identity. + :vartype principal_id: str + :ivar client_id: Client App Id associated with this identity. + :vartype client_id: str """ + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + _attribute_map = { 'principal_id': {'key': 'principalId', 'type': 'str'}, 'client_id': {'key': 'clientId', 'type': 'str'}, @@ -1263,11 +1276,8 @@ class UserAssignedIdentity(msrest.serialization.Model): def __init__( self, - *, - principal_id: Optional[str] = None, - client_id: Optional[str] = None, **kwargs ): super(UserAssignedIdentity, self).__init__(**kwargs) - self.principal_id = principal_id - self.client_id = client_id + self.principal_id = None + self.client_id = None diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/operations/_deployment_scripts_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/operations/_deployment_scripts_operations.py index 7c4e9fe26328..304e1918f225 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/operations/_deployment_scripts_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2019_10_01_preview/operations/_deployment_scripts_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentScriptsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,11 +51,11 @@ def _create_initial( self, resource_group_name, # type: str script_name, # type: str - deployment_script, # type: "models.DeploymentScript" + deployment_script, # type: "_models.DeploymentScript" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + # type: (...) -> "_models.DeploymentScript" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -91,7 +91,7 @@ def _create_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -110,10 +110,10 @@ def begin_create( self, resource_group_name, # type: str script_name, # type: str - deployment_script, # type: "models.DeploymentScript" + deployment_script, # type: "_models.DeploymentScript" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentScript"] + # type: (...) -> LROPoller["_models.DeploymentScript"] """Creates a deployment script. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -133,7 +133,7 @@ def begin_create( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -158,7 +158,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'scriptName': self._serialize.url("script_name", script_name, 'str', max_length=90, min_length=1), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -176,10 +182,10 @@ def update( self, resource_group_name, # type: str script_name, # type: str - deployment_script=None, # type: Optional["models.DeploymentScriptUpdateParameter"] + deployment_script=None, # type: Optional["_models.DeploymentScriptUpdateParameter"] **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" + # type: (...) -> "_models.DeploymentScript" """Updates deployment script tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -193,7 +199,7 @@ def update( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +238,7 @@ def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -249,7 +255,7 @@ def get( script_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" + # type: (...) -> "_models.DeploymentScript" """Gets a deployment script with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -261,7 +267,7 @@ def get( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -292,7 +298,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -353,7 +359,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -365,7 +371,7 @@ def list_by_subscription( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentScriptListResult"] + # type: (...) -> Iterable["_models.DeploymentScriptListResult"] """Lists all deployment scripts for a given subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -373,7 +379,7 @@ def list_by_subscription( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -418,7 +424,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -435,7 +441,7 @@ def get_logs( script_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ScriptLogsList" + # type: (...) -> "_models.ScriptLogsList" """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -447,7 +453,7 @@ def get_logs( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ScriptLogsList :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLogsList"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLogsList"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -478,7 +484,7 @@ def get_logs( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLogsList', pipeline_response) @@ -496,7 +502,7 @@ def get_logs_default( tail=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> "models.ScriptLog" + # type: (...) -> "_models.ScriptLog" """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -512,7 +518,7 @@ def get_logs_default( :rtype: ~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.ScriptLog :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLog"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLog"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -545,7 +551,7 @@ def get_logs_default( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLog', pipeline_response) @@ -561,7 +567,7 @@ def list_by_resource_group( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentScriptListResult"] + # type: (...) -> Iterable["_models.DeploymentScriptListResult"] """Lists deployments scripts. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -571,7 +577,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.deploymentscripts.v2019_10_01_preview.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -617,7 +623,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_deployment_scripts_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_deployment_scripts_client.py index 499472552f73..d9fd8237795f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_deployment_scripts_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_deployment_scripts_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployment_scripts = DeploymentScriptsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_metadata.json index 7c8d92e86c3e..64213d7855c5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/_deployment_scripts_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/_deployment_scripts_client.py index f89f44c0cccb..7660aef90631 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/_deployment_scripts_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/_deployment_scripts_client.py @@ -47,7 +47,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployment_scripts = DeploymentScriptsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/operations/_deployment_scripts_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/operations/_deployment_scripts_operations.py index f27839d6c42d..8e1ffbdb587c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/operations/_deployment_scripts_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/aio/operations/_deployment_scripts_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentScriptsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,10 +47,10 @@ async def _create_initial( self, resource_group_name: str, script_name: str, - deployment_script: "models.DeploymentScript", + deployment_script: "_models.DeploymentScript", **kwargs - ) -> "models.DeploymentScript": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + ) -> "_models.DeploymentScript": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -86,7 +86,7 @@ async def _create_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -105,9 +105,9 @@ async def begin_create( self, resource_group_name: str, script_name: str, - deployment_script: "models.DeploymentScript", + deployment_script: "_models.DeploymentScript", **kwargs - ) -> AsyncLROPoller["models.DeploymentScript"]: + ) -> AsyncLROPoller["_models.DeploymentScript"]: """Creates a deployment script. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -127,7 +127,7 @@ async def begin_create( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -152,7 +152,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'scriptName': self._serialize.url("script_name", script_name, 'str', max_length=90, min_length=1), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -170,9 +176,9 @@ async def update( self, resource_group_name: str, script_name: str, - deployment_script: Optional["models.DeploymentScriptUpdateParameter"] = None, + deployment_script: Optional["_models.DeploymentScriptUpdateParameter"] = None, **kwargs - ) -> "models.DeploymentScript": + ) -> "_models.DeploymentScript": """Updates deployment script tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -186,7 +192,7 @@ async def update( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +231,7 @@ async def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -241,7 +247,7 @@ async def get( resource_group_name: str, script_name: str, **kwargs - ) -> "models.DeploymentScript": + ) -> "_models.DeploymentScript": """Gets a deployment script with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -253,7 +259,7 @@ async def get( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -284,7 +290,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -344,7 +350,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -355,7 +361,7 @@ async def delete( def list_by_subscription( self, **kwargs - ) -> AsyncIterable["models.DeploymentScriptListResult"]: + ) -> AsyncIterable["_models.DeploymentScriptListResult"]: """Lists all deployment scripts for a given subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -363,7 +369,7 @@ def list_by_subscription( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -408,7 +414,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -424,7 +430,7 @@ async def get_logs( resource_group_name: str, script_name: str, **kwargs - ) -> "models.ScriptLogsList": + ) -> "_models.ScriptLogsList": """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -436,7 +442,7 @@ async def get_logs( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ScriptLogsList :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLogsList"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLogsList"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -467,7 +473,7 @@ async def get_logs( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLogsList', pipeline_response) @@ -484,7 +490,7 @@ async def get_logs_default( script_name: str, tail: Optional[int] = None, **kwargs - ) -> "models.ScriptLog": + ) -> "_models.ScriptLog": """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -500,7 +506,7 @@ async def get_logs_default( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ScriptLog :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLog"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLog"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -533,7 +539,7 @@ async def get_logs_default( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLog', pipeline_response) @@ -548,7 +554,7 @@ def list_by_resource_group( self, resource_group_name: str, **kwargs - ) -> AsyncIterable["models.DeploymentScriptListResult"]: + ) -> AsyncIterable["_models.DeploymentScriptListResult"]: """Lists deployments scripts. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -558,7 +564,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -604,7 +610,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models.py index a51cc9bfefe5..531f19316ef1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models.py @@ -148,7 +148,7 @@ class AzureCliScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -180,7 +180,7 @@ class AzureCliScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_cli_version: Required. Azure CLI module version to be used. :type az_cli_version: str @@ -235,7 +235,7 @@ def __init__( self.kind = 'AzureCLI' # type: str self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -246,7 +246,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_cli_version = kwargs['az_cli_version'] @@ -275,7 +275,7 @@ class ScriptConfigurationBase(msrest.serialization.Model): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta """ @@ -307,7 +307,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") class DeploymentScriptPropertiesBase(msrest.serialization.Model): @@ -323,7 +323,7 @@ class DeploymentScriptPropertiesBase(msrest.serialization.Model): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -359,7 +359,7 @@ def __init__( super(DeploymentScriptPropertiesBase, self).__init__(**kwargs) self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -392,7 +392,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -402,7 +402,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -457,11 +457,11 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_cli_version = kwargs['az_cli_version'] self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -503,7 +503,7 @@ class AzurePowerShellScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -535,7 +535,7 @@ class AzurePowerShellScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_power_shell_version: Required. Azure PowerShell module version to be used. :type az_power_shell_version: str @@ -590,7 +590,7 @@ def __init__( self.kind = 'AzurePowerShell' # type: str self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -601,7 +601,7 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_power_shell_version = kwargs['az_power_shell_version'] @@ -632,7 +632,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -642,7 +642,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -697,11 +697,11 @@ def __init__( self.environment_variables = kwargs.get('environment_variables', None) self.force_update_tag = kwargs.get('force_update_tag', None) self.retention_interval = kwargs['retention_interval'] - self.timeout = kwargs.get('timeout', None) + self.timeout = kwargs.get('timeout', "P1D") self.az_power_shell_version = kwargs['az_power_shell_version'] self.container_settings = kwargs.get('container_settings', None) self.storage_account_settings = kwargs.get('storage_account_settings', None) - self.cleanup_preference = kwargs.get('cleanup_preference', None) + self.cleanup_preference = kwargs.get('cleanup_preference', "Always") self.provisioning_state = None self.status = None self.outputs = None @@ -772,7 +772,8 @@ def __init__( class DeploymentScriptsError(msrest.serialization.Model): """Deployment scripts error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ErrorResponse """ @@ -888,7 +889,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -1104,7 +1105,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -1133,12 +1134,19 @@ def __init__( class UserAssignedIdentity(msrest.serialization.Model): """User-assigned managed identity. - :param principal_id: Azure Active Directory principal ID associated with this identity. - :type principal_id: str - :param client_id: Client App Id associated with this identity. - :type client_id: str + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Azure Active Directory principal ID associated with this identity. + :vartype principal_id: str + :ivar client_id: Client App Id associated with this identity. + :vartype client_id: str """ + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + _attribute_map = { 'principal_id': {'key': 'principalId', 'type': 'str'}, 'client_id': {'key': 'clientId', 'type': 'str'}, @@ -1149,5 +1157,5 @@ def __init__( **kwargs ): super(UserAssignedIdentity, self).__init__(**kwargs) - self.principal_id = kwargs.get('principal_id', None) - self.client_id = kwargs.get('client_id', None) + self.principal_id = None + self.client_id = None diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models_py3.py index 0f7d7d041047..df488a2d6a26 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/models/_models_py3.py @@ -157,7 +157,7 @@ class AzureCliScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -189,7 +189,7 @@ class AzureCliScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_cli_version: Required. Azure CLI module version to be used. :type az_cli_version: str @@ -246,14 +246,14 @@ def __init__( tags: Optional[Dict[str, str]] = None, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", primary_script_uri: Optional[str] = None, supporting_script_uris: Optional[List[str]] = None, script_content: Optional[str] = None, arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(AzureCliScript, self).__init__(identity=identity, location=location, tags=tags, **kwargs) @@ -300,7 +300,7 @@ class ScriptConfigurationBase(msrest.serialization.Model): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta """ @@ -330,7 +330,7 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(ScriptConfigurationBase, self).__init__(**kwargs) @@ -357,7 +357,7 @@ class DeploymentScriptPropertiesBase(msrest.serialization.Model): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -391,7 +391,7 @@ def __init__( *, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(DeploymentScriptPropertiesBase, self).__init__(**kwargs) @@ -430,7 +430,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -440,7 +440,7 @@ class AzureCliScriptProperties(DeploymentScriptPropertiesBase, ScriptConfigurati ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -494,10 +494,10 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(AzureCliScriptProperties, self).__init__(container_settings=container_settings, storage_account_settings=storage_account_settings, cleanup_preference=cleanup_preference, primary_script_uri=primary_script_uri, supporting_script_uris=supporting_script_uris, script_content=script_content, arguments=arguments, environment_variables=environment_variables, force_update_tag=force_update_tag, retention_interval=retention_interval, timeout=timeout, **kwargs) @@ -554,7 +554,7 @@ class AzurePowerShellScript(DeploymentScript): ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -586,7 +586,7 @@ class AzurePowerShellScript(DeploymentScript): Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param az_power_shell_version: Required. Azure PowerShell module version to be used. :type az_power_shell_version: str @@ -643,14 +643,14 @@ def __init__( tags: Optional[Dict[str, str]] = None, container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", primary_script_uri: Optional[str] = None, supporting_script_uris: Optional[List[str]] = None, script_content: Optional[str] = None, arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", **kwargs ): super(AzurePowerShellScript, self).__init__(identity=identity, location=location, tags=tags, **kwargs) @@ -699,7 +699,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf Duration is based on ISO 8601 pattern (for example P7D means one week). :type retention_interval: ~datetime.timedelta :param timeout: Maximum allowed script execution time specified in ISO 8601 format. Default - value is PT1H. + value is P1D. :type timeout: ~datetime.timedelta :param container_settings: Container settings. :type container_settings: @@ -709,7 +709,7 @@ class AzurePowerShellScriptProperties(DeploymentScriptPropertiesBase, ScriptConf ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.StorageAccountConfiguration :param cleanup_preference: The clean up preference when the script execution gets in a terminal state. Default setting is 'Always'. Possible values include: "Always", "OnSuccess", - "OnExpiration". + "OnExpiration". Default value: "Always". :type cleanup_preference: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CleanupOptions :ivar provisioning_state: State of the script execution. This only appears in the response. @@ -763,10 +763,10 @@ def __init__( arguments: Optional[str] = None, environment_variables: Optional[List["EnvironmentVariable"]] = None, force_update_tag: Optional[str] = None, - timeout: Optional[datetime.timedelta] = None, + timeout: Optional[datetime.timedelta] = "P1D", container_settings: Optional["ContainerConfiguration"] = None, storage_account_settings: Optional["StorageAccountConfiguration"] = None, - cleanup_preference: Optional[Union[str, "CleanupOptions"]] = None, + cleanup_preference: Optional[Union[str, "CleanupOptions"]] = "Always", **kwargs ): super(AzurePowerShellScriptProperties, self).__init__(container_settings=container_settings, storage_account_settings=storage_account_settings, cleanup_preference=cleanup_preference, primary_script_uri=primary_script_uri, supporting_script_uris=supporting_script_uris, script_content=script_content, arguments=arguments, environment_variables=environment_variables, force_update_tag=force_update_tag, retention_interval=retention_interval, timeout=timeout, **kwargs) @@ -856,7 +856,8 @@ def __init__( class DeploymentScriptsError(msrest.serialization.Model): """Deployment scripts error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ErrorResponse """ @@ -980,7 +981,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -1206,7 +1207,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -1242,12 +1243,19 @@ def __init__( class UserAssignedIdentity(msrest.serialization.Model): """User-assigned managed identity. - :param principal_id: Azure Active Directory principal ID associated with this identity. - :type principal_id: str - :param client_id: Client App Id associated with this identity. - :type client_id: str + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: Azure Active Directory principal ID associated with this identity. + :vartype principal_id: str + :ivar client_id: Client App Id associated with this identity. + :vartype client_id: str """ + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + _attribute_map = { 'principal_id': {'key': 'principalId', 'type': 'str'}, 'client_id': {'key': 'clientId', 'type': 'str'}, @@ -1255,11 +1263,8 @@ class UserAssignedIdentity(msrest.serialization.Model): def __init__( self, - *, - principal_id: Optional[str] = None, - client_id: Optional[str] = None, **kwargs ): super(UserAssignedIdentity, self).__init__(**kwargs) - self.principal_id = principal_id - self.client_id = client_id + self.principal_id = None + self.client_id = None diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/operations/_deployment_scripts_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/operations/_deployment_scripts_operations.py index 8cba6c60f30b..fdd357dfa6d7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/operations/_deployment_scripts_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/deploymentscripts/v2020_10_01/operations/_deployment_scripts_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentScriptsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,11 +51,11 @@ def _create_initial( self, resource_group_name, # type: str script_name, # type: str - deployment_script, # type: "models.DeploymentScript" + deployment_script, # type: "_models.DeploymentScript" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + # type: (...) -> "_models.DeploymentScript" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -91,7 +91,7 @@ def _create_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -110,10 +110,10 @@ def begin_create( self, resource_group_name, # type: str script_name, # type: str - deployment_script, # type: "models.DeploymentScript" + deployment_script, # type: "_models.DeploymentScript" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentScript"] + # type: (...) -> LROPoller["_models.DeploymentScript"] """Creates a deployment script. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -133,7 +133,7 @@ def begin_create( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -158,7 +158,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'scriptName': self._serialize.url("script_name", script_name, 'str', max_length=90, min_length=1), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -176,10 +182,10 @@ def update( self, resource_group_name, # type: str script_name, # type: str - deployment_script=None, # type: Optional["models.DeploymentScriptUpdateParameter"] + deployment_script=None, # type: Optional["_models.DeploymentScriptUpdateParameter"] **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" + # type: (...) -> "_models.DeploymentScript" """Updates deployment script tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -193,7 +199,7 @@ def update( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +238,7 @@ def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -249,7 +255,7 @@ def get( script_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentScript" + # type: (...) -> "_models.DeploymentScript" """Gets a deployment script with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -261,7 +267,7 @@ def get( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScript :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScript"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScript"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -292,7 +298,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('DeploymentScript', pipeline_response) @@ -353,7 +359,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -365,7 +371,7 @@ def list_by_subscription( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentScriptListResult"] + # type: (...) -> Iterable["_models.DeploymentScriptListResult"] """Lists all deployment scripts for a given subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -373,7 +379,7 @@ def list_by_subscription( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -418,7 +424,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -435,7 +441,7 @@ def get_logs( script_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ScriptLogsList" + # type: (...) -> "_models.ScriptLogsList" """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -447,7 +453,7 @@ def get_logs( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ScriptLogsList :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLogsList"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLogsList"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -478,7 +484,7 @@ def get_logs( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLogsList', pipeline_response) @@ -496,7 +502,7 @@ def get_logs_default( tail=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> "models.ScriptLog" + # type: (...) -> "_models.ScriptLog" """Gets deployment script logs for a given deployment script name. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -512,7 +518,7 @@ def get_logs_default( :rtype: ~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.ScriptLog :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ScriptLog"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ScriptLog"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -545,7 +551,7 @@ def get_logs_default( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('ScriptLog', pipeline_response) @@ -561,7 +567,7 @@ def list_by_resource_group( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentScriptListResult"] + # type: (...) -> Iterable["_models.DeploymentScriptListResult"] """Lists deployments scripts. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -571,7 +577,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.deploymentscripts.v2020_10_01.models.DeploymentScriptListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentScriptListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentScriptListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -617,7 +623,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.DeploymentScriptsError, response) + error = self._deserialize(_models.DeploymentScriptsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/aio/_operations_mixin.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/aio/_operations_mixin.py index 60c48b8f12c5..25e18a7fd4f3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/aio/_operations_mixin.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/aio/_operations_mixin.py @@ -24,7 +24,7 @@ class FeatureClientOperationsMixin(object): def list_operations( self, **kwargs - ) -> AsyncItemPaged["models.OperationListResult"]: + ) -> AsyncItemPaged["_models.OperationListResult"]: """Lists all of the available Microsoft.Features REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_feature_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_feature_client.py index 6b1b3d27a08a..68f7d1bf5b36 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_feature_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_feature_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.features = FeaturesOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_metadata.json index f985344b83de..7d8e5fbbedf5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true @@ -61,7 +62,7 @@ }, "async": { "coroutine": false, - "signature": "def list_operations(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"models.OperationListResult\"]:\n", + "signature": "def list_operations(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.OperationListResult\"]:\n", "doc": "\"\"\"Lists all of the available Microsoft.Features REST API operations.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either OperationListResult or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.OperationListResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "call": "" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/_feature_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/_feature_client.py index fe36e14941ae..d875a01aee0d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/_feature_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/_feature_client.py @@ -47,7 +47,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.features = FeaturesOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_feature_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_feature_client_operations.py index 68659ccaa024..84086940cf56 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_feature_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_feature_client_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -24,7 +24,7 @@ class FeatureClientOperationsMixin: def list_operations( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Features REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -32,7 +32,7 @@ def list_operations( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_features_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_features_operations.py index acd272e1f874..aa7dd05d2fa9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_features_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/aio/operations/_features_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class FeaturesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list_all( self, **kwargs - ) -> AsyncIterable["models.FeatureOperationsListResult"]: + ) -> AsyncIterable["_models.FeatureOperationsListResult"]: """Gets all the preview features that are available through AFEC for the subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list_all( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.FeatureOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -111,7 +111,7 @@ def list( self, resource_provider_namespace: str, **kwargs - ) -> AsyncIterable["models.FeatureOperationsListResult"]: + ) -> AsyncIterable["_models.FeatureOperationsListResult"]: """Gets all the preview features in a provider namespace that are available through AFEC for the subscription. @@ -123,7 +123,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.FeatureOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -184,7 +184,7 @@ async def get( resource_provider_namespace: str, feature_name: str, **kwargs - ) -> "models.FeatureResult": + ) -> "_models.FeatureResult": """Gets the preview feature with the specified name. :param resource_provider_namespace: The resource provider namespace for the feature. @@ -196,7 +196,7 @@ async def get( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ async def register( resource_provider_namespace: str, feature_name: str, **kwargs - ) -> "models.FeatureResult": + ) -> "_models.FeatureResult": """Registers the preview feature for the subscription. :param resource_provider_namespace: The namespace of the resource provider. @@ -254,7 +254,7 @@ async def register( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -300,7 +300,7 @@ async def unregister( resource_provider_namespace: str, feature_name: str, **kwargs - ) -> "models.FeatureResult": + ) -> "_models.FeatureResult": """Unregisters the preview feature for the subscription. :param resource_provider_namespace: The namespace of the resource provider. @@ -312,7 +312,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_feature_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_feature_client_operations.py index 0f683d7c2f95..8c19d28293e8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_feature_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_feature_client_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -29,7 +29,7 @@ def list_operations( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Features REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -37,7 +37,7 @@ def list_operations( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_features_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_features_operations.py index 95f21a21220b..c87a0167a201 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_features_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/features/v2015_12_01/operations/_features_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class FeaturesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list_all( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.FeatureOperationsListResult"] + # type: (...) -> Iterable["_models.FeatureOperationsListResult"] """Gets all the preview features that are available through AFEC for the subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list_all( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.FeatureOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,7 +117,7 @@ def list( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.FeatureOperationsListResult"] + # type: (...) -> Iterable["_models.FeatureOperationsListResult"] """Gets all the preview features in a provider namespace that are available through AFEC for the subscription. @@ -129,7 +129,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.features.v2015_12_01.models.FeatureOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -191,7 +191,7 @@ def get( feature_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.FeatureResult" + # type: (...) -> "_models.FeatureResult" """Gets the preview feature with the specified name. :param resource_provider_namespace: The resource provider namespace for the feature. @@ -203,7 +203,7 @@ def get( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def register( feature_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.FeatureResult" + # type: (...) -> "_models.FeatureResult" """Registers the preview feature for the subscription. :param resource_provider_namespace: The namespace of the resource provider. @@ -262,7 +262,7 @@ def register( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -309,7 +309,7 @@ def unregister( feature_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.FeatureResult" + # type: (...) -> "_models.FeatureResult" """Unregisters the preview feature for the subscription. :param resource_provider_namespace: The namespace of the resource provider. @@ -321,7 +321,7 @@ def unregister( :rtype: ~azure.mgmt.resource.features.v2015_12_01.models.FeatureResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.FeatureResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.FeatureResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_management_link_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_management_link_client.py index 3f48a479518e..5920e3d4e966 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_management_link_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_management_link_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_metadata.json index 217c47ad61bb..2706e6f18e71 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/_management_link_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/_management_link_client.py index 4290ba648070..781505a0eea1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/_management_link_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/_management_link_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_operations.py index 198c0c7e8443..43219e31b0f8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_resource_links_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_resource_links_operations.py index a1ee4b7d2a2d..7e1eb667d6e9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_resource_links_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/aio/operations/_resource_links_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ResourceLinksOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -95,9 +95,9 @@ async def delete( async def create_or_update( self, link_id: str, - parameters: "models.ResourceLink", + parameters: "_models.ResourceLink", **kwargs - ) -> "models.ResourceLink": + ) -> "_models.ResourceLink": """Creates or updates a resource link between the specified resources. :param link_id: The fully qualified ID of the resource link. Use the format, @@ -112,7 +112,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.links.v2016_09_01.models.ResourceLink :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLink"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLink"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -164,7 +164,7 @@ async def get( self, link_id: str, **kwargs - ) -> "models.ResourceLink": + ) -> "_models.ResourceLink": """Gets a resource link with the specified ID. :param link_id: The fully qualified Id of the resource link. For example, @@ -175,7 +175,7 @@ async def get( :rtype: ~azure.mgmt.resource.links.v2016_09_01.models.ResourceLink :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLink"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLink"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,7 +218,7 @@ def list_at_subscription( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ResourceLinkResult"]: + ) -> AsyncIterable["_models.ResourceLinkResult"]: """Gets all the linked resources for the subscription. :param filter: The filter to apply on the list resource links operation. The supported filter @@ -229,7 +229,7 @@ def list_at_subscription( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.ResourceLinkResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLinkResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLinkResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -291,7 +291,7 @@ def list_at_source_scope( scope: str, filter: Optional[str] = "atScope()", **kwargs - ) -> AsyncIterable["models.ResourceLinkResult"]: + ) -> AsyncIterable["_models.ResourceLinkResult"]: """Gets a list of resource links at and below the specified source scope. :param scope: The fully qualified ID of the scope for getting the resource links. For example, @@ -306,7 +306,7 @@ def list_at_source_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.ResourceLinkResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLinkResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLinkResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_operations.py index 5df9746cab89..f75bcabcd8fc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_resource_links_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_resource_links_operations.py index dd3242158077..a82266dddbf4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_resource_links_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/links/v2016_09_01/operations/_resource_links_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ResourceLinksOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -100,10 +100,10 @@ def delete( def create_or_update( self, link_id, # type: str - parameters, # type: "models.ResourceLink" + parameters, # type: "_models.ResourceLink" **kwargs # type: Any ): - # type: (...) -> "models.ResourceLink" + # type: (...) -> "_models.ResourceLink" """Creates or updates a resource link between the specified resources. :param link_id: The fully qualified ID of the resource link. Use the format, @@ -118,7 +118,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.links.v2016_09_01.models.ResourceLink :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLink"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLink"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -171,7 +171,7 @@ def get( link_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceLink" + # type: (...) -> "_models.ResourceLink" """Gets a resource link with the specified ID. :param link_id: The fully qualified Id of the resource link. For example, @@ -182,7 +182,7 @@ def get( :rtype: ~azure.mgmt.resource.links.v2016_09_01.models.ResourceLink :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLink"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLink"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -226,7 +226,7 @@ def list_at_subscription( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceLinkResult"] + # type: (...) -> Iterable["_models.ResourceLinkResult"] """Gets all the linked resources for the subscription. :param filter: The filter to apply on the list resource links operation. The supported filter @@ -237,7 +237,7 @@ def list_at_subscription( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.ResourceLinkResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLinkResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLinkResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -300,7 +300,7 @@ def list_at_source_scope( filter="atScope()", # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceLinkResult"] + # type: (...) -> Iterable["_models.ResourceLinkResult"] """Gets a list of resource links at and below the specified source scope. :param scope: The fully qualified ID of the scope for getting the resource links. For example, @@ -315,7 +315,7 @@ def list_at_source_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.links.v2016_09_01.models.ResourceLinkResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceLinkResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceLinkResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_management_lock_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_management_lock_client.py index 0d2c1615ebd2..ea22fb0c4532 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_management_lock_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_management_lock_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.management_locks = ManagementLocksOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_metadata.json index 1ef520504287..0af57a217511 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/_management_lock_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/_management_lock_client.py index d08a1b372e2d..3534403a4856 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/_management_lock_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/_management_lock_client.py @@ -46,7 +46,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.management_locks = ManagementLocksOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/operations/_management_locks_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/operations/_management_locks_operations.py index 782c246fb605..5c20fdd98eff 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/operations/_management_locks_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/aio/operations/_management_locks_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ManagementLocksOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,9 +45,9 @@ async def create_or_update_at_resource_group_level( self, resource_group_name: str, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Create or update a management lock at the resource group level. :param resource_group_name: The resource group name. @@ -61,7 +61,7 @@ async def create_or_update_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def get_at_resource_group_level( resource_group_name: str, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Gets a management lock at the resource group level. :param resource_group_name: The resource group name. @@ -181,7 +181,7 @@ async def get_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -230,9 +230,9 @@ async def create_or_update_at_resource_level( resource_type: str, resource_name: str, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Create or update a management lock at the resource level or any level below resource. :param resource_group_name: The name of the resource group. @@ -254,7 +254,7 @@ async def create_or_update_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -380,9 +380,9 @@ async def delete_at_resource_level( async def create_or_update_at_subscription_level( self, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Create or update a management lock at the subscription level. :param lock_name: The name of lock. @@ -394,7 +394,7 @@ async def create_or_update_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -496,7 +496,7 @@ async def get( self, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Gets the management lock of a scope. :param lock_name: Name of the management lock. @@ -506,7 +506,7 @@ async def get( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -551,7 +551,7 @@ def list_at_resource_group_level( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks of a resource group. :param resource_group_name: Resource group name. @@ -563,7 +563,7 @@ def list_at_resource_group_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -630,7 +630,7 @@ def list_at_resource_level( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks of a resource or any level below resource. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -650,7 +650,7 @@ def list_at_resource_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -716,7 +716,7 @@ def list_at_subscription_level( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks of a subscription. :param filter: The filter to apply on the operation. @@ -726,7 +726,7 @@ def list_at_subscription_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/operations/_management_locks_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/operations/_management_locks_operations.py index 37abd5ac076f..aad1b98589d7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/operations/_management_locks_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2015_01_01/operations/_management_locks_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ManagementLocksOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,10 +49,10 @@ def create_or_update_at_resource_group_level( self, resource_group_name, # type: str lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Create or update a management lock at the resource group level. :param resource_group_name: The resource group name. @@ -66,7 +66,7 @@ def create_or_update_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def get_at_resource_group_level( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Gets a management lock at the resource group level. :param resource_group_name: The resource group name. @@ -188,7 +188,7 @@ def get_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -237,10 +237,10 @@ def create_or_update_at_resource_level( resource_type, # type: str resource_name, # type: str lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Create or update a management lock at the resource level or any level below resource. :param resource_group_name: The name of the resource group. @@ -262,7 +262,7 @@ def create_or_update_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -389,10 +389,10 @@ def delete_at_resource_level( def create_or_update_at_subscription_level( self, lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Create or update a management lock at the subscription level. :param lock_name: The name of lock. @@ -404,7 +404,7 @@ def create_or_update_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -508,7 +508,7 @@ def get( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Gets the management lock of a scope. :param lock_name: Name of the management lock. @@ -518,7 +518,7 @@ def get( :rtype: ~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -564,7 +564,7 @@ def list_at_resource_group_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks of a resource group. :param resource_group_name: Resource group name. @@ -576,7 +576,7 @@ def list_at_resource_group_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -644,7 +644,7 @@ def list_at_resource_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks of a resource or any level below resource. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -664,7 +664,7 @@ def list_at_resource_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -731,7 +731,7 @@ def list_at_subscription_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks of a subscription. :param filter: The filter to apply on the operation. @@ -741,7 +741,7 @@ def list_at_subscription_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2015_01_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_management_lock_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_management_lock_client.py index 281b14edc1fc..7060878cd3e6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_management_lock_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_management_lock_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.authorization_operations = AuthorizationOperationsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_metadata.json index 6b0d03ffdf51..21218265cf9c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/_management_lock_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/_management_lock_client.py index 375e00ed72e2..81581db1b174 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/_management_lock_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/_management_lock_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.authorization_operations = AuthorizationOperationsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_authorization_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_authorization_operations_operations.py index aba848441770..6458adbb88a7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_authorization_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_authorization_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class AuthorizationOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Authorization REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_management_locks_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_management_locks_operations.py index aea5f632d0c8..27ec1b80b82a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_management_locks_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/aio/operations/_management_locks_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ManagementLocksOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,9 +45,9 @@ async def create_or_update_at_resource_group_level( self, resource_group_name: str, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Creates or updates a management lock at the resource group level. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -67,7 +67,7 @@ async def create_or_update_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -179,7 +179,7 @@ async def get_at_resource_group_level( resource_group_name: str, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Gets a management lock at the resource group level. :param resource_group_name: The name of the locked resource group. @@ -191,7 +191,7 @@ async def get_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -236,9 +236,9 @@ async def create_or_update_by_scope( self, scope: str, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Create or update a management lock by scope. :param scope: The scope for the lock. When providing a scope for the assignment, use @@ -256,7 +256,7 @@ async def create_or_update_by_scope( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -362,7 +362,7 @@ async def get_by_scope( scope: str, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Get a management lock by scope. :param scope: The scope for the lock. @@ -374,7 +374,7 @@ async def get_by_scope( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -422,9 +422,9 @@ async def create_or_update_at_resource_level( resource_type: str, resource_name: str, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Creates or updates a management lock at the resource level or any level below the resource. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -452,7 +452,7 @@ async def create_or_update_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ async def get_at_resource_level( resource_name: str, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Get the management lock of a resource or any level below resource. :param resource_group_name: The name of the resource group. @@ -611,7 +611,7 @@ async def get_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -659,9 +659,9 @@ async def get_at_resource_level( async def create_or_update_at_subscription_level( self, lock_name: str, - parameters: "models.ManagementLockObject", + parameters: "_models.ManagementLockObject", **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Creates or updates a management lock at the subscription level. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -679,7 +679,7 @@ async def create_or_update_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -785,7 +785,7 @@ async def get_at_subscription_level( self, lock_name: str, **kwargs - ) -> "models.ManagementLockObject": + ) -> "_models.ManagementLockObject": """Gets a management lock at the subscription level. :param lock_name: The name of the lock to get. @@ -795,7 +795,7 @@ async def get_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -840,7 +840,7 @@ def list_at_resource_group_level( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks for a resource group. :param resource_group_name: The name of the resource group containing the locks to get. @@ -852,7 +852,7 @@ def list_at_resource_group_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -919,7 +919,7 @@ def list_at_resource_level( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks for a resource or any level below resource. :param resource_group_name: The name of the resource group containing the locked resource. The @@ -940,7 +940,7 @@ def list_at_resource_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1006,7 +1006,7 @@ def list_at_subscription_level( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks for a subscription. :param filter: The filter to apply on the operation. @@ -1016,7 +1016,7 @@ def list_at_subscription_level( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1078,7 +1078,7 @@ def list_by_scope( scope: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ManagementLockListResult"]: + ) -> AsyncIterable["_models.ManagementLockListResult"]: """Gets all the management locks for a scope. :param scope: The scope for the lock. When providing a scope for the assignment, use @@ -1094,7 +1094,7 @@ def list_by_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_authorization_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_authorization_operations_operations.py index 1038316b1f01..048fc64e4bee 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_authorization_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_authorization_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class AuthorizationOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Authorization REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_management_locks_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_management_locks_operations.py index 483db4ae3f64..ba7a1c8feb72 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_management_locks_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/locks/v2016_09_01/operations/_management_locks_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ManagementLocksOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,10 +49,10 @@ def create_or_update_at_resource_group_level( self, resource_group_name, # type: str lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Creates or updates a management lock at the resource group level. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -72,7 +72,7 @@ def create_or_update_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -186,7 +186,7 @@ def get_at_resource_group_level( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Gets a management lock at the resource group level. :param resource_group_name: The name of the locked resource group. @@ -198,7 +198,7 @@ def get_at_resource_group_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -243,10 +243,10 @@ def create_or_update_by_scope( self, scope, # type: str lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Create or update a management lock by scope. :param scope: The scope for the lock. When providing a scope for the assignment, use @@ -264,7 +264,7 @@ def create_or_update_by_scope( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -372,7 +372,7 @@ def get_by_scope( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Get a management lock by scope. :param scope: The scope for the lock. @@ -384,7 +384,7 @@ def get_by_scope( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -432,10 +432,10 @@ def create_or_update_at_resource_level( resource_type, # type: str resource_name, # type: str lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Creates or updates a management lock at the resource level or any level below the resource. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -463,7 +463,7 @@ def create_or_update_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -603,7 +603,7 @@ def get_at_resource_level( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Get the management lock of a resource or any level below resource. :param resource_group_name: The name of the resource group. @@ -624,7 +624,7 @@ def get_at_resource_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -672,10 +672,10 @@ def get_at_resource_level( def create_or_update_at_subscription_level( self, lock_name, # type: str - parameters, # type: "models.ManagementLockObject" + parameters, # type: "_models.ManagementLockObject" **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Creates or updates a management lock at the subscription level. When you apply a lock at a parent scope, all child resources inherit the same lock. To create @@ -693,7 +693,7 @@ def create_or_update_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -801,7 +801,7 @@ def get_at_subscription_level( lock_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ManagementLockObject" + # type: (...) -> "_models.ManagementLockObject" """Gets a management lock at the subscription level. :param lock_name: The name of the lock to get. @@ -811,7 +811,7 @@ def get_at_subscription_level( :rtype: ~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockObject :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockObject"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockObject"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -857,7 +857,7 @@ def list_at_resource_group_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks for a resource group. :param resource_group_name: The name of the resource group containing the locks to get. @@ -869,7 +869,7 @@ def list_at_resource_group_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -937,7 +937,7 @@ def list_at_resource_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks for a resource or any level below resource. :param resource_group_name: The name of the resource group containing the locked resource. The @@ -958,7 +958,7 @@ def list_at_resource_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1025,7 +1025,7 @@ def list_at_subscription_level( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks for a subscription. :param filter: The filter to apply on the operation. @@ -1035,7 +1035,7 @@ def list_at_subscription_level( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1098,7 +1098,7 @@ def list_by_scope( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ManagementLockListResult"] + # type: (...) -> Iterable["_models.ManagementLockListResult"] """Gets all the management locks for a scope. :param scope: The scope for the lock. When providing a scope for the assignment, use @@ -1114,7 +1114,7 @@ def list_by_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.locks.v2016_09_01.models.ManagementLockListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ManagementLockListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ManagementLockListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_application_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_application_client.py index 8b28f1b77801..907a527ef6a0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_application_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_application_client.py @@ -18,12 +18,13 @@ from azure.core.credentials import TokenCredential from ._configuration import ApplicationClientConfiguration +from .operations import ApplicationClientOperationsMixin from .operations import ApplicationsOperations from .operations import ApplicationDefinitionsOperations from . import models -class ApplicationClient(object): +class ApplicationClient(ApplicationClientOperationsMixin): """ARM applications. :ivar applications: ApplicationsOperations operations @@ -53,7 +54,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.applications = ApplicationsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_metadata.json index a271e52c7019..43995e3a075b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true @@ -55,7 +56,19 @@ "application_definitions": "ApplicationDefinitionsOperations" }, "operation_mixins": { + "list_operations" : { + "sync": { + "signature": "def list_operations(\n self,\n **kwargs # type: Any\n):\n", + "doc": "\"\"\"Lists all of the available Microsoft.Solutions REST API operations.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either OperationListResult or the result of cls(response)\n:rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.managedapplications.models.OperationListResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "async": { + "coroutine": false, + "signature": "def list_operations(\n self,\n **kwargs\n) -\u003e AsyncItemPaged[\"_models.OperationListResult\"]:\n", + "doc": "\"\"\"Lists all of the available Microsoft.Solutions REST API operations.\n\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: An iterator like instance of either OperationListResult or the result of cls(response)\n:rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.managedapplications.models.OperationListResult]\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" + }, + "call": "" + } }, - "sync_imports": "None", - "async_imports": "None" + "sync_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"HttpRequest\", \"HttpResponse\"], \"azure.core.paging\": [\"ItemPaged\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"Callable\", \"Dict\", \"Generic\", \"Iterable\", \"Optional\", \"TypeVar\"]}}}", + "async_imports": "{\"regular\": {\"azurecore\": {\"azure.core.exceptions\": [\"ClientAuthenticationError\", \"HttpResponseError\", \"ResourceExistsError\", \"ResourceNotFoundError\", \"map_error\"], \"azure.mgmt.core.exceptions\": [\"ARMErrorFormat\"], \"azure.core.pipeline\": [\"PipelineResponse\"], \"azure.core.pipeline.transport\": [\"AsyncHttpResponse\", \"HttpRequest\"], \"azure.core.async_paging\": [\"AsyncItemPaged\", \"AsyncList\"]}, \"stdlib\": {\"warnings\": [null]}}, \"conditional\": {\"stdlib\": {\"typing\": [\"Any\", \"AsyncIterable\", \"Callable\", \"Dict\", \"Generic\", \"Optional\", \"TypeVar\"]}}}" } \ No newline at end of file diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/_application_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/_application_client.py index 9a2a6b52e797..4ad42b8657f2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/_application_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/_application_client.py @@ -16,12 +16,13 @@ from azure.core.credentials_async import AsyncTokenCredential from ._configuration import ApplicationClientConfiguration +from .operations import ApplicationClientOperationsMixin from .operations import ApplicationsOperations from .operations import ApplicationDefinitionsOperations from .. import models -class ApplicationClient(object): +class ApplicationClient(ApplicationClientOperationsMixin): """ARM applications. :ivar applications: ApplicationsOperations operations @@ -50,7 +51,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.applications = ApplicationsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/__init__.py index cef7549ec472..76e2d17b2d58 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/__init__.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/__init__.py @@ -6,10 +6,12 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- +from ._application_client_operations import ApplicationClientOperationsMixin from ._applications_operations import ApplicationsOperations from ._application_definitions_operations import ApplicationDefinitionsOperations __all__ = [ + 'ApplicationClientOperationsMixin', 'ApplicationsOperations', 'ApplicationDefinitionsOperations', ] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_client_operations.py new file mode 100644 index 000000000000..687395592a77 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_client_operations.py @@ -0,0 +1,84 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationClientOperationsMixin: + + def list_operations( + self, + **kwargs + ) -> AsyncIterable["_models.OperationListResult"]: + """Lists all of the available Microsoft.Solutions REST API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.managedapplications.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Solutions/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_definitions_operations.py index 7817a88adc54..bfb52041645c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_application_definitions_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ApplicationDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -48,7 +48,7 @@ async def get( resource_group_name: str, application_definition_name: str, **kwargs - ) -> Optional["models.ApplicationDefinition"]: + ) -> Optional["_models.ApplicationDefinition"]: """Gets the managed application definition. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -60,7 +60,7 @@ async def get( :rtype: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ApplicationDefinition"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationDefinition"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -91,7 +91,7 @@ async def get( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -141,7 +141,7 @@ async def _delete_initial( if response.status_code not in [200, 202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -193,7 +193,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +217,10 @@ async def _create_or_update_initial( self, resource_group_name: str, application_definition_name: str, - parameters: "models.ApplicationDefinition", + parameters: "_models.ApplicationDefinition", **kwargs - ) -> "models.ApplicationDefinition": - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + ) -> "_models.ApplicationDefinition": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +256,7 @@ async def _create_or_update_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -269,9 +275,9 @@ async def begin_create_or_update( self, resource_group_name: str, application_definition_name: str, - parameters: "models.ApplicationDefinition", + parameters: "_models.ApplicationDefinition", **kwargs - ) -> AsyncLROPoller["models.ApplicationDefinition"]: + ) -> AsyncLROPoller["_models.ApplicationDefinition"]: """Creates a new managed application definition. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -292,7 +298,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -317,7 +323,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -335,7 +347,7 @@ def list_by_resource_group( self, resource_group_name: str, **kwargs - ) -> AsyncIterable["models.ApplicationDefinitionListResult"]: + ) -> AsyncIterable["_models.ApplicationDefinitionListResult"]: """Lists the managed application definitions in a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -345,7 +357,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -391,7 +403,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -404,22 +416,22 @@ async def get_next(next_link=None): async def get_by_id( self, - application_definition_id: str, + resource_group_name: str, + application_definition_name: str, **kwargs - ) -> Optional["models.ApplicationDefinition"]: + ) -> Optional["_models.ApplicationDefinition"]: """Gets the managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :keyword callable cls: A custom type or function that will be passed the direct response :return: ApplicationDefinition, or the result of cls(response) :rtype: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ApplicationDefinition"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationDefinition"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -430,7 +442,9 @@ async def get_by_id( # Construct URL url = self.get_by_id.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -448,7 +462,7 @@ async def get_by_id( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -459,11 +473,12 @@ async def get_by_id( return cls(pipeline_response, deserialized, {}) return deserialized - get_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + get_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore async def _delete_by_id_initial( self, - application_definition_id: str, + resource_group_name: str, + application_definition_name: str, **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -477,7 +492,9 @@ async def _delete_by_id_initial( # Construct URL url = self._delete_by_id_initial.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -495,26 +512,26 @@ async def _delete_by_id_initial( if response.status_code not in [200, 202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: return cls(pipeline_response, None, {}) - _delete_by_id_initial.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + _delete_by_id_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore async def begin_delete_by_id( self, - application_definition_id: str, + resource_group_name: str, + application_definition_name: str, **kwargs ) -> AsyncLROPoller[None]: """Deletes the managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -534,7 +551,8 @@ async def begin_delete_by_id( cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] if cont_token is None: raw_result = await self._delete_by_id_initial( - application_definition_id=application_definition_id, + resource_group_name=resource_group_name, + application_definition_name=application_definition_name, cls=lambda x,y,z: x, **kwargs ) @@ -546,7 +564,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -558,15 +582,16 @@ def get_long_running_output(pipeline_response): ) else: return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) - begin_delete_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + begin_delete_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore async def _create_or_update_by_id_initial( self, - application_definition_id: str, - parameters: "models.ApplicationDefinition", + resource_group_name: str, + application_definition_name: str, + parameters: "_models.ApplicationDefinition", **kwargs - ) -> "models.ApplicationDefinition": - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + ) -> "_models.ApplicationDefinition": + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -578,7 +603,9 @@ async def _create_or_update_by_id_initial( # Construct URL url = self._create_or_update_by_id_initial.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -600,7 +627,7 @@ async def _create_or_update_by_id_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -613,21 +640,21 @@ async def _create_or_update_by_id_initial( return cls(pipeline_response, deserialized, {}) return deserialized - _create_or_update_by_id_initial.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + _create_or_update_by_id_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore async def begin_create_or_update_by_id( self, - application_definition_id: str, - parameters: "models.ApplicationDefinition", + resource_group_name: str, + application_definition_name: str, + parameters: "_models.ApplicationDefinition", **kwargs - ) -> AsyncLROPoller["models.ApplicationDefinition"]: + ) -> AsyncLROPoller["_models.ApplicationDefinition"]: """Creates a new managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :param parameters: Parameters supplied to the create or update a managed application definition. :type parameters: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition @@ -642,7 +669,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -650,7 +677,8 @@ async def begin_create_or_update_by_id( cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] if cont_token is None: raw_result = await self._create_or_update_by_id_initial( - application_definition_id=application_definition_id, + resource_group_name=resource_group_name, + application_definition_name=application_definition_name, parameters=parameters, cls=lambda x,y,z: x, **kwargs @@ -666,7 +694,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -678,4 +712,4 @@ def get_long_running_output(pipeline_response): ) else: return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) - begin_create_or_update_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + begin_create_or_update_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_applications_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_applications_operations.py index f22c4d1b61a6..635a0db9297a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_applications_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/aio/operations/_applications_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ApplicationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -48,7 +48,7 @@ async def get( resource_group_name: str, application_name: str, **kwargs - ) -> Optional["models.Application"]: + ) -> Optional["_models.Application"]: """Gets the managed application. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -60,7 +60,7 @@ async def get( :rtype: ~azure.mgmt.resource.managedapplications.models.Application or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.Application"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Application"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -91,7 +91,7 @@ async def get( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -141,7 +141,7 @@ async def _delete_initial( if response.status_code not in [202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -193,7 +193,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationName': self._serialize.url("application_name", application_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +217,10 @@ async def _create_or_update_initial( self, resource_group_name: str, application_name: str, - parameters: "models.Application", + parameters: "_models.Application", **kwargs - ) -> "models.Application": - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + ) -> "_models.Application": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +256,7 @@ async def _create_or_update_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -269,9 +275,9 @@ async def begin_create_or_update( self, resource_group_name: str, application_name: str, - parameters: "models.Application", + parameters: "_models.Application", **kwargs - ) -> AsyncLROPoller["models.Application"]: + ) -> AsyncLROPoller["_models.Application"]: """Creates a new managed application. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -291,7 +297,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -316,7 +322,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationName': self._serialize.url("application_name", application_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -334,9 +346,9 @@ async def update( self, resource_group_name: str, application_name: str, - parameters: Optional["models.Application"] = None, + parameters: Optional["_models.ApplicationPatchable"] = None, **kwargs - ) -> "models.Application": + ) -> "_models.Application": """Updates an existing managed application. The only value that can be updated via PATCH currently is the tags. @@ -345,13 +357,13 @@ async def update( :param application_name: The name of the managed application. :type application_name: str :param parameters: Parameters supplied to update an existing managed application. - :type parameters: ~azure.mgmt.resource.managedapplications.models.Application + :type parameters: ~azure.mgmt.resource.managedapplications.models.ApplicationPatchable :keyword callable cls: A custom type or function that will be passed the direct response :return: Application, or the result of cls(response) :rtype: ~azure.mgmt.resource.managedapplications.models.Application :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -380,7 +392,7 @@ async def update( body_content_kwargs = {} # type: Dict[str, Any] if parameters is not None: - body_content = self._serialize.body(parameters, 'Application') + body_content = self._serialize.body(parameters, 'ApplicationPatchable') else: body_content = None body_content_kwargs['content'] = body_content @@ -390,7 +402,7 @@ async def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('Application', pipeline_response) @@ -405,7 +417,7 @@ def list_by_resource_group( self, resource_group_name: str, **kwargs - ) -> AsyncIterable["models.ApplicationListResult"]: + ) -> AsyncIterable["_models.ApplicationListResult"]: """Gets all the applications within a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -415,7 +427,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,7 +473,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -475,7 +487,7 @@ async def get_next(next_link=None): def list_by_subscription( self, **kwargs - ) -> AsyncIterable["models.ApplicationListResult"]: + ) -> AsyncIterable["_models.ApplicationListResult"]: """Gets all the applications within a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -483,7 +495,7 @@ def list_by_subscription( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -528,7 +540,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -543,7 +555,7 @@ async def get_by_id( self, application_id: str, **kwargs - ) -> Optional["models.Application"]: + ) -> Optional["_models.Application"]: """Gets the managed application. :param application_id: The fully qualified ID of the managed application, including the managed @@ -556,7 +568,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.managedapplications.models.Application or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.Application"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Application"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -585,7 +597,7 @@ async def get_by_id( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -632,7 +644,7 @@ async def _delete_by_id_initial( if response.status_code not in [202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -683,7 +695,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'applicationId': self._serialize.url("application_id", application_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -700,10 +716,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, application_id: str, - parameters: "models.Application", + parameters: "_models.Application", **kwargs - ) -> "models.Application": - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + ) -> "_models.Application": + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -737,7 +753,7 @@ async def _create_or_update_by_id_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -755,9 +771,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, application_id: str, - parameters: "models.Application", + parameters: "_models.Application", **kwargs - ) -> AsyncLROPoller["models.Application"]: + ) -> AsyncLROPoller["_models.Application"]: """Creates a new managed application. :param application_id: The fully qualified ID of the managed application, including the managed @@ -778,7 +794,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -802,7 +818,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'applicationId': self._serialize.url("application_id", application_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -819,9 +839,9 @@ def get_long_running_output(pipeline_response): async def update_by_id( self, application_id: str, - parameters: Optional["models.Application"] = None, + parameters: Optional["_models.Application"] = None, **kwargs - ) -> "models.Application": + ) -> "_models.Application": """Updates an existing managed application. The only value that can be updated via PATCH currently is the tags. @@ -837,7 +857,7 @@ async def update_by_id( :rtype: ~azure.mgmt.resource.managedapplications.models.Application :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -874,7 +894,7 @@ async def update_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('Application', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/__init__.py index b2c0a87c88db..d2be17a3e275 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/__init__.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/__init__.py @@ -17,6 +17,9 @@ from ._models_py3 import ErrorResponse from ._models_py3 import GenericResource from ._models_py3 import Identity + from ._models_py3 import Operation + from ._models_py3 import OperationDisplay + from ._models_py3 import OperationListResult from ._models_py3 import Plan from ._models_py3 import PlanPatchable from ._models_py3 import Resource @@ -32,6 +35,9 @@ from ._models import ErrorResponse # type: ignore from ._models import GenericResource # type: ignore from ._models import Identity # type: ignore + from ._models import Operation # type: ignore + from ._models import OperationDisplay # type: ignore + from ._models import OperationListResult # type: ignore from ._models import Plan # type: ignore from ._models import PlanPatchable # type: ignore from ._models import Resource # type: ignore @@ -54,6 +60,9 @@ 'ErrorResponse', 'GenericResource', 'Identity', + 'Operation', + 'OperationDisplay', + 'OperationListResult', 'Plan', 'PlanPatchable', 'Resource', diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models.py index 0e8ea174e497..9a195f33c16b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models.py @@ -537,6 +537,79 @@ def __init__( self.tenant_id = None +class Operation(msrest.serialization.Model): + """Microsoft.Solutions operation. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: The object that represents the operation. + :type display: ~azure.mgmt.resource.managedapplications.models.OperationDisplay + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + } + + def __init__( + self, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + + +class OperationDisplay(msrest.serialization.Model): + """The object that represents the operation. + + :param provider: Service provider: Microsoft.Solutions. + :type provider: str + :param resource: Resource on which the operation is performed: Application, JitRequest, etc. + :type resource: str + :param operation: Operation type: Read, write, delete, etc. + :type operation: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationDisplay, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + + +class OperationListResult(msrest.serialization.Model): + """Result of the request to list Microsoft.Solutions operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Microsoft.Solutions operations. + :type value: list[~azure.mgmt.resource.managedapplications.models.Operation] + :param next_link: URL to get the next set of operation list results if there are any. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Operation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + class Plan(msrest.serialization.Model): """Plan for the managed application. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models_py3.py index 3c2d2df62ec6..f41bbfe488e7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/models/_models_py3.py @@ -604,6 +604,89 @@ def __init__( self.tenant_id = None +class Operation(msrest.serialization.Model): + """Microsoft.Solutions operation. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: The object that represents the operation. + :type display: ~azure.mgmt.resource.managedapplications.models.OperationDisplay + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional["OperationDisplay"] = None, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = name + self.display = display + + +class OperationDisplay(msrest.serialization.Model): + """The object that represents the operation. + + :param provider: Service provider: Microsoft.Solutions. + :type provider: str + :param resource: Resource on which the operation is performed: Application, JitRequest, etc. + :type resource: str + :param operation: Operation type: Read, write, delete, etc. + :type operation: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + **kwargs + ): + super(OperationDisplay, self).__init__(**kwargs) + self.provider = provider + self.resource = resource + self.operation = operation + + +class OperationListResult(msrest.serialization.Model): + """Result of the request to list Microsoft.Solutions operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Microsoft.Solutions operations. + :type value: list[~azure.mgmt.resource.managedapplications.models.Operation] + :param next_link: URL to get the next set of operation list results if there are any. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Operation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Operation"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + class Plan(msrest.serialization.Model): """Plan for the managed application. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/__init__.py index cef7549ec472..76e2d17b2d58 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/__init__.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/__init__.py @@ -6,10 +6,12 @@ # Changes may cause incorrect behavior and will be lost if the code is regenerated. # -------------------------------------------------------------------------- +from ._application_client_operations import ApplicationClientOperationsMixin from ._applications_operations import ApplicationsOperations from ._application_definitions_operations import ApplicationDefinitionsOperations __all__ = [ + 'ApplicationClientOperationsMixin', 'ApplicationsOperations', 'ApplicationDefinitionsOperations', ] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_client_operations.py new file mode 100644 index 000000000000..d8a9ac5a4348 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_client_operations.py @@ -0,0 +1,89 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ApplicationClientOperationsMixin(object): + + def list_operations( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.OperationListResult"] + """Lists all of the available Microsoft.Solutions REST API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.managedapplications.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2018-06-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_operations.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_operations.metadata = {'url': '/providers/Microsoft.Solutions/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_definitions_operations.py index 9b6fadf88cf6..5584768187a8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_application_definitions_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ApplicationDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -53,7 +53,7 @@ def get( application_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.ApplicationDefinition"] + # type: (...) -> Optional["_models.ApplicationDefinition"] """Gets the managed application definition. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -65,7 +65,7 @@ def get( :rtype: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ApplicationDefinition"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationDefinition"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ def get( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -147,7 +147,7 @@ def _delete_initial( if response.status_code not in [200, 202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -200,7 +200,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +224,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str application_definition_name, # type: str - parameters, # type: "models.ApplicationDefinition" + parameters, # type: "_models.ApplicationDefinition" **kwargs # type: Any ): - # type: (...) -> "models.ApplicationDefinition" - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + # type: (...) -> "_models.ApplicationDefinition" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +264,7 @@ def _create_or_update_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -277,10 +283,10 @@ def begin_create_or_update( self, resource_group_name, # type: str application_definition_name, # type: str - parameters, # type: "models.ApplicationDefinition" + parameters, # type: "_models.ApplicationDefinition" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.ApplicationDefinition"] + # type: (...) -> LROPoller["_models.ApplicationDefinition"] """Creates a new managed application definition. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -301,7 +307,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -326,7 +332,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -345,7 +357,7 @@ def list_by_resource_group( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.ApplicationDefinitionListResult"] + # type: (...) -> Iterable["_models.ApplicationDefinitionListResult"] """Lists the managed application definitions in a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -355,7 +367,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -401,7 +413,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -414,23 +426,23 @@ def get_next(next_link=None): def get_by_id( self, - application_definition_id, # type: str + resource_group_name, # type: str + application_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.ApplicationDefinition"] + # type: (...) -> Optional["_models.ApplicationDefinition"] """Gets the managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :keyword callable cls: A custom type or function that will be passed the direct response :return: ApplicationDefinition, or the result of cls(response) :rtype: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ApplicationDefinition"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ApplicationDefinition"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -441,7 +453,9 @@ def get_by_id( # Construct URL url = self.get_by_id.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -459,7 +473,7 @@ def get_by_id( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -470,11 +484,12 @@ def get_by_id( return cls(pipeline_response, deserialized, {}) return deserialized - get_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + get_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore def _delete_by_id_initial( self, - application_definition_id, # type: str + resource_group_name, # type: str + application_definition_name, # type: str **kwargs # type: Any ): # type: (...) -> None @@ -489,7 +504,9 @@ def _delete_by_id_initial( # Construct URL url = self._delete_by_id_initial.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -507,27 +524,27 @@ def _delete_by_id_initial( if response.status_code not in [200, 202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: return cls(pipeline_response, None, {}) - _delete_by_id_initial.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + _delete_by_id_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore def begin_delete_by_id( self, - application_definition_id, # type: str + resource_group_name, # type: str + application_definition_name, # type: str **kwargs # type: Any ): # type: (...) -> LROPoller[None] """Deletes the managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -547,7 +564,8 @@ def begin_delete_by_id( cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] if cont_token is None: raw_result = self._delete_by_id_initial( - application_definition_id=application_definition_id, + resource_group_name=resource_group_name, + application_definition_name=application_definition_name, cls=lambda x,y,z: x, **kwargs ) @@ -559,7 +577,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -571,16 +595,17 @@ def get_long_running_output(pipeline_response): ) else: return LROPoller(self._client, raw_result, get_long_running_output, polling_method) - begin_delete_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + begin_delete_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore def _create_or_update_by_id_initial( self, - application_definition_id, # type: str - parameters, # type: "models.ApplicationDefinition" + resource_group_name, # type: str + application_definition_name, # type: str + parameters, # type: "_models.ApplicationDefinition" **kwargs # type: Any ): - # type: (...) -> "models.ApplicationDefinition" - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + # type: (...) -> "_models.ApplicationDefinition" + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -592,7 +617,9 @@ def _create_or_update_by_id_initial( # Construct URL url = self._create_or_update_by_id_initial.metadata['url'] # type: ignore path_format_arguments = { - 'applicationDefinitionId': self._serialize.url("application_definition_id", application_definition_id, 'str', skip_quote=True), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), } url = self._client.format_url(url, **path_format_arguments) @@ -614,7 +641,7 @@ def _create_or_update_by_id_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -627,22 +654,22 @@ def _create_or_update_by_id_initial( return cls(pipeline_response, deserialized, {}) return deserialized - _create_or_update_by_id_initial.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + _create_or_update_by_id_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore def begin_create_or_update_by_id( self, - application_definition_id, # type: str - parameters, # type: "models.ApplicationDefinition" + resource_group_name, # type: str + application_definition_name, # type: str + parameters, # type: "_models.ApplicationDefinition" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.ApplicationDefinition"] + # type: (...) -> LROPoller["_models.ApplicationDefinition"] """Creates a new managed application definition. - :param application_definition_id: The fully qualified ID of the managed application definition, - including the managed application name and the managed application definition resource type. - Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- - name}/Microsoft.Solutions/applicationDefinitions/{applicationDefinition-name}. - :type application_definition_id: str + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param application_definition_name: The name of the managed application definition. + :type application_definition_name: str :param parameters: Parameters supplied to the create or update a managed application definition. :type parameters: ~azure.mgmt.resource.managedapplications.models.ApplicationDefinition @@ -657,7 +684,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationDefinition"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -665,7 +692,8 @@ def begin_create_or_update_by_id( cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] if cont_token is None: raw_result = self._create_or_update_by_id_initial( - application_definition_id=application_definition_id, + resource_group_name=resource_group_name, + application_definition_name=application_definition_name, parameters=parameters, cls=lambda x,y,z: x, **kwargs @@ -681,7 +709,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationDefinitionName': self._serialize.url("application_definition_name", application_definition_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -693,4 +727,4 @@ def get_long_running_output(pipeline_response): ) else: return LROPoller(self._client, raw_result, get_long_running_output, polling_method) - begin_create_or_update_by_id.metadata = {'url': '/{applicationDefinitionId}'} # type: ignore + begin_create_or_update_by_id.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Solutions/applicationDefinitions/{applicationDefinitionName}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_applications_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_applications_operations.py index 4cb8447bf250..04723a37bf03 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_applications_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/managedapplications/operations/_applications_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ApplicationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -53,7 +53,7 @@ def get( application_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.Application"] + # type: (...) -> Optional["_models.Application"] """Gets the managed application. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -65,7 +65,7 @@ def get( :rtype: ~azure.mgmt.resource.managedapplications.models.Application or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.Application"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Application"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ def get( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -147,7 +147,7 @@ def _delete_initial( if response.status_code not in [202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -200,7 +200,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationName': self._serialize.url("application_name", application_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +224,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str application_name, # type: str - parameters, # type: "models.Application" + parameters, # type: "_models.Application" **kwargs # type: Any ): - # type: (...) -> "models.Application" - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + # type: (...) -> "_models.Application" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +264,7 @@ def _create_or_update_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -277,10 +283,10 @@ def begin_create_or_update( self, resource_group_name, # type: str application_name, # type: str - parameters, # type: "models.Application" + parameters, # type: "_models.Application" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.Application"] + # type: (...) -> LROPoller["_models.Application"] """Creates a new managed application. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -300,7 +306,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -325,7 +331,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'applicationName': self._serialize.url("application_name", application_name, 'str', max_length=64, min_length=3), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -343,10 +355,10 @@ def update( self, resource_group_name, # type: str application_name, # type: str - parameters=None, # type: Optional["models.Application"] + parameters=None, # type: Optional["_models.ApplicationPatchable"] **kwargs # type: Any ): - # type: (...) -> "models.Application" + # type: (...) -> "_models.Application" """Updates an existing managed application. The only value that can be updated via PATCH currently is the tags. @@ -355,13 +367,13 @@ def update( :param application_name: The name of the managed application. :type application_name: str :param parameters: Parameters supplied to update an existing managed application. - :type parameters: ~azure.mgmt.resource.managedapplications.models.Application + :type parameters: ~azure.mgmt.resource.managedapplications.models.ApplicationPatchable :keyword callable cls: A custom type or function that will be passed the direct response :return: Application, or the result of cls(response) :rtype: ~azure.mgmt.resource.managedapplications.models.Application :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -390,7 +402,7 @@ def update( body_content_kwargs = {} # type: Dict[str, Any] if parameters is not None: - body_content = self._serialize.body(parameters, 'Application') + body_content = self._serialize.body(parameters, 'ApplicationPatchable') else: body_content = None body_content_kwargs['content'] = body_content @@ -400,7 +412,7 @@ def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('Application', pipeline_response) @@ -416,7 +428,7 @@ def list_by_resource_group( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.ApplicationListResult"] + # type: (...) -> Iterable["_models.ApplicationListResult"] """Gets all the applications within a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -426,7 +438,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -472,7 +484,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -487,7 +499,7 @@ def list_by_subscription( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.ApplicationListResult"] + # type: (...) -> Iterable["_models.ApplicationListResult"] """Gets all the applications within a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -495,7 +507,7 @@ def list_by_subscription( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.managedapplications.models.ApplicationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ApplicationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ApplicationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -540,7 +552,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -556,7 +568,7 @@ def get_by_id( application_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.Application"] + # type: (...) -> Optional["_models.Application"] """Gets the managed application. :param application_id: The fully qualified ID of the managed application, including the managed @@ -569,7 +581,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.managedapplications.models.Application or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.Application"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.Application"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -598,7 +610,7 @@ def get_by_id( if response.status_code not in [200, 404]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -646,7 +658,7 @@ def _delete_by_id_initial( if response.status_code not in [202, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -698,7 +710,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'applicationId': self._serialize.url("application_id", application_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -715,11 +731,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, application_id, # type: str - parameters, # type: "models.Application" + parameters, # type: "_models.Application" **kwargs # type: Any ): - # type: (...) -> "models.Application" - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + # type: (...) -> "_models.Application" + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -753,7 +769,7 @@ def _create_or_update_by_id_initial( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -771,10 +787,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, application_id, # type: str - parameters, # type: "models.Application" + parameters, # type: "_models.Application" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.Application"] + # type: (...) -> LROPoller["_models.Application"] """Creates a new managed application. :param application_id: The fully qualified ID of the managed application, including the managed @@ -795,7 +811,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -819,7 +835,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'applicationId': self._serialize.url("application_id", application_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -836,10 +856,10 @@ def get_long_running_output(pipeline_response): def update_by_id( self, application_id, # type: str - parameters=None, # type: Optional["models.Application"] + parameters=None, # type: Optional["_models.Application"] **kwargs # type: Any ): - # type: (...) -> "models.Application" + # type: (...) -> "_models.Application" """Updates an existing managed application. The only value that can be updated via PATCH currently is the tags. @@ -855,7 +875,7 @@ def update_by_id( :rtype: ~azure.mgmt.resource.managedapplications.models.Application :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Application"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Application"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -892,7 +912,7 @@ def update_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('Application', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_policy_client.py index b8c0d99385e4..7506e3b9a468 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_policy_client.py @@ -45,7 +45,7 @@ class PolicyClient(MultiApiClientMixin, _SDKClient): :type profile: azure.profiles.KnownProfiles """ - DEFAULT_API_VERSION = '2019-09-01' + DEFAULT_API_VERSION = '2020-09-01' _PROFILE_TAG = "azure.mgmt.resource.PolicyClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -89,6 +89,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2019-01-01: :mod:`v2019_01_01.models` * 2019-06-01: :mod:`v2019_06_01.models` * 2019-09-01: :mod:`v2019_09_01.models` + * 2020-09-01: :mod:`v2020_09_01.models` """ if api_version == '2015-10-01-preview': from .v2015_10_01_preview import models @@ -117,8 +118,24 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2019-09-01': from .v2019_09_01 import models return models + elif api_version == '2020-09-01': + from .v2020_09_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) + @property + def data_policy_manifests(self): + """Instance depends on the API version: + + * 2020-09-01: :class:`DataPolicyManifestsOperations` + """ + api_version = self._get_api_version('data_policy_manifests') + if api_version == '2020-09-01': + from .v2020_09_01.operations import DataPolicyManifestsOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'data_policy_manifests'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def policy_assignments(self): """Instance depends on the API version: @@ -132,6 +149,7 @@ def policy_assignments(self): * 2019-01-01: :class:`PolicyAssignmentsOperations` * 2019-06-01: :class:`PolicyAssignmentsOperations` * 2019-09-01: :class:`PolicyAssignmentsOperations` + * 2020-09-01: :class:`PolicyAssignmentsOperations` """ api_version = self._get_api_version('policy_assignments') if api_version == '2015-10-01-preview': @@ -152,6 +170,8 @@ def policy_assignments(self): from .v2019_06_01.operations import PolicyAssignmentsOperations as OperationClass elif api_version == '2019-09-01': from .v2019_09_01.operations import PolicyAssignmentsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import PolicyAssignmentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_assignments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -169,6 +189,7 @@ def policy_definitions(self): * 2019-01-01: :class:`PolicyDefinitionsOperations` * 2019-06-01: :class:`PolicyDefinitionsOperations` * 2019-09-01: :class:`PolicyDefinitionsOperations` + * 2020-09-01: :class:`PolicyDefinitionsOperations` """ api_version = self._get_api_version('policy_definitions') if api_version == '2015-10-01-preview': @@ -189,10 +210,25 @@ def policy_definitions(self): from .v2019_06_01.operations import PolicyDefinitionsOperations as OperationClass elif api_version == '2019-09-01': from .v2019_09_01.operations import PolicyDefinitionsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import PolicyDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def policy_exemptions(self): + """Instance depends on the API version: + + * 2020-09-01: :class:`PolicyExemptionsOperations` + """ + api_version = self._get_api_version('policy_exemptions') + if api_version == '2020-09-01': + from .v2020_09_01.operations import PolicyExemptionsOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'policy_exemptions'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def policy_set_definitions(self): """Instance depends on the API version: @@ -203,6 +239,7 @@ def policy_set_definitions(self): * 2019-01-01: :class:`PolicySetDefinitionsOperations` * 2019-06-01: :class:`PolicySetDefinitionsOperations` * 2019-09-01: :class:`PolicySetDefinitionsOperations` + * 2020-09-01: :class:`PolicySetDefinitionsOperations` """ api_version = self._get_api_version('policy_set_definitions') if api_version == '2017-06-01-preview': @@ -217,6 +254,8 @@ def policy_set_definitions(self): from .v2019_06_01.operations import PolicySetDefinitionsOperations as OperationClass elif api_version == '2019-09-01': from .v2019_09_01.operations import PolicySetDefinitionsOperations as OperationClass + elif api_version == '2020-09-01': + from .v2020_09_01.operations import PolicySetDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_set_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/aio/_policy_client.py index 5e28000f1cad..2fcbf95232bd 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/aio/_policy_client.py @@ -45,7 +45,7 @@ class PolicyClient(MultiApiClientMixin, _SDKClient): :type profile: azure.profiles.KnownProfiles """ - DEFAULT_API_VERSION = '2019-09-01' + DEFAULT_API_VERSION = '2020-09-01' _PROFILE_TAG = "azure.mgmt.resource.PolicyClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -89,6 +89,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2019-01-01: :mod:`v2019_01_01.models` * 2019-06-01: :mod:`v2019_06_01.models` * 2019-09-01: :mod:`v2019_09_01.models` + * 2020-09-01: :mod:`v2020_09_01.models` """ if api_version == '2015-10-01-preview': from ..v2015_10_01_preview import models @@ -117,8 +118,24 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2019-09-01': from ..v2019_09_01 import models return models + elif api_version == '2020-09-01': + from ..v2020_09_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) + @property + def data_policy_manifests(self): + """Instance depends on the API version: + + * 2020-09-01: :class:`DataPolicyManifestsOperations` + """ + api_version = self._get_api_version('data_policy_manifests') + if api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import DataPolicyManifestsOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'data_policy_manifests'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def policy_assignments(self): """Instance depends on the API version: @@ -132,6 +149,7 @@ def policy_assignments(self): * 2019-01-01: :class:`PolicyAssignmentsOperations` * 2019-06-01: :class:`PolicyAssignmentsOperations` * 2019-09-01: :class:`PolicyAssignmentsOperations` + * 2020-09-01: :class:`PolicyAssignmentsOperations` """ api_version = self._get_api_version('policy_assignments') if api_version == '2015-10-01-preview': @@ -152,6 +170,8 @@ def policy_assignments(self): from ..v2019_06_01.aio.operations import PolicyAssignmentsOperations as OperationClass elif api_version == '2019-09-01': from ..v2019_09_01.aio.operations import PolicyAssignmentsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import PolicyAssignmentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_assignments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -169,6 +189,7 @@ def policy_definitions(self): * 2019-01-01: :class:`PolicyDefinitionsOperations` * 2019-06-01: :class:`PolicyDefinitionsOperations` * 2019-09-01: :class:`PolicyDefinitionsOperations` + * 2020-09-01: :class:`PolicyDefinitionsOperations` """ api_version = self._get_api_version('policy_definitions') if api_version == '2015-10-01-preview': @@ -189,10 +210,25 @@ def policy_definitions(self): from ..v2019_06_01.aio.operations import PolicyDefinitionsOperations as OperationClass elif api_version == '2019-09-01': from ..v2019_09_01.aio.operations import PolicyDefinitionsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import PolicyDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def policy_exemptions(self): + """Instance depends on the API version: + + * 2020-09-01: :class:`PolicyExemptionsOperations` + """ + api_version = self._get_api_version('policy_exemptions') + if api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import PolicyExemptionsOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'policy_exemptions'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def policy_set_definitions(self): """Instance depends on the API version: @@ -203,6 +239,7 @@ def policy_set_definitions(self): * 2019-01-01: :class:`PolicySetDefinitionsOperations` * 2019-06-01: :class:`PolicySetDefinitionsOperations` * 2019-09-01: :class:`PolicySetDefinitionsOperations` + * 2020-09-01: :class:`PolicySetDefinitionsOperations` """ api_version = self._get_api_version('policy_set_definitions') if api_version == '2017-06-01-preview': @@ -217,6 +254,8 @@ def policy_set_definitions(self): from ..v2019_06_01.aio.operations import PolicySetDefinitionsOperations as OperationClass elif api_version == '2019-09-01': from ..v2019_09_01.aio.operations import PolicySetDefinitionsOperations as OperationClass + elif api_version == '2020-09-01': + from ..v2020_09_01.aio.operations import PolicySetDefinitionsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'policy_set_definitions'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/models.py index 1d5d79558e5e..5ed8fbe3db24 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/models.py @@ -4,4 +4,4 @@ # Licensed under the MIT License. See License.txt in the project root for # license information. # -------------------------------------------------------------------------- -from .v2019_09_01.models import * +from .v2020_09_01.models import * diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_metadata.json index 43d7bb0aeba2..bcd17ea3d8af 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_policy_client.py index 4fc0c187ca77..bfc49a81b53d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/_policy_client.py index 268ca149cdd5..5fa3545e4654 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/_policy_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_assignments_operations.py index ed44cb1d12ab..fe6faa8755aa 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -58,7 +58,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -102,9 +102,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -121,7 +121,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -171,7 +171,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -183,7 +183,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -228,7 +228,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -240,7 +240,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -307,7 +307,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -328,7 +328,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -394,7 +394,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -404,7 +404,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -481,7 +481,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -523,9 +523,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -545,7 +545,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -593,7 +593,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -609,7 +609,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_definitions_operations.py index 540dcb9de37b..31e67ce125fe 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -58,7 +58,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -156,7 +156,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -166,7 +166,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -210,7 +210,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription. :param filter: The filter to apply on the operation. @@ -220,7 +220,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_assignments_operations.py index 88908eb437ca..a06c6a41f9c6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -63,7 +63,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -107,10 +107,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -127,7 +127,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -190,7 +190,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -236,7 +236,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -248,7 +248,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -316,7 +316,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -337,7 +337,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -404,7 +404,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -414,7 +414,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -476,7 +476,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -492,7 +492,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,10 +534,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -557,7 +557,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -606,7 +606,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -622,7 +622,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_definitions_operations.py index f66575aae022..4f62c3d1a733 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2015_10_01_preview/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -63,7 +63,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -163,7 +163,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -173,7 +173,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,7 +218,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription. :param filter: The filter to apply on the operation. @@ -228,7 +228,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2015_10_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_metadata.json index 507386d197bc..ad24b89a34bc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_policy_client.py index 8d31aeb882c3..a69637331906 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/_policy_client.py index ee98427879c7..ae6342b6fd99 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/_policy_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_assignments_operations.py index 5f197183f71d..d069efe85462 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -58,7 +58,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -102,9 +102,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -121,7 +121,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -171,7 +171,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -183,7 +183,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -228,7 +228,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -240,7 +240,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -307,7 +307,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -328,7 +328,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -394,7 +394,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -404,7 +404,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -481,7 +481,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -523,9 +523,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -545,7 +545,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -593,7 +593,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -609,7 +609,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_definitions_operations.py index c6d20f561bd5..140aafef0f63 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -58,7 +58,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -156,7 +156,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -166,7 +166,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -210,7 +210,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription. :param filter: The filter to apply on the operation. @@ -220,7 +220,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_assignments_operations.py index e998108b896c..8228a187d963 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -63,7 +63,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -107,10 +107,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -127,7 +127,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -190,7 +190,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -236,7 +236,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -248,7 +248,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -316,7 +316,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -337,7 +337,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -404,7 +404,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -414,7 +414,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -476,7 +476,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -492,7 +492,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,10 +534,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -557,7 +557,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -606,7 +606,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -622,7 +622,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_definitions_operations.py index b9b1c7ca694a..55da28e0c31e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_04_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -63,7 +63,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -163,7 +163,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -173,7 +173,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,7 +218,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription. :param filter: The filter to apply on the operation. @@ -228,7 +228,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_04_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_metadata.json index b84ac8cb468d..b47bdbc65b46 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_policy_client.py index ff320276c680..0ccc1be9fe8f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_definitions = PolicyDefinitionsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/_policy_client.py index efd6c5380f66..ca5c4130ed6a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/_policy_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_definitions = PolicyDefinitionsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_assignments_operations.py index 12336f35db41..9618082b2313 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -58,7 +58,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -104,9 +104,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -123,7 +123,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -173,7 +173,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -185,7 +185,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -230,7 +230,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -242,7 +242,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -309,7 +309,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -330,7 +330,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -396,7 +396,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -406,7 +406,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -467,7 +467,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -483,7 +483,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,9 +525,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -547,7 +547,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -595,7 +595,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -611,7 +611,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_definitions_operations.py index 304bf5138a89..57877e707864 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -58,7 +58,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -156,7 +156,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -166,7 +166,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -210,7 +210,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the built in policy definition. :param policy_definition_name: The name of the built in policy definition to get. @@ -220,7 +220,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -263,9 +263,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition at management group level. :param policy_definition_name: The name of the policy definition to create. @@ -279,7 +279,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -381,7 +381,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition at management group level. :param policy_definition_name: The name of the policy definition to get. @@ -393,7 +393,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -436,7 +436,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -444,7 +444,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -502,7 +502,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the built in policy definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -510,7 +510,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -565,7 +565,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription at management group level. :param management_group_id: The ID of the management group. @@ -575,7 +575,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_assignments_operations.py index c9ab58d9a3c3..cae1b440a511 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -63,7 +63,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -109,10 +109,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -129,7 +129,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -180,7 +180,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -192,7 +192,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -238,7 +238,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -250,7 +250,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -318,7 +318,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -339,7 +339,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -406,7 +406,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -416,7 +416,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -478,7 +478,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -494,7 +494,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -536,10 +536,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -559,7 +559,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -608,7 +608,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -624,7 +624,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_definitions_operations.py index f7d51125c258..f32fff4d2fb3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2016_12_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -63,7 +63,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -163,7 +163,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -173,7 +173,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,7 +218,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the built in policy definition. :param policy_definition_name: The name of the built in policy definition to get. @@ -228,7 +228,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -271,10 +271,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition at management group level. :param policy_definition_name: The name of the policy definition to create. @@ -288,7 +288,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -392,7 +392,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition at management group level. :param policy_definition_name: The name of the policy definition to get. @@ -404,7 +404,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -448,7 +448,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -456,7 +456,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -515,7 +515,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the built in policy definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -523,7 +523,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -579,7 +579,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription at management group level. :param management_group_id: The ID of the management group. @@ -589,7 +589,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2016_12_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_metadata.json index 09829ebf03a0..2f993df26736 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_policy_client.py index 70d2e76852d8..8ee98c4dd70b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/_policy_client.py index 93a049550e61..231e4ca7569d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_assignments_operations.py index 09a2a9ab3d60..7f88fae672d1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -58,7 +58,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -88,7 +88,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -105,9 +105,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -124,7 +124,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -159,7 +159,7 @@ async def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -175,7 +175,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -187,7 +187,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -217,7 +217,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -233,7 +233,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -245,7 +245,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -293,7 +293,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -313,7 +313,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -334,7 +334,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -386,7 +386,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -401,7 +401,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -411,7 +411,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -458,7 +458,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -473,7 +473,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -489,7 +489,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -518,7 +518,7 @@ async def delete_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -532,9 +532,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -554,7 +554,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -588,7 +588,7 @@ async def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -603,7 +603,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -619,7 +619,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -648,7 +648,7 @@ async def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_definitions_operations.py index 07528b9d3568..7bfcc79a8164 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -58,7 +58,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -156,7 +156,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -166,7 +166,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -210,7 +210,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the built in policy definition. :param policy_definition_name: The name of the built in policy definition to get. @@ -220,7 +220,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -263,9 +263,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition at management group level. :param policy_definition_name: The name of the policy definition to create. @@ -279,7 +279,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -381,7 +381,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Gets the policy definition at management group level. :param policy_definition_name: The name of the policy definition to get. @@ -393,7 +393,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -436,7 +436,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -444,7 +444,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -502,7 +502,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the built in policy definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -510,7 +510,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -565,7 +565,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Gets all the policy definitions for a subscription at management group level. :param management_group_id: The ID of the management group. @@ -575,7 +575,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_set_definitions_operations.py index a375c50f820c..9b97fe2d421c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. :param policy_set_definition_name: The name of the policy set definition to create. @@ -58,7 +58,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -93,7 +93,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -152,7 +152,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -164,7 +164,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Gets the policy set definition. :param policy_set_definition_name: The name of the policy set definition to get. @@ -174,7 +174,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -204,7 +204,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -219,7 +219,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Gets the built in policy set definition. :param policy_set_definition_name: The name of the policy set definition to get. @@ -229,7 +229,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +258,7 @@ async def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -272,7 +272,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Gets all the policy set definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,7 +325,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -339,7 +339,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Gets all the built in policy set definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -347,7 +347,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -403,9 +403,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition at management group level. :param policy_set_definition_name: The name of the policy set definition to create. @@ -419,7 +419,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -454,7 +454,7 @@ async def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -516,7 +516,7 @@ async def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -529,7 +529,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Gets the policy set definition at management group level. :param policy_set_definition_name: The name of the policy set definition to get. @@ -541,7 +541,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -571,7 +571,7 @@ async def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -586,7 +586,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Gets all the policy set definitions for a subscription at management group. :param management_group_id: The ID of the management group. @@ -596,7 +596,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -641,7 +641,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_assignments_operations.py index 238fbba7a796..f55114ca39f3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. :param scope: The scope of the policy assignment. @@ -63,7 +63,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -93,7 +93,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -110,10 +110,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -130,7 +130,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -165,7 +165,7 @@ def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -182,7 +182,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment. :param scope: The scope of the policy assignment. @@ -194,7 +194,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -224,7 +224,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -241,7 +241,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for the resource group. :param resource_group_name: The name of the resource group that contains policy assignments. @@ -253,7 +253,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -301,7 +301,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -322,7 +322,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets policy assignments for a resource. :param resource_group_name: The name of the resource group containing the resource. The name is @@ -343,7 +343,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,7 +395,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -411,7 +411,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Gets all the policy assignments for a subscription. :param filter: The filter to apply on the operation. @@ -421,7 +421,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -468,7 +468,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -484,7 +484,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Deletes a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -500,7 +500,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -529,7 +529,7 @@ def delete_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -543,10 +543,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates a policy assignment by ID. Policy assignments are inherited by child resources. For example, when you apply a policy to a @@ -566,7 +566,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -616,7 +616,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Gets a policy assignment by ID. When providing a scope for the assignment, use '/subscriptions/{subscription-id}/' for @@ -632,7 +632,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -661,7 +661,7 @@ def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_definitions_operations.py index 0f54d769c025..de7afdbc1538 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition. :param policy_definition_name: The name of the policy definition to create. @@ -63,7 +63,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -163,7 +163,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition. :param policy_definition_name: The name of the policy definition to get. @@ -173,7 +173,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,7 +218,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the built in policy definition. :param policy_definition_name: The name of the built in policy definition to get. @@ -228,7 +228,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -271,10 +271,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition at management group level. :param policy_definition_name: The name of the policy definition to create. @@ -288,7 +288,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -392,7 +392,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Gets the policy definition at management group level. :param policy_definition_name: The name of the policy definition to get. @@ -404,7 +404,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -448,7 +448,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -456,7 +456,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -515,7 +515,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the built in policy definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -523,7 +523,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -579,7 +579,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Gets all the policy definitions for a subscription at management group level. :param management_group_id: The ID of the management group. @@ -589,7 +589,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_set_definitions_operations.py index b4caecdcd46f..61f35e603075 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2017_06_01_preview/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. :param policy_set_definition_name: The name of the policy set definition to create. @@ -63,7 +63,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -98,7 +98,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -158,7 +158,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -171,7 +171,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Gets the policy set definition. :param policy_set_definition_name: The name of the policy set definition to get. @@ -181,7 +181,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -211,7 +211,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -227,7 +227,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Gets the built in policy set definition. :param policy_set_definition_name: The name of the policy set definition to get. @@ -237,7 +237,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -266,7 +266,7 @@ def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Gets all the policy set definitions for a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -334,7 +334,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -349,7 +349,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Gets all the built in policy set definitions. :keyword callable cls: A custom type or function that will be passed the direct response @@ -357,7 +357,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -398,7 +398,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -413,10 +413,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition at management group level. :param policy_set_definition_name: The name of the policy set definition to create. @@ -430,7 +430,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -528,7 +528,7 @@ def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -542,7 +542,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Gets the policy set definition at management group level. :param policy_set_definition_name: The name of the policy set definition to get. @@ -554,7 +554,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -584,7 +584,7 @@ def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -600,7 +600,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Gets all the policy set definitions for a subscription at management group. :param management_group_id: The ID of the management group. @@ -610,7 +610,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2017_06_01_preview.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -655,7 +655,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_metadata.json index 2d86e0438c3c..17a6c2bb66a3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_policy_client.py index cb421154e07f..18329797b522 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/_policy_client.py index c3a2b2f9774b..748d669c533f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_assignments_operations.py index cacc69b36afc..34f7b45ad0e6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -66,7 +66,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -113,9 +113,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -137,7 +137,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -172,7 +172,7 @@ async def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -188,7 +188,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -207,7 +207,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -237,7 +237,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -253,7 +253,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -277,7 +277,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,7 +325,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -345,7 +345,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -391,7 +391,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -443,7 +443,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -458,7 +458,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -480,7 +480,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -527,7 +527,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -542,7 +542,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -561,7 +561,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ async def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -606,9 +606,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -632,7 +632,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -666,7 +666,7 @@ async def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -681,7 +681,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -701,7 +701,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,7 +730,7 @@ async def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_definitions_operations.py index 0aaa9d714ae2..f7e4014b60ac 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -173,7 +173,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -217,7 +217,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -229,7 +229,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,9 +272,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -291,7 +291,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,7 +395,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -410,7 +410,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,7 +453,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -463,7 +463,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +521,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -531,7 +531,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -586,7 +586,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -598,7 +598,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_set_definitions_operations.py index 5c4270678a60..d45f63c03fa5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -157,7 +157,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -169,7 +169,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -182,7 +182,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -212,7 +212,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -227,7 +227,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -239,7 +239,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -268,7 +268,7 @@ async def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -282,7 +282,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -292,7 +292,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -337,7 +337,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -351,7 +351,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -361,7 +361,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -402,7 +402,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -417,9 +417,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -436,7 +436,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -471,7 +471,7 @@ async def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -536,7 +536,7 @@ async def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -549,7 +549,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -564,7 +564,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -594,7 +594,7 @@ async def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -609,7 +609,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -622,7 +622,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -667,7 +667,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_assignments_operations.py index 10faf52ff32a..1051feaddef4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -71,7 +71,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -118,10 +118,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -143,7 +143,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -195,7 +195,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -214,7 +214,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -261,7 +261,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -285,7 +285,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -333,7 +333,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -354,7 +354,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -400,7 +400,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -452,7 +452,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -468,7 +468,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -490,7 +490,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -537,7 +537,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -553,7 +553,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -572,7 +572,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -601,7 +601,7 @@ def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -617,10 +617,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -644,7 +644,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -678,7 +678,7 @@ def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -694,7 +694,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -714,7 +714,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -743,7 +743,7 @@ def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_definitions_operations.py index 7ff946c47eaa..24d8c8df9146 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -168,7 +168,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -180,7 +180,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +225,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -237,7 +237,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -280,10 +280,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -300,7 +300,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -406,7 +406,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -421,7 +421,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -475,7 +475,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +534,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -544,7 +544,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -612,7 +612,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_set_definitions_operations.py index b5181953c6f5..6ba8d3a2c859 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_03_01/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -163,7 +163,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -176,7 +176,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -189,7 +189,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -219,7 +219,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -235,7 +235,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -247,7 +247,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -291,7 +291,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -301,7 +301,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -346,7 +346,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -361,7 +361,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -371,7 +371,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -412,7 +412,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -427,10 +427,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -447,7 +447,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -482,7 +482,7 @@ def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -548,7 +548,7 @@ def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -562,7 +562,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -577,7 +577,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -607,7 +607,7 @@ def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -623,7 +623,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -636,7 +636,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_03_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -681,7 +681,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_metadata.json index 8fdf1d3988df..88c6acbd20b5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_policy_client.py index cb99f878b5e4..16378c46b3c8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/_policy_client.py index 66d70eb88743..fd24a2cb9178 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_assignments_operations.py index 4fa693da3e0e..cc304a506aa7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -66,7 +66,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -113,9 +113,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -137,7 +137,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -172,7 +172,7 @@ async def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -188,7 +188,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -207,7 +207,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -237,7 +237,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -253,7 +253,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -277,7 +277,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,7 +325,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -345,7 +345,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -391,7 +391,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -443,7 +443,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -458,7 +458,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -480,7 +480,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -527,7 +527,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -542,7 +542,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -561,7 +561,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ async def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -606,9 +606,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -632,7 +632,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -666,7 +666,7 @@ async def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -681,7 +681,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -701,7 +701,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,7 +730,7 @@ async def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_definitions_operations.py index 30d0150d5a99..59d0c856b518 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -173,7 +173,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -217,7 +217,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -229,7 +229,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,9 +272,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -291,7 +291,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,7 +395,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -410,7 +410,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,7 +453,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -463,7 +463,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +521,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -531,7 +531,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -586,7 +586,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -598,7 +598,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_set_definitions_operations.py index c1803dd257c7..06c59831d240 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -157,7 +157,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -169,7 +169,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -182,7 +182,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -212,7 +212,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -227,7 +227,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -239,7 +239,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -268,7 +268,7 @@ async def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -282,7 +282,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -292,7 +292,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -337,7 +337,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -351,7 +351,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -361,7 +361,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -402,7 +402,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -417,9 +417,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -436,7 +436,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -471,7 +471,7 @@ async def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -536,7 +536,7 @@ async def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -549,7 +549,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -564,7 +564,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -594,7 +594,7 @@ async def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -609,7 +609,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -622,7 +622,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -667,7 +667,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_assignments_operations.py index 7592eee1bd7d..d145b764f0a3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -71,7 +71,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -118,10 +118,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -143,7 +143,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -195,7 +195,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -214,7 +214,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -261,7 +261,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -285,7 +285,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -333,7 +333,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -354,7 +354,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -400,7 +400,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -452,7 +452,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -468,7 +468,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -490,7 +490,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -537,7 +537,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -553,7 +553,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -572,7 +572,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -601,7 +601,7 @@ def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -617,10 +617,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -644,7 +644,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -678,7 +678,7 @@ def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -694,7 +694,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -714,7 +714,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -743,7 +743,7 @@ def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_definitions_operations.py index 7c918ab0010c..85795154d776 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -168,7 +168,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -180,7 +180,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +225,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -237,7 +237,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -280,10 +280,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -300,7 +300,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -406,7 +406,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -421,7 +421,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -475,7 +475,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +534,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -544,7 +544,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -612,7 +612,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_set_definitions_operations.py index 81c46c2ce52d..44d58feb2f2a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2018_05_01/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -163,7 +163,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -176,7 +176,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -189,7 +189,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -219,7 +219,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -235,7 +235,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -247,7 +247,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -291,7 +291,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -301,7 +301,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -346,7 +346,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -361,7 +361,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -371,7 +371,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -412,7 +412,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -427,10 +427,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -447,7 +447,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -482,7 +482,7 @@ def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -548,7 +548,7 @@ def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -562,7 +562,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -577,7 +577,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -607,7 +607,7 @@ def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -623,7 +623,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -636,7 +636,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2018_05_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -681,7 +681,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_metadata.json index 57da98c6b9e2..86b2c03e2457 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_policy_client.py index 5d28d166fab0..939cfda595fb 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/_policy_client.py index 82d046c3996c..21c4a89a0a48 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_assignments_operations.py index 15983474c514..02483f424a65 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -66,7 +66,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -113,9 +113,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -137,7 +137,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -172,7 +172,7 @@ async def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -188,7 +188,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -207,7 +207,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -237,7 +237,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -253,7 +253,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -277,7 +277,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,7 +325,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -345,7 +345,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -391,7 +391,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -443,7 +443,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -458,7 +458,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -480,7 +480,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -527,7 +527,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -542,7 +542,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -561,7 +561,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ async def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -606,9 +606,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -632,7 +632,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -666,7 +666,7 @@ async def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -681,7 +681,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -701,7 +701,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,7 +730,7 @@ async def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_definitions_operations.py index ba4753264dbf..ef72c9e8cf0a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -173,7 +173,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -217,7 +217,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -229,7 +229,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,9 +272,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -291,7 +291,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,7 +395,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -410,7 +410,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,7 +453,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -463,7 +463,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +521,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -531,7 +531,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -586,7 +586,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -598,7 +598,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_set_definitions_operations.py index 8588367bb3ee..7d07adc9525a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -157,7 +157,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -169,7 +169,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -182,7 +182,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -212,7 +212,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -227,7 +227,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -239,7 +239,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -268,7 +268,7 @@ async def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -282,7 +282,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -292,7 +292,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -337,7 +337,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -351,7 +351,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -361,7 +361,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -402,7 +402,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -417,9 +417,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -436,7 +436,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -471,7 +471,7 @@ async def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -536,7 +536,7 @@ async def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -549,7 +549,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -564,7 +564,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -594,7 +594,7 @@ async def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -609,7 +609,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -622,7 +622,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -667,7 +667,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_assignments_operations.py index 92421c75188c..6d5b3a03863d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -71,7 +71,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -118,10 +118,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -143,7 +143,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -195,7 +195,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -214,7 +214,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -261,7 +261,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -285,7 +285,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -333,7 +333,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -354,7 +354,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -400,7 +400,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -452,7 +452,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -468,7 +468,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -490,7 +490,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -537,7 +537,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -553,7 +553,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -572,7 +572,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -601,7 +601,7 @@ def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -617,10 +617,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -644,7 +644,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -678,7 +678,7 @@ def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -694,7 +694,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -714,7 +714,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -743,7 +743,7 @@ def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_definitions_operations.py index 30a10ee64c6f..0e7fc13eff0b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -168,7 +168,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -180,7 +180,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +225,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -237,7 +237,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -280,10 +280,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -300,7 +300,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -406,7 +406,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -421,7 +421,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -475,7 +475,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +534,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -544,7 +544,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -612,7 +612,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_set_definitions_operations.py index 6b31ad56f979..fe8ffbb91118 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_01_01/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -163,7 +163,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -176,7 +176,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -189,7 +189,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -219,7 +219,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -235,7 +235,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -247,7 +247,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -291,7 +291,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -301,7 +301,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -346,7 +346,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -361,7 +361,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -371,7 +371,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -412,7 +412,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -427,10 +427,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -447,7 +447,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -482,7 +482,7 @@ def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -548,7 +548,7 @@ def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -562,7 +562,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -577,7 +577,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -607,7 +607,7 @@ def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -623,7 +623,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -636,7 +636,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_01_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -681,7 +681,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_metadata.json index 6e24ce8ab357..ca65a0d4f5fb 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_policy_client.py index dc94923d3bcb..3d7998160ed3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/_policy_client.py index cb8ab5229f72..4ccd792fabca 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_assignments_operations.py index aa2f85740932..abec5a53bc62 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -66,7 +66,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -113,9 +113,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -137,7 +137,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -172,7 +172,7 @@ async def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -188,7 +188,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -207,7 +207,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -237,7 +237,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -253,7 +253,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -277,7 +277,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,7 +325,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -345,7 +345,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -391,7 +391,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -443,7 +443,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -458,7 +458,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -480,7 +480,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -527,7 +527,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -542,7 +542,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -561,7 +561,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ async def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -606,9 +606,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -632,7 +632,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -666,7 +666,7 @@ async def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -681,7 +681,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -701,7 +701,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,7 +730,7 @@ async def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_definitions_operations.py index 1fa96500b267..4bef5e7e2be8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -173,7 +173,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -217,7 +217,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -229,7 +229,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,9 +272,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -291,7 +291,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,7 +395,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -410,7 +410,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,7 +453,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -463,7 +463,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +521,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -531,7 +531,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -586,7 +586,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -598,7 +598,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_set_definitions_operations.py index 6c147f8fe12d..0121cd20feb3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -96,7 +96,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -157,7 +157,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -169,7 +169,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -182,7 +182,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -212,7 +212,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -227,7 +227,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -239,7 +239,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -268,7 +268,7 @@ async def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -282,7 +282,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -292,7 +292,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -337,7 +337,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -351,7 +351,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -361,7 +361,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -402,7 +402,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -417,9 +417,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -436,7 +436,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -471,7 +471,7 @@ async def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -536,7 +536,7 @@ async def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -549,7 +549,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -564,7 +564,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -594,7 +594,7 @@ async def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -609,7 +609,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -622,7 +622,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -667,7 +667,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_assignments_operations.py index 032a36306a49..5bb4b2f62d7f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -71,7 +71,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -118,10 +118,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -143,7 +143,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -178,7 +178,7 @@ def create( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -195,7 +195,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -214,7 +214,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -261,7 +261,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -285,7 +285,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -333,7 +333,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -354,7 +354,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -400,7 +400,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -452,7 +452,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -468,7 +468,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -490,7 +490,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -537,7 +537,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -553,7 +553,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -572,7 +572,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -601,7 +601,7 @@ def delete_by_id( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = None @@ -617,10 +617,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -644,7 +644,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -678,7 +678,7 @@ def create_by_id( if response.status_code not in [201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) @@ -694,7 +694,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -714,7 +714,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -743,7 +743,7 @@ def get_by_id( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicyAssignment', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_definitions_operations.py index aad1be7d68ea..8813c23be84d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -168,7 +168,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -180,7 +180,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,7 +225,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -237,7 +237,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -280,10 +280,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -300,7 +300,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -406,7 +406,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -421,7 +421,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +465,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -475,7 +475,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +534,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -544,7 +544,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -612,7 +612,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_set_definitions_operations.py index c2b060f7f410..13ddc1c2e638 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_06_01/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -163,7 +163,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -176,7 +176,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -189,7 +189,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -219,7 +219,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -235,7 +235,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -247,7 +247,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ def get_built_in( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -291,7 +291,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -301,7 +301,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -346,7 +346,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -361,7 +361,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -371,7 +371,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -412,7 +412,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -427,10 +427,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -447,7 +447,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -482,7 +482,7 @@ def create_or_update_at_management_group( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -548,7 +548,7 @@ def delete_at_management_group( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -562,7 +562,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -577,7 +577,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -607,7 +607,7 @@ def get_at_management_group( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('PolicySetDefinition', pipeline_response) @@ -623,7 +623,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -636,7 +636,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_06_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -681,7 +681,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_metadata.json index cc08fd646bfd..5f95272a3b22 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_policy_client.py index 1d7890f2bebf..db80bcccce06 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/_policy_client.py @@ -55,7 +55,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/_policy_client.py index faa74a96aa06..675c9e00b7d8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/_policy_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/_policy_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.policy_assignments = PolicyAssignmentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_assignments_operations.py index 7b280c5e9652..fde45942622d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyAssignmentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def delete( scope: str, policy_assignment_name: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -66,7 +66,7 @@ async def delete( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -112,9 +112,9 @@ async def create( self, scope: str, policy_assignment_name: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -136,7 +136,7 @@ async def create( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -186,7 +186,7 @@ async def get( scope: str, policy_assignment_name: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -205,7 +205,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list_for_resource_group( resource_group_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -274,7 +274,7 @@ def list_for_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -341,7 +341,7 @@ def list_for_resource( resource_name: str, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -387,7 +387,7 @@ def list_for_resource( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -454,7 +454,7 @@ def list_for_management_group( management_group_id: str, filter: str, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a management group. This operation retrieves the list of all policy assignments applicable to the management group @@ -475,7 +475,7 @@ def list_for_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -535,7 +535,7 @@ def list( self, filter: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.PolicyAssignmentListResult"]: + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -557,7 +557,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -618,7 +618,7 @@ async def delete_by_id( self, policy_assignment_id: str, **kwargs - ) -> Optional["models.PolicyAssignment"]: + ) -> Optional["_models.PolicyAssignment"]: """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -637,7 +637,7 @@ async def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -681,9 +681,9 @@ async def delete_by_id( async def create_by_id( self, policy_assignment_id: str, - parameters: "models.PolicyAssignment", + parameters: "_models.PolicyAssignment", **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -707,7 +707,7 @@ async def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -755,7 +755,7 @@ async def get_by_id( self, policy_assignment_id: str, **kwargs - ) -> "models.PolicyAssignment": + ) -> "_models.PolicyAssignment": """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -775,7 +775,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_definitions_operations.py index b0e70bd24cb5..c003da206627 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicyDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_definition_name: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -163,7 +163,7 @@ async def get( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -175,7 +175,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -219,7 +219,7 @@ async def get_built_in( self, policy_definition_name: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -231,7 +231,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -274,9 +274,9 @@ async def create_or_update_at_management_group( self, policy_definition_name: str, management_group_id: str, - parameters: "models.PolicyDefinition", + parameters: "_models.PolicyDefinition", **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -293,7 +293,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -399,7 +399,7 @@ async def get_at_management_group( policy_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicyDefinition": + ) -> "_models.PolicyDefinition": """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -414,7 +414,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -457,7 +457,7 @@ async def get_at_management_group( def list( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -467,7 +467,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,7 +525,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -535,7 +535,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -590,7 +590,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicyDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -602,7 +602,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_set_definitions_operations.py index af6d7ae4c14a..2e7ca931967e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/aio/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class PolicySetDefinitionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,9 +44,9 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def create_or_update( self, policy_set_definition_name: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ async def get( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -180,7 +180,7 @@ async def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -224,7 +224,7 @@ async def get_built_in( self, policy_set_definition_name: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -236,7 +236,7 @@ async def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -278,7 +278,7 @@ async def get_built_in( def list( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -288,7 +288,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -346,7 +346,7 @@ async def get_next(next_link=None): def list_built_in( self, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -356,7 +356,7 @@ def list_built_in( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -411,9 +411,9 @@ async def create_or_update_at_management_group( self, policy_set_definition_name: str, management_group_id: str, - parameters: "models.PolicySetDefinition", + parameters: "_models.PolicySetDefinition", **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -430,7 +430,7 @@ async def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -541,7 +541,7 @@ async def get_at_management_group( policy_set_definition_name: str, management_group_id: str, **kwargs - ) -> "models.PolicySetDefinition": + ) -> "_models.PolicySetDefinition": """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -556,7 +556,7 @@ async def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -600,7 +600,7 @@ def list_by_management_group( self, management_group_id: str, **kwargs - ) -> AsyncIterable["models.PolicySetDefinitionListResult"]: + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -613,7 +613,7 @@ def list_by_management_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models.py index a8b2893e8e34..589b7cf19845 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models.py @@ -40,7 +40,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models_py3.py index 9604a1bd73c0..5f740c0fb3be 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/models/_models_py3.py @@ -44,7 +44,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_assignments_operations.py index 2b966bbe5551..88daff7794b9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_assignments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_assignments_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyAssignmentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def delete( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes a policy assignment, given its name and the scope it was created in. The @@ -71,7 +71,7 @@ def delete( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,10 +117,10 @@ def create( self, scope, # type: str policy_assignment_name, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates a policy assignment with the given scope and name. Policy @@ -142,7 +142,7 @@ def create( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -193,7 +193,7 @@ def get( policy_assignment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves a policy assignment. This operation retrieves a single policy assignment, given its name and the scope it was @@ -212,7 +212,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +258,7 @@ def list_for_resource_group( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource group. This operation retrieves the list of all policy assignments associated with the given resource @@ -282,7 +282,7 @@ def list_for_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -350,7 +350,7 @@ def list_for_resource( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a resource. This operation retrieves the list of all policy assignments associated with the specified @@ -396,7 +396,7 @@ def list_for_resource( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -464,7 +464,7 @@ def list_for_management_group( filter, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a management group. This operation retrieves the list of all policy assignments applicable to the management group @@ -485,7 +485,7 @@ def list_for_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -546,7 +546,7 @@ def list( filter=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyAssignmentListResult"] + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] """Retrieves all policy assignments that apply to a subscription. This operation retrieves the list of all policy assignments associated with the given @@ -568,7 +568,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignmentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignmentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -630,7 +630,7 @@ def delete_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> Optional["models.PolicyAssignment"] + # type: (...) -> Optional["_models.PolicyAssignment"] """Deletes a policy assignment. This operation deletes the policy with the given ID. Policy assignment IDs have this format: @@ -649,7 +649,7 @@ def delete_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment or None :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.PolicyAssignment"]] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -693,10 +693,10 @@ def delete_by_id( def create_by_id( self, policy_assignment_id, # type: str - parameters, # type: "models.PolicyAssignment" + parameters, # type: "_models.PolicyAssignment" **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Creates or updates a policy assignment. This operation creates or updates the policy assignment with the given ID. Policy assignments @@ -720,7 +720,7 @@ def create_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -769,7 +769,7 @@ def get_by_id( policy_assignment_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyAssignment" + # type: (...) -> "_models.PolicyAssignment" """Retrieves the policy assignment with the given ID. The operation retrieves the policy assignment with the given ID. Policy assignment IDs have @@ -789,7 +789,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyAssignment :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyAssignment"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_definitions_operations.py index 550783cbb6f6..db6ad67c34ba 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicyDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_definition_name, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a subscription. This operation creates or updates a policy definition in the given subscription with the given @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -170,7 +170,7 @@ def get( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a policy definition in a subscription. This operation retrieves the policy definition in the given subscription with the given name. @@ -182,7 +182,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -227,7 +227,7 @@ def get_built_in( policy_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieves a built-in policy definition. This operation retrieves the built-in policy definition with the given name. @@ -239,7 +239,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -282,10 +282,10 @@ def create_or_update_at_management_group( self, policy_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicyDefinition" + parameters, # type: "_models.PolicyDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Creates or updates a policy definition in a management group. This operation creates or updates a policy definition in the given management group with the @@ -302,7 +302,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -410,7 +410,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicyDefinition" + # type: (...) -> "_models.PolicyDefinition" """Retrieve a policy definition in a management group. This operation retrieves the policy definition in the given management group with the given @@ -425,7 +425,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -469,7 +469,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieves policy definitions in a subscription. This operation retrieves a list of all the policy definitions in a given subscription. @@ -479,7 +479,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -538,7 +538,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve built-in policy definitions. This operation retrieves a list of all the built-in policy definitions. @@ -548,7 +548,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -604,7 +604,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicyDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] """Retrieve policy definitions in a management group. This operation retrieves a list of all the policy definitions in a given management group. @@ -616,7 +616,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicyDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicyDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_set_definitions_operations.py index cdf3bb2fd832..67a0021a1240 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_set_definitions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2019_09_01/operations/_policy_set_definitions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class PolicySetDefinitionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -48,10 +48,10 @@ def __init__(self, client, config, serializer, deserializer): def create_or_update( self, policy_set_definition_name, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given subscription with the @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -174,7 +174,7 @@ def get( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given subscription with the given @@ -187,7 +187,7 @@ def get( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ def get_built_in( policy_set_definition_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a built in policy set definition. This operation retrieves the built-in policy set definition with the given name. @@ -244,7 +244,7 @@ def get_built_in( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -287,7 +287,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves the policy set definitions for a subscription. This operation retrieves a list of all the policy set definitions in the given subscription. @@ -297,7 +297,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -356,7 +356,7 @@ def list_built_in( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves built-in policy set definitions. This operation retrieves a list of all the built-in policy set definitions. @@ -366,7 +366,7 @@ def list_built_in( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -421,10 +421,10 @@ def create_or_update_at_management_group( self, policy_set_definition_name, # type: str management_group_id, # type: str - parameters, # type: "models.PolicySetDefinition" + parameters, # type: "_models.PolicySetDefinition" **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Creates or updates a policy set definition. This operation creates or updates a policy set definition in the given management group with @@ -441,7 +441,7 @@ def create_or_update_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -554,7 +554,7 @@ def get_at_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.PolicySetDefinition" + # type: (...) -> "_models.PolicySetDefinition" """Retrieves a policy set definition. This operation retrieves the policy set definition in the given management group with the given @@ -569,7 +569,7 @@ def get_at_management_group( :rtype: ~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinition :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinition"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -614,7 +614,7 @@ def list_by_management_group( management_group_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.PolicySetDefinitionListResult"] + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] """Retrieves all policy set definitions in management group. This operation retrieves a list of all the a policy set definition in the given management @@ -627,7 +627,7 @@ def list_by_management_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2019_09_01.models.PolicySetDefinitionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.PolicySetDefinitionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/__init__.py new file mode 100644 index 000000000000..ce44eb7e8b4e --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/__init__.py @@ -0,0 +1,16 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._policy_client import PolicyClient +__all__ = ['PolicyClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_configuration.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_configuration.py new file mode 100644 index 000000000000..da3746811945 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_configuration.py @@ -0,0 +1,69 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + + from azure.core.credentials import TokenCredential + +VERSION = "unknown" + +class PolicyClientConfiguration(Configuration): + """Configuration for PolicyClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(PolicyClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-resource/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_metadata.json new file mode 100644 index 000000000000..1114f0343005 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_metadata.json @@ -0,0 +1,65 @@ +{ + "chosen_version": "2020-09-01", + "total_api_version_list": ["2020-07-01-preview", "2020-09-01"], + "client": { + "name": "PolicyClient", + "filename": "_policy_client", + "description": "To manage and control access to your resources, you can define customized policies and assign them at a scope.", + "base_url": "\u0027https://management.azure.com\u0027", + "custom_base_url": null, + "azure_arm": true, + "has_lro_operations": false, + "client_side_validation": true + }, + "global_parameters": { + "sync": { + "credential": { + "signature": "credential, # type: \"TokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials.TokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The ID of the target subscription.", + "docstring_type": "str", + "required": true + } + }, + "async": { + "credential": { + "signature": "credential, # type: \"AsyncTokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The ID of the target subscription.", + "docstring_type": "str", + "required": true + } + }, + "constant": { + }, + "call": "credential, subscription_id" + }, + "config": { + "credential": true, + "credential_scopes": ["https://management.azure.com/.default"], + "credential_default_policy_type": "BearerTokenCredentialPolicy", + "credential_default_policy_type_has_async_version": true, + "credential_key_header_name": null + }, + "operation_groups": { + "data_policy_manifests": "DataPolicyManifestsOperations", + "policy_assignments": "PolicyAssignmentsOperations", + "policy_definitions": "PolicyDefinitionsOperations", + "policy_set_definitions": "PolicySetDefinitionsOperations", + "policy_exemptions": "PolicyExemptionsOperations" + }, + "operation_mixins": { + }, + "sync_imports": "None", + "async_imports": "None" +} \ No newline at end of file diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_policy_client.py new file mode 100644 index 000000000000..2dfcd933d607 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/_policy_client.py @@ -0,0 +1,88 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.mgmt.core import ARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + + from azure.core.credentials import TokenCredential + +from ._configuration import PolicyClientConfiguration +from .operations import DataPolicyManifestsOperations +from .operations import PolicyAssignmentsOperations +from .operations import PolicyDefinitionsOperations +from .operations import PolicySetDefinitionsOperations +from .operations import PolicyExemptionsOperations +from . import models + + +class PolicyClient(object): + """To manage and control access to your resources, you can define customized policies and assign them at a scope. + + :ivar data_policy_manifests: DataPolicyManifestsOperations operations + :vartype data_policy_manifests: azure.mgmt.resource.policy.v2020_09_01.operations.DataPolicyManifestsOperations + :ivar policy_assignments: PolicyAssignmentsOperations operations + :vartype policy_assignments: azure.mgmt.resource.policy.v2020_09_01.operations.PolicyAssignmentsOperations + :ivar policy_definitions: PolicyDefinitionsOperations operations + :vartype policy_definitions: azure.mgmt.resource.policy.v2020_09_01.operations.PolicyDefinitionsOperations + :ivar policy_set_definitions: PolicySetDefinitionsOperations operations + :vartype policy_set_definitions: azure.mgmt.resource.policy.v2020_09_01.operations.PolicySetDefinitionsOperations + :ivar policy_exemptions: PolicyExemptionsOperations operations + :vartype policy_exemptions: azure.mgmt.resource.policy.v2020_09_01.operations.PolicyExemptionsOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + :param str base_url: Service URL + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://management.azure.com' + self._config = PolicyClientConfiguration(credential, subscription_id, **kwargs) + self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.data_policy_manifests = DataPolicyManifestsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_assignments = PolicyAssignmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_definitions = PolicyDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_set_definitions = PolicySetDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_exemptions = PolicyExemptionsOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> PolicyClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/__init__.py new file mode 100644 index 000000000000..63f5892fe30b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/__init__.py @@ -0,0 +1,10 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._policy_client import PolicyClient +__all__ = ['PolicyClient'] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_configuration.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_configuration.py new file mode 100644 index 000000000000..67976bccabc2 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_configuration.py @@ -0,0 +1,65 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +VERSION = "unknown" + +class PolicyClientConfiguration(Configuration): + """Configuration for PolicyClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + **kwargs: Any + ) -> None: + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(PolicyClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-resource/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_policy_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_policy_client.py new file mode 100644 index 000000000000..238b50c8409b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/_policy_client.py @@ -0,0 +1,82 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional, TYPE_CHECKING + +from azure.mgmt.core import AsyncARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +from ._configuration import PolicyClientConfiguration +from .operations import DataPolicyManifestsOperations +from .operations import PolicyAssignmentsOperations +from .operations import PolicyDefinitionsOperations +from .operations import PolicySetDefinitionsOperations +from .operations import PolicyExemptionsOperations +from .. import models + + +class PolicyClient(object): + """To manage and control access to your resources, you can define customized policies and assign them at a scope. + + :ivar data_policy_manifests: DataPolicyManifestsOperations operations + :vartype data_policy_manifests: azure.mgmt.resource.policy.v2020_09_01.aio.operations.DataPolicyManifestsOperations + :ivar policy_assignments: PolicyAssignmentsOperations operations + :vartype policy_assignments: azure.mgmt.resource.policy.v2020_09_01.aio.operations.PolicyAssignmentsOperations + :ivar policy_definitions: PolicyDefinitionsOperations operations + :vartype policy_definitions: azure.mgmt.resource.policy.v2020_09_01.aio.operations.PolicyDefinitionsOperations + :ivar policy_set_definitions: PolicySetDefinitionsOperations operations + :vartype policy_set_definitions: azure.mgmt.resource.policy.v2020_09_01.aio.operations.PolicySetDefinitionsOperations + :ivar policy_exemptions: PolicyExemptionsOperations operations + :vartype policy_exemptions: azure.mgmt.resource.policy.v2020_09_01.aio.operations.PolicyExemptionsOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + :param str base_url: Service URL + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://management.azure.com' + self._config = PolicyClientConfiguration(credential, subscription_id, **kwargs) + self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.data_policy_manifests = DataPolicyManifestsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_assignments = PolicyAssignmentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_definitions = PolicyDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_set_definitions = PolicySetDefinitionsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.policy_exemptions = PolicyExemptionsOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "PolicyClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/__init__.py new file mode 100644 index 000000000000..a39cae740704 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/__init__.py @@ -0,0 +1,21 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._data_policy_manifests_operations import DataPolicyManifestsOperations +from ._policy_assignments_operations import PolicyAssignmentsOperations +from ._policy_definitions_operations import PolicyDefinitionsOperations +from ._policy_set_definitions_operations import PolicySetDefinitionsOperations +from ._policy_exemptions_operations import PolicyExemptionsOperations + +__all__ = [ + 'DataPolicyManifestsOperations', + 'PolicyAssignmentsOperations', + 'PolicyDefinitionsOperations', + 'PolicySetDefinitionsOperations', + 'PolicyExemptionsOperations', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_data_policy_manifests_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_data_policy_manifests_operations.py new file mode 100644 index 000000000000..a5a1bc94f560 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_data_policy_manifests_operations.py @@ -0,0 +1,173 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DataPolicyManifestsOperations: + """DataPolicyManifestsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get_by_policy_mode( + self, + policy_mode: str, + **kwargs + ) -> "_models.DataPolicyManifest": + """Retrieves a data policy manifest. + + This operation retrieves the data policy manifest with the given policy mode. + + :param policy_mode: The policy mode of the data policy manifest to get. + :type policy_mode: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DataPolicyManifest, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DataPolicyManifest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_policy_mode.metadata['url'] # type: ignore + path_format_arguments = { + 'policyMode': self._serialize.url("policy_mode", policy_mode, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DataPolicyManifest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_policy_mode.metadata = {'url': '/providers/Microsoft.Authorization/dataPolicyManifests/{policyMode}'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.DataPolicyManifestListResult"]: + """Retrieves data policy manifests. + + This operation retrieves a list of all the data policy manifests that match the optional given + $filter. Valid values for $filter are: "$filter=namespace eq '{0}'". If $filter is not + provided, the unfiltered list includes all data policy manifests for data resource types. If + $filter=namespace is provided, the returned list only includes all data policy manifests that + have a namespace matching the provided value. + + :param filter: The filter to apply on the operation. Valid values for $filter are: "namespace + eq '{value}'". If $filter is not provided, no filtering is performed. If $filter=namespace eq + '{value}' is provided, the returned list only includes all data policy manifests that have a + namespace matching the provided value. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DataPolicyManifestListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifestListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DataPolicyManifestListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DataPolicyManifestListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.Authorization/dataPolicyManifests'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_assignments_operations.py new file mode 100644 index 000000000000..435acbf808a8 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_assignments_operations.py @@ -0,0 +1,869 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class PolicyAssignmentsOperations: + """PolicyAssignmentsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def delete( + self, + scope: str, + policy_assignment_name: str, + **kwargs + ) -> Optional["_models.PolicyAssignment"]: + """Deletes a policy assignment. + + This operation deletes a policy assignment, given its name and the scope it was created in. The + scope of a policy assignment is the part of its ID preceding + '/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment to delete. + :type policy_assignment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + delete.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + async def create( + self, + scope: str, + policy_assignment_name: str, + parameters: "_models.PolicyAssignment", + **kwargs + ) -> "_models.PolicyAssignment": + """Creates or updates a policy assignment. + + This operation creates or updates a policy assignment with the given scope and name. Policy + assignments apply to all resources contained within their scope. For example, when you assign a + policy at resource group scope, that policy applies to all resources in the group. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment. + :type policy_assignment_name: str + :param parameters: Parameters for the policy assignment. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyAssignment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + async def get( + self, + scope: str, + policy_assignment_name: str, + **kwargs + ) -> "_models.PolicyAssignment": + """Retrieves a policy assignment. + + This operation retrieves a single policy assignment, given its name and the scope it was + created at. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment to get. + :type policy_assignment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + def list_for_resource_group( + self, + resource_group_name: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: + """Retrieves all policy assignments that apply to a resource group. + + This operation retrieves the list of all policy assignments associated with the given resource + group in the given subscription that match the optional given $filter. Valid values for $filter + are: 'atScope()', 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not + provided, the unfiltered list includes all policy assignments associated with the resource + group, including those that apply directly or apply from containing scopes, as well as any + applied to resources contained within the resource group. If $filter=atScope() is provided, the + returned list includes all policy assignments that apply to the resource group, which is + everything in the unfiltered list except those applied to resources contained within the + resource group. If $filter=atExactScope() is provided, the returned list only includes all + policy assignments that at the resource group. If $filter=policyDefinitionId eq '{value}' is + provided, the returned list includes all policy assignments of the policy definition whose id + is {value} that apply to the resource group. + + :param resource_group_name: The name of the resource group that contains policy assignments. + :type resource_group_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list_for_resource( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: + """Retrieves all policy assignments that apply to a resource. + + This operation retrieves the list of all policy assignments associated with the specified + resource in the given resource group and subscription that match the optional given $filter. + Valid values for $filter are: 'atScope()', 'atExactScope()' or 'policyDefinitionId eq + '{value}''. If $filter is not provided, the unfiltered list includes all policy assignments + associated with the resource, including those that apply directly or from all containing + scopes, as well as any applied to resources contained within the resource. If $filter=atScope() + is provided, the returned list includes all policy assignments that apply to the resource, + which is everything in the unfiltered list except those applied to resources contained within + the resource. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the resource level. If $filter=policyDefinitionId eq '{value}' is provided, + the returned list includes all policy assignments of the policy definition whose id is {value} + that apply to the resource. Three parameters plus the resource name are used to identify a + specific resource. If the resource is not part of a parent resource (the more common case), the + parent resource path should not be provided (or provided as ''). For example a web app could be + specified as ({resourceProviderNamespace} == 'Microsoft.Web', {parentResourcePath} == '', + {resourceType} == 'sites', {resourceName} == 'MyWebApp'). If the resource is part of a parent + resource, then all parameters should be provided. For example a virtual machine DNS name could + be specified as ({resourceProviderNamespace} == 'Microsoft.Compute', {parentResourcePath} == + 'virtualMachines/MyVirtualMachine', {resourceType} == 'domainNames', {resourceName} == + 'MyComputerName'). A convenient alternative to providing the namespace and type name separately + is to provide both in the {resourceType} parameter, format: ({resourceProviderNamespace} == '', + {parentResourcePath} == '', {resourceType} == 'Microsoft.Web/sites', {resourceName} == + 'MyWebApp'). + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. For example, the + namespace of a virtual machine is Microsoft.Compute (from Microsoft.Compute/virtualMachines). + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource path. Use empty string if there is none. + :type parent_resource_path: str + :param resource_type: The resource type name. For example the type name of a web app is 'sites' + (from Microsoft.Web/sites). + :type resource_type: str + :param resource_name: The name of the resource. + :type resource_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_resource.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list_for_management_group( + self, + management_group_id: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: + """Retrieves all policy assignments that apply to a management group. + + This operation retrieves the list of all policy assignments applicable to the management group + that match the given $filter. Valid values for $filter are: 'atScope()', 'atExactScope()' or + 'policyDefinitionId eq '{value}''. If $filter=atScope() is provided, the returned list includes + all policy assignments that are assigned to the management group or the management group's + ancestors. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the management group. If $filter=policyDefinitionId eq '{value}' is + provided, the returned list includes all policy assignments of the policy definition whose id + is {value} that apply to the management group. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyAssignmentListResult"]: + """Retrieves all policy assignments that apply to a subscription. + + This operation retrieves the list of all policy assignments associated with the given + subscription that match the optional given $filter. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, the + unfiltered list includes all policy assignments associated with the subscription, including + those that apply directly or from management groups that contain the given subscription, as + well as any applied to objects contained within the subscription. If $filter=atScope() is + provided, the returned list includes all policy assignments that apply to the subscription, + which is everything in the unfiltered list except those applied to objects contained within the + subscription. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the subscription. If $filter=policyDefinitionId eq '{value}' is provided, + the returned list includes all policy assignments of the policy definition whose id is {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + async def delete_by_id( + self, + policy_assignment_id: str, + **kwargs + ) -> Optional["_models.PolicyAssignment"]: + """Deletes a policy assignment. + + This operation deletes the policy with the given ID. Policy assignment IDs have this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + formats for {scope} are: '/providers/Microsoft.Management/managementGroups/{managementGroup}' + (management group), '/subscriptions/{subscriptionId}' (subscription), + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}' (resource group), or + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}' + (resource). + + :param policy_assignment_id: The ID of the policy assignment to delete. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + delete_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore + + async def create_by_id( + self, + policy_assignment_id: str, + parameters: "_models.PolicyAssignment", + **kwargs + ) -> "_models.PolicyAssignment": + """Creates or updates a policy assignment. + + This operation creates or updates the policy assignment with the given ID. Policy assignments + made on a scope apply to all resources contained in that scope. For example, when you assign a + policy to a resource group that policy applies to all resources in the group. Policy assignment + IDs have this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + + :param policy_assignment_id: The ID of the policy assignment to create. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :param parameters: Parameters for policy assignment. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyAssignment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore + + async def get_by_id( + self, + policy_assignment_id: str, + **kwargs + ) -> "_models.PolicyAssignment": + """Retrieves the policy assignment with the given ID. + + The operation retrieves the policy assignment with the given ID. Policy assignment IDs have + this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + + :param policy_assignment_id: The ID of the policy assignment to get. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_definitions_operations.py new file mode 100644 index 000000000000..7aa99dd3144d --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_definitions_operations.py @@ -0,0 +1,735 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class PolicyDefinitionsOperations: + """PolicyDefinitionsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def create_or_update( + self, + policy_definition_name: str, + parameters: "_models.PolicyDefinition", + **kwargs + ) -> "_models.PolicyDefinition": + """Creates or updates a policy definition in a subscription. + + This operation creates or updates a policy definition in the given subscription with the given + name. + + :param policy_definition_name: The name of the policy definition to create. + :type policy_definition_name: str + :param parameters: The policy definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def delete( + self, + policy_definition_name: str, + **kwargs + ) -> None: + """Deletes a policy definition in a subscription. + + This operation deletes the policy definition in the given subscription with the given name. + + :param policy_definition_name: The name of the policy definition to delete. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def get( + self, + policy_definition_name: str, + **kwargs + ) -> "_models.PolicyDefinition": + """Retrieves a policy definition in a subscription. + + This operation retrieves the policy definition in the given subscription with the given name. + + :param policy_definition_name: The name of the policy definition to get. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def get_built_in( + self, + policy_definition_name: str, + **kwargs + ) -> "_models.PolicyDefinition": + """Retrieves a built-in policy definition. + + This operation retrieves the built-in policy definition with the given name. + + :param policy_definition_name: The name of the built-in policy definition to get. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_built_in.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def create_or_update_at_management_group( + self, + policy_definition_name: str, + management_group_id: str, + parameters: "_models.PolicyDefinition", + **kwargs + ) -> "_models.PolicyDefinition": + """Creates or updates a policy definition in a management group. + + This operation creates or updates a policy definition in the given management group with the + given name. + + :param policy_definition_name: The name of the policy definition to create. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param parameters: The policy definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def delete_at_management_group( + self, + policy_definition_name: str, + management_group_id: str, + **kwargs + ) -> None: + """Deletes a policy definition in a management group. + + This operation deletes the policy definition in the given management group with the given name. + + :param policy_definition_name: The name of the policy definition to delete. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + async def get_at_management_group( + self, + policy_definition_name: str, + management_group_id: str, + **kwargs + ) -> "_models.PolicyDefinition": + """Retrieve a policy definition in a management group. + + This operation retrieves the policy definition in the given management group with the given + name. + + :param policy_definition_name: The name of the policy definition to get. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: + """Retrieves policy definitions in a subscription. + + This operation retrieves a list of all the policy definitions in a given subscription that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy definitions associated with the subscription, including those that apply + directly or from management groups that contain the given subscription. If + $filter=atExactScope() is provided, the returned list only includes all policy definitions that + at the given subscription. If $filter='policyType -eq {value}' is provided, the returned list + only includes all policy definitions whose type match the {value}. Possible policyType values + are NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is provided, + the returned list only includes all policy definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore + + def list_built_in( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: + """Retrieve built-in policy definitions. + + This operation retrieves a list of all the built-in policy definitions that match the optional + given $filter. If $filter='policyType -eq {value}' is provided, the returned list only includes + all built-in policy definitions whose type match the {value}. Possible policyType values are + NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is provided, the + returned list only includes all built-in policy definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_built_in.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore + + def list_by_management_group( + self, + management_group_id: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyDefinitionListResult"]: + """Retrieve policy definitions in a management group. + + This operation retrieves a list of all the policy definitions in a given management group that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy definitions associated with the management group, including those that + apply directly or from management groups that contain the given management group. If + $filter=atExactScope() is provided, the returned list only includes all policy definitions that + at the given management group. If $filter='policyType -eq {value}' is provided, the returned + list only includes all policy definitions whose type match the {value}. Possible policyType + values are NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is + provided, the returned list only includes all policy definitions whose category match the + {value}. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_exemptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_exemptions_operations.py new file mode 100644 index 000000000000..2c85ae4b87c4 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_exemptions_operations.py @@ -0,0 +1,642 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class PolicyExemptionsOperations: + """PolicyExemptionsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def delete( + self, + scope: str, + policy_exemption_name: str, + **kwargs + ) -> None: + """Deletes a policy exemption. + + This operation deletes a policy exemption, given its name and the scope it was created in. The + scope of a policy exemption is the part of its ID preceding + '/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + async def create_or_update( + self, + scope: str, + policy_exemption_name: str, + parameters: "_models.PolicyExemption", + **kwargs + ) -> "_models.PolicyExemption": + """Creates or updates a policy exemption. + + This operation creates or updates a policy exemption with the given scope and name. Policy + exemptions apply to all resources contained within their scope. For example, when you create a + policy exemption at resource group scope for a policy assignment at the same or above level, + the exemption exempts to all applicable resources in the resource group. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :param parameters: Parameters for the policy exemption. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyExemption, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemption"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyExemption') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + async def get( + self, + scope: str, + policy_exemption_name: str, + **kwargs + ) -> "_models.PolicyExemption": + """Retrieves a policy exemption. + + This operation retrieves a single policy exemption, given its name and the scope it was created + at. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyExemption, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemption"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyExemptionListResult"]: + """Retrieves all policy exemptions that apply to a subscription. + + This operation retrieves the list of all policy exemptions associated with the given + subscription that match the optional given $filter. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, the unfiltered list includes all policy exemptions associated with the subscription, + including those that apply directly or from management groups that contain the given + subscription, as well as any applied to objects contained within the subscription. + + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_resource_group( + self, + resource_group_name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyExemptionListResult"]: + """Retrieves all policy exemptions that apply to a resource group. + + This operation retrieves the list of all policy exemptions associated with the given resource + group in the given subscription that match the optional given $filter. Valid values for $filter + are: 'atScope()', 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If + $filter is not provided, the unfiltered list includes all policy exemptions associated with the + resource group, including those that apply directly or apply from containing scopes, as well as + any applied to resources contained within the resource group. + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_resource( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyExemptionListResult"]: + """Retrieves all policy exemptions that apply to a resource. + + This operation retrieves the list of all policy exemptions associated with the specified + resource in the given resource group and subscription that match the optional given $filter. + Valid values for $filter are: 'atScope()', 'atExactScope()', 'excludeExpired()' or + 'policyAssignmentId eq '{value}''. If $filter is not provided, the unfiltered list includes all + policy exemptions associated with the resource, including those that apply directly or from all + containing scopes, as well as any applied to resources contained within the resource. Three + parameters plus the resource name are used to identify a specific resource. If the resource is + not part of a parent resource (the more common case), the parent resource path should not be + provided (or provided as ''). For example a web app could be specified as + ({resourceProviderNamespace} == 'Microsoft.Web', {parentResourcePath} == '', {resourceType} == + 'sites', {resourceName} == 'MyWebApp'). If the resource is part of a parent resource, then all + parameters should be provided. For example a virtual machine DNS name could be specified as + ({resourceProviderNamespace} == 'Microsoft.Compute', {parentResourcePath} == + 'virtualMachines/MyVirtualMachine', {resourceType} == 'domainNames', {resourceName} == + 'MyComputerName'). A convenient alternative to providing the namespace and type name separately + is to provide both in the {resourceType} parameter, format: ({resourceProviderNamespace} == '', + {parentResourcePath} == '', {resourceType} == 'Microsoft.Web/sites', {resourceName} == + 'MyWebApp'). + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. For example, the + namespace of a virtual machine is Microsoft.Compute (from Microsoft.Compute/virtualMachines). + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource path. Use empty string if there is none. + :type parent_resource_path: str + :param resource_type: The resource type name. For example the type name of a web app is 'sites' + (from Microsoft.Web/sites). + :type resource_type: str + :param resource_name: The name of the resource. + :type resource_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_resource.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_management_group( + self, + management_group_id: str, + filter: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.PolicyExemptionListResult"]: + """Retrieves all policy exemptions that apply to a management group. + + This operation retrieves the list of all policy exemptions applicable to the management group + that match the given $filter. Valid values for $filter are: 'atScope()', 'atExactScope()', + 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter=atScope() is provided, the + returned list includes all policy exemptions that are assigned to the management group or the + management group's ancestors. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_for_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_set_definitions_operations.py new file mode 100644 index 000000000000..8bf4864ac19d --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/aio/operations/_policy_set_definitions_operations.py @@ -0,0 +1,743 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class PolicySetDefinitionsOperations: + """PolicySetDefinitionsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def create_or_update( + self, + policy_set_definition_name: str, + parameters: "_models.PolicySetDefinition", + **kwargs + ) -> "_models.PolicySetDefinition": + """Creates or updates a policy set definition. + + This operation creates or updates a policy set definition in the given subscription with the + given name. + + :param policy_set_definition_name: The name of the policy set definition to create. + :type policy_set_definition_name: str + :param parameters: The policy set definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicySetDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + async def delete( + self, + policy_set_definition_name: str, + **kwargs + ) -> None: + """Deletes a policy set definition. + + This operation deletes the policy set definition in the given subscription with the given name. + + :param policy_set_definition_name: The name of the policy set definition to delete. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + async def get( + self, + policy_set_definition_name: str, + **kwargs + ) -> "_models.PolicySetDefinition": + """Retrieves a policy set definition. + + This operation retrieves the policy set definition in the given subscription with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + async def get_built_in( + self, + policy_set_definition_name: str, + **kwargs + ) -> "_models.PolicySetDefinition": + """Retrieves a built in policy set definition. + + This operation retrieves the built-in policy set definition with the given name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_built_in.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: + """Retrieves the policy set definitions for a subscription. + + This operation retrieves a list of all the policy set definitions in a given subscription that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy set definitions associated with the subscription, including those that + apply directly or from management groups that contain the given subscription. If + $filter=atExactScope() is provided, the returned list only includes all policy set definitions + that at the given subscription. If $filter='policyType -eq {value}' is provided, the returned + list only includes all policy set definitions whose type match the {value}. Possible policyType + values are NotSpecified, BuiltIn and Custom. If $filter='category -eq {value}' is provided, the + returned list only includes all policy set definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore + + def list_built_in( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: + """Retrieves built-in policy set definitions. + + This operation retrieves a list of all the built-in policy set definitions that match the + optional given $filter. If $filter='category -eq {value}' is provided, the returned list only + includes all built-in policy set definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_built_in.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore + + async def create_or_update_at_management_group( + self, + policy_set_definition_name: str, + management_group_id: str, + parameters: "_models.PolicySetDefinition", + **kwargs + ) -> "_models.PolicySetDefinition": + """Creates or updates a policy set definition. + + This operation creates or updates a policy set definition in the given management group with + the given name. + + :param policy_set_definition_name: The name of the policy set definition to create. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param parameters: The policy set definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicySetDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + async def delete_at_management_group( + self, + policy_set_definition_name: str, + management_group_id: str, + **kwargs + ) -> None: + """Deletes a policy set definition. + + This operation deletes the policy set definition in the given management group with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to delete. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + async def get_at_management_group( + self, + policy_set_definition_name: str, + management_group_id: str, + **kwargs + ) -> "_models.PolicySetDefinition": + """Retrieves a policy set definition. + + This operation retrieves the policy set definition in the given management group with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def list_by_management_group( + self, + management_group_id: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.PolicySetDefinitionListResult"]: + """Retrieves all policy set definitions in management group. + + This operation retrieves a list of all the policy set definitions in a given management group + that match the optional given $filter. Valid values for $filter are: 'atExactScope()', + 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered + list includes all policy set definitions associated with the management group, including those + that apply directly or from management groups that contain the given management group. If + $filter=atExactScope() is provided, the returned list only includes all policy set definitions + that at the given management group. If $filter='policyType -eq {value}' is provided, the + returned list only includes all policy set definitions whose type match the {value}. Possible + policyType values are NotSpecified, BuiltIn and Custom. If $filter='category -eq {value}' is + provided, the returned list only includes all policy set definitions whose category match the + {value}. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/__init__.py new file mode 100644 index 000000000000..4fe990d01efc --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/__init__.py @@ -0,0 +1,117 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import Alias + from ._models_py3 import AliasPath + from ._models_py3 import AliasPathMetadata + from ._models_py3 import AliasPattern + from ._models_py3 import DataEffect + from ._models_py3 import DataManifestCustomResourceFunctionDefinition + from ._models_py3 import DataPolicyManifest + from ._models_py3 import DataPolicyManifestListResult + from ._models_py3 import ErrorAdditionalInfo + from ._models_py3 import ErrorResponse + from ._models_py3 import Identity + from ._models_py3 import NonComplianceMessage + from ._models_py3 import ParameterDefinitionsValue + from ._models_py3 import ParameterDefinitionsValueMetadata + from ._models_py3 import ParameterValuesValue + from ._models_py3 import PolicyAssignment + from ._models_py3 import PolicyAssignmentListResult + from ._models_py3 import PolicyDefinition + from ._models_py3 import PolicyDefinitionGroup + from ._models_py3 import PolicyDefinitionListResult + from ._models_py3 import PolicyDefinitionReference + from ._models_py3 import PolicyExemption + from ._models_py3 import PolicyExemptionListResult + from ._models_py3 import PolicySetDefinition + from ._models_py3 import PolicySetDefinitionListResult + from ._models_py3 import ResourceTypeAliases + from ._models_py3 import SystemData +except (SyntaxError, ImportError): + from ._models import Alias # type: ignore + from ._models import AliasPath # type: ignore + from ._models import AliasPathMetadata # type: ignore + from ._models import AliasPattern # type: ignore + from ._models import DataEffect # type: ignore + from ._models import DataManifestCustomResourceFunctionDefinition # type: ignore + from ._models import DataPolicyManifest # type: ignore + from ._models import DataPolicyManifestListResult # type: ignore + from ._models import ErrorAdditionalInfo # type: ignore + from ._models import ErrorResponse # type: ignore + from ._models import Identity # type: ignore + from ._models import NonComplianceMessage # type: ignore + from ._models import ParameterDefinitionsValue # type: ignore + from ._models import ParameterDefinitionsValueMetadata # type: ignore + from ._models import ParameterValuesValue # type: ignore + from ._models import PolicyAssignment # type: ignore + from ._models import PolicyAssignmentListResult # type: ignore + from ._models import PolicyDefinition # type: ignore + from ._models import PolicyDefinitionGroup # type: ignore + from ._models import PolicyDefinitionListResult # type: ignore + from ._models import PolicyDefinitionReference # type: ignore + from ._models import PolicyExemption # type: ignore + from ._models import PolicyExemptionListResult # type: ignore + from ._models import PolicySetDefinition # type: ignore + from ._models import PolicySetDefinitionListResult # type: ignore + from ._models import ResourceTypeAliases # type: ignore + from ._models import SystemData # type: ignore + +from ._policy_client_enums import ( + AliasPathAttributes, + AliasPathTokenType, + AliasPatternType, + AliasType, + CreatedByType, + EnforcementMode, + ExemptionCategory, + ParameterType, + PolicyType, + ResourceIdentityType, +) + +__all__ = [ + 'Alias', + 'AliasPath', + 'AliasPathMetadata', + 'AliasPattern', + 'DataEffect', + 'DataManifestCustomResourceFunctionDefinition', + 'DataPolicyManifest', + 'DataPolicyManifestListResult', + 'ErrorAdditionalInfo', + 'ErrorResponse', + 'Identity', + 'NonComplianceMessage', + 'ParameterDefinitionsValue', + 'ParameterDefinitionsValueMetadata', + 'ParameterValuesValue', + 'PolicyAssignment', + 'PolicyAssignmentListResult', + 'PolicyDefinition', + 'PolicyDefinitionGroup', + 'PolicyDefinitionListResult', + 'PolicyDefinitionReference', + 'PolicyExemption', + 'PolicyExemptionListResult', + 'PolicySetDefinition', + 'PolicySetDefinitionListResult', + 'ResourceTypeAliases', + 'SystemData', + 'AliasPathAttributes', + 'AliasPathTokenType', + 'AliasPatternType', + 'AliasType', + 'CreatedByType', + 'EnforcementMode', + 'ExemptionCategory', + 'ParameterType', + 'PolicyType', + 'ResourceIdentityType', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models.py new file mode 100644 index 000000000000..3ce78a671479 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models.py @@ -0,0 +1,1090 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import msrest.serialization + + +class Alias(msrest.serialization.Model): + """The alias type. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The alias name. + :type name: str + :param paths: The paths for an alias. + :type paths: list[~azure.mgmt.resource.policy.v2020_09_01.models.AliasPath] + :param type: The type of the alias. Possible values include: "NotSpecified", "PlainText", + "Mask". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasType + :param default_path: The default path for an alias. + :type default_path: str + :param default_pattern: The default pattern for an alias. + :type default_pattern: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPattern + :ivar default_metadata: The default alias path metadata. Applies to the default path and to any + alias path that doesn't have metadata. + :vartype default_metadata: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathMetadata + """ + + _validation = { + 'default_metadata': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'paths': {'key': 'paths', 'type': '[AliasPath]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_path': {'key': 'defaultPath', 'type': 'str'}, + 'default_pattern': {'key': 'defaultPattern', 'type': 'AliasPattern'}, + 'default_metadata': {'key': 'defaultMetadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + **kwargs + ): + super(Alias, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.paths = kwargs.get('paths', None) + self.type = kwargs.get('type', None) + self.default_path = kwargs.get('default_path', None) + self.default_pattern = kwargs.get('default_pattern', None) + self.default_metadata = None + + +class AliasPath(msrest.serialization.Model): + """The type of the paths for alias. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param path: The path of an alias. + :type path: str + :param api_versions: The API versions. + :type api_versions: list[str] + :param pattern: The pattern for an alias path. + :type pattern: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPattern + :ivar metadata: The metadata of the alias path. If missing, fall back to the default metadata + of the alias. + :vartype metadata: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathMetadata + """ + + _validation = { + 'metadata': {'readonly': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'pattern': {'key': 'pattern', 'type': 'AliasPattern'}, + 'metadata': {'key': 'metadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPath, self).__init__(**kwargs) + self.path = kwargs.get('path', None) + self.api_versions = kwargs.get('api_versions', None) + self.pattern = kwargs.get('pattern', None) + self.metadata = None + + +class AliasPathMetadata(msrest.serialization.Model): + """AliasPathMetadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the token that the alias path is referring to. Possible values include: + "NotSpecified", "Any", "String", "Object", "Array", "Integer", "Number", "Boolean". + :vartype type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathTokenType + :ivar attributes: The attributes of the token that the alias path is referring to. Possible + values include: "None", "Modifiable". + :vartype attributes: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathAttributes + """ + + _validation = { + 'type': {'readonly': True}, + 'attributes': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'attributes': {'key': 'attributes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPathMetadata, self).__init__(**kwargs) + self.type = None + self.attributes = None + + +class AliasPattern(msrest.serialization.Model): + """The type of the pattern for an alias path. + + :param phrase: The alias pattern phrase. + :type phrase: str + :param variable: The alias pattern variable. + :type variable: str + :param type: The type of alias pattern. Possible values include: "NotSpecified", "Extract". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPatternType + """ + + _attribute_map = { + 'phrase': {'key': 'phrase', 'type': 'str'}, + 'variable': {'key': 'variable', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPattern, self).__init__(**kwargs) + self.phrase = kwargs.get('phrase', None) + self.variable = kwargs.get('variable', None) + self.type = kwargs.get('type', None) + + +class DataEffect(msrest.serialization.Model): + """The data effect definition. + + :param name: The data effect name. + :type name: str + :param details_schema: The data effect details schema. + :type details_schema: object + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'details_schema': {'key': 'detailsSchema', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(DataEffect, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.details_schema = kwargs.get('details_schema', None) + + +class DataManifestCustomResourceFunctionDefinition(msrest.serialization.Model): + """The custom resource function definition. + + :param name: The function name as it will appear in the policy rule. eg - 'vault'. + :type name: str + :param fully_qualified_resource_type: The fully qualified control plane resource type that this + function represents. eg - 'Microsoft.KeyVault/vaults'. + :type fully_qualified_resource_type: str + :param default_properties: The top-level properties that can be selected on the function's + output. eg - [ "name", "location" ] if vault().name and vault().location are supported. + :type default_properties: list[str] + :param allow_custom_properties: A value indicating whether the custom properties within the + property bag are allowed. Needs api-version to be specified in the policy rule eg - + vault('2019-06-01'). + :type allow_custom_properties: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'fully_qualified_resource_type': {'key': 'fullyQualifiedResourceType', 'type': 'str'}, + 'default_properties': {'key': 'defaultProperties', 'type': '[str]'}, + 'allow_custom_properties': {'key': 'allowCustomProperties', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(DataManifestCustomResourceFunctionDefinition, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.fully_qualified_resource_type = kwargs.get('fully_qualified_resource_type', None) + self.default_properties = kwargs.get('default_properties', None) + self.allow_custom_properties = kwargs.get('allow_custom_properties', None) + + +class DataPolicyManifest(msrest.serialization.Model): + """The data policy manifest. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the data policy manifest. + :vartype id: str + :ivar name: The name of the data policy manifest (it's the same as the Policy Mode). + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/dataPolicyManifests). + :vartype type: str + :param namespaces: The list of namespaces for the data policy manifest. + :type namespaces: list[str] + :param policy_mode: The policy mode of the data policy manifest. + :type policy_mode: str + :param is_built_in_only: A value indicating whether policy mode is allowed only in built-in + definitions. + :type is_built_in_only: bool + :param resource_type_aliases: An array of resource type aliases. + :type resource_type_aliases: + list[~azure.mgmt.resource.policy.v2020_09_01.models.ResourceTypeAliases] + :param effects: The effect definition. + :type effects: list[~azure.mgmt.resource.policy.v2020_09_01.models.DataEffect] + :param field_values: The non-alias field accessor values that can be used in the policy rule. + :type field_values: list[str] + :param standard: The standard resource functions (subscription and/or resourceGroup). + :type standard: list[str] + :param custom: An array of data manifest custom resource definition. + :type custom: + list[~azure.mgmt.resource.policy.v2020_09_01.models.DataManifestCustomResourceFunctionDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'namespaces': {'key': 'properties.namespaces', 'type': '[str]'}, + 'policy_mode': {'key': 'properties.policyMode', 'type': 'str'}, + 'is_built_in_only': {'key': 'properties.isBuiltInOnly', 'type': 'bool'}, + 'resource_type_aliases': {'key': 'properties.resourceTypeAliases', 'type': '[ResourceTypeAliases]'}, + 'effects': {'key': 'properties.effects', 'type': '[DataEffect]'}, + 'field_values': {'key': 'properties.fieldValues', 'type': '[str]'}, + 'standard': {'key': 'properties.resourceFunctions.standard', 'type': '[str]'}, + 'custom': {'key': 'properties.resourceFunctions.custom', 'type': '[DataManifestCustomResourceFunctionDefinition]'}, + } + + def __init__( + self, + **kwargs + ): + super(DataPolicyManifest, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.namespaces = kwargs.get('namespaces', None) + self.policy_mode = kwargs.get('policy_mode', None) + self.is_built_in_only = kwargs.get('is_built_in_only', None) + self.resource_type_aliases = kwargs.get('resource_type_aliases', None) + self.effects = kwargs.get('effects', None) + self.field_values = kwargs.get('field_values', None) + self.standard = kwargs.get('standard', None) + self.custom = kwargs.get('custom', None) + + +class DataPolicyManifestListResult(msrest.serialization.Model): + """List of data policy manifests. + + :param value: An array of data policy manifests. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifest] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DataPolicyManifest]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DataPolicyManifestListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ErrorAdditionalInfo(msrest.serialization.Model): + """The resource management error additional info. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The additional info type. + :vartype type: str + :ivar info: The additional info. + :vartype info: object + """ + + _validation = { + 'type': {'readonly': True}, + 'info': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'info': {'key': 'info', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorAdditionalInfo, self).__init__(**kwargs) + self.type = None + self.info = None + + +class ErrorResponse(msrest.serialization.Model): + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: The error code. + :vartype code: str + :ivar message: The error message. + :vartype message: str + :ivar target: The error target. + :vartype target: str + :ivar details: The error details. + :vartype details: list[~azure.mgmt.resource.policy.v2020_09_01.models.ErrorResponse] + :ivar additional_info: The error additional info. + :vartype additional_info: + list[~azure.mgmt.resource.policy.v2020_09_01.models.ErrorAdditionalInfo] + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'details': {'readonly': True}, + 'additional_info': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorResponse]'}, + 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = None + self.additional_info = None + + +class Identity(msrest.serialization.Model): + """Identity for the resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal ID of the resource identity. + :vartype principal_id: str + :ivar tenant_id: The tenant ID of the resource identity. + :vartype tenant_id: str + :param type: The identity type. This is the only required field when adding a system assigned + identity to a resource. Possible values include: "SystemAssigned", "None". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.ResourceIdentityType + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Identity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = kwargs.get('type', None) + + +class NonComplianceMessage(msrest.serialization.Model): + """A message that describes why a resource is non-compliant with the policy. This is shown in 'deny' error messages and on resource's non-compliant compliance results. + + All required parameters must be populated in order to send to Azure. + + :param message: Required. A message that describes why a resource is non-compliant with the + policy. This is shown in 'deny' error messages and on resource's non-compliant compliance + results. + :type message: str + :param policy_definition_reference_id: The policy definition reference ID within a policy set + definition the message is intended for. This is only applicable if the policy assignment + assigns a policy set definition. If this is not provided the message applies to all policies + assigned by this policy assignment. + :type policy_definition_reference_id: str + """ + + _validation = { + 'message': {'required': True}, + } + + _attribute_map = { + 'message': {'key': 'message', 'type': 'str'}, + 'policy_definition_reference_id': {'key': 'policyDefinitionReferenceId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(NonComplianceMessage, self).__init__(**kwargs) + self.message = kwargs['message'] + self.policy_definition_reference_id = kwargs.get('policy_definition_reference_id', None) + + +class ParameterDefinitionsValue(msrest.serialization.Model): + """The definition of a parameter that can be provided to the policy. + + :param type: The data type of the parameter. Possible values include: "String", "Array", + "Object", "Boolean", "Integer", "Float", "DateTime". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterType + :param allowed_values: The allowed values for the parameter. + :type allowed_values: list[object] + :param default_value: The default value for the parameter if no value is provided. + :type default_value: object + :param metadata: General metadata for the parameter. + :type metadata: + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValueMetadata + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_values': {'key': 'allowedValues', 'type': '[object]'}, + 'default_value': {'key': 'defaultValue', 'type': 'object'}, + 'metadata': {'key': 'metadata', 'type': 'ParameterDefinitionsValueMetadata'}, + } + + def __init__( + self, + **kwargs + ): + super(ParameterDefinitionsValue, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.allowed_values = kwargs.get('allowed_values', None) + self.default_value = kwargs.get('default_value', None) + self.metadata = kwargs.get('metadata', None) + + +class ParameterDefinitionsValueMetadata(msrest.serialization.Model): + """General metadata for the parameter. + + :param additional_properties: Unmatched properties from the message are deserialized to this + collection. + :type additional_properties: dict[str, object] + :param display_name: The display name for the parameter. + :type display_name: str + :param description: The description of the parameter. + :type description: str + :param strong_type: Used when assigning the policy definition through the portal. Provides a + context aware list of values for the user to choose from. + :type strong_type: str + :param assign_permissions: Set to true to have Azure portal create role assignments on the + resource ID or resource scope value of this parameter during policy assignment. This property + is useful in case you wish to assign permissions outside the assignment scope. + :type assign_permissions: bool + """ + + _attribute_map = { + 'additional_properties': {'key': '', 'type': '{object}'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'strong_type': {'key': 'strongType', 'type': 'str'}, + 'assign_permissions': {'key': 'assignPermissions', 'type': 'bool'}, + } + + def __init__( + self, + **kwargs + ): + super(ParameterDefinitionsValueMetadata, self).__init__(**kwargs) + self.additional_properties = kwargs.get('additional_properties', None) + self.display_name = kwargs.get('display_name', None) + self.description = kwargs.get('description', None) + self.strong_type = kwargs.get('strong_type', None) + self.assign_permissions = kwargs.get('assign_permissions', None) + + +class ParameterValuesValue(msrest.serialization.Model): + """The value of a parameter. + + :param value: The value of the parameter. + :type value: object + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(ParameterValuesValue, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + + +class PolicyAssignment(msrest.serialization.Model): + """The policy assignment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy assignment. + :vartype id: str + :ivar type: The type of the policy assignment. + :vartype type: str + :ivar name: The name of the policy assignment. + :vartype name: str + :param location: The location of the policy assignment. Only required when utilizing managed + identity. + :type location: str + :param identity: The managed identity associated with the policy assignment. + :type identity: ~azure.mgmt.resource.policy.v2020_09_01.models.Identity + :param display_name: The display name of the policy assignment. + :type display_name: str + :param policy_definition_id: The ID of the policy definition or policy set definition being + assigned. + :type policy_definition_id: str + :ivar scope: The scope for the policy assignment. + :vartype scope: str + :param not_scopes: The policy's excluded scopes. + :type not_scopes: list[str] + :param parameters: The parameter values for the assigned policy rule. The keys are the + parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterValuesValue] + :param description: This message will be part of response in case of policy violation. + :type description: str + :param metadata: The policy assignment metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param enforcement_mode: The policy assignment enforcement mode. Possible values are Default + and DoNotEnforce. Possible values include: "Default", "DoNotEnforce". Default value: "Default". + :type enforcement_mode: str or ~azure.mgmt.resource.policy.v2020_09_01.models.EnforcementMode + :param non_compliance_messages: The messages that describe why a resource is non-compliant with + the policy. + :type non_compliance_messages: + list[~azure.mgmt.resource.policy.v2020_09_01.models.NonComplianceMessage] + """ + + _validation = { + 'id': {'readonly': True}, + 'type': {'readonly': True}, + 'name': {'readonly': True}, + 'scope': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'policy_definition_id': {'key': 'properties.policyDefinitionId', 'type': 'str'}, + 'scope': {'key': 'properties.scope', 'type': 'str'}, + 'not_scopes': {'key': 'properties.notScopes', 'type': '[str]'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterValuesValue}'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'enforcement_mode': {'key': 'properties.enforcementMode', 'type': 'str'}, + 'non_compliance_messages': {'key': 'properties.nonComplianceMessages', 'type': '[NonComplianceMessage]'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyAssignment, self).__init__(**kwargs) + self.id = None + self.type = None + self.name = None + self.location = kwargs.get('location', None) + self.identity = kwargs.get('identity', None) + self.display_name = kwargs.get('display_name', None) + self.policy_definition_id = kwargs.get('policy_definition_id', None) + self.scope = None + self.not_scopes = kwargs.get('not_scopes', None) + self.parameters = kwargs.get('parameters', None) + self.description = kwargs.get('description', None) + self.metadata = kwargs.get('metadata', None) + self.enforcement_mode = kwargs.get('enforcement_mode', "Default") + self.non_compliance_messages = kwargs.get('non_compliance_messages', None) + + +class PolicyAssignmentListResult(msrest.serialization.Model): + """List of policy assignments. + + :param value: An array of policy assignments. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyAssignment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyAssignmentListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class PolicyDefinition(msrest.serialization.Model): + """The policy definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy definition. + :vartype id: str + :ivar name: The name of the policy definition. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policyDefinitions). + :vartype type: str + :param policy_type: The type of policy definition. Possible values are NotSpecified, BuiltIn, + Custom, and Static. Possible values include: "NotSpecified", "BuiltIn", "Custom", "Static". + :type policy_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyType + :param mode: The policy definition mode. Some examples are All, Indexed, + Microsoft.KeyVault.Data. + :type mode: str + :param display_name: The display name of the policy definition. + :type display_name: str + :param description: The policy definition description. + :type description: str + :param policy_rule: The policy rule. + :type policy_rule: object + :param metadata: The policy definition metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param parameters: The parameter definitions for parameters used in the policy rule. The keys + are the parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_type': {'key': 'properties.policyType', 'type': 'str'}, + 'mode': {'key': 'properties.mode', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'policy_rule': {'key': 'properties.policyRule', 'type': 'object'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterDefinitionsValue}'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyDefinition, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.policy_type = kwargs.get('policy_type', None) + self.mode = kwargs.get('mode', "Indexed") + self.display_name = kwargs.get('display_name', None) + self.description = kwargs.get('description', None) + self.policy_rule = kwargs.get('policy_rule', None) + self.metadata = kwargs.get('metadata', None) + self.parameters = kwargs.get('parameters', None) + + +class PolicyDefinitionGroup(msrest.serialization.Model): + """The policy definition group. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the group. + :type name: str + :param display_name: The group's display name. + :type display_name: str + :param category: The group's category. + :type category: str + :param description: The group's description. + :type description: str + :param additional_metadata_id: A resource ID of a resource that contains additional metadata + about the group. + :type additional_metadata_id: str + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'additional_metadata_id': {'key': 'additionalMetadataId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyDefinitionGroup, self).__init__(**kwargs) + self.name = kwargs['name'] + self.display_name = kwargs.get('display_name', None) + self.category = kwargs.get('category', None) + self.description = kwargs.get('description', None) + self.additional_metadata_id = kwargs.get('additional_metadata_id', None) + + +class PolicyDefinitionListResult(msrest.serialization.Model): + """List of policy definitions. + + :param value: An array of policy definitions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyDefinitionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class PolicyDefinitionReference(msrest.serialization.Model): + """The policy definition reference. + + All required parameters must be populated in order to send to Azure. + + :param policy_definition_id: Required. The ID of the policy definition or policy set + definition. + :type policy_definition_id: str + :param parameters: The parameter values for the referenced policy rule. The keys are the + parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterValuesValue] + :param policy_definition_reference_id: A unique id (within the policy set definition) for this + policy definition reference. + :type policy_definition_reference_id: str + :param group_names: The name of the groups that this policy definition reference belongs to. + :type group_names: list[str] + """ + + _validation = { + 'policy_definition_id': {'required': True}, + } + + _attribute_map = { + 'policy_definition_id': {'key': 'policyDefinitionId', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '{ParameterValuesValue}'}, + 'policy_definition_reference_id': {'key': 'policyDefinitionReferenceId', 'type': 'str'}, + 'group_names': {'key': 'groupNames', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyDefinitionReference, self).__init__(**kwargs) + self.policy_definition_id = kwargs['policy_definition_id'] + self.parameters = kwargs.get('parameters', None) + self.policy_definition_reference_id = kwargs.get('policy_definition_reference_id', None) + self.group_names = kwargs.get('group_names', None) + + +class PolicyExemption(msrest.serialization.Model): + """The policy exemption. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar system_data: Azure Resource Manager metadata containing createdBy and modifiedBy + information. + :vartype system_data: ~azure.mgmt.resource.policy.v2020_09_01.models.SystemData + :ivar id: The ID of the policy exemption. + :vartype id: str + :ivar name: The name of the policy exemption. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policyExemptions). + :vartype type: str + :param policy_assignment_id: Required. The ID of the policy assignment that is being exempted. + :type policy_assignment_id: str + :param policy_definition_reference_ids: The policy definition reference ID list when the + associated policy assignment is an assignment of a policy set definition. + :type policy_definition_reference_ids: list[str] + :param exemption_category: Required. The policy exemption category. Possible values are Waiver + and Mitigated. Possible values include: "Waiver", "Mitigated". + :type exemption_category: str or + ~azure.mgmt.resource.policy.v2020_09_01.models.ExemptionCategory + :param expires_on: The expiration date and time (in UTC ISO 8601 format yyyy-MM-ddTHH:mm:ssZ) + of the policy exemption. + :type expires_on: ~datetime.datetime + :param display_name: The display name of the policy exemption. + :type display_name: str + :param description: The description of the policy exemption. + :type description: str + :param metadata: The policy exemption metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + """ + + _validation = { + 'system_data': {'readonly': True}, + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'policy_assignment_id': {'required': True}, + 'exemption_category': {'required': True}, + } + + _attribute_map = { + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_assignment_id': {'key': 'properties.policyAssignmentId', 'type': 'str'}, + 'policy_definition_reference_ids': {'key': 'properties.policyDefinitionReferenceIds', 'type': '[str]'}, + 'exemption_category': {'key': 'properties.exemptionCategory', 'type': 'str'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyExemption, self).__init__(**kwargs) + self.system_data = None + self.id = None + self.name = None + self.type = None + self.policy_assignment_id = kwargs['policy_assignment_id'] + self.policy_definition_reference_ids = kwargs.get('policy_definition_reference_ids', None) + self.exemption_category = kwargs['exemption_category'] + self.expires_on = kwargs.get('expires_on', None) + self.display_name = kwargs.get('display_name', None) + self.description = kwargs.get('description', None) + self.metadata = kwargs.get('metadata', None) + + +class PolicyExemptionListResult(msrest.serialization.Model): + """List of policy exemptions. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of policy exemptions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyExemption]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicyExemptionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class PolicySetDefinition(msrest.serialization.Model): + """The policy set definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy set definition. + :vartype id: str + :ivar name: The name of the policy set definition. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policySetDefinitions). + :vartype type: str + :param policy_type: The type of policy definition. Possible values are NotSpecified, BuiltIn, + Custom, and Static. Possible values include: "NotSpecified", "BuiltIn", "Custom", "Static". + :type policy_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyType + :param display_name: The display name of the policy set definition. + :type display_name: str + :param description: The policy set definition description. + :type description: str + :param metadata: The policy set definition metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param parameters: The policy set definition parameters that can be used in policy definition + references. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValue] + :param policy_definitions: An array of policy definition references. + :type policy_definitions: + list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionReference] + :param policy_definition_groups: The metadata describing groups of policy definition references + within the policy set definition. + :type policy_definition_groups: + list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionGroup] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_type': {'key': 'properties.policyType', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterDefinitionsValue}'}, + 'policy_definitions': {'key': 'properties.policyDefinitions', 'type': '[PolicyDefinitionReference]'}, + 'policy_definition_groups': {'key': 'properties.policyDefinitionGroups', 'type': '[PolicyDefinitionGroup]'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicySetDefinition, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.policy_type = kwargs.get('policy_type', None) + self.display_name = kwargs.get('display_name', None) + self.description = kwargs.get('description', None) + self.metadata = kwargs.get('metadata', None) + self.parameters = kwargs.get('parameters', None) + self.policy_definitions = kwargs.get('policy_definitions', None) + self.policy_definition_groups = kwargs.get('policy_definition_groups', None) + + +class PolicySetDefinitionListResult(msrest.serialization.Model): + """List of policy set definitions. + + :param value: An array of policy set definitions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicySetDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(PolicySetDefinitionListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ResourceTypeAliases(msrest.serialization.Model): + """The resource type aliases definition. + + :param resource_type: The resource type name. + :type resource_type: str + :param aliases: The aliases for property names. + :type aliases: list[~azure.mgmt.resource.policy.v2020_09_01.models.Alias] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'aliases': {'key': 'aliases', 'type': '[Alias]'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceTypeAliases, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.aliases = kwargs.get('aliases', None) + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. Possible values + include: "User", "Application", "ManagedIdentity", "Key". + :type created_by_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.CreatedByType + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. Possible + values include: "User", "Application", "ManagedIdentity", "Key". + :type last_modified_by_type: str or + ~azure.mgmt.resource.policy.v2020_09_01.models.CreatedByType + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = kwargs.get('created_by', None) + self.created_by_type = kwargs.get('created_by_type', None) + self.created_at = kwargs.get('created_at', None) + self.last_modified_by = kwargs.get('last_modified_by', None) + self.last_modified_by_type = kwargs.get('last_modified_by_type', None) + self.last_modified_at = kwargs.get('last_modified_at', None) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models_py3.py new file mode 100644 index 000000000000..3695ee296a35 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_models_py3.py @@ -0,0 +1,1214 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import datetime +from typing import Dict, List, Optional, Union + +import msrest.serialization + +from ._policy_client_enums import * + + +class Alias(msrest.serialization.Model): + """The alias type. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The alias name. + :type name: str + :param paths: The paths for an alias. + :type paths: list[~azure.mgmt.resource.policy.v2020_09_01.models.AliasPath] + :param type: The type of the alias. Possible values include: "NotSpecified", "PlainText", + "Mask". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasType + :param default_path: The default path for an alias. + :type default_path: str + :param default_pattern: The default pattern for an alias. + :type default_pattern: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPattern + :ivar default_metadata: The default alias path metadata. Applies to the default path and to any + alias path that doesn't have metadata. + :vartype default_metadata: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathMetadata + """ + + _validation = { + 'default_metadata': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'paths': {'key': 'paths', 'type': '[AliasPath]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_path': {'key': 'defaultPath', 'type': 'str'}, + 'default_pattern': {'key': 'defaultPattern', 'type': 'AliasPattern'}, + 'default_metadata': {'key': 'defaultMetadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + paths: Optional[List["AliasPath"]] = None, + type: Optional[Union[str, "AliasType"]] = None, + default_path: Optional[str] = None, + default_pattern: Optional["AliasPattern"] = None, + **kwargs + ): + super(Alias, self).__init__(**kwargs) + self.name = name + self.paths = paths + self.type = type + self.default_path = default_path + self.default_pattern = default_pattern + self.default_metadata = None + + +class AliasPath(msrest.serialization.Model): + """The type of the paths for alias. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param path: The path of an alias. + :type path: str + :param api_versions: The API versions. + :type api_versions: list[str] + :param pattern: The pattern for an alias path. + :type pattern: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPattern + :ivar metadata: The metadata of the alias path. If missing, fall back to the default metadata + of the alias. + :vartype metadata: ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathMetadata + """ + + _validation = { + 'metadata': {'readonly': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'pattern': {'key': 'pattern', 'type': 'AliasPattern'}, + 'metadata': {'key': 'metadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + *, + path: Optional[str] = None, + api_versions: Optional[List[str]] = None, + pattern: Optional["AliasPattern"] = None, + **kwargs + ): + super(AliasPath, self).__init__(**kwargs) + self.path = path + self.api_versions = api_versions + self.pattern = pattern + self.metadata = None + + +class AliasPathMetadata(msrest.serialization.Model): + """AliasPathMetadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the token that the alias path is referring to. Possible values include: + "NotSpecified", "Any", "String", "Object", "Array", "Integer", "Number", "Boolean". + :vartype type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathTokenType + :ivar attributes: The attributes of the token that the alias path is referring to. Possible + values include: "None", "Modifiable". + :vartype attributes: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPathAttributes + """ + + _validation = { + 'type': {'readonly': True}, + 'attributes': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'attributes': {'key': 'attributes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPathMetadata, self).__init__(**kwargs) + self.type = None + self.attributes = None + + +class AliasPattern(msrest.serialization.Model): + """The type of the pattern for an alias path. + + :param phrase: The alias pattern phrase. + :type phrase: str + :param variable: The alias pattern variable. + :type variable: str + :param type: The type of alias pattern. Possible values include: "NotSpecified", "Extract". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.AliasPatternType + """ + + _attribute_map = { + 'phrase': {'key': 'phrase', 'type': 'str'}, + 'variable': {'key': 'variable', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + phrase: Optional[str] = None, + variable: Optional[str] = None, + type: Optional[Union[str, "AliasPatternType"]] = None, + **kwargs + ): + super(AliasPattern, self).__init__(**kwargs) + self.phrase = phrase + self.variable = variable + self.type = type + + +class DataEffect(msrest.serialization.Model): + """The data effect definition. + + :param name: The data effect name. + :type name: str + :param details_schema: The data effect details schema. + :type details_schema: object + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'details_schema': {'key': 'detailsSchema', 'type': 'object'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + details_schema: Optional[object] = None, + **kwargs + ): + super(DataEffect, self).__init__(**kwargs) + self.name = name + self.details_schema = details_schema + + +class DataManifestCustomResourceFunctionDefinition(msrest.serialization.Model): + """The custom resource function definition. + + :param name: The function name as it will appear in the policy rule. eg - 'vault'. + :type name: str + :param fully_qualified_resource_type: The fully qualified control plane resource type that this + function represents. eg - 'Microsoft.KeyVault/vaults'. + :type fully_qualified_resource_type: str + :param default_properties: The top-level properties that can be selected on the function's + output. eg - [ "name", "location" ] if vault().name and vault().location are supported. + :type default_properties: list[str] + :param allow_custom_properties: A value indicating whether the custom properties within the + property bag are allowed. Needs api-version to be specified in the policy rule eg - + vault('2019-06-01'). + :type allow_custom_properties: bool + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'fully_qualified_resource_type': {'key': 'fullyQualifiedResourceType', 'type': 'str'}, + 'default_properties': {'key': 'defaultProperties', 'type': '[str]'}, + 'allow_custom_properties': {'key': 'allowCustomProperties', 'type': 'bool'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + fully_qualified_resource_type: Optional[str] = None, + default_properties: Optional[List[str]] = None, + allow_custom_properties: Optional[bool] = None, + **kwargs + ): + super(DataManifestCustomResourceFunctionDefinition, self).__init__(**kwargs) + self.name = name + self.fully_qualified_resource_type = fully_qualified_resource_type + self.default_properties = default_properties + self.allow_custom_properties = allow_custom_properties + + +class DataPolicyManifest(msrest.serialization.Model): + """The data policy manifest. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the data policy manifest. + :vartype id: str + :ivar name: The name of the data policy manifest (it's the same as the Policy Mode). + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/dataPolicyManifests). + :vartype type: str + :param namespaces: The list of namespaces for the data policy manifest. + :type namespaces: list[str] + :param policy_mode: The policy mode of the data policy manifest. + :type policy_mode: str + :param is_built_in_only: A value indicating whether policy mode is allowed only in built-in + definitions. + :type is_built_in_only: bool + :param resource_type_aliases: An array of resource type aliases. + :type resource_type_aliases: + list[~azure.mgmt.resource.policy.v2020_09_01.models.ResourceTypeAliases] + :param effects: The effect definition. + :type effects: list[~azure.mgmt.resource.policy.v2020_09_01.models.DataEffect] + :param field_values: The non-alias field accessor values that can be used in the policy rule. + :type field_values: list[str] + :param standard: The standard resource functions (subscription and/or resourceGroup). + :type standard: list[str] + :param custom: An array of data manifest custom resource definition. + :type custom: + list[~azure.mgmt.resource.policy.v2020_09_01.models.DataManifestCustomResourceFunctionDefinition] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'namespaces': {'key': 'properties.namespaces', 'type': '[str]'}, + 'policy_mode': {'key': 'properties.policyMode', 'type': 'str'}, + 'is_built_in_only': {'key': 'properties.isBuiltInOnly', 'type': 'bool'}, + 'resource_type_aliases': {'key': 'properties.resourceTypeAliases', 'type': '[ResourceTypeAliases]'}, + 'effects': {'key': 'properties.effects', 'type': '[DataEffect]'}, + 'field_values': {'key': 'properties.fieldValues', 'type': '[str]'}, + 'standard': {'key': 'properties.resourceFunctions.standard', 'type': '[str]'}, + 'custom': {'key': 'properties.resourceFunctions.custom', 'type': '[DataManifestCustomResourceFunctionDefinition]'}, + } + + def __init__( + self, + *, + namespaces: Optional[List[str]] = None, + policy_mode: Optional[str] = None, + is_built_in_only: Optional[bool] = None, + resource_type_aliases: Optional[List["ResourceTypeAliases"]] = None, + effects: Optional[List["DataEffect"]] = None, + field_values: Optional[List[str]] = None, + standard: Optional[List[str]] = None, + custom: Optional[List["DataManifestCustomResourceFunctionDefinition"]] = None, + **kwargs + ): + super(DataPolicyManifest, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.namespaces = namespaces + self.policy_mode = policy_mode + self.is_built_in_only = is_built_in_only + self.resource_type_aliases = resource_type_aliases + self.effects = effects + self.field_values = field_values + self.standard = standard + self.custom = custom + + +class DataPolicyManifestListResult(msrest.serialization.Model): + """List of data policy manifests. + + :param value: An array of data policy manifests. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifest] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DataPolicyManifest]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["DataPolicyManifest"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(DataPolicyManifestListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ErrorAdditionalInfo(msrest.serialization.Model): + """The resource management error additional info. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The additional info type. + :vartype type: str + :ivar info: The additional info. + :vartype info: object + """ + + _validation = { + 'type': {'readonly': True}, + 'info': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'info': {'key': 'info', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorAdditionalInfo, self).__init__(**kwargs) + self.type = None + self.info = None + + +class ErrorResponse(msrest.serialization.Model): + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: The error code. + :vartype code: str + :ivar message: The error message. + :vartype message: str + :ivar target: The error target. + :vartype target: str + :ivar details: The error details. + :vartype details: list[~azure.mgmt.resource.policy.v2020_09_01.models.ErrorResponse] + :ivar additional_info: The error additional info. + :vartype additional_info: + list[~azure.mgmt.resource.policy.v2020_09_01.models.ErrorAdditionalInfo] + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'details': {'readonly': True}, + 'additional_info': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorResponse]'}, + 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = None + self.additional_info = None + + +class Identity(msrest.serialization.Model): + """Identity for the resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal ID of the resource identity. + :vartype principal_id: str + :ivar tenant_id: The tenant ID of the resource identity. + :vartype tenant_id: str + :param type: The identity type. This is the only required field when adding a system assigned + identity to a resource. Possible values include: "SystemAssigned", "None". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.ResourceIdentityType + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ResourceIdentityType"]] = None, + **kwargs + ): + super(Identity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = type + + +class NonComplianceMessage(msrest.serialization.Model): + """A message that describes why a resource is non-compliant with the policy. This is shown in 'deny' error messages and on resource's non-compliant compliance results. + + All required parameters must be populated in order to send to Azure. + + :param message: Required. A message that describes why a resource is non-compliant with the + policy. This is shown in 'deny' error messages and on resource's non-compliant compliance + results. + :type message: str + :param policy_definition_reference_id: The policy definition reference ID within a policy set + definition the message is intended for. This is only applicable if the policy assignment + assigns a policy set definition. If this is not provided the message applies to all policies + assigned by this policy assignment. + :type policy_definition_reference_id: str + """ + + _validation = { + 'message': {'required': True}, + } + + _attribute_map = { + 'message': {'key': 'message', 'type': 'str'}, + 'policy_definition_reference_id': {'key': 'policyDefinitionReferenceId', 'type': 'str'}, + } + + def __init__( + self, + *, + message: str, + policy_definition_reference_id: Optional[str] = None, + **kwargs + ): + super(NonComplianceMessage, self).__init__(**kwargs) + self.message = message + self.policy_definition_reference_id = policy_definition_reference_id + + +class ParameterDefinitionsValue(msrest.serialization.Model): + """The definition of a parameter that can be provided to the policy. + + :param type: The data type of the parameter. Possible values include: "String", "Array", + "Object", "Boolean", "Integer", "Float", "DateTime". + :type type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterType + :param allowed_values: The allowed values for the parameter. + :type allowed_values: list[object] + :param default_value: The default value for the parameter if no value is provided. + :type default_value: object + :param metadata: General metadata for the parameter. + :type metadata: + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValueMetadata + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'allowed_values': {'key': 'allowedValues', 'type': '[object]'}, + 'default_value': {'key': 'defaultValue', 'type': 'object'}, + 'metadata': {'key': 'metadata', 'type': 'ParameterDefinitionsValueMetadata'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ParameterType"]] = None, + allowed_values: Optional[List[object]] = None, + default_value: Optional[object] = None, + metadata: Optional["ParameterDefinitionsValueMetadata"] = None, + **kwargs + ): + super(ParameterDefinitionsValue, self).__init__(**kwargs) + self.type = type + self.allowed_values = allowed_values + self.default_value = default_value + self.metadata = metadata + + +class ParameterDefinitionsValueMetadata(msrest.serialization.Model): + """General metadata for the parameter. + + :param additional_properties: Unmatched properties from the message are deserialized to this + collection. + :type additional_properties: dict[str, object] + :param display_name: The display name for the parameter. + :type display_name: str + :param description: The description of the parameter. + :type description: str + :param strong_type: Used when assigning the policy definition through the portal. Provides a + context aware list of values for the user to choose from. + :type strong_type: str + :param assign_permissions: Set to true to have Azure portal create role assignments on the + resource ID or resource scope value of this parameter during policy assignment. This property + is useful in case you wish to assign permissions outside the assignment scope. + :type assign_permissions: bool + """ + + _attribute_map = { + 'additional_properties': {'key': '', 'type': '{object}'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'strong_type': {'key': 'strongType', 'type': 'str'}, + 'assign_permissions': {'key': 'assignPermissions', 'type': 'bool'}, + } + + def __init__( + self, + *, + additional_properties: Optional[Dict[str, object]] = None, + display_name: Optional[str] = None, + description: Optional[str] = None, + strong_type: Optional[str] = None, + assign_permissions: Optional[bool] = None, + **kwargs + ): + super(ParameterDefinitionsValueMetadata, self).__init__(**kwargs) + self.additional_properties = additional_properties + self.display_name = display_name + self.description = description + self.strong_type = strong_type + self.assign_permissions = assign_permissions + + +class ParameterValuesValue(msrest.serialization.Model): + """The value of a parameter. + + :param value: The value of the parameter. + :type value: object + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': 'object'}, + } + + def __init__( + self, + *, + value: Optional[object] = None, + **kwargs + ): + super(ParameterValuesValue, self).__init__(**kwargs) + self.value = value + + +class PolicyAssignment(msrest.serialization.Model): + """The policy assignment. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy assignment. + :vartype id: str + :ivar type: The type of the policy assignment. + :vartype type: str + :ivar name: The name of the policy assignment. + :vartype name: str + :param location: The location of the policy assignment. Only required when utilizing managed + identity. + :type location: str + :param identity: The managed identity associated with the policy assignment. + :type identity: ~azure.mgmt.resource.policy.v2020_09_01.models.Identity + :param display_name: The display name of the policy assignment. + :type display_name: str + :param policy_definition_id: The ID of the policy definition or policy set definition being + assigned. + :type policy_definition_id: str + :ivar scope: The scope for the policy assignment. + :vartype scope: str + :param not_scopes: The policy's excluded scopes. + :type not_scopes: list[str] + :param parameters: The parameter values for the assigned policy rule. The keys are the + parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterValuesValue] + :param description: This message will be part of response in case of policy violation. + :type description: str + :param metadata: The policy assignment metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param enforcement_mode: The policy assignment enforcement mode. Possible values are Default + and DoNotEnforce. Possible values include: "Default", "DoNotEnforce". Default value: "Default". + :type enforcement_mode: str or ~azure.mgmt.resource.policy.v2020_09_01.models.EnforcementMode + :param non_compliance_messages: The messages that describe why a resource is non-compliant with + the policy. + :type non_compliance_messages: + list[~azure.mgmt.resource.policy.v2020_09_01.models.NonComplianceMessage] + """ + + _validation = { + 'id': {'readonly': True}, + 'type': {'readonly': True}, + 'name': {'readonly': True}, + 'scope': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'policy_definition_id': {'key': 'properties.policyDefinitionId', 'type': 'str'}, + 'scope': {'key': 'properties.scope', 'type': 'str'}, + 'not_scopes': {'key': 'properties.notScopes', 'type': '[str]'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterValuesValue}'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'enforcement_mode': {'key': 'properties.enforcementMode', 'type': 'str'}, + 'non_compliance_messages': {'key': 'properties.nonComplianceMessages', 'type': '[NonComplianceMessage]'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + identity: Optional["Identity"] = None, + display_name: Optional[str] = None, + policy_definition_id: Optional[str] = None, + not_scopes: Optional[List[str]] = None, + parameters: Optional[Dict[str, "ParameterValuesValue"]] = None, + description: Optional[str] = None, + metadata: Optional[object] = None, + enforcement_mode: Optional[Union[str, "EnforcementMode"]] = "Default", + non_compliance_messages: Optional[List["NonComplianceMessage"]] = None, + **kwargs + ): + super(PolicyAssignment, self).__init__(**kwargs) + self.id = None + self.type = None + self.name = None + self.location = location + self.identity = identity + self.display_name = display_name + self.policy_definition_id = policy_definition_id + self.scope = None + self.not_scopes = not_scopes + self.parameters = parameters + self.description = description + self.metadata = metadata + self.enforcement_mode = enforcement_mode + self.non_compliance_messages = non_compliance_messages + + +class PolicyAssignmentListResult(msrest.serialization.Model): + """List of policy assignments. + + :param value: An array of policy assignments. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyAssignment]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PolicyAssignment"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PolicyAssignmentListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class PolicyDefinition(msrest.serialization.Model): + """The policy definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy definition. + :vartype id: str + :ivar name: The name of the policy definition. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policyDefinitions). + :vartype type: str + :param policy_type: The type of policy definition. Possible values are NotSpecified, BuiltIn, + Custom, and Static. Possible values include: "NotSpecified", "BuiltIn", "Custom", "Static". + :type policy_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyType + :param mode: The policy definition mode. Some examples are All, Indexed, + Microsoft.KeyVault.Data. + :type mode: str + :param display_name: The display name of the policy definition. + :type display_name: str + :param description: The policy definition description. + :type description: str + :param policy_rule: The policy rule. + :type policy_rule: object + :param metadata: The policy definition metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param parameters: The parameter definitions for parameters used in the policy rule. The keys + are the parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValue] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_type': {'key': 'properties.policyType', 'type': 'str'}, + 'mode': {'key': 'properties.mode', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'policy_rule': {'key': 'properties.policyRule', 'type': 'object'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterDefinitionsValue}'}, + } + + def __init__( + self, + *, + policy_type: Optional[Union[str, "PolicyType"]] = None, + mode: Optional[str] = "Indexed", + display_name: Optional[str] = None, + description: Optional[str] = None, + policy_rule: Optional[object] = None, + metadata: Optional[object] = None, + parameters: Optional[Dict[str, "ParameterDefinitionsValue"]] = None, + **kwargs + ): + super(PolicyDefinition, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.policy_type = policy_type + self.mode = mode + self.display_name = display_name + self.description = description + self.policy_rule = policy_rule + self.metadata = metadata + self.parameters = parameters + + +class PolicyDefinitionGroup(msrest.serialization.Model): + """The policy definition group. + + All required parameters must be populated in order to send to Azure. + + :param name: Required. The name of the group. + :type name: str + :param display_name: The group's display name. + :type display_name: str + :param category: The group's category. + :type category: str + :param description: The group's description. + :type description: str + :param additional_metadata_id: A resource ID of a resource that contains additional metadata + about the group. + :type additional_metadata_id: str + """ + + _validation = { + 'name': {'required': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display_name': {'key': 'displayName', 'type': 'str'}, + 'category': {'key': 'category', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + 'additional_metadata_id': {'key': 'additionalMetadataId', 'type': 'str'}, + } + + def __init__( + self, + *, + name: str, + display_name: Optional[str] = None, + category: Optional[str] = None, + description: Optional[str] = None, + additional_metadata_id: Optional[str] = None, + **kwargs + ): + super(PolicyDefinitionGroup, self).__init__(**kwargs) + self.name = name + self.display_name = display_name + self.category = category + self.description = description + self.additional_metadata_id = additional_metadata_id + + +class PolicyDefinitionListResult(msrest.serialization.Model): + """List of policy definitions. + + :param value: An array of policy definitions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PolicyDefinition"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PolicyDefinitionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class PolicyDefinitionReference(msrest.serialization.Model): + """The policy definition reference. + + All required parameters must be populated in order to send to Azure. + + :param policy_definition_id: Required. The ID of the policy definition or policy set + definition. + :type policy_definition_id: str + :param parameters: The parameter values for the referenced policy rule. The keys are the + parameter names. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterValuesValue] + :param policy_definition_reference_id: A unique id (within the policy set definition) for this + policy definition reference. + :type policy_definition_reference_id: str + :param group_names: The name of the groups that this policy definition reference belongs to. + :type group_names: list[str] + """ + + _validation = { + 'policy_definition_id': {'required': True}, + } + + _attribute_map = { + 'policy_definition_id': {'key': 'policyDefinitionId', 'type': 'str'}, + 'parameters': {'key': 'parameters', 'type': '{ParameterValuesValue}'}, + 'policy_definition_reference_id': {'key': 'policyDefinitionReferenceId', 'type': 'str'}, + 'group_names': {'key': 'groupNames', 'type': '[str]'}, + } + + def __init__( + self, + *, + policy_definition_id: str, + parameters: Optional[Dict[str, "ParameterValuesValue"]] = None, + policy_definition_reference_id: Optional[str] = None, + group_names: Optional[List[str]] = None, + **kwargs + ): + super(PolicyDefinitionReference, self).__init__(**kwargs) + self.policy_definition_id = policy_definition_id + self.parameters = parameters + self.policy_definition_reference_id = policy_definition_reference_id + self.group_names = group_names + + +class PolicyExemption(msrest.serialization.Model): + """The policy exemption. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar system_data: Azure Resource Manager metadata containing createdBy and modifiedBy + information. + :vartype system_data: ~azure.mgmt.resource.policy.v2020_09_01.models.SystemData + :ivar id: The ID of the policy exemption. + :vartype id: str + :ivar name: The name of the policy exemption. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policyExemptions). + :vartype type: str + :param policy_assignment_id: Required. The ID of the policy assignment that is being exempted. + :type policy_assignment_id: str + :param policy_definition_reference_ids: The policy definition reference ID list when the + associated policy assignment is an assignment of a policy set definition. + :type policy_definition_reference_ids: list[str] + :param exemption_category: Required. The policy exemption category. Possible values are Waiver + and Mitigated. Possible values include: "Waiver", "Mitigated". + :type exemption_category: str or + ~azure.mgmt.resource.policy.v2020_09_01.models.ExemptionCategory + :param expires_on: The expiration date and time (in UTC ISO 8601 format yyyy-MM-ddTHH:mm:ssZ) + of the policy exemption. + :type expires_on: ~datetime.datetime + :param display_name: The display name of the policy exemption. + :type display_name: str + :param description: The description of the policy exemption. + :type description: str + :param metadata: The policy exemption metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + """ + + _validation = { + 'system_data': {'readonly': True}, + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'policy_assignment_id': {'required': True}, + 'exemption_category': {'required': True}, + } + + _attribute_map = { + 'system_data': {'key': 'systemData', 'type': 'SystemData'}, + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_assignment_id': {'key': 'properties.policyAssignmentId', 'type': 'str'}, + 'policy_definition_reference_ids': {'key': 'properties.policyDefinitionReferenceIds', 'type': '[str]'}, + 'exemption_category': {'key': 'properties.exemptionCategory', 'type': 'str'}, + 'expires_on': {'key': 'properties.expiresOn', 'type': 'iso-8601'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + } + + def __init__( + self, + *, + policy_assignment_id: str, + exemption_category: Union[str, "ExemptionCategory"], + policy_definition_reference_ids: Optional[List[str]] = None, + expires_on: Optional[datetime.datetime] = None, + display_name: Optional[str] = None, + description: Optional[str] = None, + metadata: Optional[object] = None, + **kwargs + ): + super(PolicyExemption, self).__init__(**kwargs) + self.system_data = None + self.id = None + self.name = None + self.type = None + self.policy_assignment_id = policy_assignment_id + self.policy_definition_reference_ids = policy_definition_reference_ids + self.exemption_category = exemption_category + self.expires_on = expires_on + self.display_name = display_name + self.description = description + self.metadata = metadata + + +class PolicyExemptionListResult(msrest.serialization.Model): + """List of policy exemptions. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of policy exemptions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicyExemption]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PolicyExemption"]] = None, + **kwargs + ): + super(PolicyExemptionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class PolicySetDefinition(msrest.serialization.Model): + """The policy set definition. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the policy set definition. + :vartype id: str + :ivar name: The name of the policy set definition. + :vartype name: str + :ivar type: The type of the resource (Microsoft.Authorization/policySetDefinitions). + :vartype type: str + :param policy_type: The type of policy definition. Possible values are NotSpecified, BuiltIn, + Custom, and Static. Possible values include: "NotSpecified", "BuiltIn", "Custom", "Static". + :type policy_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyType + :param display_name: The display name of the policy set definition. + :type display_name: str + :param description: The policy set definition description. + :type description: str + :param metadata: The policy set definition metadata. Metadata is an open ended object and is + typically a collection of key value pairs. + :type metadata: object + :param parameters: The policy set definition parameters that can be used in policy definition + references. + :type parameters: dict[str, + ~azure.mgmt.resource.policy.v2020_09_01.models.ParameterDefinitionsValue] + :param policy_definitions: An array of policy definition references. + :type policy_definitions: + list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionReference] + :param policy_definition_groups: The metadata describing groups of policy definition references + within the policy set definition. + :type policy_definition_groups: + list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionGroup] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'policy_type': {'key': 'properties.policyType', 'type': 'str'}, + 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'description': {'key': 'properties.description', 'type': 'str'}, + 'metadata': {'key': 'properties.metadata', 'type': 'object'}, + 'parameters': {'key': 'properties.parameters', 'type': '{ParameterDefinitionsValue}'}, + 'policy_definitions': {'key': 'properties.policyDefinitions', 'type': '[PolicyDefinitionReference]'}, + 'policy_definition_groups': {'key': 'properties.policyDefinitionGroups', 'type': '[PolicyDefinitionGroup]'}, + } + + def __init__( + self, + *, + policy_type: Optional[Union[str, "PolicyType"]] = None, + display_name: Optional[str] = None, + description: Optional[str] = None, + metadata: Optional[object] = None, + parameters: Optional[Dict[str, "ParameterDefinitionsValue"]] = None, + policy_definitions: Optional[List["PolicyDefinitionReference"]] = None, + policy_definition_groups: Optional[List["PolicyDefinitionGroup"]] = None, + **kwargs + ): + super(PolicySetDefinition, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.policy_type = policy_type + self.display_name = display_name + self.description = description + self.metadata = metadata + self.parameters = parameters + self.policy_definitions = policy_definitions + self.policy_definition_groups = policy_definition_groups + + +class PolicySetDefinitionListResult(msrest.serialization.Model): + """List of policy set definitions. + + :param value: An array of policy set definitions. + :type value: list[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition] + :param next_link: The URL to use for getting the next set of results. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[PolicySetDefinition]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["PolicySetDefinition"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(PolicySetDefinitionListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ResourceTypeAliases(msrest.serialization.Model): + """The resource type aliases definition. + + :param resource_type: The resource type name. + :type resource_type: str + :param aliases: The aliases for property names. + :type aliases: list[~azure.mgmt.resource.policy.v2020_09_01.models.Alias] + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'aliases': {'key': 'aliases', 'type': '[Alias]'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + aliases: Optional[List["Alias"]] = None, + **kwargs + ): + super(ResourceTypeAliases, self).__init__(**kwargs) + self.resource_type = resource_type + self.aliases = aliases + + +class SystemData(msrest.serialization.Model): + """Metadata pertaining to creation and last modification of the resource. + + :param created_by: The identity that created the resource. + :type created_by: str + :param created_by_type: The type of identity that created the resource. Possible values + include: "User", "Application", "ManagedIdentity", "Key". + :type created_by_type: str or ~azure.mgmt.resource.policy.v2020_09_01.models.CreatedByType + :param created_at: The timestamp of resource creation (UTC). + :type created_at: ~datetime.datetime + :param last_modified_by: The identity that last modified the resource. + :type last_modified_by: str + :param last_modified_by_type: The type of identity that last modified the resource. Possible + values include: "User", "Application", "ManagedIdentity", "Key". + :type last_modified_by_type: str or + ~azure.mgmt.resource.policy.v2020_09_01.models.CreatedByType + :param last_modified_at: The timestamp of resource last modification (UTC). + :type last_modified_at: ~datetime.datetime + """ + + _attribute_map = { + 'created_by': {'key': 'createdBy', 'type': 'str'}, + 'created_by_type': {'key': 'createdByType', 'type': 'str'}, + 'created_at': {'key': 'createdAt', 'type': 'iso-8601'}, + 'last_modified_by': {'key': 'lastModifiedBy', 'type': 'str'}, + 'last_modified_by_type': {'key': 'lastModifiedByType', 'type': 'str'}, + 'last_modified_at': {'key': 'lastModifiedAt', 'type': 'iso-8601'}, + } + + def __init__( + self, + *, + created_by: Optional[str] = None, + created_by_type: Optional[Union[str, "CreatedByType"]] = None, + created_at: Optional[datetime.datetime] = None, + last_modified_by: Optional[str] = None, + last_modified_by_type: Optional[Union[str, "CreatedByType"]] = None, + last_modified_at: Optional[datetime.datetime] = None, + **kwargs + ): + super(SystemData, self).__init__(**kwargs) + self.created_by = created_by + self.created_by_type = created_by_type + self.created_at = created_at + self.last_modified_by = last_modified_by + self.last_modified_by_type = last_modified_by_type + self.last_modified_at = last_modified_at diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_policy_client_enums.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_policy_client_enums.py new file mode 100644 index 000000000000..19e889de5b76 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/models/_policy_client_enums.py @@ -0,0 +1,114 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from enum import Enum, EnumMeta +from six import with_metaclass + +class _CaseInsensitiveEnumMeta(EnumMeta): + def __getitem__(self, name): + return super().__getitem__(name.upper()) + + def __getattr__(cls, name): + """Return the enum member matching `name` + We use __getattr__ instead of descriptors or inserting into the enum + class' __dict__ in order to support `name` and `value` being both + properties for enum members (which live in the class' __dict__) and + enum members themselves. + """ + try: + return cls._member_map_[name.upper()] + except KeyError: + raise AttributeError(name) + + +class AliasPathAttributes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The attributes of the token that the alias path is referring to. + """ + + NONE = "None" #: The token that the alias path is referring to has no attributes. + MODIFIABLE = "Modifiable" #: The token that the alias path is referring to is modifiable by policies with 'modify' effect. + +class AliasPathTokenType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of the token that the alias path is referring to. + """ + + NOT_SPECIFIED = "NotSpecified" #: The token type is not specified. + ANY = "Any" #: The token type can be anything. + STRING = "String" #: The token type is string. + OBJECT = "Object" #: The token type is object. + ARRAY = "Array" #: The token type is array. + INTEGER = "Integer" #: The token type is integer. + NUMBER = "Number" #: The token type is number. + BOOLEAN = "Boolean" #: The token type is boolean. + +class AliasPatternType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of alias pattern + """ + + NOT_SPECIFIED = "NotSpecified" #: NotSpecified is not allowed. + EXTRACT = "Extract" #: Extract is the only allowed value. + +class AliasType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of the alias. + """ + + NOT_SPECIFIED = "NotSpecified" #: Alias type is unknown (same as not providing alias type). + PLAIN_TEXT = "PlainText" #: Alias value is not secret. + MASK = "Mask" #: Alias value is secret. + +class CreatedByType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of identity that created the resource. + """ + + USER = "User" + APPLICATION = "Application" + MANAGED_IDENTITY = "ManagedIdentity" + KEY = "Key" + +class EnforcementMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The policy assignment enforcement mode. Possible values are Default and DoNotEnforce. + """ + + DEFAULT = "Default" #: The policy effect is enforced during resource creation or update. + DO_NOT_ENFORCE = "DoNotEnforce" #: The policy effect is not enforced during resource creation or update. + +class ExemptionCategory(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The policy exemption category. Possible values are Waiver and Mitigated. + """ + + WAIVER = "Waiver" #: This category of exemptions usually means the scope is not applicable for the policy. + MITIGATED = "Mitigated" #: This category of exemptions usually means the mitigation actions have been applied to the scope. + +class ParameterType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The data type of the parameter. + """ + + STRING = "String" + ARRAY = "Array" + OBJECT = "Object" + BOOLEAN = "Boolean" + INTEGER = "Integer" + FLOAT = "Float" + DATE_TIME = "DateTime" + +class PolicyType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of policy definition. Possible values are NotSpecified, BuiltIn, Custom, and Static. + """ + + NOT_SPECIFIED = "NotSpecified" + BUILT_IN = "BuiltIn" + CUSTOM = "Custom" + STATIC = "Static" + +class ResourceIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The identity type. This is the only required field when adding a system assigned identity to a + resource. + """ + + SYSTEM_ASSIGNED = "SystemAssigned" #: Indicates that a system assigned identity is associated with the resource. + NONE = "None" #: Indicates that no identity is associated with the resource or that the existing identity should be removed. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/__init__.py new file mode 100644 index 000000000000..a39cae740704 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/__init__.py @@ -0,0 +1,21 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._data_policy_manifests_operations import DataPolicyManifestsOperations +from ._policy_assignments_operations import PolicyAssignmentsOperations +from ._policy_definitions_operations import PolicyDefinitionsOperations +from ._policy_set_definitions_operations import PolicySetDefinitionsOperations +from ._policy_exemptions_operations import PolicyExemptionsOperations + +__all__ = [ + 'DataPolicyManifestsOperations', + 'PolicyAssignmentsOperations', + 'PolicyDefinitionsOperations', + 'PolicySetDefinitionsOperations', + 'PolicyExemptionsOperations', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_data_policy_manifests_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_data_policy_manifests_operations.py new file mode 100644 index 000000000000..45d418906060 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_data_policy_manifests_operations.py @@ -0,0 +1,179 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DataPolicyManifestsOperations(object): + """DataPolicyManifestsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_by_policy_mode( + self, + policy_mode, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DataPolicyManifest" + """Retrieves a data policy manifest. + + This operation retrieves the data policy manifest with the given policy mode. + + :param policy_mode: The policy mode of the data policy manifest to get. + :type policy_mode: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DataPolicyManifest, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifest + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DataPolicyManifest"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_policy_mode.metadata['url'] # type: ignore + path_format_arguments = { + 'policyMode': self._serialize.url("policy_mode", policy_mode, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DataPolicyManifest', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_policy_mode.metadata = {'url': '/providers/Microsoft.Authorization/dataPolicyManifests/{policyMode}'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DataPolicyManifestListResult"] + """Retrieves data policy manifests. + + This operation retrieves a list of all the data policy manifests that match the optional given + $filter. Valid values for $filter are: "$filter=namespace eq '{0}'". If $filter is not + provided, the unfiltered list includes all data policy manifests for data resource types. If + $filter=namespace is provided, the returned list only includes all data policy manifests that + have a namespace matching the provided value. + + :param filter: The filter to apply on the operation. Valid values for $filter are: "namespace + eq '{value}'". If $filter is not provided, no filtering is performed. If $filter=namespace eq + '{value}' is provided, the returned list only includes all data policy manifests that have a + namespace matching the provided value. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DataPolicyManifestListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.DataPolicyManifestListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DataPolicyManifestListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DataPolicyManifestListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.Authorization/dataPolicyManifests'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_assignments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_assignments_operations.py new file mode 100644 index 000000000000..3754967555a9 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_assignments_operations.py @@ -0,0 +1,883 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class PolicyAssignmentsOperations(object): + """PolicyAssignmentsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def delete( + self, + scope, # type: str + policy_assignment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PolicyAssignment"] + """Deletes a policy assignment. + + This operation deletes a policy assignment, given its name and the scope it was created in. The + scope of a policy assignment is the part of its ID preceding + '/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment to delete. + :type policy_assignment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + delete.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + def create( + self, + scope, # type: str + policy_assignment_name, # type: str + parameters, # type: "_models.PolicyAssignment" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyAssignment" + """Creates or updates a policy assignment. + + This operation creates or updates a policy assignment with the given scope and name. Policy + assignments apply to all resources contained within their scope. For example, when you assign a + policy at resource group scope, that policy applies to all resources in the group. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment. + :type policy_assignment_name: str + :param parameters: Parameters for the policy assignment. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyAssignment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + def get( + self, + scope, # type: str + policy_assignment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyAssignment" + """Retrieves a policy assignment. + + This operation retrieves a single policy assignment, given its name and the scope it was + created at. + + :param scope: The scope of the policy assignment. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_assignment_name: The name of the policy assignment to get. + :type policy_assignment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyAssignmentName': self._serialize.url("policy_assignment_name", policy_assignment_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'} # type: ignore + + def list_for_resource_group( + self, + resource_group_name, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] + """Retrieves all policy assignments that apply to a resource group. + + This operation retrieves the list of all policy assignments associated with the given resource + group in the given subscription that match the optional given $filter. Valid values for $filter + are: 'atScope()', 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not + provided, the unfiltered list includes all policy assignments associated with the resource + group, including those that apply directly or apply from containing scopes, as well as any + applied to resources contained within the resource group. If $filter=atScope() is provided, the + returned list includes all policy assignments that apply to the resource group, which is + everything in the unfiltered list except those applied to resources contained within the + resource group. If $filter=atExactScope() is provided, the returned list only includes all + policy assignments that at the resource group. If $filter=policyDefinitionId eq '{value}' is + provided, the returned list includes all policy assignments of the policy definition whose id + is {value} that apply to the resource group. + + :param resource_group_name: The name of the resource group that contains policy assignments. + :type resource_group_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list_for_resource( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] + """Retrieves all policy assignments that apply to a resource. + + This operation retrieves the list of all policy assignments associated with the specified + resource in the given resource group and subscription that match the optional given $filter. + Valid values for $filter are: 'atScope()', 'atExactScope()' or 'policyDefinitionId eq + '{value}''. If $filter is not provided, the unfiltered list includes all policy assignments + associated with the resource, including those that apply directly or from all containing + scopes, as well as any applied to resources contained within the resource. If $filter=atScope() + is provided, the returned list includes all policy assignments that apply to the resource, + which is everything in the unfiltered list except those applied to resources contained within + the resource. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the resource level. If $filter=policyDefinitionId eq '{value}' is provided, + the returned list includes all policy assignments of the policy definition whose id is {value} + that apply to the resource. Three parameters plus the resource name are used to identify a + specific resource. If the resource is not part of a parent resource (the more common case), the + parent resource path should not be provided (or provided as ''). For example a web app could be + specified as ({resourceProviderNamespace} == 'Microsoft.Web', {parentResourcePath} == '', + {resourceType} == 'sites', {resourceName} == 'MyWebApp'). If the resource is part of a parent + resource, then all parameters should be provided. For example a virtual machine DNS name could + be specified as ({resourceProviderNamespace} == 'Microsoft.Compute', {parentResourcePath} == + 'virtualMachines/MyVirtualMachine', {resourceType} == 'domainNames', {resourceName} == + 'MyComputerName'). A convenient alternative to providing the namespace and type name separately + is to provide both in the {resourceType} parameter, format: ({resourceProviderNamespace} == '', + {parentResourcePath} == '', {resourceType} == 'Microsoft.Web/sites', {resourceName} == + 'MyWebApp'). + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. For example, the + namespace of a virtual machine is Microsoft.Compute (from Microsoft.Compute/virtualMachines). + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource path. Use empty string if there is none. + :type parent_resource_path: str + :param resource_type: The resource type name. For example the type name of a web app is 'sites' + (from Microsoft.Web/sites). + :type resource_type: str + :param resource_name: The name of the resource. + :type resource_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_resource.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list_for_management_group( + self, + management_group_id, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] + """Retrieves all policy assignments that apply to a management group. + + This operation retrieves the list of all policy assignments applicable to the management group + that match the given $filter. Valid values for $filter are: 'atScope()', 'atExactScope()' or + 'policyDefinitionId eq '{value}''. If $filter=atScope() is provided, the returned list includes + all policy assignments that are assigned to the management group or the management group's + ancestors. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the management group. If $filter=policyDefinitionId eq '{value}' is + provided, the returned list includes all policy assignments of the policy definition whose id + is {value} that apply to the management group. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyAssignmentListResult"] + """Retrieves all policy assignments that apply to a subscription. + + This operation retrieves the list of all policy assignments associated with the given + subscription that match the optional given $filter. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, the + unfiltered list includes all policy assignments associated with the subscription, including + those that apply directly or from management groups that contain the given subscription, as + well as any applied to objects contained within the subscription. If $filter=atScope() is + provided, the returned list includes all policy assignments that apply to the subscription, + which is everything in the unfiltered list except those applied to objects contained within the + subscription. If $filter=atExactScope() is provided, the returned list only includes all policy + assignments that at the subscription. If $filter=policyDefinitionId eq '{value}' is provided, + the returned list includes all policy assignments of the policy definition whose id is {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()' or 'policyDefinitionId eq '{value}''. If $filter is not provided, no filtering + is performed. If $filter=atScope() is provided, the returned list only includes all policy + assignments that apply to the scope, which is everything in the unfiltered list except those + applied to sub scopes contained within the given scope. If $filter=atExactScope() is provided, + the returned list only includes all policy assignments that at the given scope. If + $filter=policyDefinitionId eq '{value}' is provided, the returned list includes all policy + assignments of the policy definition whose id is {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyAssignmentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignmentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignmentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyAssignmentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyAssignments'} # type: ignore + + def delete_by_id( + self, + policy_assignment_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.PolicyAssignment"] + """Deletes a policy assignment. + + This operation deletes the policy with the given ID. Policy assignment IDs have this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + formats for {scope} are: '/providers/Microsoft.Management/managementGroups/{managementGroup}' + (management group), '/subscriptions/{subscriptionId}' (subscription), + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}' (resource group), or + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}' + (resource). + + :param policy_assignment_id: The ID of the policy assignment to delete. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment or None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.PolicyAssignment"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + delete_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore + + def create_by_id( + self, + policy_assignment_id, # type: str + parameters, # type: "_models.PolicyAssignment" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyAssignment" + """Creates or updates a policy assignment. + + This operation creates or updates the policy assignment with the given ID. Policy assignments + made on a scope apply to all resources contained in that scope. For example, when you assign a + policy to a resource group that policy applies to all resources in the group. Policy assignment + IDs have this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + + :param policy_assignment_id: The ID of the policy assignment to create. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :param parameters: Parameters for policy assignment. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyAssignment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore + + def get_by_id( + self, + policy_assignment_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyAssignment" + """Retrieves the policy assignment with the given ID. + + The operation retrieves the policy assignment with the given ID. Policy assignment IDs have + this format: + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. Valid + scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + + :param policy_assignment_id: The ID of the policy assignment to get. Use the format + '{scope}/providers/Microsoft.Authorization/policyAssignments/{policyAssignmentName}'. + :type policy_assignment_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyAssignment, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyAssignment + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyAssignment"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'policyAssignmentId': self._serialize.url("policy_assignment_id", policy_assignment_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyAssignment', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_id.metadata = {'url': '/{policyAssignmentId}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_definitions_operations.py new file mode 100644 index 000000000000..3b175fdbce51 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_definitions_operations.py @@ -0,0 +1,749 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class PolicyDefinitionsOperations(object): + """PolicyDefinitionsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def create_or_update( + self, + policy_definition_name, # type: str + parameters, # type: "_models.PolicyDefinition" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyDefinition" + """Creates or updates a policy definition in a subscription. + + This operation creates or updates a policy definition in the given subscription with the given + name. + + :param policy_definition_name: The name of the policy definition to create. + :type policy_definition_name: str + :param parameters: The policy definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def delete( + self, + policy_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a policy definition in a subscription. + + This operation deletes the policy definition in the given subscription with the given name. + + :param policy_definition_name: The name of the policy definition to delete. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def get( + self, + policy_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyDefinition" + """Retrieves a policy definition in a subscription. + + This operation retrieves the policy definition in the given subscription with the given name. + + :param policy_definition_name: The name of the policy definition to get. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def get_built_in( + self, + policy_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyDefinition" + """Retrieves a built-in policy definition. + + This operation retrieves the built-in policy definition with the given name. + + :param policy_definition_name: The name of the built-in policy definition to get. + :type policy_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_built_in.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def create_or_update_at_management_group( + self, + policy_definition_name, # type: str + management_group_id, # type: str + parameters, # type: "_models.PolicyDefinition" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyDefinition" + """Creates or updates a policy definition in a management group. + + This operation creates or updates a policy definition in the given management group with the + given name. + + :param policy_definition_name: The name of the policy definition to create. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param parameters: The policy definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def delete_at_management_group( + self, + policy_definition_name, # type: str + management_group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a policy definition in a management group. + + This operation deletes the policy definition in the given management group with the given name. + + :param policy_definition_name: The name of the policy definition to delete. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def get_at_management_group( + self, + policy_definition_name, # type: str + management_group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyDefinition" + """Retrieve a policy definition in a management group. + + This operation retrieves the policy definition in the given management group with the given + name. + + :param policy_definition_name: The name of the policy definition to get. + :type policy_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policyDefinitionName': self._serialize.url("policy_definition_name", policy_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionName}'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] + """Retrieves policy definitions in a subscription. + + This operation retrieves a list of all the policy definitions in a given subscription that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy definitions associated with the subscription, including those that apply + directly or from management groups that contain the given subscription. If + $filter=atExactScope() is provided, the returned list only includes all policy definitions that + at the given subscription. If $filter='policyType -eq {value}' is provided, the returned list + only includes all policy definitions whose type match the {value}. Possible policyType values + are NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is provided, + the returned list only includes all policy definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore + + def list_built_in( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] + """Retrieve built-in policy definitions. + + This operation retrieves a list of all the built-in policy definitions that match the optional + given $filter. If $filter='policyType -eq {value}' is provided, the returned list only includes + all built-in policy definitions whose type match the {value}. Possible policyType values are + NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is provided, the + returned list only includes all built-in policy definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_built_in.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore + + def list_by_management_group( + self, + management_group_id, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyDefinitionListResult"] + """Retrieve policy definitions in a management group. + + This operation retrieves a list of all the policy definitions in a given management group that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy definitions associated with the management group, including those that + apply directly or from management groups that contain the given management group. If + $filter=atExactScope() is provided, the returned list only includes all policy definitions that + at the given management group. If $filter='policyType -eq {value}' is provided, the returned + list only includes all policy definitions whose type match the {value}. Possible policyType + values are NotSpecified, BuiltIn, Custom, and Static. If $filter='category -eq {value}' is + provided, the returned list only includes all policy definitions whose category match the + {value}. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy definitions whose type match + the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_exemptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_exemptions_operations.py new file mode 100644 index 000000000000..27d37e056641 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_exemptions_operations.py @@ -0,0 +1,653 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class PolicyExemptionsOperations(object): + """PolicyExemptionsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def delete( + self, + scope, # type: str + policy_exemption_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a policy exemption. + + This operation deletes a policy exemption, given its name and the scope it was created in. The + scope of a policy exemption is the part of its ID preceding + '/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + def create_or_update( + self, + scope, # type: str + policy_exemption_name, # type: str + parameters, # type: "_models.PolicyExemption" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyExemption" + """Creates or updates a policy exemption. + + This operation creates or updates a policy exemption with the given scope and name. Policy + exemptions apply to all resources contained within their scope. For example, when you create a + policy exemption at resource group scope for a policy assignment at the same or above level, + the exemption exempts to all applicable resources in the resource group. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :param parameters: Parameters for the policy exemption. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyExemption, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemption"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicyExemption') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + def get( + self, + scope, # type: str + policy_exemption_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicyExemption" + """Retrieves a policy exemption. + + This operation retrieves a single policy exemption, given its name and the scope it was created + at. + + :param scope: The scope of the policy exemption. Valid scopes are: management group (format: + '/providers/Microsoft.Management/managementGroups/{managementGroup}'), subscription (format: + '/subscriptions/{subscriptionId}'), resource group (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}', or resource (format: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/[{parentResourcePath}/]{resourceType}/{resourceName}'. + :type scope: str + :param policy_exemption_name: The name of the policy exemption to delete. + :type policy_exemption_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicyExemption, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemption + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemption"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'policyExemptionName': self._serialize.url("policy_exemption_name", policy_exemption_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicyExemption', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/{scope}/providers/Microsoft.Authorization/policyExemptions/{policyExemptionName}'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyExemptionListResult"] + """Retrieves all policy exemptions that apply to a subscription. + + This operation retrieves the list of all policy exemptions associated with the given + subscription that match the optional given $filter. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, the unfiltered list includes all policy exemptions associated with the subscription, + including those that apply directly or from management groups that contain the given + subscription, as well as any applied to objects contained within the subscription. + + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_resource_group( + self, + resource_group_name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyExemptionListResult"] + """Retrieves all policy exemptions that apply to a resource group. + + This operation retrieves the list of all policy exemptions associated with the given resource + group in the given subscription that match the optional given $filter. Valid values for $filter + are: 'atScope()', 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If + $filter is not provided, the unfiltered list includes all policy exemptions associated with the + resource group, including those that apply directly or apply from containing scopes, as well as + any applied to resources contained within the resource group. + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_resource( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyExemptionListResult"] + """Retrieves all policy exemptions that apply to a resource. + + This operation retrieves the list of all policy exemptions associated with the specified + resource in the given resource group and subscription that match the optional given $filter. + Valid values for $filter are: 'atScope()', 'atExactScope()', 'excludeExpired()' or + 'policyAssignmentId eq '{value}''. If $filter is not provided, the unfiltered list includes all + policy exemptions associated with the resource, including those that apply directly or from all + containing scopes, as well as any applied to resources contained within the resource. Three + parameters plus the resource name are used to identify a specific resource. If the resource is + not part of a parent resource (the more common case), the parent resource path should not be + provided (or provided as ''). For example a web app could be specified as + ({resourceProviderNamespace} == 'Microsoft.Web', {parentResourcePath} == '', {resourceType} == + 'sites', {resourceName} == 'MyWebApp'). If the resource is part of a parent resource, then all + parameters should be provided. For example a virtual machine DNS name could be specified as + ({resourceProviderNamespace} == 'Microsoft.Compute', {parentResourcePath} == + 'virtualMachines/MyVirtualMachine', {resourceType} == 'domainNames', {resourceName} == + 'MyComputerName'). A convenient alternative to providing the namespace and type name separately + is to provide both in the {resourceType} parameter, format: ({resourceProviderNamespace} == '', + {parentResourcePath} == '', {resourceType} == 'Microsoft.Web/sites', {resourceName} == + 'MyWebApp'). + + :param resource_group_name: The name of the resource group containing the resource. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. For example, the + namespace of a virtual machine is Microsoft.Compute (from Microsoft.Compute/virtualMachines). + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource path. Use empty string if there is none. + :type parent_resource_path: str + :param resource_type: The resource type name. For example the type name of a web app is 'sites' + (from Microsoft.Web/sites). + :type resource_type: str + :param resource_name: The name of the resource. + :type resource_name: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_resource.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_resource.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore + + def list_for_management_group( + self, + management_group_id, # type: str + filter=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicyExemptionListResult"] + """Retrieves all policy exemptions that apply to a management group. + + This operation retrieves the list of all policy exemptions applicable to the management group + that match the given $filter. Valid values for $filter are: 'atScope()', 'atExactScope()', + 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter=atScope() is provided, the + returned list includes all policy exemptions that are assigned to the management group or the + management group's ancestors. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: 'atScope()', + 'atExactScope()', 'excludeExpired()' or 'policyAssignmentId eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter is not provided, the unfiltered list includes + all policy exemptions associated with the scope, including those that apply directly or apply + from containing scopes. If $filter=atScope() is provided, the returned list only includes all + policy exemptions that apply to the scope, which is everything in the unfiltered list except + those applied to sub scopes contained within the given scope. If $filter=atExactScope() is + provided, the returned list only includes all policy exemptions that at the given scope. If + $filter=excludeExpired() is provided, the returned list only includes all policy exemptions + that either haven't expired or didn't set expiration date. If $filter=policyAssignmentId eq + '{value}' is provided. the returned list only includes all policy exemptions that are + associated with the give policyAssignmentId. + :type filter: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicyExemptionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicyExemptionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicyExemptionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-07-01-preview" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_for_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicyExemptionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_for_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyExemptions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_set_definitions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_set_definitions_operations.py new file mode 100644 index 000000000000..cf759630adb7 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/operations/_policy_set_definitions_operations.py @@ -0,0 +1,757 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class PolicySetDefinitionsOperations(object): + """PolicySetDefinitionsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.policy.v2020_09_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def create_or_update( + self, + policy_set_definition_name, # type: str + parameters, # type: "_models.PolicySetDefinition" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicySetDefinition" + """Creates or updates a policy set definition. + + This operation creates or updates a policy set definition in the given subscription with the + given name. + + :param policy_set_definition_name: The name of the policy set definition to create. + :type policy_set_definition_name: str + :param parameters: The policy set definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicySetDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def delete( + self, + policy_set_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a policy set definition. + + This operation deletes the policy set definition in the given subscription with the given name. + + :param policy_set_definition_name: The name of the policy set definition to delete. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def get( + self, + policy_set_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicySetDefinition" + """Retrieves a policy set definition. + + This operation retrieves the policy set definition in the given subscription with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def get_built_in( + self, + policy_set_definition_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicySetDefinition" + """Retrieves a built in policy set definition. + + This operation retrieves the built-in policy set definition with the given name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_built_in.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] + """Retrieves the policy set definitions for a subscription. + + This operation retrieves a list of all the policy set definitions in a given subscription that + match the optional given $filter. Valid values for $filter are: 'atExactScope()', 'policyType + -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered list + includes all policy set definitions associated with the subscription, including those that + apply directly or from management groups that contain the given subscription. If + $filter=atExactScope() is provided, the returned list only includes all policy set definitions + that at the given subscription. If $filter='policyType -eq {value}' is provided, the returned + list only includes all policy set definitions whose type match the {value}. Possible policyType + values are NotSpecified, BuiltIn and Custom. If $filter='category -eq {value}' is provided, the + returned list only includes all policy set definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore + + def list_built_in( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] + """Retrieves built-in policy set definitions. + + This operation retrieves a list of all the built-in policy set definitions that match the + optional given $filter. If $filter='category -eq {value}' is provided, the returned list only + includes all built-in policy set definitions whose category match the {value}. + + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_built_in.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_built_in.metadata = {'url': '/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore + + def create_or_update_at_management_group( + self, + policy_set_definition_name, # type: str + management_group_id, # type: str + parameters, # type: "_models.PolicySetDefinition" + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicySetDefinition" + """Creates or updates a policy set definition. + + This operation creates or updates a policy set definition in the given management group with + the given name. + + :param policy_set_definition_name: The name of the policy set definition to create. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param parameters: The policy set definition properties. + :type parameters: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'PolicySetDefinition') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def delete_at_management_group( + self, + policy_set_definition_name, # type: str + management_group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a policy set definition. + + This operation deletes the policy set definition in the given management group with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to delete. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def get_at_management_group( + self, + policy_set_definition_name, # type: str + management_group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.PolicySetDefinition" + """Retrieves a policy set definition. + + This operation retrieves the policy set definition in the given management group with the given + name. + + :param policy_set_definition_name: The name of the policy set definition to get. + :type policy_set_definition_name: str + :param management_group_id: The ID of the management group. + :type management_group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: PolicySetDefinition, or the result of cls(response) + :rtype: ~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinition + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinition"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'policySetDefinitionName': self._serialize.url("policy_set_definition_name", policy_set_definition_name, 'str'), + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('PolicySetDefinition', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions/{policySetDefinitionName}'} # type: ignore + + def list_by_management_group( + self, + management_group_id, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.PolicySetDefinitionListResult"] + """Retrieves all policy set definitions in management group. + + This operation retrieves a list of all the policy set definitions in a given management group + that match the optional given $filter. Valid values for $filter are: 'atExactScope()', + 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not provided, the unfiltered + list includes all policy set definitions associated with the management group, including those + that apply directly or from management groups that contain the given management group. If + $filter=atExactScope() is provided, the returned list only includes all policy set definitions + that at the given management group. If $filter='policyType -eq {value}' is provided, the + returned list only includes all policy set definitions whose type match the {value}. Possible + policyType values are NotSpecified, BuiltIn and Custom. If $filter='category -eq {value}' is + provided, the returned list only includes all policy set definitions whose category match the + {value}. + + :param management_group_id: The ID of the management group. + :type management_group_id: str + :param filter: The filter to apply on the operation. Valid values for $filter are: + 'atExactScope()', 'policyType -eq {value}' or 'category eq '{value}''. If $filter is not + provided, no filtering is performed. If $filter=atExactScope() is provided, the returned list + only includes all policy set definitions that at the given scope. If $filter='policyType -eq + {value}' is provided, the returned list only includes all policy set definitions whose type + match the {value}. Possible policyType values are NotSpecified, BuiltIn, Custom, and Static. If + $filter='category -eq {value}' is provided, the returned list only includes all policy set + definitions whose category match the {value}. + :type filter: str + :param top: Maximum number of records to return. When the $top filter is not provided, it will + return 500 records. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either PolicySetDefinitionListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.policy.v2020_09_01.models.PolicySetDefinitionListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.PolicySetDefinitionListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-09-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_management_group.metadata['url'] # type: ignore + path_format_arguments = { + 'managementGroupId': self._serialize.url("management_group_id", management_group_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str', skip_quote=True) + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int', maximum=1000, minimum=1) + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('PolicySetDefinitionListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_management_group.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policySetDefinitions'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/py.typed b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/policy/v2020_09_01/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_resource_management_client.py index c9df5c6d1c5c..b11f5770f567 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_resource_management_client.py @@ -46,7 +46,7 @@ class ResourceManagementClient(MultiApiClientMixin, _SDKClient): :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2020-06-01' + DEFAULT_API_VERSION = '2020-10-01' _PROFILE_TAG = "azure.mgmt.resource.ResourceManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -93,6 +93,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2019-08-01: :mod:`v2019_08_01.models` * 2019-10-01: :mod:`v2019_10_01.models` * 2020-06-01: :mod:`v2020_06_01.models` + * 2020-10-01: :mod:`v2020_10_01.models` """ if api_version == '2016-02-01': from .v2016_02_01 import models @@ -130,6 +131,9 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2020-06-01': from .v2020_06_01 import models return models + elif api_version == '2020-10-01': + from .v2020_10_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -148,6 +152,7 @@ def deployment_operations(self): * 2019-08-01: :class:`DeploymentOperationsOperations` * 2019-10-01: :class:`DeploymentOperationsOperations` * 2020-06-01: :class:`DeploymentOperationsOperations` + * 2020-10-01: :class:`DeploymentOperationsOperations` """ api_version = self._get_api_version('deployment_operations') if api_version == '2016-02-01': @@ -174,6 +179,8 @@ def deployment_operations(self): from .v2019_10_01.operations import DeploymentOperationsOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import DeploymentOperationsOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import DeploymentOperationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deployment_operations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -194,6 +201,7 @@ def deployments(self): * 2019-08-01: :class:`DeploymentsOperations` * 2019-10-01: :class:`DeploymentsOperations` * 2020-06-01: :class:`DeploymentsOperations` + * 2020-10-01: :class:`DeploymentsOperations` """ api_version = self._get_api_version('deployments') if api_version == '2016-02-01': @@ -220,6 +228,8 @@ def deployments(self): from .v2019_10_01.operations import DeploymentsOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import DeploymentsOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import DeploymentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deployments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -236,6 +246,7 @@ def operations(self): * 2019-08-01: :class:`Operations` * 2019-10-01: :class:`Operations` * 2020-06-01: :class:`Operations` + * 2020-10-01: :class:`Operations` """ api_version = self._get_api_version('operations') if api_version == '2018-05-01': @@ -254,10 +265,25 @@ def operations(self): from .v2019_10_01.operations import Operations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import Operations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import Operations as OperationClass else: raise ValueError("API version {} does not have operation group 'operations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def provider_resource_types(self): + """Instance depends on the API version: + + * 2020-10-01: :class:`ProviderResourceTypesOperations` + """ + api_version = self._get_api_version('provider_resource_types') + if api_version == '2020-10-01': + from .v2020_10_01.operations import ProviderResourceTypesOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'provider_resource_types'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def providers(self): """Instance depends on the API version: @@ -274,6 +300,7 @@ def providers(self): * 2019-08-01: :class:`ProvidersOperations` * 2019-10-01: :class:`ProvidersOperations` * 2020-06-01: :class:`ProvidersOperations` + * 2020-10-01: :class:`ProvidersOperations` """ api_version = self._get_api_version('providers') if api_version == '2016-02-01': @@ -300,6 +327,8 @@ def providers(self): from .v2019_10_01.operations import ProvidersOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import ProvidersOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import ProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -320,6 +349,7 @@ def resource_groups(self): * 2019-08-01: :class:`ResourceGroupsOperations` * 2019-10-01: :class:`ResourceGroupsOperations` * 2020-06-01: :class:`ResourceGroupsOperations` + * 2020-10-01: :class:`ResourceGroupsOperations` """ api_version = self._get_api_version('resource_groups') if api_version == '2016-02-01': @@ -346,6 +376,8 @@ def resource_groups(self): from .v2019_10_01.operations import ResourceGroupsOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import ResourceGroupsOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import ResourceGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -366,6 +398,7 @@ def resources(self): * 2019-08-01: :class:`ResourcesOperations` * 2019-10-01: :class:`ResourcesOperations` * 2020-06-01: :class:`ResourcesOperations` + * 2020-10-01: :class:`ResourcesOperations` """ api_version = self._get_api_version('resources') if api_version == '2016-02-01': @@ -392,6 +425,8 @@ def resources(self): from .v2019_10_01.operations import ResourcesOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import ResourcesOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import ResourcesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resources'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -412,6 +447,7 @@ def tags(self): * 2019-08-01: :class:`TagsOperations` * 2019-10-01: :class:`TagsOperations` * 2020-06-01: :class:`TagsOperations` + * 2020-10-01: :class:`TagsOperations` """ api_version = self._get_api_version('tags') if api_version == '2016-02-01': @@ -438,6 +474,8 @@ def tags(self): from .v2019_10_01.operations import TagsOperations as OperationClass elif api_version == '2020-06-01': from .v2020_06_01.operations import TagsOperations as OperationClass + elif api_version == '2020-10-01': + from .v2020_10_01.operations import TagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/aio/_resource_management_client.py index c686de0d0c11..7496bf187b21 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/aio/_resource_management_client.py @@ -46,7 +46,7 @@ class ResourceManagementClient(MultiApiClientMixin, _SDKClient): :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. """ - DEFAULT_API_VERSION = '2020-06-01' + DEFAULT_API_VERSION = '2020-10-01' _PROFILE_TAG = "azure.mgmt.resource.ResourceManagementClient" LATEST_PROFILE = ProfileDefinition({ _PROFILE_TAG: { @@ -93,6 +93,7 @@ def models(cls, api_version=DEFAULT_API_VERSION): * 2019-08-01: :mod:`v2019_08_01.models` * 2019-10-01: :mod:`v2019_10_01.models` * 2020-06-01: :mod:`v2020_06_01.models` + * 2020-10-01: :mod:`v2020_10_01.models` """ if api_version == '2016-02-01': from ..v2016_02_01 import models @@ -130,6 +131,9 @@ def models(cls, api_version=DEFAULT_API_VERSION): elif api_version == '2020-06-01': from ..v2020_06_01 import models return models + elif api_version == '2020-10-01': + from ..v2020_10_01 import models + return models raise ValueError("API version {} is not available".format(api_version)) @property @@ -148,6 +152,7 @@ def deployment_operations(self): * 2019-08-01: :class:`DeploymentOperationsOperations` * 2019-10-01: :class:`DeploymentOperationsOperations` * 2020-06-01: :class:`DeploymentOperationsOperations` + * 2020-10-01: :class:`DeploymentOperationsOperations` """ api_version = self._get_api_version('deployment_operations') if api_version == '2016-02-01': @@ -174,6 +179,8 @@ def deployment_operations(self): from ..v2019_10_01.aio.operations import DeploymentOperationsOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import DeploymentOperationsOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import DeploymentOperationsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deployment_operations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -194,6 +201,7 @@ def deployments(self): * 2019-08-01: :class:`DeploymentsOperations` * 2019-10-01: :class:`DeploymentsOperations` * 2020-06-01: :class:`DeploymentsOperations` + * 2020-10-01: :class:`DeploymentsOperations` """ api_version = self._get_api_version('deployments') if api_version == '2016-02-01': @@ -220,6 +228,8 @@ def deployments(self): from ..v2019_10_01.aio.operations import DeploymentsOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import DeploymentsOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import DeploymentsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'deployments'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -236,6 +246,7 @@ def operations(self): * 2019-08-01: :class:`Operations` * 2019-10-01: :class:`Operations` * 2020-06-01: :class:`Operations` + * 2020-10-01: :class:`Operations` """ api_version = self._get_api_version('operations') if api_version == '2018-05-01': @@ -254,10 +265,25 @@ def operations(self): from ..v2019_10_01.aio.operations import Operations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import Operations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import Operations as OperationClass else: raise ValueError("API version {} does not have operation group 'operations'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property + def provider_resource_types(self): + """Instance depends on the API version: + + * 2020-10-01: :class:`ProviderResourceTypesOperations` + """ + api_version = self._get_api_version('provider_resource_types') + if api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import ProviderResourceTypesOperations as OperationClass + else: + raise ValueError("API version {} does not have operation group 'provider_resource_types'".format(api_version)) + return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) + @property def providers(self): """Instance depends on the API version: @@ -274,6 +300,7 @@ def providers(self): * 2019-08-01: :class:`ProvidersOperations` * 2019-10-01: :class:`ProvidersOperations` * 2020-06-01: :class:`ProvidersOperations` + * 2020-10-01: :class:`ProvidersOperations` """ api_version = self._get_api_version('providers') if api_version == '2016-02-01': @@ -300,6 +327,8 @@ def providers(self): from ..v2019_10_01.aio.operations import ProvidersOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import ProvidersOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import ProvidersOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'providers'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -320,6 +349,7 @@ def resource_groups(self): * 2019-08-01: :class:`ResourceGroupsOperations` * 2019-10-01: :class:`ResourceGroupsOperations` * 2020-06-01: :class:`ResourceGroupsOperations` + * 2020-10-01: :class:`ResourceGroupsOperations` """ api_version = self._get_api_version('resource_groups') if api_version == '2016-02-01': @@ -346,6 +376,8 @@ def resource_groups(self): from ..v2019_10_01.aio.operations import ResourceGroupsOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import ResourceGroupsOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import ResourceGroupsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resource_groups'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -366,6 +398,7 @@ def resources(self): * 2019-08-01: :class:`ResourcesOperations` * 2019-10-01: :class:`ResourcesOperations` * 2020-06-01: :class:`ResourcesOperations` + * 2020-10-01: :class:`ResourcesOperations` """ api_version = self._get_api_version('resources') if api_version == '2016-02-01': @@ -392,6 +425,8 @@ def resources(self): from ..v2019_10_01.aio.operations import ResourcesOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import ResourcesOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import ResourcesOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'resources'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) @@ -412,6 +447,7 @@ def tags(self): * 2019-08-01: :class:`TagsOperations` * 2019-10-01: :class:`TagsOperations` * 2020-06-01: :class:`TagsOperations` + * 2020-10-01: :class:`TagsOperations` """ api_version = self._get_api_version('tags') if api_version == '2016-02-01': @@ -438,6 +474,8 @@ def tags(self): from ..v2019_10_01.aio.operations import TagsOperations as OperationClass elif api_version == '2020-06-01': from ..v2020_06_01.aio.operations import TagsOperations as OperationClass + elif api_version == '2020-10-01': + from ..v2020_10_01.aio.operations import TagsOperations as OperationClass else: raise ValueError("API version {} does not have operation group 'tags'".format(api_version)) return OperationClass(self._client, self._config, Serializer(self._models_dict(api_version)), Deserializer(self._models_dict(api_version))) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/models.py index ead4a104371c..3a453a73ab82 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/models.py @@ -4,4 +4,4 @@ # Licensed under the MIT License. See License.txt in the project root for # license information. # -------------------------------------------------------------------------- -from .v2020_06_01.models import * +from .v2020_10_01.models import * diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_metadata.json index 3c91ef0c448e..c3a0a474db53 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_resource_management_client.py index 383bf1ecf89a..e2549c8e686f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/_resource_management_client.py index 894ae4bc1a8a..b3adca2932c1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/_resource_management_client.py @@ -62,7 +62,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployment_operations_operations.py index 4fdcd7d6eb65..b74ea9bb8769 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Get a list of deployments operations. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -61,7 +61,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -109,7 +109,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets a list of deployments operations. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -123,7 +123,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployments_operations.py index 52b2ccf76aa7..0c1f2b5794fa 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -129,7 +129,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -202,10 +208,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -259,9 +265,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Create a named template deployment using a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -281,7 +287,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -306,7 +312,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -325,7 +337,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Get a deployment. :param resource_group_name: The name of the resource group to get. The name is case @@ -338,7 +350,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -436,9 +448,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validate a deployment template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -452,7 +464,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -507,7 +519,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports a deployment template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -519,7 +531,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -566,7 +578,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get a list of deployments. :param resource_group_name: The name of the resource group to filter by. The name is case @@ -581,7 +593,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -645,7 +657,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -655,7 +667,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_providers_operations.py index c54bdc3f2bcd..4d6ddc4f5954 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters provider from a subscription. :param resource_provider_namespace: Namespace of the resource provider. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers provider to be used with a subscription. :param resource_provider_namespace: Namespace of the resource provider. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets a list of resource providers. :param top: Query parameters. If null is passed returns all deployments. @@ -167,7 +167,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -231,7 +231,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets a resource provider. :param resource_provider_namespace: Namespace of the resource provider. @@ -244,7 +244,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resource_groups_operations.py index abc84ab253fe..bc7b66498cb7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_resources( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all of the resources under a subscription. :param resource_group_name: Query parameters. If null is passed returns all resource groups. @@ -68,7 +68,7 @@ def list_resources( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -184,9 +184,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Create a resource group. :param resource_group_name: The name of the resource group to be created or updated. @@ -199,7 +199,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -329,7 +329,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -347,7 +352,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Get a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -358,7 +363,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -401,9 +406,9 @@ async def get( async def patch( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Resource groups can be updated through a simple PATCH operation to a group address. The format of the request is the same as that for creating a resource groups, though if a field is unspecified current value will be carried over. @@ -418,7 +423,7 @@ async def patch( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -466,9 +471,9 @@ async def patch( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to be created or updated. @@ -480,7 +485,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -530,7 +535,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets a collection of resource groups. :param filter: The filter to apply on the operation. @@ -542,7 +547,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resources_operations.py index 3c115d60acf8..6ca5a02de35d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -92,7 +92,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Move resources from one resource group to another. The resources being moved should all be in @@ -134,7 +134,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -154,7 +159,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all of the resources under a subscription. :param filter: The filter to apply on the operation. @@ -170,7 +175,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -369,9 +374,9 @@ async def create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Create a resource. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -391,7 +396,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -451,10 +456,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -512,9 +517,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -541,7 +546,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -569,7 +574,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -591,7 +605,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Returns a resource belonging to a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -609,7 +623,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_tags_operations.py index d49d3d6bc7a6..36c6654550d0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Create a subscription resource tag value. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Create a subscription resource tag. :param tag_name: The name of the tag. @@ -170,7 +170,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -266,7 +266,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Get a list of subscription resource tags. :keyword callable cls: A custom type or function that will be passed the direct response @@ -274,7 +274,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models.py index 61a465147949..0a4e5fe9b3b8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models.py @@ -515,7 +515,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models_py3.py index edbf263a65b5..d5e809043cbc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/models/_models_py3.py @@ -588,7 +588,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployment_operations_operations.py index 1e3de60297cd..e7bf1adccca9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Get a list of deployments operations. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -66,7 +66,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -115,7 +115,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets a list of deployments operations. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -129,7 +129,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployments_operations.py index 4d456255baae..7c78dd223f5c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -135,7 +135,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -209,11 +215,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -267,10 +273,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Create a named template deployment using a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -290,7 +296,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -315,7 +321,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -335,7 +347,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Get a deployment. :param resource_group_name: The name of the resource group to get. The name is case @@ -348,7 +360,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -447,10 +459,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validate a deployment template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -464,7 +476,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -520,7 +532,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports a deployment template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -532,7 +544,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -580,7 +592,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get a list of deployments. :param resource_group_name: The name of the resource group to filter by. The name is case @@ -595,7 +607,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -660,7 +672,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -670,7 +682,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_providers_operations.py index 5cae348fd48b..fc3ac8b1f470 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters provider from a subscription. :param resource_provider_namespace: Namespace of the resource provider. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers provider to be used with a subscription. :param resource_provider_namespace: Namespace of the resource provider. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets a list of resource providers. :param top: Query parameters. If null is passed returns all deployments. @@ -174,7 +174,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -239,7 +239,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets a resource provider. :param resource_provider_namespace: Namespace of the resource provider. @@ -252,7 +252,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resource_groups_operations.py index a8f49a319fad..cdda9e1d1074 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_resources( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all of the resources under a subscription. :param resource_group_name: Query parameters. If null is passed returns all resource groups. @@ -73,7 +73,7 @@ def list_resources( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -190,10 +190,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Create a resource group. :param resource_group_name: The name of the resource group to be created or updated. @@ -206,7 +206,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -338,7 +338,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -357,7 +362,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Get a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -368,7 +373,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -411,10 +416,10 @@ def get( def patch( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Resource groups can be updated through a simple PATCH operation to a group address. The format of the request is the same as that for creating a resource groups, though if a field is unspecified current value will be carried over. @@ -429,7 +434,7 @@ def patch( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -477,10 +482,10 @@ def patch( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to be created or updated. @@ -492,7 +497,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -543,7 +548,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets a collection of resource groups. :param filter: The filter to apply on the operation. @@ -555,7 +560,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resources_operations.py index 12d8bf6e19c4..809c7d0c8d07 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def __init__(self, client, config, serializer, deserializer): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -97,7 +97,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -140,7 +140,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -161,7 +166,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all of the resources under a subscription. :param filter: The filter to apply on the operation. @@ -177,7 +182,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -378,10 +383,10 @@ def create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Create a resource. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -401,7 +406,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,11 +466,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -523,10 +528,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -553,7 +558,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -581,7 +586,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -604,7 +618,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Returns a resource belonging to a resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -622,7 +636,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_tags_operations.py index dc7a6604ceb5..d2a53d834a92 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_02_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Create a subscription resource tag value. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Create a subscription resource tag. :param tag_name: The name of the tag. @@ -177,7 +177,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_02_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -275,7 +275,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Get a list of subscription resource tags. :keyword callable cls: A custom type or function that will be passed the direct response @@ -283,7 +283,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_02_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_metadata.json index 2156175f0aec..0e30eb40f79b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_resource_management_client.py index 60a5a61e6c1b..b927379a4132 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/_resource_management_client.py index 7e62895f206b..2a7645a9ca97 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/_resource_management_client.py @@ -62,7 +62,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployment_operations_operations.py index 3aaf15d6ee56..2bb2fe85b018 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -61,7 +61,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -109,7 +109,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -123,7 +123,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployments_operations.py index d9b386ec324a..6365e68bfbfe 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -139,7 +139,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -212,10 +218,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -269,9 +275,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -294,7 +300,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -319,7 +325,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -338,7 +350,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -350,7 +362,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,9 +465,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -471,7 +483,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -526,7 +538,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -538,7 +550,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -585,7 +597,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -601,7 +613,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +677,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -675,7 +687,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_providers_operations.py index 3adb590302d6..1f7891cdaa87 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resource_groups_operations.py index 0a6a2236dc1f..5f9d374e5d41 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_resources( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -68,7 +68,7 @@ def list_resources( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -184,9 +184,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -198,7 +198,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,7 +331,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -349,7 +354,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -360,7 +365,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -403,9 +408,9 @@ async def get( async def patch( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -422,7 +427,7 @@ async def patch( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -470,9 +475,9 @@ async def patch( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -484,7 +489,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +539,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -546,7 +551,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resources_operations.py index 38861bd620f2..722a0efdfb7b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -92,7 +92,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -139,7 +139,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -159,7 +164,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -175,7 +180,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -408,7 +413,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -429,10 +443,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -493,9 +507,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -522,7 +536,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -550,7 +564,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -571,10 +594,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -632,9 +655,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -661,7 +684,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -689,7 +712,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -711,7 +743,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -730,7 +762,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -906,7 +938,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -923,10 +959,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -978,9 +1014,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1000,7 +1036,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1024,7 +1060,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1041,10 +1081,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1093,9 +1133,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1115,7 +1155,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1139,7 +1179,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1157,7 +1201,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1169,7 +1213,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_tags_operations.py index d334bab884e4..ef89a91304e1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models.py index 44aff0e4dfa9..03bbbd663cbe 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models.py @@ -579,7 +579,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models_py3.py index 3390b47ee2d4..ea0c269450f5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/models/_models_py3.py @@ -635,7 +635,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployment_operations_operations.py index 1b604329e7c6..a410f6846b1f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -66,7 +66,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -115,7 +115,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -129,7 +129,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployments_operations.py index f5a98444220a..701d99f725a0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -145,7 +145,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -219,11 +225,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -277,10 +283,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -303,7 +309,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -328,7 +334,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -348,7 +360,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -360,7 +372,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -464,10 +476,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -483,7 +495,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -539,7 +551,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -551,7 +563,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -599,7 +611,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -615,7 +627,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -680,7 +692,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -690,7 +702,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_providers_operations.py index cb8fa77e05b2..81fe1285b656 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resource_groups_operations.py index ab921aa7febe..b8d26a92fd1c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_resources( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -73,7 +73,7 @@ def list_resources( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -190,10 +190,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -205,7 +205,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -340,7 +340,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -359,7 +364,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -370,7 +375,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -413,10 +418,10 @@ def get( def patch( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -433,7 +438,7 @@ def patch( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -481,10 +486,10 @@ def patch( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -496,7 +501,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -547,7 +552,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -559,7 +564,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resources_operations.py index 5c4161412f41..4f4d19f5c3b7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def __init__(self, client, config, serializer, deserializer): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -97,7 +97,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -145,7 +145,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -166,7 +171,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -182,7 +187,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -418,7 +423,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -439,11 +453,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -504,10 +518,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -534,7 +548,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -562,7 +576,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -583,11 +606,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -645,10 +668,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -675,7 +698,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -703,7 +726,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -726,7 +758,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -745,7 +777,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -924,7 +956,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -941,11 +977,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -997,10 +1033,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1020,7 +1056,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1044,7 +1080,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1061,11 +1101,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1114,10 +1154,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1137,7 +1177,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1161,7 +1201,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1180,7 +1224,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1192,7 +1236,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_tags_operations.py index 7e55e5f098ba..2441a972c186 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2016_09_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2016_09_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2016_09_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_metadata.json index 66a56cf6a0da..d8f2c0f9bb97 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_resource_management_client.py index 3f01877e3502..68a9f4c22548 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/_resource_management_client.py index 8a204cbf5f34..ee8cb7857c3d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/_resource_management_client.py @@ -62,7 +62,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployment_operations_operations.py index 5aceee5e44d7..0971370197d6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -61,7 +61,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -109,7 +109,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -123,7 +123,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployments_operations.py index 8be97357f53e..f9dec12ecefc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -139,7 +139,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -212,10 +218,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -269,9 +275,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -294,7 +300,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -319,7 +325,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -338,7 +350,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -350,7 +362,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,9 +465,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -471,7 +483,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -526,7 +538,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -538,7 +550,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -585,7 +597,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -601,7 +613,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +677,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -675,7 +687,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_providers_operations.py index 47820433d4d2..38dcfce853a4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resource_groups_operations.py index ca379fbd4c87..d0c8f91f7309 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -111,7 +111,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -273,7 +278,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -316,9 +321,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -335,7 +340,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -383,9 +388,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -397,7 +402,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -447,7 +452,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -459,7 +464,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resources_operations.py index 34823d192729..95034f2dc0dc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -68,7 +68,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -133,7 +133,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -179,7 +179,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -226,7 +226,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -243,7 +248,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -289,7 +294,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -338,7 +343,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -358,7 +368,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -374,7 +384,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -607,7 +617,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -628,10 +647,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -692,9 +711,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -721,7 +740,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -749,7 +768,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -770,10 +798,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -831,9 +859,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -860,7 +888,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -888,7 +916,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -910,7 +947,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -929,7 +966,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1105,7 +1142,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1122,10 +1163,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1177,9 +1218,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1199,7 +1240,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1223,7 +1264,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1240,10 +1285,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1292,9 +1337,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1314,7 +1359,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1338,7 +1383,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1356,7 +1405,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1368,7 +1417,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_tags_operations.py index 03a439e02c32..e6892a6e1b70 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models.py index 6e2f34bc6ce9..57e5972c93a7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models.py @@ -579,7 +579,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models_py3.py index 2358ee3e1221..9bf62e0634f6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/models/_models_py3.py @@ -635,7 +635,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployment_operations_operations.py index 79dfb6fcb990..41873f90deaf 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -66,7 +66,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -115,7 +115,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -129,7 +129,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployments_operations.py index 505c61d43b1c..25539a120ff3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -145,7 +145,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -219,11 +225,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -277,10 +283,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -303,7 +309,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -328,7 +334,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -348,7 +360,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -360,7 +372,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -464,10 +476,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -483,7 +495,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -539,7 +551,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -551,7 +563,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -599,7 +611,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -615,7 +627,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -680,7 +692,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -690,7 +702,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_providers_operations.py index d101cf1de039..00068ea87df3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resource_groups_operations.py index ba31cf8424f2..55d0b77c102d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -117,7 +117,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -252,7 +252,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -271,7 +276,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -282,7 +287,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,10 +330,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -345,7 +350,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -393,10 +398,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -408,7 +413,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -459,7 +464,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -471,7 +476,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resources_operations.py index a7af883648f9..7a36f593aead 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -73,7 +73,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -138,7 +138,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -185,7 +185,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -233,7 +233,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -250,7 +255,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -297,7 +302,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -347,7 +352,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -368,7 +378,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -384,7 +394,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -620,7 +630,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -641,11 +660,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -706,10 +725,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -736,7 +755,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -764,7 +783,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -785,11 +813,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -847,10 +875,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -877,7 +905,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -905,7 +933,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -928,7 +965,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -947,7 +984,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1126,7 +1163,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1143,11 +1184,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1199,10 +1240,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1222,7 +1263,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1246,7 +1287,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1263,11 +1308,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1316,10 +1361,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1339,7 +1384,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1363,7 +1408,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1382,7 +1431,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1394,7 +1443,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_tags_operations.py index 43d7a8105656..736eabed5f91 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2017_05_10/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2017_05_10.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2017_05_10.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_metadata.json index aff7c8743149..d0bdfad742de 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_resource_management_client.py index 025b3b52f6de..ae1287c9906a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/_resource_management_client.py index 188d08f9f6b0..e4321230d368 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/_resource_management_client.py @@ -62,7 +62,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.deployments = DeploymentsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployment_operations_operations.py index bc2d9eb868be..ff0f056910c1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -61,7 +61,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -109,7 +109,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -123,7 +123,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployments_operations.py index 88154e0eac83..d1dc607ab52f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -139,7 +139,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -212,10 +218,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -269,9 +275,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -294,7 +300,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -319,7 +325,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -338,7 +350,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -350,7 +362,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,9 +465,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -471,7 +483,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -526,7 +538,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -538,7 +550,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -585,7 +597,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -601,7 +613,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +677,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -675,7 +687,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_providers_operations.py index 615f622f2c27..80abd3648e46 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resource_groups_operations.py index e2bf42864676..087d66f2beaf 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -111,7 +111,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -244,7 +244,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -273,7 +278,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -316,9 +321,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -335,7 +340,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -383,9 +388,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -397,7 +402,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -447,7 +452,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -459,7 +464,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resources_operations.py index ba5d0c67bdd1..ca9d50b1a00a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -68,7 +68,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -133,7 +133,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -179,7 +179,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -226,7 +226,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -243,7 +248,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -289,7 +294,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -338,7 +343,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -358,7 +368,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -372,7 +382,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -605,7 +615,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -626,10 +645,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -690,9 +709,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -719,7 +738,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -747,7 +766,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -768,10 +796,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -829,9 +857,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -858,7 +886,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -886,7 +914,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -908,7 +945,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -927,7 +964,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1103,7 +1140,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1120,10 +1161,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1175,9 +1216,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1197,7 +1238,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1221,7 +1262,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1238,10 +1283,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1290,9 +1335,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1312,7 +1357,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1336,7 +1381,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1354,7 +1403,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1366,7 +1415,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_tags_operations.py index 669dd4109309..5f516b911a60 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models.py index 3b62d2d1828f..aea2c9cef4b4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models.py @@ -588,7 +588,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models_py3.py index 7c87ac810eb5..60ddfd01e772 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/models/_models_py3.py @@ -646,7 +646,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployment_operations_operations.py index e72ba3a31d0d..2f2ce99259e4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -66,7 +66,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -115,7 +115,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -129,7 +129,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployments_operations.py index 8f352af80004..86c636296924 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -145,7 +145,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -219,11 +225,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -277,10 +283,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -303,7 +309,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -328,7 +334,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -348,7 +360,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -360,7 +372,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -464,10 +476,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -483,7 +495,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -539,7 +551,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -551,7 +563,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -599,7 +611,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -615,7 +627,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -680,7 +692,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -690,7 +702,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_providers_operations.py index 7f0f2226712a..d23050575de0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resource_groups_operations.py index f90bc1a242a6..30120065fcd8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. @@ -117,7 +117,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -252,7 +252,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -271,7 +276,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -282,7 +287,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -325,10 +330,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -345,7 +350,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -393,10 +398,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -408,7 +413,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -459,7 +464,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation. @@ -471,7 +476,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resources_operations.py index 5d0c42018946..f558e10e9ee5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -73,7 +73,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -138,7 +138,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -185,7 +185,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -233,7 +233,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -250,7 +255,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -297,7 +302,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -347,7 +352,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -368,7 +378,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation. @@ -382,7 +392,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -618,7 +628,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -639,11 +658,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -704,10 +723,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -734,7 +753,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -762,7 +781,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -783,11 +811,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -845,10 +873,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -875,7 +903,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -903,7 +931,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -926,7 +963,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -945,7 +982,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1124,7 +1161,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1141,11 +1182,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1197,10 +1238,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1220,7 +1261,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1244,7 +1285,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1261,11 +1306,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1314,10 +1359,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1337,7 +1382,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1361,7 +1406,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1380,7 +1429,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1392,7 +1441,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_tags_operations.py index 158d7dd2e80e..43810df820ee 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_02_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_02_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_02_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_metadata.json index d47b3ad00f94..791916fb4a39 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_resource_management_client.py index bf7f9087aea3..98dde11dc598 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/_resource_management_client.py index 35dd085ec1c8..1977c399b7e2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployment_operations_operations.py index f239145f580e..48c9b2d84925 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -58,7 +58,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -104,7 +104,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment with the operation to get. @@ -116,7 +116,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -180,7 +180,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -194,7 +194,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -256,7 +256,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployments_operations.py index a518e24f9aff..7e25c0209dde 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -131,7 +131,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -198,10 +203,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -253,9 +258,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -275,7 +280,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -299,7 +304,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -317,7 +327,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment to get. @@ -327,7 +337,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -424,9 +434,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -439,7 +449,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -492,7 +502,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment from which to get the template. @@ -502,7 +512,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -547,7 +557,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -560,7 +570,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -715,7 +725,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -788,10 +804,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -845,9 +861,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -870,7 +886,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -895,7 +911,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -914,7 +936,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -926,7 +948,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1029,9 +1051,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1047,7 +1069,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1102,7 +1124,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1114,7 +1136,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1161,7 +1183,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1177,7 +1199,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1241,7 +1263,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1251,7 +1273,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_operations.py index c6f45d56a20b..b4e4ed3f2254 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_providers_operations.py index 4075db7dbc3f..645f0a1d7f11 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resource_groups_operations.py index 2caea719ec35..5893ec5653b7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -113,7 +113,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -246,7 +246,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -264,7 +269,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -275,7 +280,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -318,9 +323,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -337,7 +342,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -385,9 +390,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -399,7 +404,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -449,7 +454,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -463,7 +468,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resources_operations.py index 33d42a3bfe11..0b7b9ad2aa14 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -80,7 +80,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -145,7 +145,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -191,7 +191,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -238,7 +238,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -255,7 +260,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -301,7 +306,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -350,7 +355,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -370,7 +380,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -398,7 +408,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -631,7 +641,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -652,10 +671,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -716,9 +735,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -745,7 +764,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -773,7 +792,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -794,10 +822,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -855,9 +883,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -884,7 +912,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -912,7 +940,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -934,7 +971,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -953,7 +990,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1129,7 +1166,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1146,10 +1187,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1201,9 +1242,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1223,7 +1264,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1247,7 +1288,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1264,10 +1309,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1316,9 +1361,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1338,7 +1383,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1362,7 +1407,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1380,7 +1429,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1392,7 +1441,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_tags_operations.py index adcf8113449c..33174816fdfd 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models.py index d0795ab8abbc..4dac25af4835 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models.py @@ -629,7 +629,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models_py3.py index 571ff69fcbc3..2b7ccece4b1c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/models/_models_py3.py @@ -688,7 +688,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployment_operations_operations.py index 60eb8082ea9c..d70ee043195e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -63,7 +63,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -110,7 +110,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment with the operation to get. @@ -122,7 +122,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -187,7 +187,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -201,7 +201,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -264,7 +264,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployments_operations.py index 24df0e4fef6a..df2fdbd8d448 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -137,7 +137,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -205,11 +210,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -261,10 +266,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -284,7 +289,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -308,7 +313,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -327,7 +337,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment to get. @@ -337,7 +347,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -435,10 +445,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -451,7 +461,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -505,7 +515,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment from which to get the template. @@ -515,7 +525,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -561,7 +571,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -574,7 +584,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -731,7 +741,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -805,11 +821,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -863,10 +879,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -889,7 +905,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -914,7 +930,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -934,7 +956,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -946,7 +968,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1050,10 +1072,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1069,7 +1091,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1125,7 +1147,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1137,7 +1159,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1185,7 +1207,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1201,7 +1223,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1266,7 +1288,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1276,7 +1298,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_operations.py index e0601bfab6ec..73902fc2546a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_providers_operations.py index a359617c35de..9f4d2bbab472 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resource_groups_operations.py index 503b12edb20f..74b314338243 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -119,7 +119,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -254,7 +254,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -273,7 +278,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -284,7 +289,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -327,10 +332,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -347,7 +352,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,10 +400,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -410,7 +415,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,7 +466,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -475,7 +480,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resources_operations.py index efd29f8a0403..c1cb6e449f55 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -85,7 +85,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -150,7 +150,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -197,7 +197,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -245,7 +245,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -309,7 +314,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -359,7 +364,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -380,7 +390,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -408,7 +418,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -644,7 +654,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -665,11 +684,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,10 +749,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -760,7 +779,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -788,7 +807,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -809,11 +837,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -871,10 +899,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -901,7 +929,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +957,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -952,7 +989,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -971,7 +1008,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1150,7 +1187,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1167,11 +1208,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1223,10 +1264,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1246,7 +1287,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1270,7 +1311,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1287,11 +1332,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1340,10 +1385,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1363,7 +1408,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1387,7 +1432,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1406,7 +1455,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1418,7 +1467,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_tags_operations.py index a4a9b941c900..ddf6431e4f68 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2018_05_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2018_05_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2018_05_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_metadata.json index f0069c0cd02f..a66e721be528 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_resource_management_client.py index 56a16d57c141..3e7061d253f4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/_resource_management_client.py index aeb1a294f2e2..7b9ac4e501d4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployment_operations_operations.py index d8754f972de3..cfdc8e5cd643 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,7 +46,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -58,7 +58,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -104,7 +104,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment with the operation to get. @@ -116,7 +116,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -180,7 +180,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -194,7 +194,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -256,7 +256,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployments_operations.py index 1243f476218e..c146bbedd7f5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -131,7 +131,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -198,10 +203,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -253,9 +258,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -275,7 +280,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -299,7 +304,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -317,7 +327,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment to get. @@ -327,7 +337,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -424,9 +434,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -439,7 +449,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -492,7 +502,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment from which to get the template. @@ -502,7 +512,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -547,7 +557,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -560,7 +570,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -715,7 +725,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -788,10 +804,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -845,9 +861,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -870,7 +886,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -895,7 +911,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -914,7 +936,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -926,7 +948,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1029,9 +1051,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1047,7 +1069,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1102,7 +1124,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1114,7 +1136,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1161,7 +1183,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1177,7 +1199,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1241,7 +1263,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1251,7 +1273,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_operations.py index b561b82cdc19..63d507148da5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_providers_operations.py index 24cd481732aa..89d44a0cc848 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resource_groups_operations.py index 01b60e2e2422..23b09c06c167 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -113,7 +113,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -246,7 +246,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -264,7 +269,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -275,7 +280,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -318,9 +323,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -337,7 +342,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -385,9 +390,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -399,7 +404,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -449,7 +454,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -463,7 +468,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resources_operations.py index aebf5d48b6a6..107d35abfdf1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -80,7 +80,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -145,7 +145,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -191,7 +191,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -238,7 +238,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -255,7 +260,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -301,7 +306,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -350,7 +355,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -370,7 +380,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -398,7 +408,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -631,7 +641,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -652,10 +671,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -716,9 +735,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -745,7 +764,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -773,7 +792,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -794,10 +822,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -855,9 +883,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -884,7 +912,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -912,7 +940,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -934,7 +971,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -953,7 +990,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1129,7 +1166,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1146,10 +1187,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1201,9 +1242,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1223,7 +1264,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1247,7 +1288,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1264,10 +1309,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1316,9 +1361,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1338,7 +1383,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1362,7 +1407,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1380,7 +1429,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1392,7 +1441,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_tags_operations.py index 41fddaa4ba6f..bb16c37f2c5f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models.py index 2994ed6178eb..194539e079e7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models.py @@ -629,7 +629,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models_py3.py index 476c7955932d..2cbb24176a5a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/models/_models_py3.py @@ -688,7 +688,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployment_operations_operations.py index 0961057fa1b7..d9c0b995fb9e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -51,7 +51,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -63,7 +63,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -110,7 +110,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment with the operation to get. @@ -122,7 +122,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -187,7 +187,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -201,7 +201,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -264,7 +264,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployments_operations.py index dbf85b8e6707..52ec90f3cc7a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -137,7 +137,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -205,11 +210,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -261,10 +266,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -284,7 +289,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -308,7 +313,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -327,7 +337,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment to get. @@ -337,7 +347,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -435,10 +445,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -451,7 +461,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -505,7 +515,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment from which to get the template. @@ -515,7 +525,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -561,7 +571,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -574,7 +584,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -731,7 +741,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -805,11 +821,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -863,10 +879,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -889,7 +905,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -914,7 +930,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -934,7 +956,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -946,7 +968,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1050,10 +1072,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1069,7 +1091,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1125,7 +1147,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1137,7 +1159,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1185,7 +1207,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1201,7 +1223,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1266,7 +1288,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1276,7 +1298,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_operations.py index 9b8ba8c4c10c..ae7d74397b77 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_providers_operations.py index cc0a7f7c898e..48f0b7cfe69a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resource_groups_operations.py index 6f1d4177862f..6159e3c1c414 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -119,7 +119,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -254,7 +254,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -273,7 +278,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -284,7 +289,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -327,10 +332,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -347,7 +352,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,10 +400,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -410,7 +415,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,7 +466,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -475,7 +480,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resources_operations.py index 8c97f366d6ff..92f320a21d08 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -85,7 +85,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -150,7 +150,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -197,7 +197,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -245,7 +245,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -309,7 +314,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -359,7 +364,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -380,7 +390,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -408,7 +418,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -644,7 +654,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -665,11 +684,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,10 +749,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -760,7 +779,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -788,7 +807,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -809,11 +837,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -871,10 +899,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -901,7 +929,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +957,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -952,7 +989,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -971,7 +1008,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1150,7 +1187,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1167,11 +1208,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1223,10 +1264,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1246,7 +1287,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1270,7 +1311,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1287,11 +1332,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1340,10 +1385,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1363,7 +1408,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1387,7 +1432,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1406,7 +1455,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1418,7 +1467,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_tags_operations.py index 3fb817496194..f825e11a96e3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_03_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_03_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_03_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_metadata.json index 31639926960c..6327530cd18c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_resource_management_client.py index e06b959c3737..a4b7a4b3f5c4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/_resource_management_client.py index cd8063ab8484..baedfa1450d4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployment_operations_operations.py index 7aa5f9dba2e0..d1cdd6ab4e36 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -61,7 +61,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -122,7 +122,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -243,7 +243,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -255,7 +255,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -319,7 +319,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -333,7 +333,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -381,7 +381,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -395,7 +395,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployments_operations.py index 4b5761eb4042..3fc5afe5684e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -136,7 +136,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -207,10 +212,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -263,9 +268,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -287,7 +292,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -312,7 +317,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -331,7 +341,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -343,7 +353,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -444,9 +454,9 @@ async def validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -461,7 +471,7 @@ async def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -515,7 +525,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -527,7 +537,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -573,7 +583,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -588,7 +598,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -735,7 +745,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -802,10 +817,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -857,9 +872,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -879,7 +894,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -903,7 +918,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -921,7 +941,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -931,7 +951,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1028,9 +1048,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1043,7 +1063,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1096,7 +1116,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1106,7 +1126,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1151,7 +1171,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -1164,7 +1184,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1319,7 +1339,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1392,10 +1418,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1449,9 +1475,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -1474,7 +1500,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1499,7 +1525,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1518,7 +1550,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1530,7 +1562,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1633,9 +1665,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1651,7 +1683,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1706,7 +1738,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1718,7 +1750,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1765,7 +1797,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1781,7 +1813,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1845,7 +1877,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1855,7 +1887,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_operations.py index 8128896acb26..bfdf6d96740f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_providers_operations.py index 62c7b8e1470b..118990d4ac40 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -245,7 +245,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resource_groups_operations.py index 4d548c17aa9d..83f02e931ff8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -113,7 +113,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -246,7 +246,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -264,7 +269,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -275,7 +280,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -318,9 +323,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -337,7 +342,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -385,9 +390,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -399,7 +404,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -449,7 +454,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -463,7 +468,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resources_operations.py index 7a154f3bc49f..f63b660f7eb1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -80,7 +80,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -145,7 +145,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -191,7 +191,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -238,7 +238,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -255,7 +260,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -301,7 +306,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -350,7 +355,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -370,7 +380,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -398,7 +408,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -631,7 +641,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -652,10 +671,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -716,9 +735,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -745,7 +764,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -773,7 +792,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -794,10 +822,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -855,9 +883,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -884,7 +912,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -912,7 +940,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -934,7 +971,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -953,7 +990,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1129,7 +1166,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1146,10 +1187,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1201,9 +1242,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1223,7 +1264,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1247,7 +1288,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1264,10 +1309,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1316,9 +1361,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1338,7 +1383,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1362,7 +1407,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1380,7 +1429,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1392,7 +1441,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_tags_operations.py index 7b12ff33af9a..e2147b21b0e5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models.py index 19a599456635..b7eac53d6d81 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models.py @@ -639,7 +639,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models_py3.py index 546422b9c18f..0dc68b766eac 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/models/_models_py3.py @@ -698,7 +698,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployment_operations_operations.py index 78e1444508f1..2777c43d12f2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -66,7 +66,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -128,7 +128,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -251,7 +251,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -263,7 +263,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -328,7 +328,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -342,7 +342,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -391,7 +391,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -405,7 +405,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployments_operations.py index 5d2cfc8c68fe..f61d4050309e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -142,7 +142,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -214,11 +219,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -271,10 +276,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -296,7 +301,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -321,7 +326,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -341,7 +351,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -353,7 +363,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,10 +465,10 @@ def validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -473,7 +483,7 @@ def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -528,7 +538,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -540,7 +550,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -587,7 +597,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -602,7 +612,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -751,7 +761,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -819,11 +834,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -875,10 +890,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -898,7 +913,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -922,7 +937,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -941,7 +961,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -951,7 +971,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1049,10 +1069,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1065,7 +1085,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1119,7 +1139,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1129,7 +1149,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1175,7 +1195,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -1188,7 +1208,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1345,7 +1365,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1419,11 +1445,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1477,10 +1503,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -1503,7 +1529,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1528,7 +1554,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1548,7 +1580,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1560,7 +1592,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1664,10 +1696,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1683,7 +1715,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1739,7 +1771,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1751,7 +1783,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1799,7 +1831,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1815,7 +1847,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1880,7 +1912,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1890,7 +1922,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_operations.py index e040e872d4c2..8c30c0595cd4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_providers_operations.py index 470e6dc6f132..85d20bee1f5d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -253,7 +253,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resource_groups_operations.py index 7dc7ba7c6313..1644bac12f44 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -119,7 +119,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -254,7 +254,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -273,7 +278,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -284,7 +289,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -327,10 +332,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -347,7 +352,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,10 +400,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -410,7 +415,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,7 +466,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -475,7 +480,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resources_operations.py index 57e098afc989..440f4e656a06 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -85,7 +85,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -150,7 +150,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -197,7 +197,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -245,7 +245,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -309,7 +314,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -359,7 +364,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -380,7 +390,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -408,7 +418,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -644,7 +654,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -665,11 +684,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,10 +749,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -760,7 +779,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -788,7 +807,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -809,11 +837,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -871,10 +899,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -901,7 +929,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +957,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -952,7 +989,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -971,7 +1008,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1150,7 +1187,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1167,11 +1208,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1223,10 +1264,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1246,7 +1287,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1270,7 +1311,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1287,11 +1332,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1340,10 +1385,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1363,7 +1408,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1387,7 +1432,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1406,7 +1455,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1418,7 +1467,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_tags_operations.py index c4ad6b0b2c73..579025185871 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_metadata.json index c2e88076230f..2c3fb9b839a6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_resource_management_client.py index 4082ddf26ebe..e1d125144354 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/_resource_management_client.py index 7d0484890d62..05aa63015c89 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployment_operations_operations.py index 202db6b2336e..fea2f0c6a581 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -61,7 +61,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -122,7 +122,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -243,7 +243,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -255,7 +255,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -319,7 +319,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -333,7 +333,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -381,7 +381,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -395,7 +395,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployments_operations.py index f375a05eef28..30f214b64ea8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -136,7 +136,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -207,10 +212,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -263,9 +268,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -287,7 +292,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -312,7 +317,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -331,7 +341,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -343,7 +353,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -444,9 +454,9 @@ async def validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -461,7 +471,7 @@ async def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -515,7 +525,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -527,7 +537,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -573,7 +583,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -588,7 +598,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -735,7 +745,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -802,10 +817,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -857,9 +872,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -879,7 +894,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -903,7 +918,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -921,7 +941,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -931,7 +951,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1028,9 +1048,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1043,7 +1063,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1096,7 +1116,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1106,7 +1126,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1151,7 +1171,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -1164,7 +1184,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1319,7 +1339,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1392,10 +1418,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1449,9 +1475,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -1474,7 +1500,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1499,7 +1525,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1518,7 +1550,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1530,7 +1562,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1633,9 +1665,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1651,7 +1683,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1706,7 +1738,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1718,7 +1750,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1765,7 +1797,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1781,7 +1813,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1845,7 +1877,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1855,7 +1887,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_operations.py index a95ffbcf7010..ad301959a057 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_providers_operations.py index 7f8f31ac8605..3deb0a7e131e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ def list_at_tenant_scope( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -246,7 +246,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -306,7 +306,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -319,7 +319,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,7 +366,7 @@ async def get_at_tenant_scope( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -379,7 +379,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resource_groups_operations.py index e7af182547b2..3f254edd0d50 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -97,9 +97,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -113,7 +113,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -246,7 +246,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -264,7 +269,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -275,7 +280,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -318,9 +323,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -337,7 +342,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -385,9 +390,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -399,7 +404,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -449,7 +454,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -463,7 +468,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resources_operations.py index 10d616d352b7..9be15e854620 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -80,7 +80,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -145,7 +145,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -191,7 +191,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -238,7 +238,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -255,7 +260,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -301,7 +306,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -350,7 +355,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -370,7 +380,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -398,7 +408,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -631,7 +641,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -652,10 +671,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -716,9 +735,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -745,7 +764,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -773,7 +792,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -794,10 +822,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -855,9 +883,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -884,7 +912,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -912,7 +940,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -934,7 +971,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -953,7 +990,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1129,7 +1166,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1146,10 +1187,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1201,9 +1242,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1223,7 +1264,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1247,7 +1288,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1264,10 +1309,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1316,9 +1361,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1338,7 +1383,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1362,7 +1407,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1380,7 +1429,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1392,7 +1441,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_tags_operations.py index ed7ec3fa6fb6..375df3e3daa0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,7 +99,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -111,7 +111,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -160,7 +160,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -174,7 +174,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -272,7 +272,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -280,7 +280,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models.py index 784262bd4ab0..d1a372e590eb 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models.py @@ -639,7 +639,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models_py3.py index 72b320d1b04a..df0a24c4227d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/models/_models_py3.py @@ -698,7 +698,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployment_operations_operations.py index 60a194085578..01fac8cf725f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -66,7 +66,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -128,7 +128,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -251,7 +251,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -263,7 +263,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -328,7 +328,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -342,7 +342,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -391,7 +391,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -405,7 +405,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployments_operations.py index d68208e1879e..491a48915f75 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -142,7 +142,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -214,11 +219,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -271,10 +276,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -296,7 +301,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -321,7 +326,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -341,7 +351,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -353,7 +363,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,10 +465,10 @@ def validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -473,7 +483,7 @@ def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -528,7 +538,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -540,7 +550,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -587,7 +597,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -602,7 +612,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -751,7 +761,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -819,11 +834,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -875,10 +890,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -898,7 +913,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -922,7 +937,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -941,7 +961,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -951,7 +971,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1049,10 +1069,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1065,7 +1085,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1119,7 +1139,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1129,7 +1149,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1175,7 +1195,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -1188,7 +1208,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1345,7 +1365,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1419,11 +1445,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1477,10 +1503,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -1503,7 +1529,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1528,7 +1554,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1548,7 +1580,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1560,7 +1592,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1664,10 +1696,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1683,7 +1715,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1739,7 +1771,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -1751,7 +1783,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1799,7 +1831,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -1815,7 +1847,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1880,7 +1912,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -1890,7 +1922,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_operations.py index bb56723d8f9a..cdb3162f79f5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_providers_operations.py index 6e97540ed38c..ae2dc64e91ba 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def list_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -315,7 +315,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -328,7 +328,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -376,7 +376,7 @@ def get_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -389,7 +389,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resource_groups_operations.py index 44dfbccb8fae..a58806e425a5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -102,10 +102,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -119,7 +119,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -254,7 +254,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -273,7 +278,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -284,7 +289,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -327,10 +332,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -347,7 +352,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -395,10 +400,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -410,7 +415,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,7 +466,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -475,7 +480,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resources_operations.py index b9c8b792a6e9..fa0eae0ce5d5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -85,7 +85,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -150,7 +150,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -197,7 +197,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -245,7 +245,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -262,7 +267,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -309,7 +314,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -359,7 +364,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -380,7 +390,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -408,7 +418,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -644,7 +654,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -665,11 +684,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -730,10 +749,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -760,7 +779,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -788,7 +807,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -809,11 +837,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -871,10 +899,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -901,7 +929,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +957,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -952,7 +989,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -971,7 +1008,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1150,7 +1187,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1167,11 +1208,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1223,10 +1264,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1246,7 +1287,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1270,7 +1311,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1287,11 +1332,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1340,10 +1385,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1363,7 +1408,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1387,7 +1432,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1406,7 +1455,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1418,7 +1467,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_tags_operations.py index f87672594a97..68f64b0f170a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_05_10/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -105,7 +105,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -117,7 +117,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,7 +167,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -181,7 +181,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_05_10.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -281,7 +281,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -289,7 +289,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_05_10.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_metadata.json index 6d7788bd039d..e63443855a66 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_resource_management_client.py index 5e808e500326..34257dae8eae 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/_resource_management_client.py index 5e3e690bd4eb..eb39aeac091e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployment_operations_operations.py index b812ac360ec8..164413b3963b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param scope: The scope of a deployment. @@ -61,7 +61,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param scope: The scope of a deployment. @@ -122,7 +122,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_tenant_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list_at_tenant_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -317,7 +317,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -331,7 +331,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -378,7 +378,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -392,7 +392,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,7 +455,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -467,7 +467,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -513,7 +513,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -525,7 +525,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -589,7 +589,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -603,7 +603,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -651,7 +651,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -665,7 +665,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployments_operations.py index b5e24ffc02ad..7e7d5fbf2f28 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -138,7 +138,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +216,10 @@ async def _create_or_update_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -267,9 +272,9 @@ async def begin_create_or_update_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -291,7 +296,7 @@ async def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -316,7 +321,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -335,7 +345,7 @@ async def get_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param scope: The scope of a deployment. @@ -347,7 +357,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -450,9 +460,9 @@ async def validate_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -467,7 +477,7 @@ async def validate_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +531,7 @@ async def export_template_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param scope: The scope of a deployment. @@ -533,7 +543,7 @@ async def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -579,7 +589,7 @@ def list_at_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the given scope. :param scope: The scope of a deployment. @@ -594,7 +604,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -742,7 +752,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -810,10 +824,10 @@ async def check_existence_at_tenant_scope( async def _create_or_update_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -864,9 +878,9 @@ async def _create_or_update_at_tenant_scope_initial( async def begin_create_or_update_at_tenant_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -886,7 +900,7 @@ async def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -910,7 +924,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -928,7 +946,7 @@ async def get_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -938,7 +956,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1035,9 +1053,9 @@ async def cancel_at_tenant_scope( async def validate_at_tenant_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1050,7 +1068,7 @@ async def validate_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1102,7 +1120,7 @@ async def export_template_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1112,7 +1130,7 @@ async def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1156,7 +1174,7 @@ def list_at_tenant_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1169,7 +1187,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1319,7 +1337,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1392,10 +1415,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1448,9 +1471,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1472,7 +1495,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1497,7 +1520,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1516,7 +1544,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -1528,7 +1556,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1631,9 +1659,9 @@ async def validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1648,7 +1676,7 @@ async def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1702,7 +1730,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -1714,7 +1742,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1760,7 +1788,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -1775,7 +1803,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1924,7 +1952,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1993,10 +2026,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2048,9 +2081,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2070,7 +2103,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2094,7 +2127,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2112,7 +2150,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2122,7 +2160,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2221,9 +2259,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2236,7 +2274,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2288,10 +2326,10 @@ async def validate_at_subscription_scope( async def _what_if_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2346,9 +2384,9 @@ async def _what_if_at_subscription_scope_initial( async def begin_what_if_at_subscription_scope( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2367,7 +2405,7 @@ async def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2391,7 +2429,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2409,7 +2452,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2419,7 +2462,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2464,7 +2507,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2477,7 +2520,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2634,7 +2677,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2709,10 +2758,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2766,9 +2815,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -2791,7 +2840,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2816,7 +2865,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2835,7 +2890,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -2847,7 +2902,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2952,9 +3007,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2970,7 +3025,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3024,10 +3079,10 @@ async def _what_if_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3084,9 +3139,9 @@ async def begin_what_if( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3108,7 +3163,7 @@ async def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3133,7 +3188,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3152,7 +3213,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3164,7 +3225,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3211,7 +3272,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3227,7 +3288,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3291,7 +3352,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3301,7 +3362,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_operations.py index 4a94a02bf310..e43e2871dcb9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_providers_operations.py index 13dd95bc8a28..7cf326393d36 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ def list_at_tenant_scope( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -246,7 +246,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -306,7 +306,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -319,7 +319,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,7 +366,7 @@ async def get_at_tenant_scope( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -379,7 +379,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resource_groups_operations.py index 95a716ca6238..af044324f91e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,9 +99,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -115,7 +115,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -268,7 +273,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -279,7 +284,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -322,9 +327,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -341,7 +346,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -389,9 +394,9 @@ async def update( async def export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> "models.ResourceGroupExportResult": + ) -> "_models.ResourceGroupExportResult": """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -403,7 +408,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,7 +458,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -467,7 +472,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resources_operations.py index 024cebf6e8ab..191d60ad1b18 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -80,7 +80,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -145,7 +145,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -193,7 +193,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -240,7 +240,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -257,7 +262,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -305,7 +310,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -354,7 +359,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -374,7 +384,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -402,7 +412,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -639,7 +649,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -660,10 +679,10 @@ async def _create_or_update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -724,9 +743,9 @@ async def begin_create_or_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -753,7 +772,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -781,7 +800,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -802,10 +830,10 @@ async def _update_initial( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -863,9 +891,9 @@ async def begin_update( parent_resource_path: str, resource_type: str, resource_name: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -892,7 +920,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -920,7 +948,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -942,7 +979,7 @@ async def get( resource_type: str, resource_name: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -961,7 +998,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1141,7 +1178,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1158,10 +1199,10 @@ def get_long_running_output(pipeline_response): async def _create_or_update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1213,9 +1254,9 @@ async def _create_or_update_by_id_initial( async def begin_create_or_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1235,7 +1276,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1259,7 +1300,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1276,10 +1321,10 @@ def get_long_running_output(pipeline_response): async def _update_by_id_initial( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1328,9 +1373,9 @@ async def _update_by_id_initial( async def begin_update_by_id( self, resource_id: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1350,7 +1395,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1374,7 +1419,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1392,7 +1441,7 @@ async def get_by_id( self, resource_id: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1404,7 +1453,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_tags_operations.py index ba03d84c5d3e..863f3b4aa8f2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -101,7 +101,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -113,7 +113,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -162,7 +162,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -176,7 +176,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -284,7 +284,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models.py index f148c36a7ca0..315ce71c3fa9 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models.py @@ -749,7 +749,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models_py3.py index e7cc866df312..7cffd586aa49 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/models/_models_py3.py @@ -822,7 +822,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployment_operations_operations.py index 0b9441781470..c59d7776ab74 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param scope: The scope of a deployment. @@ -66,7 +66,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param scope: The scope of a deployment. @@ -128,7 +128,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_tenant_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -262,7 +262,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -326,7 +326,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -340,7 +340,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -402,7 +402,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -466,7 +466,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -478,7 +478,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,7 +525,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -537,7 +537,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -602,7 +602,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -616,7 +616,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +665,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -679,7 +679,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployments_operations.py index 85d2578f1083..cf03ffcb050b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -144,7 +144,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +223,11 @@ def _create_or_update_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -275,10 +280,10 @@ def begin_create_or_update_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -300,7 +305,7 @@ def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -325,7 +330,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -345,7 +355,7 @@ def get_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param scope: The scope of a deployment. @@ -357,7 +367,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,10 +471,10 @@ def validate_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -479,7 +489,7 @@ def validate_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +544,7 @@ def export_template_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param scope: The scope of a deployment. @@ -546,7 +556,7 @@ def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -593,7 +603,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the given scope. :param scope: The scope of a deployment. @@ -608,7 +618,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -758,7 +768,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -827,11 +841,11 @@ def check_existence_at_tenant_scope( def _create_or_update_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -882,10 +896,10 @@ def _create_or_update_at_tenant_scope_initial( def begin_create_or_update_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -905,7 +919,7 @@ def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +943,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -948,7 +966,7 @@ def get_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -958,7 +976,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1056,10 +1074,10 @@ def cancel_at_tenant_scope( def validate_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1072,7 +1090,7 @@ def validate_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1125,7 +1143,7 @@ def export_template_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1135,7 +1153,7 @@ def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1180,7 +1198,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1193,7 +1211,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1345,7 +1363,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1419,11 +1442,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1476,10 +1499,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1501,7 +1524,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1526,7 +1549,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1546,7 +1574,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -1558,7 +1586,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1662,10 +1690,10 @@ def validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1680,7 +1708,7 @@ def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1735,7 +1763,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -1747,7 +1775,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1794,7 +1822,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -1809,7 +1837,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1960,7 +1988,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2030,11 +2063,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2086,10 +2119,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2109,7 +2142,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2133,7 +2166,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2152,7 +2190,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2162,7 +2200,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2262,10 +2300,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2278,7 +2316,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2330,11 +2368,11 @@ def validate_at_subscription_scope( def _what_if_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2389,10 +2427,10 @@ def _what_if_at_subscription_scope_initial( def begin_what_if_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2411,7 +2449,7 @@ def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2435,7 +2473,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2454,7 +2497,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2464,7 +2507,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2510,7 +2553,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2523,7 +2566,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2682,7 +2725,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2758,11 +2807,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2816,10 +2865,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -2842,7 +2891,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2867,7 +2916,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2887,7 +2942,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -2899,7 +2954,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3005,10 +3060,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3024,7 +3079,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3078,11 +3133,11 @@ def _what_if_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3139,10 +3194,10 @@ def begin_what_if( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3164,7 +3219,7 @@ def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3189,7 +3244,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3209,7 +3270,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3221,7 +3282,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3269,7 +3330,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3285,7 +3346,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3350,7 +3411,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3360,7 +3421,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_operations.py index ca3b8b0c7214..efb76119031a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_providers_operations.py index 547d043d7784..3cfc8d08aa21 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def list_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -315,7 +315,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -328,7 +328,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -376,7 +376,7 @@ def get_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -389,7 +389,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resource_groups_operations.py index 7937ef077a11..bfe7702de4d2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -104,10 +104,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -121,7 +121,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +258,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -277,7 +282,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -288,7 +293,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,10 +336,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -351,7 +356,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -399,10 +404,10 @@ def update( def export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroupExportResult" + # type: (...) -> "_models.ResourceGroupExportResult" """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group to export as a template. @@ -414,7 +419,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroupExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -465,7 +470,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -479,7 +484,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resources_operations.py index 016b38b525e2..05eb3b8b3220 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -85,7 +85,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -150,7 +150,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -199,7 +199,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -247,7 +247,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -264,7 +269,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -313,7 +318,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -363,7 +368,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -384,7 +394,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -412,7 +422,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -652,7 +662,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -673,11 +692,11 @@ def _create_or_update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -738,10 +757,10 @@ def begin_create_or_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -768,7 +787,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -796,7 +815,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -817,11 +845,11 @@ def _update_initial( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -879,10 +907,10 @@ def begin_update( parent_resource_path, # type: str resource_type, # type: str resource_name, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -909,7 +937,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -937,7 +965,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -960,7 +997,7 @@ def get( resource_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -979,7 +1016,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1162,7 +1199,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1179,11 +1220,11 @@ def get_long_running_output(pipeline_response): def _create_or_update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1235,10 +1276,10 @@ def _create_or_update_by_id_initial( def begin_create_or_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1258,7 +1299,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1282,7 +1323,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1299,11 +1344,11 @@ def get_long_running_output(pipeline_response): def _update_by_id_initial( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1352,10 +1397,10 @@ def _update_by_id_initial( def begin_update_by_id( self, resource_id, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1375,7 +1420,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1399,7 +1444,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1418,7 +1467,7 @@ def get_by_id( resource_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1430,7 +1479,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_tags_operations.py index 4c8c58839bef..7a91be3ead2a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_07_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -107,7 +107,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -119,7 +119,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -183,7 +183,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_07_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -285,7 +285,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -293,7 +293,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_07_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_metadata.json index 2ed84be9916f..8836ed37854c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_resource_management_client.py index 2e37f96858d4..49e2e9dd2655 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/_resource_management_client.py index bbd6d5b57114..a6bb5bf4d5c7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployment_operations_operations.py index 978eb21fc29b..3382404a5c00 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param scope: The scope of a deployment. @@ -61,7 +61,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param scope: The scope of a deployment. @@ -122,7 +122,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_tenant_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list_at_tenant_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -317,7 +317,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -331,7 +331,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -378,7 +378,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -392,7 +392,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,7 +455,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -467,7 +467,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -513,7 +513,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -525,7 +525,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -589,7 +589,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -603,7 +603,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -651,7 +651,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -665,7 +665,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployments_operations.py index 42b74eb197a6..6415ee2d50ae 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -138,7 +138,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +216,10 @@ async def _create_or_update_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -267,9 +272,9 @@ async def begin_create_or_update_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -291,7 +296,7 @@ async def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -316,7 +321,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -335,7 +345,7 @@ async def get_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param scope: The scope of a deployment. @@ -347,7 +357,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -450,9 +460,9 @@ async def validate_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -467,7 +477,7 @@ async def validate_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -521,7 +531,7 @@ async def export_template_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param scope: The scope of a deployment. @@ -533,7 +543,7 @@ async def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -579,7 +589,7 @@ def list_at_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the given scope. :param scope: The scope of a deployment. @@ -594,7 +604,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -742,7 +752,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -810,10 +824,10 @@ async def check_existence_at_tenant_scope( async def _create_or_update_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -864,9 +878,9 @@ async def _create_or_update_at_tenant_scope_initial( async def begin_create_or_update_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -886,7 +900,7 @@ async def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -910,7 +924,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -928,7 +946,7 @@ async def get_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -938,7 +956,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1035,9 +1053,9 @@ async def cancel_at_tenant_scope( async def validate_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1050,7 +1068,7 @@ async def validate_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1102,7 +1120,7 @@ async def export_template_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1112,7 +1130,7 @@ async def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1156,7 +1174,7 @@ def list_at_tenant_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1169,7 +1187,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1319,7 +1337,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1392,10 +1415,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1448,9 +1471,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1472,7 +1495,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1497,7 +1520,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1516,7 +1544,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -1528,7 +1556,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1631,9 +1659,9 @@ async def validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1648,7 +1676,7 @@ async def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1702,7 +1730,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -1714,7 +1742,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1760,7 +1788,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -1775,7 +1803,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1924,7 +1952,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1993,10 +2026,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2048,9 +2081,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2070,7 +2103,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2094,7 +2127,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2112,7 +2150,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2122,7 +2160,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2221,9 +2259,9 @@ async def cancel_at_subscription_scope( async def validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2236,7 +2274,7 @@ async def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2288,10 +2326,10 @@ async def validate_at_subscription_scope( async def _what_if_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2346,9 +2384,9 @@ async def _what_if_at_subscription_scope_initial( async def begin_what_if_at_subscription_scope( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2367,7 +2405,7 @@ async def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2391,7 +2429,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2409,7 +2452,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2419,7 +2462,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2464,7 +2507,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2477,7 +2520,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2634,7 +2677,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2709,10 +2758,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2766,9 +2815,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -2791,7 +2840,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2816,7 +2865,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2835,7 +2890,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -2847,7 +2902,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2952,9 +3007,9 @@ async def validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentValidateResult": + ) -> "_models.DeploymentValidateResult": """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2970,7 +3025,7 @@ async def validate( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3024,10 +3079,10 @@ async def _what_if_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3084,9 +3139,9 @@ async def begin_what_if( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3108,7 +3163,7 @@ async def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3133,7 +3188,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3152,7 +3213,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3164,7 +3225,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3211,7 +3272,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3227,7 +3288,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3291,7 +3352,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3301,7 +3362,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_operations.py index aa34f6e4c0b9..0ab36e366bcc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_providers_operations.py index d5d97e655261..43c29b7afaa1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ def list_at_tenant_scope( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -246,7 +246,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -306,7 +306,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -319,7 +319,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,7 +366,7 @@ async def get_at_tenant_scope( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -379,7 +379,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resource_groups_operations.py index 9488b9eefe66..9b1176745acd 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,9 +99,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -115,7 +115,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -268,7 +273,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -279,7 +284,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -322,9 +327,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -341,7 +346,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -389,10 +394,10 @@ async def update( async def _export_template_initial( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> Optional["models.ResourceGroupExportResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + ) -> Optional["_models.ResourceGroupExportResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -442,9 +447,9 @@ async def _export_template_initial( async def begin_export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> AsyncLROPoller["models.ResourceGroupExportResult"]: + ) -> AsyncLROPoller["_models.ResourceGroupExportResult"]: """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -462,7 +467,7 @@ async def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -486,7 +491,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -505,7 +515,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -519,7 +529,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resources_operations.py index dfdb5b775c15..403d102ffe11 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -81,7 +81,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -146,7 +146,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -194,7 +194,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -241,7 +241,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -258,7 +263,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -306,7 +311,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -355,7 +360,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -375,7 +385,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -404,7 +414,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -647,7 +657,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -669,10 +688,10 @@ async def _create_or_update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -733,9 +752,9 @@ async def begin_create_or_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -764,7 +783,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -793,7 +812,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -815,10 +843,10 @@ async def _update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -876,9 +904,9 @@ async def begin_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -907,7 +935,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -936,7 +964,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -959,7 +996,7 @@ async def get( resource_name: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -980,7 +1017,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1165,7 +1202,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1183,10 +1224,10 @@ async def _create_or_update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1238,9 +1279,9 @@ async def begin_create_or_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1262,7 +1303,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1287,7 +1328,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1305,10 +1350,10 @@ async def _update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1357,9 +1402,9 @@ async def begin_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1381,7 +1426,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1406,7 +1451,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1425,7 +1474,7 @@ async def get_by_id( resource_id: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1439,7 +1488,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_tags_operations.py index 11f9a265c4fa..8a72b94801ee 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -101,7 +101,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -113,7 +113,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -162,7 +162,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -176,7 +176,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -276,7 +276,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -284,7 +284,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models.py index 2d554906d180..052c8bb085fc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models.py @@ -749,7 +749,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models_py3.py index d284dec71b9c..243d0e07f81c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/models/_models_py3.py @@ -822,7 +822,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployment_operations_operations.py index 1ac926e4f579..e3447fe5b435 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param scope: The scope of a deployment. @@ -66,7 +66,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param scope: The scope of a deployment. @@ -128,7 +128,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_tenant_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -262,7 +262,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -326,7 +326,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -340,7 +340,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -402,7 +402,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -466,7 +466,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -478,7 +478,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,7 +525,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -537,7 +537,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -602,7 +602,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -616,7 +616,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +665,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -679,7 +679,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployments_operations.py index 2d1943115c49..c7d306c5a4ac 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -144,7 +144,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +223,11 @@ def _create_or_update_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -275,10 +280,10 @@ def begin_create_or_update_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -300,7 +305,7 @@ def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -325,7 +330,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -345,7 +355,7 @@ def get_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param scope: The scope of a deployment. @@ -357,7 +367,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,10 +471,10 @@ def validate_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -479,7 +489,7 @@ def validate_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -534,7 +544,7 @@ def export_template_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param scope: The scope of a deployment. @@ -546,7 +556,7 @@ def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -593,7 +603,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the given scope. :param scope: The scope of a deployment. @@ -608,7 +618,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -758,7 +768,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -827,11 +841,11 @@ def check_existence_at_tenant_scope( def _create_or_update_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -882,10 +896,10 @@ def _create_or_update_at_tenant_scope_initial( def begin_create_or_update_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -905,7 +919,7 @@ def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -929,7 +943,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -948,7 +966,7 @@ def get_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -958,7 +976,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1056,10 +1074,10 @@ def cancel_at_tenant_scope( def validate_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1072,7 +1090,7 @@ def validate_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1125,7 +1143,7 @@ def export_template_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1135,7 +1153,7 @@ def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1180,7 +1198,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1193,7 +1211,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1345,7 +1363,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1419,11 +1442,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1476,10 +1499,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1501,7 +1524,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1526,7 +1549,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1546,7 +1574,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -1558,7 +1586,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1662,10 +1690,10 @@ def validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1680,7 +1708,7 @@ def validate_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1735,7 +1763,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -1747,7 +1775,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1794,7 +1822,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -1809,7 +1837,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1960,7 +1988,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2030,11 +2063,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2086,10 +2119,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2109,7 +2142,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2133,7 +2166,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2152,7 +2190,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2162,7 +2200,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2262,10 +2300,10 @@ def cancel_at_subscription_scope( def validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2278,7 +2316,7 @@ def validate_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2330,11 +2368,11 @@ def validate_at_subscription_scope( def _what_if_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2389,10 +2427,10 @@ def _what_if_at_subscription_scope_initial( def begin_what_if_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2411,7 +2449,7 @@ def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2435,7 +2473,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2454,7 +2497,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2464,7 +2507,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2510,7 +2553,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2523,7 +2566,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2682,7 +2725,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2758,11 +2807,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2816,10 +2865,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -2842,7 +2891,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2867,7 +2916,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2887,7 +2942,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -2899,7 +2954,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3005,10 +3060,10 @@ def validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentValidateResult" + # type: (...) -> "_models.DeploymentValidateResult" """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3024,7 +3079,7 @@ def validate( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentValidateResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3078,11 +3133,11 @@ def _what_if_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3139,10 +3194,10 @@ def begin_what_if( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3164,7 +3219,7 @@ def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3189,7 +3244,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3209,7 +3270,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3221,7 +3282,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3269,7 +3330,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3285,7 +3346,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3350,7 +3411,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3360,7 +3421,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_operations.py index edd30bea5e42..0a68b12d204d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_providers_operations.py index fafdc223ae73..29b54623ec5c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def list_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -315,7 +315,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -328,7 +328,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -376,7 +376,7 @@ def get_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -389,7 +389,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resource_groups_operations.py index c567abfc3229..1159f7efbdc2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -104,10 +104,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -121,7 +121,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +258,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -277,7 +282,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -288,7 +293,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,10 +336,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -351,7 +356,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -399,11 +404,11 @@ def update( def _export_template_initial( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> Optional["models.ResourceGroupExportResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + # type: (...) -> Optional["_models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,10 +458,10 @@ def _export_template_initial( def begin_export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.ResourceGroupExportResult"] + # type: (...) -> LROPoller["_models.ResourceGroupExportResult"] """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -474,7 +479,7 @@ def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -498,7 +503,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -518,7 +528,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -532,7 +542,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resources_operations.py index 4742216ebabd..d804934c1be2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -86,7 +86,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -151,7 +151,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -200,7 +200,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -248,7 +248,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -265,7 +270,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -314,7 +319,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -364,7 +369,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -385,7 +395,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -414,7 +424,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -660,7 +670,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -682,11 +701,11 @@ def _create_or_update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -747,10 +766,10 @@ def begin_create_or_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -779,7 +798,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -808,7 +827,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -830,11 +858,11 @@ def _update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -892,10 +920,10 @@ def begin_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -924,7 +952,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -953,7 +981,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -977,7 +1014,7 @@ def get( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -998,7 +1035,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1186,7 +1223,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1204,11 +1245,11 @@ def _create_or_update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1260,10 +1301,10 @@ def begin_create_or_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1285,7 +1326,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1310,7 +1351,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1328,11 +1373,11 @@ def _update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1381,10 +1426,10 @@ def begin_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1406,7 +1451,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1431,7 +1476,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1451,7 +1500,7 @@ def get_by_id( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1465,7 +1514,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_tags_operations.py index 658e150b1659..0daf2ec09ebc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_08_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -107,7 +107,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a tag value. The name of the tag must already exist. :param tag_name: The name of the tag. @@ -119,7 +119,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a tag in the subscription. The tag name can have a maximum of 512 characters and is case insensitive. Tag names created by @@ -183,7 +183,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_08_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -285,7 +285,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets the names and values of all resource tags that are defined in a subscription. :keyword callable cls: A custom type or function that will be passed the direct response @@ -293,7 +293,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_08_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_metadata.json index 9c6add02d720..f45a45041ff1 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_resource_management_client.py index 19e0b3b4d907..d366324241d7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/_resource_management_client.py index f84a7736afa8..d1188a3ae441 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployment_operations_operations.py index 5f49784b69fa..7a721f5d9e7b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param scope: The resource scope. @@ -61,7 +61,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param scope: The resource scope. @@ -122,7 +122,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_tenant_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list_at_tenant_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -317,7 +317,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -331,7 +331,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -378,7 +378,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -392,7 +392,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,7 +455,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -467,7 +467,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -513,7 +513,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -525,7 +525,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -589,7 +589,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -603,7 +603,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -651,7 +651,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -665,7 +665,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployments_operations.py index 72a17baed276..278837b493dc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -138,7 +138,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +216,10 @@ async def _create_or_update_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -267,9 +272,9 @@ async def begin_create_or_update_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -291,7 +296,7 @@ async def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -316,7 +321,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -335,7 +345,7 @@ async def get_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param scope: The resource scope. @@ -347,7 +357,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -450,10 +460,10 @@ async def _validate_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -507,9 +517,9 @@ async def begin_validate_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -530,7 +540,7 @@ async def begin_validate_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -555,7 +565,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -574,7 +589,7 @@ async def export_template_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param scope: The resource scope. @@ -586,7 +601,7 @@ async def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -632,7 +647,7 @@ def list_at_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the given scope. :param scope: The resource scope. @@ -647,7 +662,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -795,7 +810,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -863,10 +882,10 @@ async def check_existence_at_tenant_scope( async def _create_or_update_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -917,9 +936,9 @@ async def _create_or_update_at_tenant_scope_initial( async def begin_create_or_update_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -939,7 +958,7 @@ async def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -963,7 +982,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -981,7 +1004,7 @@ async def get_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -991,7 +1014,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1088,10 +1111,10 @@ async def cancel_at_tenant_scope( async def _validate_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1143,9 +1166,9 @@ async def _validate_at_tenant_scope_initial( async def begin_validate_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1164,7 +1187,7 @@ async def begin_validate_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1188,7 +1211,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1205,10 +1232,10 @@ def get_long_running_output(pipeline_response): async def _what_if_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1262,9 +1289,9 @@ async def _what_if_at_tenant_scope_initial( async def begin_what_if_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the tenant group. @@ -1283,7 +1310,7 @@ async def begin_what_if_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1307,7 +1334,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1325,7 +1356,7 @@ async def export_template_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1335,7 +1366,7 @@ async def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1379,7 +1410,7 @@ def list_at_tenant_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1392,7 +1423,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1542,7 +1573,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1615,10 +1651,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1671,9 +1707,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1695,7 +1731,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1720,7 +1756,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1739,7 +1780,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -1751,7 +1792,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1854,10 +1895,10 @@ async def _validate_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1911,9 +1952,9 @@ async def begin_validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1934,7 +1975,7 @@ async def begin_validate_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1959,7 +2000,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1977,10 +2023,10 @@ async def _what_if_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2036,9 +2082,9 @@ async def begin_what_if_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the management group. @@ -2059,7 +2105,7 @@ async def begin_what_if_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2084,7 +2130,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2103,7 +2154,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -2115,7 +2166,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2161,7 +2212,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -2176,7 +2227,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2325,7 +2376,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2394,10 +2450,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2449,9 +2505,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2471,7 +2527,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2495,7 +2551,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2513,7 +2574,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2523,7 +2584,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2622,10 +2683,10 @@ async def cancel_at_subscription_scope( async def _validate_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2678,9 +2739,9 @@ async def _validate_at_subscription_scope_initial( async def begin_validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2699,7 +2760,7 @@ async def begin_validate_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2723,7 +2784,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2740,10 +2806,10 @@ def get_long_running_output(pipeline_response): async def _what_if_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2798,9 +2864,9 @@ async def _what_if_at_subscription_scope_initial( async def begin_what_if_at_subscription_scope( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2819,7 +2885,7 @@ async def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2843,7 +2909,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2861,7 +2932,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2871,7 +2942,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2916,7 +2987,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2929,7 +3000,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3086,7 +3157,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3161,10 +3238,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3218,9 +3295,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -3243,7 +3320,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3268,7 +3345,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3287,7 +3370,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3299,7 +3382,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3404,10 +3487,10 @@ async def _validate_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3462,9 +3545,9 @@ async def begin_validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3486,7 +3569,7 @@ async def begin_validate( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3511,7 +3594,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3529,10 +3618,10 @@ async def _what_if_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3589,9 +3678,9 @@ async def begin_what_if( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3613,7 +3702,7 @@ async def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3638,7 +3727,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3657,7 +3752,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3669,7 +3764,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3716,7 +3811,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3732,7 +3827,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3796,7 +3891,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3806,7 +3901,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_operations.py index 48e9a4c9c7ef..26fa281e7cc6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_providers_operations.py index 498f876dffc7..27eb4ce3a3c7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -99,7 +99,7 @@ async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +109,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +154,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +168,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +232,7 @@ def list_at_tenant_scope( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -246,7 +246,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -306,7 +306,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -319,7 +319,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,7 +366,7 @@ async def get_at_tenant_scope( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -379,7 +379,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resource_groups_operations.py index 1f60115f078a..4a67a9c0b6bd 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,9 +99,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -115,7 +115,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -268,7 +273,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -279,7 +284,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -322,9 +327,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -341,7 +346,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -389,10 +394,10 @@ async def update( async def _export_template_initial( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> Optional["models.ResourceGroupExportResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + ) -> Optional["_models.ResourceGroupExportResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -442,9 +447,9 @@ async def _export_template_initial( async def begin_export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> AsyncLROPoller["models.ResourceGroupExportResult"]: + ) -> AsyncLROPoller["_models.ResourceGroupExportResult"]: """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -462,7 +467,7 @@ async def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -486,7 +491,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -505,7 +515,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -519,7 +529,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resources_operations.py index 4af271e8a5eb..600c78e3a504 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -81,7 +81,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -146,7 +146,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -194,7 +194,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -241,7 +241,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -258,7 +263,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -306,7 +311,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -355,7 +360,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -375,7 +385,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -404,7 +414,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -647,7 +657,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -669,10 +688,10 @@ async def _create_or_update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -733,9 +752,9 @@ async def begin_create_or_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -764,7 +783,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -793,7 +812,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -815,10 +843,10 @@ async def _update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -876,9 +904,9 @@ async def begin_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -907,7 +935,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -936,7 +964,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -959,7 +996,7 @@ async def get( resource_name: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -980,7 +1017,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1165,7 +1202,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1183,10 +1224,10 @@ async def _create_or_update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1238,9 +1279,9 @@ async def begin_create_or_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1262,7 +1303,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1287,7 +1328,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1305,10 +1350,10 @@ async def _update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1357,9 +1402,9 @@ async def begin_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1381,7 +1426,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1406,7 +1451,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1425,7 +1474,7 @@ async def get_by_id( resource_id: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1439,7 +1488,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_tags_operations.py index e60da910a8e6..acd7758c02af 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -105,7 +105,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a predefined value for a predefined tag name. This operation allows adding a value to the list of predefined values for an existing @@ -120,7 +120,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a predefined tag name. This operation allows adding a name to the list of predefined tag names for the given @@ -184,7 +184,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -286,7 +286,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets a summary of tag usage under the subscription. This operation performs a union of predefined tags, resource tags, resource group tags and @@ -299,7 +299,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -357,9 +357,9 @@ async def get_next(next_link=None): async def create_or_update_at_scope( self, scope: str, - parameters: "models.TagsResource", + parameters: "_models.TagsResource", **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Creates or updates the entire set of tags on a resource or subscription. This operation allows adding or replacing the entire set of tags on the specified resource or @@ -374,7 +374,7 @@ async def create_or_update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -421,9 +421,9 @@ async def create_or_update_at_scope( async def update_at_scope( self, scope: str, - parameters: "models.TagsPatchResource", + parameters: "_models.TagsPatchResource", **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Selectively updates the set of tags on a resource or subscription. This operation allows replacing, merging or selectively deleting tags on the specified resource @@ -442,7 +442,7 @@ async def update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -490,7 +490,7 @@ async def get_at_scope( self, scope: str, **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Gets the entire set of tags on a resource or subscription. Gets the entire set of tags on a resource or subscription. @@ -502,7 +502,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models.py index 4054e83576ce..c9825d6a2e53 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models.py @@ -810,7 +810,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models_py3.py index 20e355efa5e2..b817f8302789 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/models/_models_py3.py @@ -881,7 +881,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployment_operations_operations.py index 0fe47b016492..19e8eb90234c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param scope: The resource scope. @@ -66,7 +66,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param scope: The resource scope. @@ -128,7 +128,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_tenant_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -262,7 +262,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -326,7 +326,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -340,7 +340,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -402,7 +402,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -466,7 +466,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -478,7 +478,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,7 +525,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -537,7 +537,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -602,7 +602,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -616,7 +616,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +665,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -679,7 +679,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployments_operations.py index f19d6e7d4b03..9e86db033bfe 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -144,7 +144,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +223,11 @@ def _create_or_update_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -275,10 +280,10 @@ def begin_create_or_update_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -300,7 +305,7 @@ def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -325,7 +330,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -345,7 +355,7 @@ def get_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param scope: The resource scope. @@ -357,7 +367,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,11 +471,11 @@ def _validate_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -519,10 +529,10 @@ def begin_validate_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -543,7 +553,7 @@ def begin_validate_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -568,7 +578,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -588,7 +603,7 @@ def export_template_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param scope: The resource scope. @@ -600,7 +615,7 @@ def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -647,7 +662,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the given scope. :param scope: The resource scope. @@ -662,7 +677,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -812,7 +827,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -881,11 +900,11 @@ def check_existence_at_tenant_scope( def _create_or_update_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -936,10 +955,10 @@ def _create_or_update_at_tenant_scope_initial( def begin_create_or_update_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -959,7 +978,7 @@ def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -983,7 +1002,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1002,7 +1025,7 @@ def get_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -1012,7 +1035,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1110,11 +1133,11 @@ def cancel_at_tenant_scope( def _validate_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1166,10 +1189,10 @@ def _validate_at_tenant_scope_initial( def begin_validate_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1188,7 +1211,7 @@ def begin_validate_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1212,7 +1235,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1229,11 +1256,11 @@ def get_long_running_output(pipeline_response): def _what_if_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1287,10 +1314,10 @@ def _what_if_at_tenant_scope_initial( def begin_what_if_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the tenant group. @@ -1309,7 +1336,7 @@ def begin_what_if_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1333,7 +1360,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1352,7 +1383,7 @@ def export_template_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1362,7 +1393,7 @@ def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1407,7 +1438,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1420,7 +1451,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1572,7 +1603,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1646,11 +1682,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1703,10 +1739,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1728,7 +1764,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1753,7 +1789,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1773,7 +1814,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -1785,7 +1826,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1889,11 +1930,11 @@ def _validate_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1947,10 +1988,10 @@ def begin_validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1971,7 +2012,7 @@ def begin_validate_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1996,7 +2037,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2014,11 +2060,11 @@ def _what_if_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2074,10 +2120,10 @@ def begin_what_if_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the management group. @@ -2098,7 +2144,7 @@ def begin_what_if_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2123,7 +2169,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2143,7 +2194,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -2155,7 +2206,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2202,7 +2253,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -2217,7 +2268,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2368,7 +2419,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2438,11 +2494,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2494,10 +2550,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2517,7 +2573,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2541,7 +2597,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2560,7 +2621,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2570,7 +2631,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2670,11 +2731,11 @@ def cancel_at_subscription_scope( def _validate_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2727,10 +2788,10 @@ def _validate_at_subscription_scope_initial( def begin_validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2749,7 +2810,7 @@ def begin_validate_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2773,7 +2834,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2790,11 +2856,11 @@ def get_long_running_output(pipeline_response): def _what_if_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2849,10 +2915,10 @@ def _what_if_at_subscription_scope_initial( def begin_what_if_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2871,7 +2937,7 @@ def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2895,7 +2961,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2914,7 +2985,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2924,7 +2995,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2970,7 +3041,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2983,7 +3054,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3142,7 +3213,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3218,11 +3295,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3276,10 +3353,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -3302,7 +3379,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3327,7 +3404,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3347,7 +3430,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3359,7 +3442,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3465,11 +3548,11 @@ def _validate_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3524,10 +3607,10 @@ def begin_validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3549,7 +3632,7 @@ def begin_validate( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3574,7 +3657,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3592,11 +3681,11 @@ def _what_if_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3653,10 +3742,10 @@ def begin_what_if( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3678,7 +3767,7 @@ def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3703,7 +3792,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3723,7 +3818,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3735,7 +3830,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3783,7 +3878,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3799,7 +3894,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3864,7 +3959,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3874,7 +3969,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_operations.py index 39c8db89825c..546439566d4e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_providers_operations.py index 74bdd487885c..4e962822e8c2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -105,7 +105,7 @@ def register( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +115,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +161,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +175,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +240,7 @@ def list_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -315,7 +315,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -328,7 +328,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -376,7 +376,7 @@ def get_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -389,7 +389,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resource_groups_operations.py index e2e795f12649..b868764c6d92 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -104,10 +104,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -121,7 +121,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -258,7 +258,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -277,7 +282,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -288,7 +293,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,10 +336,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -351,7 +356,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -399,11 +404,11 @@ def update( def _export_template_initial( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> Optional["models.ResourceGroupExportResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + # type: (...) -> Optional["_models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,10 +458,10 @@ def _export_template_initial( def begin_export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.ResourceGroupExportResult"] + # type: (...) -> LROPoller["_models.ResourceGroupExportResult"] """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -474,7 +479,7 @@ def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -498,7 +503,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -518,7 +528,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -532,7 +542,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resources_operations.py index 521f77fc490e..5b62d8043082 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -86,7 +86,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -151,7 +151,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -200,7 +200,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -248,7 +248,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -265,7 +270,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -314,7 +319,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -364,7 +369,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -385,7 +395,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -414,7 +424,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -660,7 +670,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -682,11 +701,11 @@ def _create_or_update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -747,10 +766,10 @@ def begin_create_or_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -779,7 +798,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -808,7 +827,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -830,11 +858,11 @@ def _update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -892,10 +920,10 @@ def begin_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -924,7 +952,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -953,7 +981,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -977,7 +1014,7 @@ def get( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -998,7 +1035,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1186,7 +1223,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1204,11 +1245,11 @@ def _create_or_update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1260,10 +1301,10 @@ def begin_create_or_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1285,7 +1326,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1310,7 +1351,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1328,11 +1373,11 @@ def _update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1381,10 +1426,10 @@ def begin_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1406,7 +1451,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1431,7 +1476,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1451,7 +1500,7 @@ def get_by_id( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1465,7 +1514,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_tags_operations.py index 365564d686fb..39055169a46e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2019_10_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -111,7 +111,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a predefined value for a predefined tag name. This operation allows adding a value to the list of predefined values for an existing @@ -126,7 +126,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a predefined tag name. This operation allows adding a name to the list of predefined tag names for the given @@ -191,7 +191,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -295,7 +295,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets a summary of tag usage under the subscription. This operation performs a union of predefined tags, resource tags, resource group tags and @@ -308,7 +308,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2019_10_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,10 +366,10 @@ def get_next(next_link=None): def create_or_update_at_scope( self, scope, # type: str - parameters, # type: "models.TagsResource" + parameters, # type: "_models.TagsResource" **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Creates or updates the entire set of tags on a resource or subscription. This operation allows adding or replacing the entire set of tags on the specified resource or @@ -384,7 +384,7 @@ def create_or_update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -431,10 +431,10 @@ def create_or_update_at_scope( def update_at_scope( self, scope, # type: str - parameters, # type: "models.TagsPatchResource" + parameters, # type: "_models.TagsPatchResource" **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Selectively updates the set of tags on a resource or subscription. This operation allows replacing, merging or selectively deleting tags on the specified resource @@ -453,7 +453,7 @@ def update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -502,7 +502,7 @@ def get_at_scope( scope, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Gets the entire set of tags on a resource or subscription. Gets the entire set of tags on a resource or subscription. @@ -514,7 +514,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2019_10_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_metadata.json index afc057646b5a..0462efde8040 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": true + "has_lro_operations": true, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "The ID of the target subscription.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_resource_management_client.py index 200126b8f45d..f01b2936e92f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/_resource_management_client.py @@ -68,7 +68,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/_resource_management_client.py index eb4a2f1cac47..373d2a254b89 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/_resource_management_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/_resource_management_client.py @@ -65,7 +65,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployment_operations_operations.py index 0d37e22f4cde..d446fea82cce 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class DeploymentOperationsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -47,7 +47,7 @@ async def get_at_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param scope: The resource scope. @@ -61,7 +61,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -108,7 +108,7 @@ def list_at_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param scope: The resource scope. @@ -122,7 +122,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -185,7 +185,7 @@ async def get_at_tenant_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -197,7 +197,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -242,7 +242,7 @@ def list_at_tenant_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -254,7 +254,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -317,7 +317,7 @@ async def get_at_management_group_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param group_id: The management group ID. @@ -331,7 +331,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -378,7 +378,7 @@ def list_at_management_group_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -392,7 +392,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -455,7 +455,7 @@ async def get_at_subscription_scope( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -467,7 +467,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -513,7 +513,7 @@ def list_at_subscription_scope( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -525,7 +525,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -589,7 +589,7 @@ async def get( deployment_name: str, operation_id: str, **kwargs - ) -> "models.DeploymentOperation": + ) -> "_models.DeploymentOperation": """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -603,7 +603,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -651,7 +651,7 @@ def list( deployment_name: str, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentOperationsListResult"]: + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -665,7 +665,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployments_operations.py index 06d2a3042093..3534ee6563ca 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class DeploymentsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -138,7 +138,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -211,10 +216,10 @@ async def _create_or_update_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -267,9 +272,9 @@ async def begin_create_or_update_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -291,7 +296,7 @@ async def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -316,7 +321,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -335,7 +345,7 @@ async def get_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param scope: The resource scope. @@ -347,7 +357,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -450,10 +460,10 @@ async def _validate_at_scope_initial( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -507,9 +517,9 @@ async def begin_validate_at_scope( self, scope: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -530,7 +540,7 @@ async def begin_validate_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -555,7 +565,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -574,7 +589,7 @@ async def export_template_at_scope( scope: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param scope: The resource scope. @@ -586,7 +601,7 @@ async def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -632,7 +647,7 @@ def list_at_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the given scope. :param scope: The resource scope. @@ -647,7 +662,7 @@ def list_at_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -795,7 +810,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -863,10 +882,10 @@ async def check_existence_at_tenant_scope( async def _create_or_update_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -917,9 +936,9 @@ async def _create_or_update_at_tenant_scope_initial( async def begin_create_or_update_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -939,7 +958,7 @@ async def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -963,7 +982,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -981,7 +1004,7 @@ async def get_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -991,7 +1014,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1088,10 +1111,10 @@ async def cancel_at_tenant_scope( async def _validate_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1143,9 +1166,9 @@ async def _validate_at_tenant_scope_initial( async def begin_validate_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1164,7 +1187,7 @@ async def begin_validate_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1188,7 +1211,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1205,10 +1232,10 @@ def get_long_running_output(pipeline_response): async def _what_if_at_tenant_scope_initial( self, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1262,9 +1289,9 @@ async def _what_if_at_tenant_scope_initial( async def begin_what_if_at_tenant_scope( self, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the tenant group. @@ -1283,7 +1310,7 @@ async def begin_what_if_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1307,7 +1334,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1325,7 +1356,7 @@ async def export_template_at_tenant_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1335,7 +1366,7 @@ async def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1379,7 +1410,7 @@ def list_at_tenant_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1392,7 +1423,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1542,7 +1573,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1615,10 +1651,10 @@ async def _create_or_update_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1671,9 +1707,9 @@ async def begin_create_or_update_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1695,7 +1731,7 @@ async def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1720,7 +1756,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1739,7 +1780,7 @@ async def get_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param group_id: The management group ID. @@ -1751,7 +1792,7 @@ async def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1854,10 +1895,10 @@ async def _validate_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1911,9 +1952,9 @@ async def begin_validate_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeployment", + parameters: "_models.ScopedDeployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1934,7 +1975,7 @@ async def begin_validate_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1959,7 +2000,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1977,10 +2023,10 @@ async def _what_if_at_management_group_scope_initial( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2036,9 +2082,9 @@ async def begin_what_if_at_management_group_scope( self, group_id: str, deployment_name: str, - parameters: "models.ScopedDeploymentWhatIf", + parameters: "_models.ScopedDeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the management group. @@ -2059,7 +2105,7 @@ async def begin_what_if_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2084,7 +2130,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2103,7 +2154,7 @@ async def export_template_at_management_group_scope( group_id: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -2115,7 +2166,7 @@ async def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2161,7 +2212,7 @@ def list_at_management_group_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a management group. :param group_id: The management group ID. @@ -2176,7 +2227,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2325,7 +2376,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2394,10 +2450,10 @@ async def check_existence_at_subscription_scope( async def _create_or_update_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2449,9 +2505,9 @@ async def _create_or_update_at_subscription_scope_initial( async def begin_create_or_update_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2471,7 +2527,7 @@ async def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2495,7 +2551,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2513,7 +2574,7 @@ async def get_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2523,7 +2584,7 @@ async def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2622,10 +2683,10 @@ async def cancel_at_subscription_scope( async def _validate_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2678,9 +2739,9 @@ async def _validate_at_subscription_scope_initial( async def begin_validate_at_subscription_scope( self, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2699,7 +2760,7 @@ async def begin_validate_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2723,7 +2784,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2740,10 +2806,10 @@ def get_long_running_output(pipeline_response): async def _what_if_at_subscription_scope_initial( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2798,9 +2864,9 @@ async def _what_if_at_subscription_scope_initial( async def begin_what_if_at_subscription_scope( self, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2819,7 +2885,7 @@ async def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2843,7 +2909,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -2861,7 +2932,7 @@ async def export_template_at_subscription_scope( self, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2871,7 +2942,7 @@ async def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2916,7 +2987,7 @@ def list_at_subscription_scope( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2929,7 +3000,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3086,7 +3157,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3161,10 +3238,10 @@ async def _create_or_update_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> "models.DeploymentExtended": - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3218,9 +3295,9 @@ async def begin_create_or_update( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentExtended"]: + ) -> AsyncLROPoller["_models.DeploymentExtended"]: """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -3243,7 +3320,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3268,7 +3345,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3287,7 +3370,7 @@ async def get( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExtended": + ) -> "_models.DeploymentExtended": """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3299,7 +3382,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3404,10 +3487,10 @@ async def _validate_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> Optional["models.DeploymentValidateResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3462,9 +3545,9 @@ async def begin_validate( self, resource_group_name: str, deployment_name: str, - parameters: "models.Deployment", + parameters: "_models.Deployment", **kwargs - ) -> AsyncLROPoller["models.DeploymentValidateResult"]: + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3486,7 +3569,7 @@ async def begin_validate( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3511,7 +3594,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3529,10 +3618,10 @@ async def _what_if_initial( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> Optional["models.WhatIfOperationResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3589,9 +3678,9 @@ async def begin_what_if( self, resource_group_name: str, deployment_name: str, - parameters: "models.DeploymentWhatIf", + parameters: "_models.DeploymentWhatIf", **kwargs - ) -> AsyncLROPoller["models.WhatIfOperationResult"]: + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3613,7 +3702,7 @@ async def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3638,7 +3727,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -3657,7 +3752,7 @@ async def export_template( resource_group_name: str, deployment_name: str, **kwargs - ) -> "models.DeploymentExportResult": + ) -> "_models.DeploymentExportResult": """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3669,7 +3764,7 @@ async def export_template( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3716,7 +3811,7 @@ def list_by_resource_group( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.DeploymentListResult"]: + ) -> AsyncIterable["_models.DeploymentListResult"]: """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3732,7 +3827,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3796,7 +3891,7 @@ async def calculate_template_hash( self, template: object, **kwargs - ) -> "models.TemplateHashResult": + ) -> "_models.TemplateHashResult": """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3806,7 +3901,7 @@ async def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_operations.py index 3e0a543671c0..44b828a70ae4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_providers_operations.py index 86afb45c6bbb..9b04984bd565 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class ProvidersOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ async def unregister( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -55,7 +55,7 @@ async def unregister( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -95,11 +95,65 @@ async def unregister( return deserialized unregister.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/unregister'} # type: ignore + async def register_at_management_group_scope( + self, + resource_provider_namespace: str, + group_id: str, + **kwargs + ) -> None: + """Registers a management group with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :param group_id: The management group ID. + :type group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.register_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + register_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/{resourceProviderNamespace}/register'} # type: ignore + async def register( self, resource_provider_namespace: str, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -109,7 +163,7 @@ async def register( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -154,7 +208,7 @@ def list( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -168,7 +222,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -232,7 +286,7 @@ def list_at_tenant_scope( top: Optional[int] = None, expand: Optional[str] = None, **kwargs - ) -> AsyncIterable["models.ProviderListResult"]: + ) -> AsyncIterable["_models.ProviderListResult"]: """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -246,7 +300,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -306,7 +360,7 @@ async def get( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -319,7 +373,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,7 +420,7 @@ async def get_at_tenant_scope( resource_provider_namespace: str, expand: Optional[str] = None, **kwargs - ) -> "models.Provider": + ) -> "_models.Provider": """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -379,7 +433,7 @@ async def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resource_groups_operations.py index 41ad22c56698..59255cc53981 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourceGroupsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -99,9 +99,9 @@ async def check_existence( async def create_or_update( self, resource_group_name: str, - parameters: "models.ResourceGroup", + parameters: "_models.ResourceGroup", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -115,7 +115,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -167,6 +167,7 @@ async def create_or_update( async def _delete_initial( self, resource_group_name: str, + force_deletion_resource_types: Optional[str] = None, **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -187,6 +188,8 @@ async def _delete_initial( # Construct parameters query_parameters = {} # type: Dict[str, Any] + if force_deletion_resource_types is not None: + query_parameters['forceDeletionResourceTypes'] = self._serialize.query("force_deletion_resource_types", force_deletion_resource_types, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') # Construct headers @@ -209,6 +212,7 @@ async def _delete_initial( async def begin_delete( self, resource_group_name: str, + force_deletion_resource_types: Optional[str] = None, **kwargs ) -> AsyncLROPoller[None]: """Deletes a resource group. @@ -219,6 +223,10 @@ async def begin_delete( :param resource_group_name: The name of the resource group to delete. The name is case insensitive. :type resource_group_name: str + :param force_deletion_resource_types: The resource types you want to force delete. Currently, + only the following is supported: + forceDeletionResourceTypes=Microsoft.Compute/virtualMachines,Microsoft.Compute/virtualMachineScaleSets. + :type force_deletion_resource_types: str :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -239,6 +247,7 @@ async def begin_delete( if cont_token is None: raw_result = await self._delete_initial( resource_group_name=resource_group_name, + force_deletion_resource_types=force_deletion_resource_types, cls=lambda x,y,z: x, **kwargs ) @@ -250,7 +259,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -268,7 +282,7 @@ async def get( self, resource_group_name: str, **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -279,7 +293,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -322,9 +336,9 @@ async def get( async def update( self, resource_group_name: str, - parameters: "models.ResourceGroupPatchable", + parameters: "_models.ResourceGroupPatchable", **kwargs - ) -> "models.ResourceGroup": + ) -> "_models.ResourceGroup": """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -341,7 +355,7 @@ async def update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -389,10 +403,10 @@ async def update( async def _export_template_initial( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> Optional["models.ResourceGroupExportResult"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + ) -> Optional["_models.ResourceGroupExportResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -442,9 +456,9 @@ async def _export_template_initial( async def begin_export_template( self, resource_group_name: str, - parameters: "models.ExportTemplateRequest", + parameters: "_models.ExportTemplateRequest", **kwargs - ) -> AsyncLROPoller["models.ResourceGroupExportResult"]: + ) -> AsyncLROPoller["_models.ResourceGroupExportResult"]: """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -462,7 +476,7 @@ async def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -486,7 +500,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -505,7 +524,7 @@ def list( filter: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceGroupListResult"]: + ) -> AsyncIterable["_models.ResourceGroupListResult"]: """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -519,7 +538,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resources_operations.py index 6bbc39ef7c26..0e7479e17deb 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -35,7 +35,7 @@ class ResourcesOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -50,7 +50,7 @@ def list_by_resource_group( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -81,7 +81,7 @@ def list_by_resource_group( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -146,7 +146,7 @@ async def get_next(next_link=None): async def _move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -194,7 +194,7 @@ async def _move_resources_initial( async def begin_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Moves resources from one resource group to another resource group. @@ -241,7 +241,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -258,7 +263,7 @@ def get_long_running_output(pipeline_response): async def _validate_move_resources_initial( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> None: cls = kwargs.pop('cls', None) # type: ClsType[None] @@ -306,7 +311,7 @@ async def _validate_move_resources_initial( async def begin_validate_move_resources( self, source_resource_group_name: str, - parameters: "models.ResourcesMoveInfo", + parameters: "_models.ResourcesMoveInfo", **kwargs ) -> AsyncLROPoller[None]: """Validates whether resources can be moved from one resource group to another resource group. @@ -355,7 +360,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -375,7 +385,7 @@ def list( expand: Optional[str] = None, top: Optional[int] = None, **kwargs - ) -> AsyncIterable["models.ResourceListResult"]: + ) -> AsyncIterable["_models.ResourceListResult"]: """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -404,7 +414,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -647,7 +657,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -669,10 +688,10 @@ async def _create_or_update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -733,9 +752,9 @@ async def begin_create_or_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -764,7 +783,7 @@ async def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -793,7 +812,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -815,10 +843,10 @@ async def _update_initial( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -876,9 +904,9 @@ async def begin_update( resource_type: str, resource_name: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -907,7 +935,7 @@ async def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -936,7 +964,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -959,7 +996,7 @@ async def get( resource_name: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -980,7 +1017,7 @@ async def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1165,7 +1202,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1183,10 +1224,10 @@ async def _create_or_update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1238,9 +1279,9 @@ async def begin_create_or_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1262,7 +1303,7 @@ async def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1287,7 +1328,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1305,10 +1350,10 @@ async def _update_by_id_initial( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> Optional["models.GenericResource"]: - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1357,9 +1402,9 @@ async def begin_update_by_id( self, resource_id: str, api_version: str, - parameters: "models.GenericResource", + parameters: "_models.GenericResource", **kwargs - ) -> AsyncLROPoller["models.GenericResource"]: + ) -> AsyncLROPoller["_models.GenericResource"]: """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1381,7 +1426,7 @@ async def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1406,7 +1451,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = AsyncARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = AsyncNoPolling() else: polling_method = polling if cont_token: @@ -1425,7 +1474,7 @@ async def get_by_id( resource_id: str, api_version: str, **kwargs - ) -> "models.GenericResource": + ) -> "_models.GenericResource": """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1439,7 +1488,7 @@ async def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_tags_operations.py index f167bddff988..a677cfaf943a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/aio/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TagsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -105,7 +105,7 @@ async def create_or_update_value( tag_name: str, tag_value: str, **kwargs - ) -> "models.TagValue": + ) -> "_models.TagValue": """Creates a predefined value for a predefined tag name. This operation allows adding a value to the list of predefined values for an existing @@ -120,7 +120,7 @@ async def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def create_or_update( self, tag_name: str, **kwargs - ) -> "models.TagDetails": + ) -> "_models.TagDetails": """Creates a predefined tag name. This operation allows adding a name to the list of predefined tag names for the given @@ -184,7 +184,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -286,7 +286,7 @@ async def delete( def list( self, **kwargs - ) -> AsyncIterable["models.TagsListResult"]: + ) -> AsyncIterable["_models.TagsListResult"]: """Gets a summary of tag usage under the subscription. This operation performs a union of predefined tags, resource tags, resource group tags and @@ -299,7 +299,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -357,9 +357,9 @@ async def get_next(next_link=None): async def create_or_update_at_scope( self, scope: str, - parameters: "models.TagsResource", + parameters: "_models.TagsResource", **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Creates or updates the entire set of tags on a resource or subscription. This operation allows adding or replacing the entire set of tags on the specified resource or @@ -374,7 +374,7 @@ async def create_or_update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -421,9 +421,9 @@ async def create_or_update_at_scope( async def update_at_scope( self, scope: str, - parameters: "models.TagsPatchResource", + parameters: "_models.TagsPatchResource", **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Selectively updates the set of tags on a resource or subscription. This operation allows replacing, merging or selectively deleting tags on the specified resource @@ -442,7 +442,7 @@ async def update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -490,7 +490,7 @@ async def get_at_scope( self, scope: str, **kwargs - ) -> "models.TagsResource": + ) -> "_models.TagsResource": """Gets the entire set of tags on a resource or subscription. Gets the entire set of tags on a resource or subscription. @@ -502,7 +502,7 @@ async def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/__init__.py index e3e01f11bb7b..2a9d8a639fb3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/__init__.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/__init__.py @@ -32,6 +32,7 @@ from ._models_py3 import ErrorAdditionalInfo from ._models_py3 import ErrorResponse from ._models_py3 import ExportTemplateRequest + from ._models_py3 import ExpressionEvaluationOptions from ._models_py3 import GenericResource from ._models_py3 import GenericResourceExpanded from ._models_py3 import GenericResourceFilter @@ -103,6 +104,7 @@ from ._models import ErrorAdditionalInfo # type: ignore from ._models import ErrorResponse # type: ignore from ._models import ExportTemplateRequest # type: ignore + from ._models import ExpressionEvaluationOptions # type: ignore from ._models import GenericResource # type: ignore from ._models import GenericResourceExpanded # type: ignore from ._models import GenericResourceFilter # type: ignore @@ -156,6 +158,7 @@ AliasType, ChangeType, DeploymentMode, + ExpressionEvaluationOptionsScopeType, OnErrorDeploymentType, PropertyChangeType, ProvisioningOperation, @@ -191,6 +194,7 @@ 'ErrorAdditionalInfo', 'ErrorResponse', 'ExportTemplateRequest', + 'ExpressionEvaluationOptions', 'GenericResource', 'GenericResourceExpanded', 'GenericResourceFilter', @@ -242,6 +246,7 @@ 'AliasType', 'ChangeType', 'DeploymentMode', + 'ExpressionEvaluationOptionsScopeType', 'OnErrorDeploymentType', 'PropertyChangeType', 'ProvisioningOperation', diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models.py index 179ac5d4fddc..7266e0032c4b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models.py @@ -586,6 +586,11 @@ class DeploymentProperties(msrest.serialization.Model): :type debug_setting: ~azure.mgmt.resource.resources.v2020_06_01.models.DebugSetting :param on_error_deployment: The deployment on error behavior. :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_06_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptions """ _validation = { @@ -600,6 +605,7 @@ class DeploymentProperties(msrest.serialization.Model): 'mode': {'key': 'mode', 'type': 'str'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, } def __init__( @@ -614,6 +620,7 @@ def __init__( self.mode = kwargs['mode'] self.debug_setting = kwargs.get('debug_setting', None) self.on_error_deployment = kwargs.get('on_error_deployment', None) + self.expression_evaluation_options = kwargs.get('expression_evaluation_options', None) class DeploymentPropertiesExtended(msrest.serialization.Model): @@ -820,6 +827,11 @@ class DeploymentWhatIfProperties(DeploymentProperties): :type debug_setting: ~azure.mgmt.resource.resources.v2020_06_01.models.DebugSetting :param on_error_deployment: The deployment on error behavior. :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_06_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptions :param what_if_settings: Optional What-If operation settings. :type what_if_settings: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentWhatIfSettings @@ -837,6 +849,7 @@ class DeploymentWhatIfProperties(DeploymentProperties): 'mode': {'key': 'mode', 'type': 'str'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, 'what_if_settings': {'key': 'whatIfSettings', 'type': 'DeploymentWhatIfSettings'}, } @@ -900,7 +913,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -971,6 +984,27 @@ def __init__( self.options = kwargs.get('options', None) +class ExpressionEvaluationOptions(msrest.serialization.Model): + """Specifies whether template expressions are evaluated within the scope of the parent template or nested template. + + :param scope: The scope to be used for evaluation of parameters, variables and functions in a + nested template. Possible values include: "NotSpecified", "Outer", "Inner". + :type scope: str or + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptionsScopeType + """ + + _attribute_map = { + 'scope': {'key': 'scope', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressionEvaluationOptions, self).__init__(**kwargs) + self.scope = kwargs.get('scope', None) + + class Resource(msrest.serialization.Model): """Specified resource. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models_py3.py index 344c24cabd8f..fafd86d58d3e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_models_py3.py @@ -633,6 +633,11 @@ class DeploymentProperties(msrest.serialization.Model): :type debug_setting: ~azure.mgmt.resource.resources.v2020_06_01.models.DebugSetting :param on_error_deployment: The deployment on error behavior. :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_06_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptions """ _validation = { @@ -647,6 +652,7 @@ class DeploymentProperties(msrest.serialization.Model): 'mode': {'key': 'mode', 'type': 'str'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, } def __init__( @@ -659,6 +665,7 @@ def __init__( parameters_link: Optional["ParametersLink"] = None, debug_setting: Optional["DebugSetting"] = None, on_error_deployment: Optional["OnErrorDeployment"] = None, + expression_evaluation_options: Optional["ExpressionEvaluationOptions"] = None, **kwargs ): super(DeploymentProperties, self).__init__(**kwargs) @@ -669,6 +676,7 @@ def __init__( self.mode = mode self.debug_setting = debug_setting self.on_error_deployment = on_error_deployment + self.expression_evaluation_options = expression_evaluation_options class DeploymentPropertiesExtended(msrest.serialization.Model): @@ -880,6 +888,11 @@ class DeploymentWhatIfProperties(DeploymentProperties): :type debug_setting: ~azure.mgmt.resource.resources.v2020_06_01.models.DebugSetting :param on_error_deployment: The deployment on error behavior. :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_06_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptions :param what_if_settings: Optional What-If operation settings. :type what_if_settings: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentWhatIfSettings @@ -897,6 +910,7 @@ class DeploymentWhatIfProperties(DeploymentProperties): 'mode': {'key': 'mode', 'type': 'str'}, 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, 'what_if_settings': {'key': 'whatIfSettings', 'type': 'DeploymentWhatIfSettings'}, } @@ -910,10 +924,11 @@ def __init__( parameters_link: Optional["ParametersLink"] = None, debug_setting: Optional["DebugSetting"] = None, on_error_deployment: Optional["OnErrorDeployment"] = None, + expression_evaluation_options: Optional["ExpressionEvaluationOptions"] = None, what_if_settings: Optional["DeploymentWhatIfSettings"] = None, **kwargs ): - super(DeploymentWhatIfProperties, self).__init__(template=template, template_link=template_link, parameters=parameters, parameters_link=parameters_link, mode=mode, debug_setting=debug_setting, on_error_deployment=on_error_deployment, **kwargs) + super(DeploymentWhatIfProperties, self).__init__(template=template, template_link=template_link, parameters=parameters, parameters_link=parameters_link, mode=mode, debug_setting=debug_setting, on_error_deployment=on_error_deployment, expression_evaluation_options=expression_evaluation_options, **kwargs) self.what_if_settings = what_if_settings @@ -971,7 +986,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -1045,6 +1060,29 @@ def __init__( self.options = options +class ExpressionEvaluationOptions(msrest.serialization.Model): + """Specifies whether template expressions are evaluated within the scope of the parent template or nested template. + + :param scope: The scope to be used for evaluation of parameters, variables and functions in a + nested template. Possible values include: "NotSpecified", "Outer", "Inner". + :type scope: str or + ~azure.mgmt.resource.resources.v2020_06_01.models.ExpressionEvaluationOptionsScopeType + """ + + _attribute_map = { + 'scope': {'key': 'scope', 'type': 'str'}, + } + + def __init__( + self, + *, + scope: Optional[Union[str, "ExpressionEvaluationOptionsScopeType"]] = None, + **kwargs + ): + super(ExpressionEvaluationOptions, self).__init__(**kwargs) + self.scope = scope + + class Resource(msrest.serialization.Model): """Specified resource. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_resource_management_client_enums.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_resource_management_client_enums.py index e7a6ad5566dd..0870d71c7b06 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_resource_management_client_enums.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/models/_resource_management_client_enums.py @@ -83,6 +83,15 @@ class DeploymentMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): INCREMENTAL = "Incremental" COMPLETE = "Complete" +class ExpressionEvaluationOptionsScopeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The scope to be used for evaluation of parameters, variables and functions in a nested + template. + """ + + NOT_SPECIFIED = "NotSpecified" + OUTER = "Outer" + INNER = "Inner" + class OnErrorDeploymentType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): """The deployment on error behavior type. Possible values are LastSuccessful and SpecificDeployment. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployment_operations_operations.py index 511685377c52..e872276382c4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployment_operations_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployment_operations_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class DeploymentOperationsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -52,7 +52,7 @@ def get_at_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param scope: The resource scope. @@ -66,7 +66,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -114,7 +114,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param scope: The resource scope. @@ -128,7 +128,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -192,7 +192,7 @@ def get_at_tenant_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -204,7 +204,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -262,7 +262,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -326,7 +326,7 @@ def get_at_management_group_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param group_id: The management group ID. @@ -340,7 +340,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param group_id: The management group ID. @@ -402,7 +402,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -466,7 +466,7 @@ def get_at_subscription_scope( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param deployment_name: The name of the deployment. @@ -478,7 +478,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -525,7 +525,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param deployment_name: The name of the deployment. @@ -537,7 +537,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -602,7 +602,7 @@ def get( operation_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentOperation" + # type: (...) -> "_models.DeploymentOperation" """Gets a deployments operation. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -616,7 +616,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperation :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperation"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -665,7 +665,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentOperationsListResult"] + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] """Gets all deployments operations for a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -679,7 +679,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentOperationsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentOperationsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployments_operations.py index 6574a39f82ee..d3c966af0b24 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployments_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_deployments_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class DeploymentsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -144,7 +144,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -218,11 +223,11 @@ def _create_or_update_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -275,10 +280,10 @@ def begin_create_or_update_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at a given scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -300,7 +305,7 @@ def begin_create_or_update_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -325,7 +330,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -345,7 +355,7 @@ def get_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param scope: The resource scope. @@ -357,7 +367,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -461,11 +471,11 @@ def _validate_at_scope_initial( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -519,10 +529,10 @@ def begin_validate_at_scope( self, scope, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -543,7 +553,7 @@ def begin_validate_at_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -568,7 +578,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -588,7 +603,7 @@ def export_template_at_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param scope: The resource scope. @@ -600,7 +615,7 @@ def export_template_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -647,7 +662,7 @@ def list_at_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the given scope. :param scope: The resource scope. @@ -662,7 +677,7 @@ def list_at_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -812,7 +827,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -881,11 +900,11 @@ def check_existence_at_tenant_scope( def _create_or_update_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -936,10 +955,10 @@ def _create_or_update_at_tenant_scope_initial( def begin_create_or_update_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at tenant scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -959,7 +978,7 @@ def begin_create_or_update_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -983,7 +1002,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1002,7 +1025,7 @@ def get_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -1012,7 +1035,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1110,11 +1133,11 @@ def cancel_at_tenant_scope( def _validate_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1166,10 +1189,10 @@ def _validate_at_tenant_scope_initial( def begin_validate_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1188,7 +1211,7 @@ def begin_validate_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1212,7 +1235,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1229,11 +1256,11 @@ def get_long_running_output(pipeline_response): def _what_if_at_tenant_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1287,10 +1314,10 @@ def _what_if_at_tenant_scope_initial( def begin_what_if_at_tenant_scope( self, deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the tenant group. @@ -1309,7 +1336,7 @@ def begin_what_if_at_tenant_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1333,7 +1360,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1352,7 +1383,7 @@ def export_template_at_tenant_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -1362,7 +1393,7 @@ def export_template_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1407,7 +1438,7 @@ def list_at_tenant_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments at the tenant scope. :param filter: The filter to apply on the operation. For example, you can use @@ -1420,7 +1451,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1572,7 +1603,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1646,11 +1682,11 @@ def _create_or_update_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1703,10 +1739,10 @@ def begin_create_or_update_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at management group scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -1728,7 +1764,7 @@ def begin_create_or_update_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1753,7 +1789,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1773,7 +1814,7 @@ def get_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param group_id: The management group ID. @@ -1785,7 +1826,7 @@ def get_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1889,11 +1930,11 @@ def _validate_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1947,10 +1988,10 @@ def begin_validate_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeployment" + parameters, # type: "_models.ScopedDeployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -1971,7 +2012,7 @@ def begin_validate_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1996,7 +2037,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2014,11 +2060,11 @@ def _what_if_at_management_group_scope_initial( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2074,10 +2120,10 @@ def begin_what_if_at_management_group_scope( self, group_id, # type: str deployment_name, # type: str - parameters, # type: "models.ScopedDeploymentWhatIf" + parameters, # type: "_models.ScopedDeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the management group. @@ -2098,7 +2144,7 @@ def begin_what_if_at_management_group_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2123,7 +2169,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2143,7 +2194,7 @@ def export_template_at_management_group_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param group_id: The management group ID. @@ -2155,7 +2206,7 @@ def export_template_at_management_group_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2202,7 +2253,7 @@ def list_at_management_group_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a management group. :param group_id: The management group ID. @@ -2217,7 +2268,7 @@ def list_at_management_group_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2368,7 +2419,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2438,11 +2494,11 @@ def check_existence_at_subscription_scope( def _create_or_update_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2494,10 +2550,10 @@ def _create_or_update_at_subscription_scope_initial( def begin_create_or_update_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources at subscription scope. You can provide the template and parameters directly in the request or link to JSON files. @@ -2517,7 +2573,7 @@ def begin_create_or_update_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2541,7 +2597,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2560,7 +2621,7 @@ def get_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param deployment_name: The name of the deployment. @@ -2570,7 +2631,7 @@ def get_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2670,11 +2731,11 @@ def cancel_at_subscription_scope( def _validate_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2727,10 +2788,10 @@ def _validate_at_subscription_scope_initial( def begin_validate_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -2749,7 +2810,7 @@ def begin_validate_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2773,7 +2834,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2790,11 +2856,11 @@ def get_long_running_output(pipeline_response): def _what_if_at_subscription_scope_initial( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2849,10 +2915,10 @@ def _what_if_at_subscription_scope_initial( def begin_what_if_at_subscription_scope( self, deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the subscription. @@ -2871,7 +2937,7 @@ def begin_what_if_at_subscription_scope( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -2895,7 +2961,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -2914,7 +2985,7 @@ def export_template_at_subscription_scope( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param deployment_name: The name of the deployment. @@ -2924,7 +2995,7 @@ def export_template_at_subscription_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -2970,7 +3041,7 @@ def list_at_subscription_scope( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a subscription. :param filter: The filter to apply on the operation. For example, you can use @@ -2983,7 +3054,7 @@ def list_at_subscription_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3142,7 +3213,13 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3218,11 +3295,11 @@ def _create_or_update_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3276,10 +3353,10 @@ def begin_create_or_update( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentExtended"] + # type: (...) -> LROPoller["_models.DeploymentExtended"] """Deploys resources to a resource group. You can provide the template and parameters directly in the request or link to JSON files. @@ -3302,7 +3379,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3327,7 +3404,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3347,7 +3430,7 @@ def get( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExtended" + # type: (...) -> "_models.DeploymentExtended" """Gets a deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3359,7 +3442,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExtended :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExtended"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3465,11 +3548,11 @@ def _validate_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> Optional["models.DeploymentValidateResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.DeploymentValidateResult"]] + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3524,10 +3607,10 @@ def begin_validate( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.Deployment" + parameters, # type: "_models.Deployment" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.DeploymentValidateResult"] + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] """Validates whether the specified template is syntactically correct and will be accepted by Azure Resource Manager.. @@ -3549,7 +3632,7 @@ def begin_validate( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3574,7 +3657,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3592,11 +3681,11 @@ def _what_if_initial( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> Optional["models.WhatIfOperationResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.WhatIfOperationResult"]] + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3653,10 +3742,10 @@ def begin_what_if( self, resource_group_name, # type: str deployment_name, # type: str - parameters, # type: "models.DeploymentWhatIf" + parameters, # type: "_models.DeploymentWhatIf" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.WhatIfOperationResult"] + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] """Returns changes that will be made by the deployment if executed at the scope of the resource group. @@ -3678,7 +3767,7 @@ def begin_what_if( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -3703,7 +3792,13 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -3723,7 +3818,7 @@ def export_template( deployment_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.DeploymentExportResult" + # type: (...) -> "_models.DeploymentExportResult" """Exports the template used for specified deployment. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -3735,7 +3830,7 @@ def export_template( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentExportResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3783,7 +3878,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.DeploymentListResult"] + # type: (...) -> Iterable["_models.DeploymentListResult"] """Get all the deployments for a resource group. :param resource_group_name: The name of the resource group with the deployments to get. The @@ -3799,7 +3894,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.DeploymentListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.DeploymentListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -3864,7 +3959,7 @@ def calculate_template_hash( template, # type: object **kwargs # type: Any ): - # type: (...) -> "models.TemplateHashResult" + # type: (...) -> "_models.TemplateHashResult" """Calculate the hash of the given template. :param template: The template provided to calculate hash. @@ -3874,7 +3969,7 @@ def calculate_template_hash( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TemplateHashResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateHashResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_operations.py index f8536e4cfae4..ef18f4630d22 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_providers_operations.py index 7eb9ba5547bb..3bd1f6f08461 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_providers_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_providers_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class ProvidersOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def unregister( resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Unregisters a subscription from a resource provider. :param resource_provider_namespace: The namespace of the resource provider to unregister. @@ -60,7 +60,7 @@ def unregister( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -100,12 +100,67 @@ def unregister( return deserialized unregister.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/unregister'} # type: ignore + def register_at_management_group_scope( + self, + resource_provider_namespace, # type: str + group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Registers a management group with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :param group_id: The management group ID. + :type group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-06-01" + accept = "application/json" + + # Construct URL + url = self.register_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + register_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/{resourceProviderNamespace}/register'} # type: ignore + def register( self, resource_provider_namespace, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Registers a subscription with a resource provider. :param resource_provider_namespace: The namespace of the resource provider to register. @@ -115,7 +170,7 @@ def register( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -161,7 +216,7 @@ def list( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for a subscription. :param top: The number of results to return. If null is passed returns all deployments. @@ -175,7 +230,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -240,7 +295,7 @@ def list_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ProviderListResult"] + # type: (...) -> Iterable["_models.ProviderListResult"] """Gets all resource providers for the tenant. :param top: The number of results to return. If null is passed returns all providers. @@ -254,7 +309,7 @@ def list_at_tenant_scope( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ProviderListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ProviderListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -315,7 +370,7 @@ def get( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider. :param resource_provider_namespace: The namespace of the resource provider. @@ -328,7 +383,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -376,7 +431,7 @@ def get_at_tenant_scope( expand=None, # type: Optional[str] **kwargs # type: Any ): - # type: (...) -> "models.Provider" + # type: (...) -> "_models.Provider" """Gets the specified resource provider at the tenant level. :param resource_provider_namespace: The namespace of the resource provider. @@ -389,7 +444,7 @@ def get_at_tenant_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.Provider :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Provider"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resource_groups_operations.py index 9932c8b61675..77d3cd8bf74f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resource_groups_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resource_groups_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourceGroupsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -104,10 +104,10 @@ def check_existence( def create_or_update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroup" + parameters, # type: "_models.ResourceGroup" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Creates or updates a resource group. :param resource_group_name: The name of the resource group to create or update. Can include @@ -121,7 +121,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -173,6 +173,7 @@ def create_or_update( def _delete_initial( self, resource_group_name, # type: str + force_deletion_resource_types=None, # type: Optional[str] **kwargs # type: Any ): # type: (...) -> None @@ -194,6 +195,8 @@ def _delete_initial( # Construct parameters query_parameters = {} # type: Dict[str, Any] + if force_deletion_resource_types is not None: + query_parameters['forceDeletionResourceTypes'] = self._serialize.query("force_deletion_resource_types", force_deletion_resource_types, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') # Construct headers @@ -216,6 +219,7 @@ def _delete_initial( def begin_delete( self, resource_group_name, # type: str + force_deletion_resource_types=None, # type: Optional[str] **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -227,6 +231,10 @@ def begin_delete( :param resource_group_name: The name of the resource group to delete. The name is case insensitive. :type resource_group_name: str + :param force_deletion_resource_types: The resource types you want to force delete. Currently, + only the following is supported: + forceDeletionResourceTypes=Microsoft.Compute/virtualMachines,Microsoft.Compute/virtualMachineScaleSets. + :type force_deletion_resource_types: str :keyword callable cls: A custom type or function that will be passed the direct response :keyword str continuation_token: A continuation token to restart a poller from a saved state. :keyword polling: True for ARMPolling, False for no polling, or a @@ -247,6 +255,7 @@ def begin_delete( if cont_token is None: raw_result = self._delete_initial( resource_group_name=resource_group_name, + force_deletion_resource_types=force_deletion_resource_types, cls=lambda x,y,z: x, **kwargs ) @@ -258,7 +267,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -277,7 +291,7 @@ def get( resource_group_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Gets a resource group. :param resource_group_name: The name of the resource group to get. The name is case @@ -288,7 +302,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,10 +345,10 @@ def get( def update( self, resource_group_name, # type: str - parameters, # type: "models.ResourceGroupPatchable" + parameters, # type: "_models.ResourceGroupPatchable" **kwargs # type: Any ): - # type: (...) -> "models.ResourceGroup" + # type: (...) -> "_models.ResourceGroup" """Updates a resource group. Resource groups can be updated through a simple PATCH operation to a group address. The format @@ -351,7 +365,7 @@ def update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroup :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroup"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -399,11 +413,11 @@ def update( def _export_template_initial( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> Optional["models.ResourceGroupExportResult"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.ResourceGroupExportResult"]] + # type: (...) -> Optional["_models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -453,10 +467,10 @@ def _export_template_initial( def begin_export_template( self, resource_group_name, # type: str - parameters, # type: "models.ExportTemplateRequest" + parameters, # type: "_models.ExportTemplateRequest" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.ResourceGroupExportResult"] + # type: (...) -> LROPoller["_models.ResourceGroupExportResult"] """Captures the specified resource group as a template. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -474,7 +488,7 @@ def begin_export_template( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -498,7 +512,12 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, **kwargs) + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -518,7 +537,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceGroupListResult"] + # type: (...) -> Iterable["_models.ResourceGroupListResult"] """Gets all the resource groups for a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by @@ -532,7 +551,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceGroupListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceGroupListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resources_operations.py index fc0871ccd898..99439e7dd36e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resources_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_resources_operations.py @@ -16,7 +16,7 @@ from azure.mgmt.core.exceptions import ARMErrorFormat from azure.mgmt.core.polling.arm_polling import ARMPolling -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -39,7 +39,7 @@ class ResourcesOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -55,7 +55,7 @@ def list_by_resource_group( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources for a resource group. :param resource_group_name: The resource group with the resources to get. @@ -86,7 +86,7 @@ def list_by_resource_group( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -151,7 +151,7 @@ def get_next(next_link=None): def _move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -200,7 +200,7 @@ def _move_resources_initial( def begin_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -248,7 +248,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -265,7 +270,7 @@ def get_long_running_output(pipeline_response): def _validate_move_resources_initial( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> None @@ -314,7 +319,7 @@ def _validate_move_resources_initial( def begin_validate_move_resources( self, source_resource_group_name, # type: str - parameters, # type: "models.ResourcesMoveInfo" + parameters, # type: "_models.ResourcesMoveInfo" **kwargs # type: Any ): # type: (...) -> LROPoller[None] @@ -364,7 +369,12 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -385,7 +395,7 @@ def list( top=None, # type: Optional[int] **kwargs # type: Any ): - # type: (...) -> Iterable["models.ResourceListResult"] + # type: (...) -> Iterable["_models.ResourceListResult"] """Get all the resources in a subscription. :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you @@ -414,7 +424,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.ResourceListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.ResourceListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -660,7 +670,16 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -682,11 +701,11 @@ def _create_or_update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -747,10 +766,10 @@ def begin_create_or_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Creates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -779,7 +798,7 @@ def begin_create_or_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -808,7 +827,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -830,11 +858,11 @@ def _update_initial( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -892,10 +920,10 @@ def begin_update( resource_type, # type: str resource_name, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource. :param resource_group_name: The name of the resource group for the resource. The name is case @@ -924,7 +952,7 @@ def begin_update( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -953,7 +981,16 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -977,7 +1014,7 @@ def get( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource. :param resource_group_name: The name of the resource group containing the resource to get. The @@ -998,7 +1035,7 @@ def get( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1186,7 +1223,11 @@ def get_long_running_output(pipeline_response): if cls: return cls(pipeline_response, None, {}) - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1204,11 +1245,11 @@ def _create_or_update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1260,10 +1301,10 @@ def begin_create_or_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Create a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1285,7 +1326,7 @@ def begin_create_or_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1310,7 +1351,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1328,11 +1373,11 @@ def _update_by_id_initial( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> Optional["models.GenericResource"] - cls = kwargs.pop('cls', None) # type: ClsType[Optional["models.GenericResource"]] + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -1381,10 +1426,10 @@ def begin_update_by_id( self, resource_id, # type: str api_version, # type: str - parameters, # type: "models.GenericResource" + parameters, # type: "_models.GenericResource" **kwargs # type: Any ): - # type: (...) -> LROPoller["models.GenericResource"] + # type: (...) -> LROPoller["_models.GenericResource"] """Updates a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1406,7 +1451,7 @@ def begin_update_by_id( :raises ~azure.core.exceptions.HttpResponseError: """ polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] lro_delay = kwargs.pop( 'polling_interval', self._config.polling_interval @@ -1431,7 +1476,11 @@ def get_long_running_output(pipeline_response): return cls(pipeline_response, deserialized, {}) return deserialized - if polling is True: polling_method = ARMPolling(lro_delay, **kwargs) + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) elif polling is False: polling_method = NoPolling() else: polling_method = polling if cont_token: @@ -1451,7 +1500,7 @@ def get_by_id( api_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.GenericResource" + # type: (...) -> "_models.GenericResource" """Gets a resource by ID. :param resource_id: The fully qualified ID of the resource, including the resource name and @@ -1465,7 +1514,7 @@ def get_by_id( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.GenericResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_tags_operations.py index 6afbfdab4087..51db4878a8e3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_tags_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_06_01/operations/_tags_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TagsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -111,7 +111,7 @@ def create_or_update_value( tag_value, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagValue" + # type: (...) -> "_models.TagValue" """Creates a predefined value for a predefined tag name. This operation allows adding a value to the list of predefined values for an existing @@ -126,7 +126,7 @@ def create_or_update_value( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagValue :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagValue"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def create_or_update( tag_name, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagDetails" + # type: (...) -> "_models.TagDetails" """Creates a predefined tag name. This operation allows adding a name to the list of predefined tag names for the given @@ -191,7 +191,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagDetails :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagDetails"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -295,7 +295,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TagsListResult"] + # type: (...) -> Iterable["_models.TagsListResult"] """Gets a summary of tag usage under the subscription. This operation performs a union of predefined tags, resource tags, resource group tags and @@ -308,7 +308,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_06_01.models.TagsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -366,10 +366,10 @@ def get_next(next_link=None): def create_or_update_at_scope( self, scope, # type: str - parameters, # type: "models.TagsResource" + parameters, # type: "_models.TagsResource" **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Creates or updates the entire set of tags on a resource or subscription. This operation allows adding or replacing the entire set of tags on the specified resource or @@ -384,7 +384,7 @@ def create_or_update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -431,10 +431,10 @@ def create_or_update_at_scope( def update_at_scope( self, scope, # type: str - parameters, # type: "models.TagsPatchResource" + parameters, # type: "_models.TagsPatchResource" **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Selectively updates the set of tags on a resource or subscription. This operation allows replacing, merging or selectively deleting tags on the specified resource @@ -453,7 +453,7 @@ def update_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -502,7 +502,7 @@ def get_at_scope( scope, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TagsResource" + # type: (...) -> "_models.TagsResource" """Gets the entire set of tags on a resource or subscription. Gets the entire set of tags on a resource or subscription. @@ -514,7 +514,7 @@ def get_at_scope( :rtype: ~azure.mgmt.resource.resources.v2020_06_01.models.TagsResource :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TagsResource"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/__init__.py new file mode 100644 index 000000000000..07fb5205b898 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/__init__.py @@ -0,0 +1,16 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._resource_management_client import ResourceManagementClient +__all__ = ['ResourceManagementClient'] + +try: + from ._patch import patch_sdk # type: ignore + patch_sdk() +except ImportError: + pass diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_configuration.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_configuration.py new file mode 100644 index 000000000000..f33ccefd0bb4 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_configuration.py @@ -0,0 +1,70 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any + + from azure.core.credentials import TokenCredential + +VERSION = "unknown" + +class ResourceManagementClientConfiguration(Configuration): + """Configuration for ResourceManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(ResourceManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-10-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-resource/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs # type: Any + ): + # type: (...) -> None + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.RetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.RedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.BearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_metadata.json new file mode 100644 index 000000000000..4cb0af7bc60e --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_metadata.json @@ -0,0 +1,68 @@ +{ + "chosen_version": "2020-10-01", + "total_api_version_list": ["2020-10-01"], + "client": { + "name": "ResourceManagementClient", + "filename": "_resource_management_client", + "description": "Provides operations for working with resources and resource groups.", + "base_url": "\u0027https://management.azure.com\u0027", + "custom_base_url": null, + "azure_arm": true, + "has_lro_operations": true, + "client_side_validation": true + }, + "global_parameters": { + "sync": { + "credential": { + "signature": "credential, # type: \"TokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials.TokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The ID of the target subscription.", + "docstring_type": "str", + "required": true + } + }, + "async": { + "credential": { + "signature": "credential, # type: \"AsyncTokenCredential\"", + "description": "Credential needed for the client to connect to Azure.", + "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", + "required": true + }, + "subscription_id": { + "signature": "subscription_id, # type: str", + "description": "The ID of the target subscription.", + "docstring_type": "str", + "required": true + } + }, + "constant": { + }, + "call": "credential, subscription_id" + }, + "config": { + "credential": true, + "credential_scopes": ["https://management.azure.com/.default"], + "credential_default_policy_type": "BearerTokenCredentialPolicy", + "credential_default_policy_type_has_async_version": true, + "credential_key_header_name": null + }, + "operation_groups": { + "operations": "Operations", + "deployments": "DeploymentsOperations", + "providers": "ProvidersOperations", + "provider_resource_types": "ProviderResourceTypesOperations", + "resources": "ResourcesOperations", + "resource_groups": "ResourceGroupsOperations", + "tags": "TagsOperations", + "deployment_operations": "DeploymentOperationsOperations" + }, + "operation_mixins": { + }, + "sync_imports": "None", + "async_imports": "None" +} \ No newline at end of file diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_resource_management_client.py new file mode 100644 index 000000000000..b677d9ea3ded --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/_resource_management_client.py @@ -0,0 +1,104 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import TYPE_CHECKING + +from azure.mgmt.core import ARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Optional + + from azure.core.credentials import TokenCredential + +from ._configuration import ResourceManagementClientConfiguration +from .operations import Operations +from .operations import DeploymentsOperations +from .operations import ProvidersOperations +from .operations import ProviderResourceTypesOperations +from .operations import ResourcesOperations +from .operations import ResourceGroupsOperations +from .operations import TagsOperations +from .operations import DeploymentOperationsOperations +from . import models + + +class ResourceManagementClient(object): + """Provides operations for working with resources and resource groups. + + :ivar operations: Operations operations + :vartype operations: azure.mgmt.resource.resources.v2020_10_01.operations.Operations + :ivar deployments: DeploymentsOperations operations + :vartype deployments: azure.mgmt.resource.resources.v2020_10_01.operations.DeploymentsOperations + :ivar providers: ProvidersOperations operations + :vartype providers: azure.mgmt.resource.resources.v2020_10_01.operations.ProvidersOperations + :ivar provider_resource_types: ProviderResourceTypesOperations operations + :vartype provider_resource_types: azure.mgmt.resource.resources.v2020_10_01.operations.ProviderResourceTypesOperations + :ivar resources: ResourcesOperations operations + :vartype resources: azure.mgmt.resource.resources.v2020_10_01.operations.ResourcesOperations + :ivar resource_groups: ResourceGroupsOperations operations + :vartype resource_groups: azure.mgmt.resource.resources.v2020_10_01.operations.ResourceGroupsOperations + :ivar tags: TagsOperations operations + :vartype tags: azure.mgmt.resource.resources.v2020_10_01.operations.TagsOperations + :ivar deployment_operations: DeploymentOperationsOperations operations + :vartype deployment_operations: azure.mgmt.resource.resources.v2020_10_01.operations.DeploymentOperationsOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials.TokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential, # type: "TokenCredential" + subscription_id, # type: str + base_url=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> None + if not base_url: + base_url = 'https://management.azure.com' + self._config = ResourceManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = ARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.deployments = DeploymentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.providers = ProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider_resource_types = ProviderResourceTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resources = ResourcesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_groups = ResourceGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.tags = TagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deployment_operations = DeploymentOperationsOperations( + self._client, self._config, self._serialize, self._deserialize) + + def close(self): + # type: () -> None + self._client.close() + + def __enter__(self): + # type: () -> ResourceManagementClient + self._client.__enter__() + return self + + def __exit__(self, *exc_details): + # type: (Any) -> None + self._client.__exit__(*exc_details) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/__init__.py new file mode 100644 index 000000000000..f11762bdb19b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/__init__.py @@ -0,0 +1,10 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._resource_management_client import ResourceManagementClient +__all__ = ['ResourceManagementClient'] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_configuration.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_configuration.py new file mode 100644 index 000000000000..dd935e3e3370 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_configuration.py @@ -0,0 +1,66 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, TYPE_CHECKING + +from azure.core.configuration import Configuration +from azure.core.pipeline import policies +from azure.mgmt.core.policies import ARMHttpLoggingPolicy + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +VERSION = "unknown" + +class ResourceManagementClientConfiguration(Configuration): + """Configuration for ResourceManagementClient. + + Note that all parameters used to create this instance are saved as instance + attributes. + + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + **kwargs: Any + ) -> None: + if credential is None: + raise ValueError("Parameter 'credential' must not be None.") + if subscription_id is None: + raise ValueError("Parameter 'subscription_id' must not be None.") + super(ResourceManagementClientConfiguration, self).__init__(**kwargs) + + self.credential = credential + self.subscription_id = subscription_id + self.api_version = "2020-10-01" + self.credential_scopes = kwargs.pop('credential_scopes', ['https://management.azure.com/.default']) + kwargs.setdefault('sdk_moniker', 'mgmt-resource/{}'.format(VERSION)) + self._configure(**kwargs) + + def _configure( + self, + **kwargs: Any + ) -> None: + self.user_agent_policy = kwargs.get('user_agent_policy') or policies.UserAgentPolicy(**kwargs) + self.headers_policy = kwargs.get('headers_policy') or policies.HeadersPolicy(**kwargs) + self.proxy_policy = kwargs.get('proxy_policy') or policies.ProxyPolicy(**kwargs) + self.logging_policy = kwargs.get('logging_policy') or policies.NetworkTraceLoggingPolicy(**kwargs) + self.http_logging_policy = kwargs.get('http_logging_policy') or ARMHttpLoggingPolicy(**kwargs) + self.retry_policy = kwargs.get('retry_policy') or policies.AsyncRetryPolicy(**kwargs) + self.custom_hook_policy = kwargs.get('custom_hook_policy') or policies.CustomHookPolicy(**kwargs) + self.redirect_policy = kwargs.get('redirect_policy') or policies.AsyncRedirectPolicy(**kwargs) + self.authentication_policy = kwargs.get('authentication_policy') + if self.credential and not self.authentication_policy: + self.authentication_policy = policies.AsyncBearerTokenCredentialPolicy(self.credential, *self.credential_scopes, **kwargs) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_resource_management_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_resource_management_client.py new file mode 100644 index 000000000000..eed34bfed4e5 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/_resource_management_client.py @@ -0,0 +1,98 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Any, Optional, TYPE_CHECKING + +from azure.mgmt.core import AsyncARMPipelineClient +from msrest import Deserializer, Serializer + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from azure.core.credentials_async import AsyncTokenCredential + +from ._configuration import ResourceManagementClientConfiguration +from .operations import Operations +from .operations import DeploymentsOperations +from .operations import ProvidersOperations +from .operations import ProviderResourceTypesOperations +from .operations import ResourcesOperations +from .operations import ResourceGroupsOperations +from .operations import TagsOperations +from .operations import DeploymentOperationsOperations +from .. import models + + +class ResourceManagementClient(object): + """Provides operations for working with resources and resource groups. + + :ivar operations: Operations operations + :vartype operations: azure.mgmt.resource.resources.v2020_10_01.aio.operations.Operations + :ivar deployments: DeploymentsOperations operations + :vartype deployments: azure.mgmt.resource.resources.v2020_10_01.aio.operations.DeploymentsOperations + :ivar providers: ProvidersOperations operations + :vartype providers: azure.mgmt.resource.resources.v2020_10_01.aio.operations.ProvidersOperations + :ivar provider_resource_types: ProviderResourceTypesOperations operations + :vartype provider_resource_types: azure.mgmt.resource.resources.v2020_10_01.aio.operations.ProviderResourceTypesOperations + :ivar resources: ResourcesOperations operations + :vartype resources: azure.mgmt.resource.resources.v2020_10_01.aio.operations.ResourcesOperations + :ivar resource_groups: ResourceGroupsOperations operations + :vartype resource_groups: azure.mgmt.resource.resources.v2020_10_01.aio.operations.ResourceGroupsOperations + :ivar tags: TagsOperations operations + :vartype tags: azure.mgmt.resource.resources.v2020_10_01.aio.operations.TagsOperations + :ivar deployment_operations: DeploymentOperationsOperations operations + :vartype deployment_operations: azure.mgmt.resource.resources.v2020_10_01.aio.operations.DeploymentOperationsOperations + :param credential: Credential needed for the client to connect to Azure. + :type credential: ~azure.core.credentials_async.AsyncTokenCredential + :param subscription_id: The ID of the target subscription. + :type subscription_id: str + :param str base_url: Service URL + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + """ + + def __init__( + self, + credential: "AsyncTokenCredential", + subscription_id: str, + base_url: Optional[str] = None, + **kwargs: Any + ) -> None: + if not base_url: + base_url = 'https://management.azure.com' + self._config = ResourceManagementClientConfiguration(credential, subscription_id, **kwargs) + self._client = AsyncARMPipelineClient(base_url=base_url, config=self._config, **kwargs) + + client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} + self._serialize = Serializer(client_models) + self._deserialize = Deserializer(client_models) + + self.operations = Operations( + self._client, self._config, self._serialize, self._deserialize) + self.deployments = DeploymentsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.providers = ProvidersOperations( + self._client, self._config, self._serialize, self._deserialize) + self.provider_resource_types = ProviderResourceTypesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resources = ResourcesOperations( + self._client, self._config, self._serialize, self._deserialize) + self.resource_groups = ResourceGroupsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.tags = TagsOperations( + self._client, self._config, self._serialize, self._deserialize) + self.deployment_operations = DeploymentOperationsOperations( + self._client, self._config, self._serialize, self._deserialize) + + async def close(self) -> None: + await self._client.close() + + async def __aenter__(self) -> "ResourceManagementClient": + await self._client.__aenter__() + return self + + async def __aexit__(self, *exc_details) -> None: + await self._client.__aexit__(*exc_details) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/__init__.py new file mode 100644 index 000000000000..b5dcba5d6d4b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/__init__.py @@ -0,0 +1,27 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._operations import Operations +from ._deployments_operations import DeploymentsOperations +from ._providers_operations import ProvidersOperations +from ._provider_resource_types_operations import ProviderResourceTypesOperations +from ._resources_operations import ResourcesOperations +from ._resource_groups_operations import ResourceGroupsOperations +from ._tags_operations import TagsOperations +from ._deployment_operations_operations import DeploymentOperationsOperations + +__all__ = [ + 'Operations', + 'DeploymentsOperations', + 'ProvidersOperations', + 'ProviderResourceTypesOperations', + 'ResourcesOperations', + 'ResourceGroupsOperations', + 'TagsOperations', + 'DeploymentOperationsOperations', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployment_operations_operations.py new file mode 100644 index 000000000000..37a8286c8811 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployment_operations_operations.py @@ -0,0 +1,725 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DeploymentOperationsOperations: + """DeploymentOperationsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def get_at_scope( + self, + scope: str, + deployment_name: str, + operation_id: str, + **kwargs + ) -> "_models.DeploymentOperation": + """Gets a deployments operation. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_scope( + self, + scope: str, + deployment_name: str, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: + """Gets all deployments operations for a deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + async def get_at_tenant_scope( + self, + deployment_name: str, + operation_id: str, + **kwargs + ) -> "_models.DeploymentOperation": + """Gets a deployments operation. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_tenant_scope( + self, + deployment_name: str, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: + """Gets all deployments operations for a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + async def get_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + operation_id: str, + **kwargs + ) -> "_models.DeploymentOperation": + """Gets a deployments operation. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: + """Gets all deployments operations for a deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + async def get_at_subscription_scope( + self, + deployment_name: str, + operation_id: str, + **kwargs + ) -> "_models.DeploymentOperation": + """Gets a deployments operation. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_subscription_scope( + self, + deployment_name: str, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: + """Gets all deployments operations for a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + async def get( + self, + resource_group_name: str, + deployment_name: str, + operation_id: str, + **kwargs + ) -> "_models.DeploymentOperation": + """Gets a deployments operation. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list( + self, + resource_group_name: str, + deployment_name: str, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentOperationsListResult"]: + """Gets all deployments operations for a deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/deployments/{deploymentName}/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployments_operations.py new file mode 100644 index 000000000000..6bbdbdfcf867 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_deployments_operations.py @@ -0,0 +1,3942 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class DeploymentsOperations: + """DeploymentsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def _delete_at_scope_initial( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_delete_at_scope( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def check_existence_at_scope( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> bool: + """Checks whether the deployment exists. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def _create_or_update_at_scope_initial( + self, + scope: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_create_or_update_at_scope( + self, + scope: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentExtended"]: + """Deploys resources at a given scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def get_at_scope( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExtended": + """Gets a deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def cancel_at_scope( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> None: + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + async def _validate_at_scope_initial( + self, + scope: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def begin_validate_at_scope( + self, + scope: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def export_template_at_scope( + self, + scope: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExportResult": + """Exports the template used for specified deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_scope( + self, + scope: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentListResult"]: + """Get all the deployments at the given scope. + + :param scope: The resource scope. + :type scope: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/'} # type: ignore + + async def _delete_at_tenant_scope_initial( + self, + deployment_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_delete_at_tenant_scope( + self, + deployment_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_at_tenant_scope_initial( + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def check_existence_at_tenant_scope( + self, + deployment_name: str, + **kwargs + ) -> bool: + """Checks whether the deployment exists. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def _create_or_update_at_tenant_scope_initial( + self, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_create_or_update_at_tenant_scope( + self, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentExtended"]: + """Deploys resources at tenant scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def get_at_tenant_scope( + self, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExtended": + """Gets a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def cancel_at_tenant_scope( + self, + deployment_name: str, + **kwargs + ) -> None: + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + async def _validate_at_tenant_scope_initial( + self, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def begin_validate_at_tenant_scope( + self, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def _what_if_at_tenant_scope_initial( + self, + deployment_name: str, + parameters: "_models.ScopedDeploymentWhatIf", + **kwargs + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def begin_what_if_at_tenant_scope( + self, + deployment_name: str, + parameters: "_models.ScopedDeploymentWhatIf", + **kwargs + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: + """Returns changes that will be made by the deployment if executed at the scope of the tenant + group. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._what_if_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def export_template_at_tenant_scope( + self, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExportResult": + """Exports the template used for specified deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_tenant_scope( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentListResult"]: + """Get all the deployments at the tenant scope. + + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/'} # type: ignore + + async def _delete_at_management_group_scope_initial( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_delete_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def check_existence_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> bool: + """Checks whether the deployment exists. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def _create_or_update_at_management_group_scope_initial( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_create_or_update_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentExtended"]: + """Deploys resources at management group scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def get_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExtended": + """Gets a deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def cancel_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> None: + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + async def _validate_at_management_group_scope_initial( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def begin_validate_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def _what_if_at_management_group_scope_initial( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeploymentWhatIf", + **kwargs + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def begin_what_if_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + parameters: "_models.ScopedDeploymentWhatIf", + **kwargs + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: + """Returns changes that will be made by the deployment if executed at the scope of the management + group. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._what_if_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def export_template_at_management_group_scope( + self, + group_id: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExportResult": + """Exports the template used for specified deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_management_group_scope( + self, + group_id: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentListResult"]: + """Get all the deployments for a management group. + + :param group_id: The management group ID. + :type group_id: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/'} # type: ignore + + async def _delete_at_subscription_scope_initial( + self, + deployment_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_delete_at_subscription_scope( + self, + deployment_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_at_subscription_scope_initial( + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def check_existence_at_subscription_scope( + self, + deployment_name: str, + **kwargs + ) -> bool: + """Checks whether the deployment exists. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def _create_or_update_at_subscription_scope_initial( + self, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_create_or_update_at_subscription_scope( + self, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentExtended"]: + """Deploys resources at subscription scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def get_at_subscription_scope( + self, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExtended": + """Gets a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def cancel_at_subscription_scope( + self, + deployment_name: str, + **kwargs + ) -> None: + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + async def _validate_at_subscription_scope_initial( + self, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def begin_validate_at_subscription_scope( + self, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def _what_if_at_subscription_scope_initial( + self, + deployment_name: str, + parameters: "_models.DeploymentWhatIf", + **kwargs + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def begin_what_if_at_subscription_scope( + self, + deployment_name: str, + parameters: "_models.DeploymentWhatIf", + **kwargs + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: + """Returns changes that will be made by the deployment if executed at the scope of the + subscription. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to What If. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._what_if_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def export_template_at_subscription_scope( + self, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExportResult": + """Exports the template used for specified deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_subscription_scope( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentListResult"]: + """Get all the deployments for a subscription. + + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. Deleting a template deployment does + not affect the state of the resource group. This is an asynchronous operation that returns a + status of 202 until the template deployment is successfully deleted. The Location response + header contains the URI that is used to obtain the status of the process. While the process is + running, a call to the URI in the Location header returns a status of 202. When the process + finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param resource_group_name: The name of the resource group with the deployment to delete. The + name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def check_existence( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> bool: + """Checks whether the deployment exists. + + :param resource_group_name: The name of the resource group with the deployment to check. The + name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> "_models.DeploymentExtended": + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentExtended"]: + """Deploys resources to a resource group. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param resource_group_name: The name of the resource group to deploy the resources to. The name + is case insensitive. The resource group must already exist. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExtended": + """Gets a deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + async def cancel( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> None: + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resource group + partially deployed. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + async def _validate_initial( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> Optional["_models.DeploymentValidateResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def begin_validate( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.Deployment", + **kwargs + ) -> AsyncLROPoller["_models.DeploymentValidateResult"]: + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param resource_group_name: The name of the resource group the template will be deployed to. + The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + async def _what_if_initial( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.DeploymentWhatIf", + **kwargs + ) -> Optional["_models.WhatIfOperationResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def begin_what_if( + self, + resource_group_name: str, + deployment_name: str, + parameters: "_models.DeploymentWhatIf", + **kwargs + ) -> AsyncLROPoller["_models.WhatIfOperationResult"]: + """Returns changes that will be made by the deployment if executed at the scope of the resource + group. + + :param resource_group_name: The name of the resource group the template will be deployed to. + The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._what_if_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + async def export_template( + self, + resource_group_name: str, + deployment_name: str, + **kwargs + ) -> "_models.DeploymentExportResult": + """Exports the template used for specified deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name: str, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.DeploymentListResult"]: + """Get all the deployments for a resource group. + + :param resource_group_name: The name of the resource group with the deployments to get. The + name is case insensitive. + :type resource_group_name: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/'} # type: ignore + + async def calculate_template_hash( + self, + template: object, + **kwargs + ) -> "_models.TemplateHashResult": + """Calculate the hash of the given template. + + :param template: The template provided to calculate hash. + :type template: object + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TemplateHashResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateHashResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.calculate_template_hash.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(template, 'object') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TemplateHashResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + calculate_template_hash.metadata = {'url': '/providers/Microsoft.Resources/calculateTemplateHash'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_operations.py new file mode 100644 index 000000000000..689228a6c6ee --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_operations.py @@ -0,0 +1,104 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class Operations: + """Operations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.OperationListResult"]: + """Lists all of the available Microsoft.Resources REST API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.Resources/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_provider_resource_types_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_provider_resource_types_operations.py new file mode 100644 index 000000000000..11db6dd69f84 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_provider_resource_types_operations.py @@ -0,0 +1,101 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ProviderResourceTypesOperations: + """ProviderResourceTypesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def list( + self, + resource_provider_namespace: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.ProviderResourceTypeListResult": + """List the resource types for a specified resource provider. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProviderResourceTypeListResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceTypeListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderResourceTypeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ProviderResourceTypeListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/resourceTypes'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_providers_operations.py new file mode 100644 index 000000000000..2a570c8c915b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_providers_operations.py @@ -0,0 +1,475 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ProvidersOperations: + """ProvidersOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def unregister( + self, + resource_provider_namespace: str, + **kwargs + ) -> "_models.Provider": + """Unregisters a subscription from a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to unregister. + :type resource_provider_namespace: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.unregister.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + unregister.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/unregister'} # type: ignore + + async def register_at_management_group_scope( + self, + resource_provider_namespace: str, + group_id: str, + **kwargs + ) -> None: + """Registers a management group with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :param group_id: The management group ID. + :type group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.register_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + register_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/{resourceProviderNamespace}/register'} # type: ignore + + async def register( + self, + resource_provider_namespace: str, + **kwargs + ) -> "_models.Provider": + """Registers a subscription with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.register.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + register.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/register'} # type: ignore + + def list( + self, + top: Optional[int] = None, + expand: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.ProviderListResult"]: + """Gets all resource providers for a subscription. + + :param top: The number of results to return. If null is passed returns all deployments. + :type top: int + :param expand: The properties to include in the results. For example, use &$expand=metadata in + the query string to retrieve resource provider metadata. To include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProviderListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers'} # type: ignore + + def list_at_tenant_scope( + self, + top: Optional[int] = None, + expand: Optional[str] = None, + **kwargs + ) -> AsyncIterable["_models.ProviderListResult"]: + """Gets all resource providers for the tenant. + + :param top: The number of results to return. If null is passed returns all providers. + :type top: int + :param expand: The properties to include in the results. For example, use &$expand=metadata in + the query string to retrieve resource provider metadata. To include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProviderListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers'} # type: ignore + + async def get( + self, + resource_provider_namespace: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.Provider": + """Gets the specified resource provider. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}'} # type: ignore + + async def get_at_tenant_scope( + self, + resource_provider_namespace: str, + expand: Optional[str] = None, + **kwargs + ) -> "_models.Provider": + """Gets the specified resource provider at the tenant level. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/{resourceProviderNamespace}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resource_groups_operations.py new file mode 100644 index 000000000000..410073e03a1d --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resource_groups_operations.py @@ -0,0 +1,589 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ResourceGroupsOperations: + """ResourceGroupsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def check_existence( + self, + resource_group_name: str, + **kwargs + ) -> bool: + """Checks whether a resource group exists. + + :param resource_group_name: The name of the resource group to check. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def create_or_update( + self, + resource_group_name: str, + parameters: "_models.ResourceGroup", + **kwargs + ) -> "_models.ResourceGroup": + """Creates or updates a resource group. + + :param resource_group_name: The name of the resource group to create or update. Can include + alphanumeric, underscore, parentheses, hyphen, period (except at end), and Unicode characters + that match the allowed characters. + :type resource_group_name: str + :param parameters: Parameters supplied to the create or update a resource group. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourceGroup') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a resource group. + + When you delete a resource group, all of its resources are also deleted. Deleting a resource + group deletes all of its template deployments and currently stored operations. + + :param resource_group_name: The name of the resource group to delete. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + **kwargs + ) -> "_models.ResourceGroup": + """Gets a resource group. + + :param resource_group_name: The name of the resource group to get. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def update( + self, + resource_group_name: str, + parameters: "_models.ResourceGroupPatchable", + **kwargs + ) -> "_models.ResourceGroup": + """Updates a resource group. + + Resource groups can be updated through a simple PATCH operation to a group address. The format + of the request is the same as that for creating a resource group. If a field is unspecified, + the current value is retained. + + :param resource_group_name: The name of the resource group to update. The name is case + insensitive. + :type resource_group_name: str + :param parameters: Parameters supplied to update a resource group. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupPatchable + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourceGroupPatchable') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + async def _export_template_initial( + self, + resource_group_name: str, + parameters: "_models.ExportTemplateRequest", + **kwargs + ) -> Optional["_models.ResourceGroupExportResult"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._export_template_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ExportTemplateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ResourceGroupExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _export_template_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/exportTemplate'} # type: ignore + + async def begin_export_template( + self, + resource_group_name: str, + parameters: "_models.ExportTemplateRequest", + **kwargs + ) -> AsyncLROPoller["_models.ResourceGroupExportResult"]: + """Captures the specified resource group as a template. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param parameters: Parameters for exporting the template. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ExportTemplateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either ResourceGroupExportResult or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupExportResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._export_template_initial( + resource_group_name=resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ResourceGroupExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_export_template.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/exportTemplate'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.ResourceGroupListResult"]: + """Gets all the resource groups for a subscription. + + :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by + tag names and values. For example, to filter for a tag name and value, use $filter=tagName eq + 'tag1' and tagValue eq 'Value1'. + :type filter: str + :param top: The number of results to return. If null is passed, returns all resource groups. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceGroupListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resources_operations.py new file mode 100644 index 000000000000..3cb8abd1af0f --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_resources_operations.py @@ -0,0 +1,1527 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.core.polling import AsyncLROPoller, AsyncNoPolling, AsyncPollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.async_arm_polling import AsyncARMPolling + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class ResourcesOperations: + """ResourcesOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_resource_group( + self, + resource_group_name: str, + filter: Optional[str] = None, + expand: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.ResourceListResult"]: + """Get all the resources for a resource group. + + :param resource_group_name: The resource group with the resources to get. + :type resource_group_name: str + :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you + can use for eq (equals) or ne (not equals) are: location, resourceType, name, resourceGroup, + identity, identity/principalId, plan, plan/publisher, plan/product, plan/name, plan/version, + and plan/promotionCode.:code:`
`:code:`
`For example, to filter by a resource type, use: + $filter=resourceType eq 'Microsoft.Network/virtualNetworks':code:`
`:code:`
`You can use + substringof(value, property) in the filter. The properties you can use for substring are: name + and resourceGroup.:code:`
`:code:`
`For example, to get all resources with 'demo' + anywhere in the name, use: $filter=substringof('demo', name):code:`
`:code:`
`You can + link more than one substringof together by adding and/or operators.:code:`
`:code:`
`You + can filter by tag names and values. For example, to filter for a tag name and value, use + $filter=tagName eq 'tag1' and tagValue eq 'Value1'. When you filter by a tag name and value, + the tags for each resource are not returned in the results.:code:`
`:code:`
`You can use + some properties together when filtering. The combinations you can use are: substringof and/or + resourceType, plan and plan/publisher and plan/name, identity and identity/principalId. + :type filter: str + :param expand: Comma-separated list of additional properties to be included in the response. + Valid values include ``createdTime``\ , ``changedTime`` and ``provisioningState``. For example, + ``$expand=createdTime,changedTime``. + :type expand: str + :param top: The number of results to return. If null is passed, returns all resources. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/resources'} # type: ignore + + async def _move_resources_initial( + self, + source_resource_group_name: str, + parameters: "_models.ResourcesMoveInfo", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._move_resources_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourcesMoveInfo') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _move_resources_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/moveResources'} # type: ignore + + async def begin_move_resources( + self, + source_resource_group_name: str, + parameters: "_models.ResourcesMoveInfo", + **kwargs + ) -> AsyncLROPoller[None]: + """Moves resources from one resource group to another resource group. + + The resources to move must be in the same source resource group. The target resource group may + be in a different subscription. When moving resources, both the source group and the target + group are locked for the duration of the operation. Write and delete operations are blocked on + the groups until the move completes. + + :param source_resource_group_name: The name of the resource group containing the resources to + move. + :type source_resource_group_name: str + :param parameters: Parameters for moving resources. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourcesMoveInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._move_resources_initial( + source_resource_group_name=source_resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_move_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/moveResources'} # type: ignore + + async def _validate_move_resources_initial( + self, + source_resource_group_name: str, + parameters: "_models.ResourcesMoveInfo", + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_move_resources_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourcesMoveInfo') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _validate_move_resources_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/validateMoveResources'} # type: ignore + + async def begin_validate_move_resources( + self, + source_resource_group_name: str, + parameters: "_models.ResourcesMoveInfo", + **kwargs + ) -> AsyncLROPoller[None]: + """Validates whether resources can be moved from one resource group to another resource group. + + This operation checks whether the specified resources can be moved to the target. The resources + to move must be in the same source resource group. The target resource group may be in a + different subscription. If validation succeeds, it returns HTTP response code 204 (no content). + If validation fails, it returns HTTP response code 409 (Conflict) with an error message. + Retrieve the URL in the Location header value to check the result of the long-running + operation. + + :param source_resource_group_name: The name of the resource group containing the resources to + validate for move. + :type source_resource_group_name: str + :param parameters: Parameters for moving resources. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourcesMoveInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._validate_move_resources_initial( + source_resource_group_name=source_resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_move_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/validateMoveResources'} # type: ignore + + def list( + self, + filter: Optional[str] = None, + expand: Optional[str] = None, + top: Optional[int] = None, + **kwargs + ) -> AsyncIterable["_models.ResourceListResult"]: + """Get all the resources in a subscription. + + :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you + can use for eq (equals) or ne (not equals) are: location, resourceType, name, resourceGroup, + identity, identity/principalId, plan, plan/publisher, plan/product, plan/name, plan/version, + and plan/promotionCode.:code:`
`:code:`
`For example, to filter by a resource type, use: + $filter=resourceType eq 'Microsoft.Network/virtualNetworks':code:`
`:code:`
`You can use + substringof(value, property) in the filter. The properties you can use for substring are: name + and resourceGroup.:code:`
`:code:`
`For example, to get all resources with 'demo' + anywhere in the name, use: $filter=substringof('demo', name):code:`
`:code:`
`You can + link more than one substringof together by adding and/or operators.:code:`
`:code:`
`You + can filter by tag names and values. For example, to filter for a tag name and value, use + $filter=tagName eq 'tag1' and tagValue eq 'Value1'. When you filter by a tag name and value, + the tags for each resource are not returned in the results.:code:`
`:code:`
`You can use + some properties together when filtering. The combinations you can use are: substringof and/or + resourceType, plan and plan/publisher and plan/name, identity and identity/principalId. + :type filter: str + :param expand: Comma-separated list of additional properties to be included in the response. + Valid values include ``createdTime``\ , ``changedTime`` and ``provisioningState``. For example, + ``$expand=createdTime,changedTime``. + :type expand: str + :param top: The number of results to return. If null is passed, returns all resource groups. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resources'} # type: ignore + + async def check_existence( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + **kwargs + ) -> bool: + """Checks whether a resource exists. + + :param resource_group_name: The name of the resource group containing the resource to check. + The name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The resource provider of the resource to check. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type. + :type resource_type: str + :param resource_name: The name of the resource to check whether it exists. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def _delete_initial( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def begin_delete( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a resource. + + :param resource_group_name: The name of the resource group that contains the resource to + delete. The name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type. + :type resource_type: str + :param resource_name: The name of the resource to delete. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def _create_or_update_initial( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def begin_create_or_update( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> AsyncLROPoller["_models.GenericResource"]: + """Creates a resource. + + :param resource_group_name: The name of the resource group for the resource. The name is case + insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource to create. + :type resource_type: str + :param resource_name: The name of the resource to create. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Parameters for creating or updating the resource. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def _update_initial( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def begin_update( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> AsyncLROPoller["_models.GenericResource"]: + """Updates a resource. + + :param resource_group_name: The name of the resource group for the resource. The name is case + insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource to update. + :type resource_type: str + :param resource_name: The name of the resource to update. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Parameters for updating the resource. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._update_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def get( + self, + resource_group_name: str, + resource_provider_namespace: str, + parent_resource_path: str, + resource_type: str, + resource_name: str, + api_version: str, + **kwargs + ) -> "_models.GenericResource": + """Gets a resource. + + :param resource_group_name: The name of the resource group containing the resource to get. The + name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource. + :type resource_type: str + :param resource_name: The name of the resource to get. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenericResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + async def check_existence_by_id( + self, + resource_id: str, + api_version: str, + **kwargs + ) -> bool: + """Checks by ID whether a resource exists. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.check_existence_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + async def _delete_by_id_initial( + self, + resource_id: str, + api_version: str, + **kwargs + ) -> None: + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self._delete_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + async def begin_delete_by_id( + self, + resource_id: str, + api_version: str, + **kwargs + ) -> AsyncLROPoller[None]: + """Deletes a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._delete_by_id_initial( + resource_id=resource_id, + api_version=api_version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + async def _create_or_update_by_id_initial( + self, + resource_id: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + async def begin_create_or_update_by_id( + self, + resource_id: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> AsyncLROPoller["_models.GenericResource"]: + """Create a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Create or update resource parameters. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._create_or_update_by_id_initial( + resource_id=resource_id, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + async def _update_by_id_initial( + self, + resource_id: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> Optional["_models.GenericResource"]: + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + async def begin_update_by_id( + self, + resource_id: str, + api_version: str, + parameters: "_models.GenericResource", + **kwargs + ) -> AsyncLROPoller["_models.GenericResource"]: + """Updates a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Update resource parameters. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.AsyncPollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of AsyncLROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.AsyncLROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, AsyncPollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = await self._update_by_id_initial( + resource_id=resource_id, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = AsyncARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = AsyncNoPolling() + else: polling_method = polling + if cont_token: + return AsyncLROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return AsyncLROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_update_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + async def get_by_id( + self, + resource_id: str, + api_version: str, + **kwargs + ) -> "_models.GenericResource": + """Gets a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenericResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.get_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_id.metadata = {'url': '/{resourceId}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_tags_operations.py new file mode 100644 index 000000000000..92cea48f8220 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/aio/operations/_tags_operations.py @@ -0,0 +1,594 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import Any, AsyncIterable, Callable, Dict, Generic, Optional, TypeVar, Union +import warnings + +from azure.core.async_paging import AsyncItemPaged, AsyncList +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest +from azure.mgmt.core.exceptions import ARMErrorFormat + +from ... import models as _models + +T = TypeVar('T') +ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] + +class TagsOperations: + """TagsOperations async operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer) -> None: + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + async def delete_value( + self, + tag_name: str, + tag_value: str, + **kwargs + ) -> None: + """Deletes a predefined tag value for a predefined tag name. + + This operation allows deleting a value from the list of predefined values for an existing + predefined tag name. The value being deleted must not be in use as a tag value for the given + tag name for any resource. + + :param tag_name: The name of the tag. + :type tag_name: str + :param tag_value: The value of the tag to delete. + :type tag_value: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete_value.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'tagValue': self._serialize.url("tag_value", tag_value, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_value.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}/tagValues/{tagValue}'} # type: ignore + + async def create_or_update_value( + self, + tag_name: str, + tag_value: str, + **kwargs + ) -> "_models.TagValue": + """Creates a predefined value for a predefined tag name. + + This operation allows adding a value to the list of predefined values for an existing + predefined tag name. A tag value can have a maximum of 256 characters. + + :param tag_name: The name of the tag. + :type tag_name: str + :param tag_value: The value of the tag to create. + :type tag_value: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagValue, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagValue + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_value.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'tagValue': self._serialize.url("tag_value", tag_value, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TagValue', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('TagValue', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_value.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}/tagValues/{tagValue}'} # type: ignore + + async def create_or_update( + self, + tag_name: str, + **kwargs + ) -> "_models.TagDetails": + """Creates a predefined tag name. + + This operation allows adding a name to the list of predefined tag names for the given + subscription. A tag name can have a maximum of 512 characters and is case-insensitive. Tag + names cannot have the following prefixes which are reserved for Azure use: 'microsoft', + 'azure', 'windows'. + + :param tag_name: The name of the tag to create. + :type tag_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagDetails, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TagDetails', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('TagDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}'} # type: ignore + + async def delete( + self, + tag_name: str, + **kwargs + ) -> None: + """Deletes a predefined tag name. + + This operation allows deleting a name from the list of predefined tag names for the given + subscription. The name being deleted must not be in use as a tag name for any resource. All + predefined values for the given name must have already been deleted. + + :param tag_name: The name of the tag. + :type tag_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}'} # type: ignore + + def list( + self, + **kwargs + ) -> AsyncIterable["_models.TagsListResult"]: + """Gets a summary of tag usage under the subscription. + + This operation performs a union of predefined tags, resource tags, resource group tags and + subscription tags, and returns a summary of usage for each tag name and value under the given + subscription. In case of a large number of tags, this operation may return a previously cached + result. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TagsListResult or the result of cls(response) + :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.TagsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + async def extract_data(pipeline_response): + deserialized = self._deserialize('TagsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, AsyncList(list_of_elem) + + async def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return AsyncItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames'} # type: ignore + + async def create_or_update_at_scope( + self, + scope: str, + parameters: "_models.TagsResource", + **kwargs + ) -> "_models.TagsResource": + """Creates or updates the entire set of tags on a resource or subscription. + + This operation allows adding or replacing the entire set of tags on the specified resource or + subscription. The specified entity can have a maximum of 50 tags. + + :param scope: The resource scope. + :type scope: str + :param parameters: + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'TagsResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + async def update_at_scope( + self, + scope: str, + parameters: "_models.TagsPatchResource", + **kwargs + ) -> "_models.TagsResource": + """Selectively updates the set of tags on a resource or subscription. + + This operation allows replacing, merging or selectively deleting tags on the specified resource + or subscription. The specified entity can have a maximum of 50 tags at the end of the + operation. The 'replace' option replaces the entire set of existing tags with a new set. The + 'merge' option allows adding tags with new names and updating the values of tags with existing + names. The 'delete' option allows selectively deleting tags based on given names or name/value + pairs. + + :param scope: The resource scope. + :type scope: str + :param parameters: + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'TagsPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + async def get_at_scope( + self, + scope: str, + **kwargs + ) -> "_models.TagsResource": + """Gets the entire set of tags on a resource or subscription. + + Gets the entire set of tags on a resource or subscription. + + :param scope: The resource scope. + :type scope: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + async def delete_at_scope( + self, + scope: str, + **kwargs + ) -> None: + """Deletes the entire set of tags on a resource or subscription. + + Deletes the entire set of tags on a resource or subscription. + + :param scope: The resource scope. + :type scope: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = await self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/__init__.py new file mode 100644 index 000000000000..b01726eb794e --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/__init__.py @@ -0,0 +1,263 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +try: + from ._models_py3 import Alias + from ._models_py3 import AliasPath + from ._models_py3 import AliasPathMetadata + from ._models_py3 import AliasPattern + from ._models_py3 import ApiProfile + from ._models_py3 import BasicDependency + from ._models_py3 import DebugSetting + from ._models_py3 import Dependency + from ._models_py3 import Deployment + from ._models_py3 import DeploymentExportResult + from ._models_py3 import DeploymentExtended + from ._models_py3 import DeploymentExtendedFilter + from ._models_py3 import DeploymentListResult + from ._models_py3 import DeploymentOperation + from ._models_py3 import DeploymentOperationProperties + from ._models_py3 import DeploymentOperationsListResult + from ._models_py3 import DeploymentProperties + from ._models_py3 import DeploymentPropertiesExtended + from ._models_py3 import DeploymentValidateResult + from ._models_py3 import DeploymentWhatIf + from ._models_py3 import DeploymentWhatIfProperties + from ._models_py3 import DeploymentWhatIfSettings + from ._models_py3 import ErrorAdditionalInfo + from ._models_py3 import ErrorResponse + from ._models_py3 import ExportTemplateRequest + from ._models_py3 import ExpressionEvaluationOptions + from ._models_py3 import GenericResource + from ._models_py3 import GenericResourceExpanded + from ._models_py3 import GenericResourceFilter + from ._models_py3 import HttpMessage + from ._models_py3 import Identity + from ._models_py3 import IdentityUserAssignedIdentitiesValue + from ._models_py3 import OnErrorDeployment + from ._models_py3 import OnErrorDeploymentExtended + from ._models_py3 import Operation + from ._models_py3 import OperationDisplay + from ._models_py3 import OperationListResult + from ._models_py3 import ParametersLink + from ._models_py3 import Plan + from ._models_py3 import Provider + from ._models_py3 import ProviderExtendedLocation + from ._models_py3 import ProviderListResult + from ._models_py3 import ProviderResourceType + from ._models_py3 import ProviderResourceTypeListResult + from ._models_py3 import Resource + from ._models_py3 import ResourceGroup + from ._models_py3 import ResourceGroupExportResult + from ._models_py3 import ResourceGroupFilter + from ._models_py3 import ResourceGroupListResult + from ._models_py3 import ResourceGroupPatchable + from ._models_py3 import ResourceGroupProperties + from ._models_py3 import ResourceListResult + from ._models_py3 import ResourceProviderOperationDisplayProperties + from ._models_py3 import ResourceReference + from ._models_py3 import ResourcesMoveInfo + from ._models_py3 import ScopedDeployment + from ._models_py3 import ScopedDeploymentWhatIf + from ._models_py3 import Sku + from ._models_py3 import StatusMessage + from ._models_py3 import SubResource + from ._models_py3 import TagCount + from ._models_py3 import TagDetails + from ._models_py3 import TagValue + from ._models_py3 import Tags + from ._models_py3 import TagsListResult + from ._models_py3 import TagsPatchResource + from ._models_py3 import TagsResource + from ._models_py3 import TargetResource + from ._models_py3 import TemplateHashResult + from ._models_py3 import TemplateLink + from ._models_py3 import WhatIfChange + from ._models_py3 import WhatIfOperationResult + from ._models_py3 import WhatIfPropertyChange +except (SyntaxError, ImportError): + from ._models import Alias # type: ignore + from ._models import AliasPath # type: ignore + from ._models import AliasPathMetadata # type: ignore + from ._models import AliasPattern # type: ignore + from ._models import ApiProfile # type: ignore + from ._models import BasicDependency # type: ignore + from ._models import DebugSetting # type: ignore + from ._models import Dependency # type: ignore + from ._models import Deployment # type: ignore + from ._models import DeploymentExportResult # type: ignore + from ._models import DeploymentExtended # type: ignore + from ._models import DeploymentExtendedFilter # type: ignore + from ._models import DeploymentListResult # type: ignore + from ._models import DeploymentOperation # type: ignore + from ._models import DeploymentOperationProperties # type: ignore + from ._models import DeploymentOperationsListResult # type: ignore + from ._models import DeploymentProperties # type: ignore + from ._models import DeploymentPropertiesExtended # type: ignore + from ._models import DeploymentValidateResult # type: ignore + from ._models import DeploymentWhatIf # type: ignore + from ._models import DeploymentWhatIfProperties # type: ignore + from ._models import DeploymentWhatIfSettings # type: ignore + from ._models import ErrorAdditionalInfo # type: ignore + from ._models import ErrorResponse # type: ignore + from ._models import ExportTemplateRequest # type: ignore + from ._models import ExpressionEvaluationOptions # type: ignore + from ._models import GenericResource # type: ignore + from ._models import GenericResourceExpanded # type: ignore + from ._models import GenericResourceFilter # type: ignore + from ._models import HttpMessage # type: ignore + from ._models import Identity # type: ignore + from ._models import IdentityUserAssignedIdentitiesValue # type: ignore + from ._models import OnErrorDeployment # type: ignore + from ._models import OnErrorDeploymentExtended # type: ignore + from ._models import Operation # type: ignore + from ._models import OperationDisplay # type: ignore + from ._models import OperationListResult # type: ignore + from ._models import ParametersLink # type: ignore + from ._models import Plan # type: ignore + from ._models import Provider # type: ignore + from ._models import ProviderExtendedLocation # type: ignore + from ._models import ProviderListResult # type: ignore + from ._models import ProviderResourceType # type: ignore + from ._models import ProviderResourceTypeListResult # type: ignore + from ._models import Resource # type: ignore + from ._models import ResourceGroup # type: ignore + from ._models import ResourceGroupExportResult # type: ignore + from ._models import ResourceGroupFilter # type: ignore + from ._models import ResourceGroupListResult # type: ignore + from ._models import ResourceGroupPatchable # type: ignore + from ._models import ResourceGroupProperties # type: ignore + from ._models import ResourceListResult # type: ignore + from ._models import ResourceProviderOperationDisplayProperties # type: ignore + from ._models import ResourceReference # type: ignore + from ._models import ResourcesMoveInfo # type: ignore + from ._models import ScopedDeployment # type: ignore + from ._models import ScopedDeploymentWhatIf # type: ignore + from ._models import Sku # type: ignore + from ._models import StatusMessage # type: ignore + from ._models import SubResource # type: ignore + from ._models import TagCount # type: ignore + from ._models import TagDetails # type: ignore + from ._models import TagValue # type: ignore + from ._models import Tags # type: ignore + from ._models import TagsListResult # type: ignore + from ._models import TagsPatchResource # type: ignore + from ._models import TagsResource # type: ignore + from ._models import TargetResource # type: ignore + from ._models import TemplateHashResult # type: ignore + from ._models import TemplateLink # type: ignore + from ._models import WhatIfChange # type: ignore + from ._models import WhatIfOperationResult # type: ignore + from ._models import WhatIfPropertyChange # type: ignore + +from ._resource_management_client_enums import ( + AliasPathAttributes, + AliasPathTokenType, + AliasPatternType, + AliasType, + ChangeType, + DeploymentMode, + ExpressionEvaluationOptionsScopeType, + OnErrorDeploymentType, + PropertyChangeType, + ProvisioningOperation, + ProvisioningState, + ResourceIdentityType, + TagsPatchOperation, + WhatIfResultFormat, +) + +__all__ = [ + 'Alias', + 'AliasPath', + 'AliasPathMetadata', + 'AliasPattern', + 'ApiProfile', + 'BasicDependency', + 'DebugSetting', + 'Dependency', + 'Deployment', + 'DeploymentExportResult', + 'DeploymentExtended', + 'DeploymentExtendedFilter', + 'DeploymentListResult', + 'DeploymentOperation', + 'DeploymentOperationProperties', + 'DeploymentOperationsListResult', + 'DeploymentProperties', + 'DeploymentPropertiesExtended', + 'DeploymentValidateResult', + 'DeploymentWhatIf', + 'DeploymentWhatIfProperties', + 'DeploymentWhatIfSettings', + 'ErrorAdditionalInfo', + 'ErrorResponse', + 'ExportTemplateRequest', + 'ExpressionEvaluationOptions', + 'GenericResource', + 'GenericResourceExpanded', + 'GenericResourceFilter', + 'HttpMessage', + 'Identity', + 'IdentityUserAssignedIdentitiesValue', + 'OnErrorDeployment', + 'OnErrorDeploymentExtended', + 'Operation', + 'OperationDisplay', + 'OperationListResult', + 'ParametersLink', + 'Plan', + 'Provider', + 'ProviderExtendedLocation', + 'ProviderListResult', + 'ProviderResourceType', + 'ProviderResourceTypeListResult', + 'Resource', + 'ResourceGroup', + 'ResourceGroupExportResult', + 'ResourceGroupFilter', + 'ResourceGroupListResult', + 'ResourceGroupPatchable', + 'ResourceGroupProperties', + 'ResourceListResult', + 'ResourceProviderOperationDisplayProperties', + 'ResourceReference', + 'ResourcesMoveInfo', + 'ScopedDeployment', + 'ScopedDeploymentWhatIf', + 'Sku', + 'StatusMessage', + 'SubResource', + 'TagCount', + 'TagDetails', + 'TagValue', + 'Tags', + 'TagsListResult', + 'TagsPatchResource', + 'TagsResource', + 'TargetResource', + 'TemplateHashResult', + 'TemplateLink', + 'WhatIfChange', + 'WhatIfOperationResult', + 'WhatIfPropertyChange', + 'AliasPathAttributes', + 'AliasPathTokenType', + 'AliasPatternType', + 'AliasType', + 'ChangeType', + 'DeploymentMode', + 'ExpressionEvaluationOptionsScopeType', + 'OnErrorDeploymentType', + 'PropertyChangeType', + 'ProvisioningOperation', + 'ProvisioningState', + 'ResourceIdentityType', + 'TagsPatchOperation', + 'WhatIfResultFormat', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models.py new file mode 100644 index 000000000000..74a2a1191ec3 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models.py @@ -0,0 +1,2547 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +import msrest.serialization + + +class Alias(msrest.serialization.Model): + """The alias type. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The alias name. + :type name: str + :param paths: The paths for an alias. + :type paths: list[~azure.mgmt.resource.resources.v2020_10_01.models.AliasPath] + :param type: The type of the alias. Possible values include: "NotSpecified", "PlainText", + "Mask". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasType + :param default_path: The default path for an alias. + :type default_path: str + :param default_pattern: The default pattern for an alias. + :type default_pattern: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPattern + :ivar default_metadata: The default alias path metadata. Applies to the default path and to any + alias path that doesn't have metadata. + :vartype default_metadata: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathMetadata + """ + + _validation = { + 'default_metadata': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'paths': {'key': 'paths', 'type': '[AliasPath]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_path': {'key': 'defaultPath', 'type': 'str'}, + 'default_pattern': {'key': 'defaultPattern', 'type': 'AliasPattern'}, + 'default_metadata': {'key': 'defaultMetadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + **kwargs + ): + super(Alias, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.paths = kwargs.get('paths', None) + self.type = kwargs.get('type', None) + self.default_path = kwargs.get('default_path', None) + self.default_pattern = kwargs.get('default_pattern', None) + self.default_metadata = None + + +class AliasPath(msrest.serialization.Model): + """The type of the paths for alias. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param path: The path of an alias. + :type path: str + :param api_versions: The API versions. + :type api_versions: list[str] + :param pattern: The pattern for an alias path. + :type pattern: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPattern + :ivar metadata: The metadata of the alias path. If missing, fall back to the default metadata + of the alias. + :vartype metadata: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathMetadata + """ + + _validation = { + 'metadata': {'readonly': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'pattern': {'key': 'pattern', 'type': 'AliasPattern'}, + 'metadata': {'key': 'metadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPath, self).__init__(**kwargs) + self.path = kwargs.get('path', None) + self.api_versions = kwargs.get('api_versions', None) + self.pattern = kwargs.get('pattern', None) + self.metadata = None + + +class AliasPathMetadata(msrest.serialization.Model): + """AliasPathMetadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the token that the alias path is referring to. Possible values include: + "NotSpecified", "Any", "String", "Object", "Array", "Integer", "Number", "Boolean". + :vartype type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathTokenType + :ivar attributes: The attributes of the token that the alias path is referring to. Possible + values include: "None", "Modifiable". + :vartype attributes: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathAttributes + """ + + _validation = { + 'type': {'readonly': True}, + 'attributes': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'attributes': {'key': 'attributes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPathMetadata, self).__init__(**kwargs) + self.type = None + self.attributes = None + + +class AliasPattern(msrest.serialization.Model): + """The type of the pattern for an alias path. + + :param phrase: The alias pattern phrase. + :type phrase: str + :param variable: The alias pattern variable. + :type variable: str + :param type: The type of alias pattern. Possible values include: "NotSpecified", "Extract". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPatternType + """ + + _attribute_map = { + 'phrase': {'key': 'phrase', 'type': 'str'}, + 'variable': {'key': 'variable', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPattern, self).__init__(**kwargs) + self.phrase = kwargs.get('phrase', None) + self.variable = kwargs.get('variable', None) + self.type = kwargs.get('type', None) + + +class ApiProfile(msrest.serialization.Model): + """ApiProfile. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar profile_version: The profile version. + :vartype profile_version: str + :ivar api_version: The API version. + :vartype api_version: str + """ + + _validation = { + 'profile_version': {'readonly': True}, + 'api_version': {'readonly': True}, + } + + _attribute_map = { + 'profile_version': {'key': 'profileVersion', 'type': 'str'}, + 'api_version': {'key': 'apiVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiProfile, self).__init__(**kwargs) + self.profile_version = None + self.api_version = None + + +class BasicDependency(msrest.serialization.Model): + """Deployment dependency information. + + :param id: The ID of the dependency. + :type id: str + :param resource_type: The dependency resource type. + :type resource_type: str + :param resource_name: The dependency resource name. + :type resource_name: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(BasicDependency, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.resource_type = kwargs.get('resource_type', None) + self.resource_name = kwargs.get('resource_name', None) + + +class DebugSetting(msrest.serialization.Model): + """The debug setting. + + :param detail_level: Specifies the type of information to log for debugging. The permitted + values are none, requestContent, responseContent, or both requestContent and responseContent + separated by a comma. The default is none. When setting this value, carefully consider the type + of information you are passing in during deployment. By logging information about the request + or response, you could potentially expose sensitive data that is retrieved through the + deployment operations. + :type detail_level: str + """ + + _attribute_map = { + 'detail_level': {'key': 'detailLevel', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DebugSetting, self).__init__(**kwargs) + self.detail_level = kwargs.get('detail_level', None) + + +class Dependency(msrest.serialization.Model): + """Deployment dependency information. + + :param depends_on: The list of dependencies. + :type depends_on: list[~azure.mgmt.resource.resources.v2020_10_01.models.BasicDependency] + :param id: The ID of the dependency. + :type id: str + :param resource_type: The dependency resource type. + :type resource_type: str + :param resource_name: The dependency resource name. + :type resource_name: str + """ + + _attribute_map = { + 'depends_on': {'key': 'dependsOn', 'type': '[BasicDependency]'}, + 'id': {'key': 'id', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Dependency, self).__init__(**kwargs) + self.depends_on = kwargs.get('depends_on', None) + self.id = kwargs.get('id', None) + self.resource_type = kwargs.get('resource_type', None) + self.resource_name = kwargs.get('resource_name', None) + + +class Deployment(msrest.serialization.Model): + """Deployment operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentProperties + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentProperties'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(Deployment, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.properties = kwargs['properties'] + self.tags = kwargs.get('tags', None) + + +class DeploymentExportResult(msrest.serialization.Model): + """The deployment export result. + + :param template: The template content. + :type template: object + """ + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentExportResult, self).__init__(**kwargs) + self.template = kwargs.get('template', None) + + +class DeploymentExtended(msrest.serialization.Model): + """Deployment information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the deployment. + :vartype id: str + :ivar name: The name of the deployment. + :vartype name: str + :ivar type: The type of the deployment. + :vartype type: str + :param location: the location of the deployment. + :type location: str + :param properties: Deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentPropertiesExtended + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentExtended, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = kwargs.get('location', None) + self.properties = kwargs.get('properties', None) + self.tags = kwargs.get('tags', None) + + +class DeploymentExtendedFilter(msrest.serialization.Model): + """Deployment filter. + + :param provisioning_state: The provisioning state. + :type provisioning_state: str + """ + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentExtendedFilter, self).__init__(**kwargs) + self.provisioning_state = kwargs.get('provisioning_state', None) + + +class DeploymentListResult(msrest.serialization.Model): + """List of deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of deployments. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeploymentExtended]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class DeploymentOperation(msrest.serialization.Model): + """Deployment operation information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Full deployment operation ID. + :vartype id: str + :ivar operation_id: Deployment operation ID. + :vartype operation_id: str + :param properties: Deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'operation_id': {'key': 'operationId', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentOperationProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentOperation, self).__init__(**kwargs) + self.id = None + self.operation_id = None + self.properties = kwargs.get('properties', None) + + +class DeploymentOperationProperties(msrest.serialization.Model): + """Deployment operation properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_operation: The name of the current provisioning operation. Possible values + include: "NotSpecified", "Create", "Delete", "Waiting", "AzureAsyncOperationWaiting", + "ResourceCacheWaiting", "Action", "Read", "EvaluateDeploymentOutput", "DeploymentCleanup". + :vartype provisioning_operation: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ProvisioningOperation + :ivar provisioning_state: The state of the provisioning. + :vartype provisioning_state: str + :ivar timestamp: The date and time of the operation. + :vartype timestamp: ~datetime.datetime + :ivar duration: The duration of the operation. + :vartype duration: str + :ivar service_request_id: Deployment operation service request id. + :vartype service_request_id: str + :ivar status_code: Operation status code from the resource provider. This property may not be + set if a response has not yet been received. + :vartype status_code: str + :ivar status_message: Operation status message from the resource provider. This property is + optional. It will only be provided if an error was received from the resource provider. + :vartype status_message: ~azure.mgmt.resource.resources.v2020_10_01.models.StatusMessage + :ivar target_resource: The target resource. + :vartype target_resource: ~azure.mgmt.resource.resources.v2020_10_01.models.TargetResource + :ivar request: The HTTP request message. + :vartype request: ~azure.mgmt.resource.resources.v2020_10_01.models.HttpMessage + :ivar response: The HTTP response message. + :vartype response: ~azure.mgmt.resource.resources.v2020_10_01.models.HttpMessage + """ + + _validation = { + 'provisioning_operation': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'timestamp': {'readonly': True}, + 'duration': {'readonly': True}, + 'service_request_id': {'readonly': True}, + 'status_code': {'readonly': True}, + 'status_message': {'readonly': True}, + 'target_resource': {'readonly': True}, + 'request': {'readonly': True}, + 'response': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_operation': {'key': 'provisioningOperation', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'duration': {'key': 'duration', 'type': 'str'}, + 'service_request_id': {'key': 'serviceRequestId', 'type': 'str'}, + 'status_code': {'key': 'statusCode', 'type': 'str'}, + 'status_message': {'key': 'statusMessage', 'type': 'StatusMessage'}, + 'target_resource': {'key': 'targetResource', 'type': 'TargetResource'}, + 'request': {'key': 'request', 'type': 'HttpMessage'}, + 'response': {'key': 'response', 'type': 'HttpMessage'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentOperationProperties, self).__init__(**kwargs) + self.provisioning_operation = None + self.provisioning_state = None + self.timestamp = None + self.duration = None + self.service_request_id = None + self.status_code = None + self.status_message = None + self.target_resource = None + self.request = None + self.response = None + + +class DeploymentOperationsListResult(msrest.serialization.Model): + """List of deployment operations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of deployment operations. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeploymentOperation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentOperationsListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class DeploymentProperties(msrest.serialization.Model): + """Deployment properties. + + All required parameters must be populated in order to send to Azure. + + :param template: The template content. You use this element when you want to pass the template + syntax directly in the request rather than link to an existing template. It can be a JObject or + well-formed JSON string. Use either the templateLink property or the template property, but not + both. + :type template: object + :param template_link: The URI of the template. Use either the templateLink property or the + template property, but not both. + :type template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :param parameters: Name and value pairs that define the deployment parameters for the template. + You use this element when you want to provide the parameter values directly in the request + rather than link to an existing parameter file. Use either the parametersLink property or the + parameters property, but not both. It can be a JObject or a well formed JSON string. + :type parameters: object + :param parameters_link: The URI of parameters file. You use this element to link to an existing + parameters file. Use either the parametersLink property or the parameters property, but not + both. + :type parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :param mode: Required. The mode that is used to deploy resources. This value can be either + Incremental or Complete. In Incremental mode, resources are deployed without deleting existing + resources that are not included in the template. In Complete mode, resources are deployed and + existing resources in the resource group that are not included in the template are deleted. Be + careful when using Complete mode as you may unintentionally delete resources. Possible values + include: "Incremental", "Complete". + :type mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :param debug_setting: The debug setting of the deployment. + :type debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :param on_error_deployment: The deployment on error behavior. + :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptions + """ + + _validation = { + 'mode': {'required': True}, + } + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentProperties, self).__init__(**kwargs) + self.template = kwargs.get('template', None) + self.template_link = kwargs.get('template_link', None) + self.parameters = kwargs.get('parameters', None) + self.parameters_link = kwargs.get('parameters_link', None) + self.mode = kwargs['mode'] + self.debug_setting = kwargs.get('debug_setting', None) + self.on_error_deployment = kwargs.get('on_error_deployment', None) + self.expression_evaluation_options = kwargs.get('expression_evaluation_options', None) + + +class DeploymentPropertiesExtended(msrest.serialization.Model): + """Deployment properties with additional details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: Denotes the state of provisioning. Possible values include: + "NotSpecified", "Accepted", "Running", "Ready", "Creating", "Created", "Deleting", "Deleted", + "Canceled", "Failed", "Succeeded", "Updating". + :vartype provisioning_state: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ProvisioningState + :ivar correlation_id: The correlation ID of the deployment. + :vartype correlation_id: str + :ivar timestamp: The timestamp of the template deployment. + :vartype timestamp: ~datetime.datetime + :ivar duration: The duration of the template deployment. + :vartype duration: str + :ivar outputs: Key/value pairs that represent deployment output. + :vartype outputs: object + :ivar providers: The list of resource providers needed for the deployment. + :vartype providers: list[~azure.mgmt.resource.resources.v2020_10_01.models.Provider] + :ivar dependencies: The list of deployment dependencies. + :vartype dependencies: list[~azure.mgmt.resource.resources.v2020_10_01.models.Dependency] + :ivar template_link: The URI referencing the template. + :vartype template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :ivar parameters: Deployment parameters. + :vartype parameters: object + :ivar parameters_link: The URI referencing the parameters. + :vartype parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :ivar mode: The deployment mode. Possible values are Incremental and Complete. Possible values + include: "Incremental", "Complete". + :vartype mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :ivar debug_setting: The debug setting of the deployment. + :vartype debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :ivar on_error_deployment: The deployment on error behavior. + :vartype on_error_deployment: + ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentExtended + :ivar template_hash: The hash produced for the template. + :vartype template_hash: str + :ivar output_resources: Array of provisioned resources. + :vartype output_resources: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceReference] + :ivar validated_resources: Array of validated resources. + :vartype validated_resources: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceReference] + :ivar error: The deployment error. + :vartype error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'timestamp': {'readonly': True}, + 'duration': {'readonly': True}, + 'outputs': {'readonly': True}, + 'providers': {'readonly': True}, + 'dependencies': {'readonly': True}, + 'template_link': {'readonly': True}, + 'parameters': {'readonly': True}, + 'parameters_link': {'readonly': True}, + 'mode': {'readonly': True}, + 'debug_setting': {'readonly': True}, + 'on_error_deployment': {'readonly': True}, + 'template_hash': {'readonly': True}, + 'output_resources': {'readonly': True}, + 'validated_resources': {'readonly': True}, + 'error': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'duration': {'key': 'duration', 'type': 'str'}, + 'outputs': {'key': 'outputs', 'type': 'object'}, + 'providers': {'key': 'providers', 'type': '[Provider]'}, + 'dependencies': {'key': 'dependencies', 'type': '[Dependency]'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeploymentExtended'}, + 'template_hash': {'key': 'templateHash', 'type': 'str'}, + 'output_resources': {'key': 'outputResources', 'type': '[ResourceReference]'}, + 'validated_resources': {'key': 'validatedResources', 'type': '[ResourceReference]'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentPropertiesExtended, self).__init__(**kwargs) + self.provisioning_state = None + self.correlation_id = None + self.timestamp = None + self.duration = None + self.outputs = None + self.providers = None + self.dependencies = None + self.template_link = None + self.parameters = None + self.parameters_link = None + self.mode = None + self.debug_setting = None + self.on_error_deployment = None + self.template_hash = None + self.output_resources = None + self.validated_resources = None + self.error = None + + +class DeploymentValidateResult(msrest.serialization.Model): + """Information from validate template deployment response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: The deployment validation error. + :vartype error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + :param properties: The template deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentPropertiesExtended + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentValidateResult, self).__init__(**kwargs) + self.error = None + self.properties = kwargs.get('properties', None) + + +class DeploymentWhatIf(msrest.serialization.Model): + """Deployment What-if operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfProperties + """ + + _validation = { + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentWhatIfProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentWhatIf, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.properties = kwargs['properties'] + + +class DeploymentWhatIfProperties(DeploymentProperties): + """Deployment What-if properties. + + All required parameters must be populated in order to send to Azure. + + :param template: The template content. You use this element when you want to pass the template + syntax directly in the request rather than link to an existing template. It can be a JObject or + well-formed JSON string. Use either the templateLink property or the template property, but not + both. + :type template: object + :param template_link: The URI of the template. Use either the templateLink property or the + template property, but not both. + :type template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :param parameters: Name and value pairs that define the deployment parameters for the template. + You use this element when you want to provide the parameter values directly in the request + rather than link to an existing parameter file. Use either the parametersLink property or the + parameters property, but not both. It can be a JObject or a well formed JSON string. + :type parameters: object + :param parameters_link: The URI of parameters file. You use this element to link to an existing + parameters file. Use either the parametersLink property or the parameters property, but not + both. + :type parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :param mode: Required. The mode that is used to deploy resources. This value can be either + Incremental or Complete. In Incremental mode, resources are deployed without deleting existing + resources that are not included in the template. In Complete mode, resources are deployed and + existing resources in the resource group that are not included in the template are deleted. Be + careful when using Complete mode as you may unintentionally delete resources. Possible values + include: "Incremental", "Complete". + :type mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :param debug_setting: The debug setting of the deployment. + :type debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :param on_error_deployment: The deployment on error behavior. + :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptions + :param what_if_settings: Optional What-If operation settings. + :type what_if_settings: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfSettings + """ + + _validation = { + 'mode': {'required': True}, + } + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, + 'what_if_settings': {'key': 'whatIfSettings', 'type': 'DeploymentWhatIfSettings'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentWhatIfProperties, self).__init__(**kwargs) + self.what_if_settings = kwargs.get('what_if_settings', None) + + +class DeploymentWhatIfSettings(msrest.serialization.Model): + """Deployment What-If operation settings. + + :param result_format: The format of the What-If results. Possible values include: + "ResourceIdOnly", "FullResourcePayloads". + :type result_format: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfResultFormat + """ + + _attribute_map = { + 'result_format': {'key': 'resultFormat', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentWhatIfSettings, self).__init__(**kwargs) + self.result_format = kwargs.get('result_format', None) + + +class ErrorAdditionalInfo(msrest.serialization.Model): + """The resource management error additional info. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The additional info type. + :vartype type: str + :ivar info: The additional info. + :vartype info: object + """ + + _validation = { + 'type': {'readonly': True}, + 'info': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'info': {'key': 'info', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorAdditionalInfo, self).__init__(**kwargs) + self.type = None + self.info = None + + +class ErrorResponse(msrest.serialization.Model): + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: The error code. + :vartype code: str + :ivar message: The error message. + :vartype message: str + :ivar target: The error target. + :vartype target: str + :ivar details: The error details. + :vartype details: list[~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse] + :ivar additional_info: The error additional info. + :vartype additional_info: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ErrorAdditionalInfo] + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'details': {'readonly': True}, + 'additional_info': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorResponse]'}, + 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = None + self.additional_info = None + + +class ExportTemplateRequest(msrest.serialization.Model): + """Export resource group template request parameters. + + :param resources: The IDs of the resources to filter the export by. To export all resources, + supply an array with single entry '*'. + :type resources: list[str] + :param options: The export template options. A CSV-formatted list containing zero or more of + the following: 'IncludeParameterDefaultValue', 'IncludeComments', + 'SkipResourceNameParameterization', 'SkipAllParameterization'. + :type options: str + """ + + _attribute_map = { + 'resources': {'key': 'resources', 'type': '[str]'}, + 'options': {'key': 'options', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExportTemplateRequest, self).__init__(**kwargs) + self.resources = kwargs.get('resources', None) + self.options = kwargs.get('options', None) + + +class ExpressionEvaluationOptions(msrest.serialization.Model): + """Specifies whether template expressions are evaluated within the scope of the parent template or nested template. + + :param scope: The scope to be used for evaluation of parameters, variables and functions in a + nested template. Possible values include: "NotSpecified", "Outer", "Inner". + :type scope: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptionsScopeType + """ + + _attribute_map = { + 'scope': {'key': 'scope', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ExpressionEvaluationOptions, self).__init__(**kwargs) + self.scope = kwargs.get('scope', None) + + +class Resource(msrest.serialization.Model): + """Specified resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = kwargs.get('location', None) + self.tags = kwargs.get('tags', None) + + +class GenericResource(Resource): + """Resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param plan: The plan of the resource. + :type plan: ~azure.mgmt.resource.resources.v2020_10_01.models.Plan + :param properties: The resource properties. + :type properties: object + :param kind: The kind of the resource. + :type kind: str + :param managed_by: ID of the resource that manages this resource. + :type managed_by: str + :param sku: The SKU of the resource. + :type sku: ~azure.mgmt.resource.resources.v2020_10_01.models.Sku + :param identity: The identity of the resource. + :type identity: ~azure.mgmt.resource.resources.v2020_10_01.models.Identity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'plan': {'key': 'plan', 'type': 'Plan'}, + 'properties': {'key': 'properties', 'type': 'object'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + } + + def __init__( + self, + **kwargs + ): + super(GenericResource, self).__init__(**kwargs) + self.plan = kwargs.get('plan', None) + self.properties = kwargs.get('properties', None) + self.kind = kwargs.get('kind', None) + self.managed_by = kwargs.get('managed_by', None) + self.sku = kwargs.get('sku', None) + self.identity = kwargs.get('identity', None) + + +class GenericResourceExpanded(GenericResource): + """Resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param plan: The plan of the resource. + :type plan: ~azure.mgmt.resource.resources.v2020_10_01.models.Plan + :param properties: The resource properties. + :type properties: object + :param kind: The kind of the resource. + :type kind: str + :param managed_by: ID of the resource that manages this resource. + :type managed_by: str + :param sku: The SKU of the resource. + :type sku: ~azure.mgmt.resource.resources.v2020_10_01.models.Sku + :param identity: The identity of the resource. + :type identity: ~azure.mgmt.resource.resources.v2020_10_01.models.Identity + :ivar created_time: The created time of the resource. This is only present if requested via the + $expand query parameter. + :vartype created_time: ~datetime.datetime + :ivar changed_time: The changed time of the resource. This is only present if requested via the + $expand query parameter. + :vartype changed_time: ~datetime.datetime + :ivar provisioning_state: The provisioning state of the resource. This is only present if + requested via the $expand query parameter. + :vartype provisioning_state: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, + 'created_time': {'readonly': True}, + 'changed_time': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'plan': {'key': 'plan', 'type': 'Plan'}, + 'properties': {'key': 'properties', 'type': 'object'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'changed_time': {'key': 'changedTime', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GenericResourceExpanded, self).__init__(**kwargs) + self.created_time = None + self.changed_time = None + self.provisioning_state = None + + +class GenericResourceFilter(msrest.serialization.Model): + """Resource filter. + + :param resource_type: The resource type. + :type resource_type: str + :param tagname: The tag name. + :type tagname: str + :param tagvalue: The tag value. + :type tagvalue: str + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'tagname': {'key': 'tagname', 'type': 'str'}, + 'tagvalue': {'key': 'tagvalue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(GenericResourceFilter, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.tagname = kwargs.get('tagname', None) + self.tagvalue = kwargs.get('tagvalue', None) + + +class HttpMessage(msrest.serialization.Model): + """HTTP message. + + :param content: HTTP message content. + :type content: object + """ + + _attribute_map = { + 'content': {'key': 'content', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(HttpMessage, self).__init__(**kwargs) + self.content = kwargs.get('content', None) + + +class Identity(msrest.serialization.Model): + """Identity for the resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal ID of resource identity. + :vartype principal_id: str + :ivar tenant_id: The tenant ID of resource. + :vartype tenant_id: str + :param type: The identity type. Possible values include: "SystemAssigned", "UserAssigned", + "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceIdentityType + :param user_assigned_identities: The list of user identities associated with the resource. The + user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: dict[str, + ~azure.mgmt.resource.resources.v2020_10_01.models.IdentityUserAssignedIdentitiesValue] + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{IdentityUserAssignedIdentitiesValue}'}, + } + + def __init__( + self, + **kwargs + ): + super(Identity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = kwargs.get('type', None) + self.user_assigned_identities = kwargs.get('user_assigned_identities', None) + + +class IdentityUserAssignedIdentitiesValue(msrest.serialization.Model): + """IdentityUserAssignedIdentitiesValue. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of user assigned identity. + :vartype principal_id: str + :ivar client_id: The client id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentityUserAssignedIdentitiesValue, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class OnErrorDeployment(msrest.serialization.Model): + """Deployment on error behavior. + + :param type: The deployment on error behavior type. Possible values are LastSuccessful and + SpecificDeployment. Possible values include: "LastSuccessful", "SpecificDeployment". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentType + :param deployment_name: The deployment to be used on error case. + :type deployment_name: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'deployment_name': {'key': 'deploymentName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OnErrorDeployment, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.deployment_name = kwargs.get('deployment_name', None) + + +class OnErrorDeploymentExtended(msrest.serialization.Model): + """Deployment on error behavior with additional details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: The state of the provisioning for the on error deployment. + :vartype provisioning_state: str + :param type: The deployment on error behavior type. Possible values are LastSuccessful and + SpecificDeployment. Possible values include: "LastSuccessful", "SpecificDeployment". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentType + :param deployment_name: The deployment to be used on error case. + :type deployment_name: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deployment_name': {'key': 'deploymentName', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OnErrorDeploymentExtended, self).__init__(**kwargs) + self.provisioning_state = None + self.type = kwargs.get('type', None) + self.deployment_name = kwargs.get('deployment_name', None) + + +class Operation(msrest.serialization.Model): + """Microsoft.Resources operation. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: The object that represents the operation. + :type display: ~azure.mgmt.resource.resources.v2020_10_01.models.OperationDisplay + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + } + + def __init__( + self, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.display = kwargs.get('display', None) + + +class OperationDisplay(msrest.serialization.Model): + """The object that represents the operation. + + :param provider: Service provider: Microsoft.Resources. + :type provider: str + :param resource: Resource on which the operation is performed: Profile, endpoint, etc. + :type resource: str + :param operation: Operation type: Read, write, delete, etc. + :type operation: str + :param description: Description of the operation. + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationDisplay, self).__init__(**kwargs) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + self.description = kwargs.get('description', None) + + +class OperationListResult(msrest.serialization.Model): + """Result of the request to list Microsoft.Resources operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Microsoft.Resources operations. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.Operation] + :param next_link: URL to get the next set of operation list results if there are any. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Operation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = kwargs.get('next_link', None) + + +class ParametersLink(msrest.serialization.Model): + """Entity representing the reference to the deployment parameters. + + All required parameters must be populated in order to send to Azure. + + :param uri: Required. The URI of the parameters file. + :type uri: str + :param content_version: If included, must match the ContentVersion in the template. + :type content_version: str + """ + + _validation = { + 'uri': {'required': True}, + } + + _attribute_map = { + 'uri': {'key': 'uri', 'type': 'str'}, + 'content_version': {'key': 'contentVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ParametersLink, self).__init__(**kwargs) + self.uri = kwargs['uri'] + self.content_version = kwargs.get('content_version', None) + + +class Plan(msrest.serialization.Model): + """Plan for the resource. + + :param name: The plan ID. + :type name: str + :param publisher: The publisher ID. + :type publisher: str + :param product: The offer ID. + :type product: str + :param promotion_code: The promotion code. + :type promotion_code: str + :param version: The plan's version. + :type version: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'publisher': {'key': 'publisher', 'type': 'str'}, + 'product': {'key': 'product', 'type': 'str'}, + 'promotion_code': {'key': 'promotionCode', 'type': 'str'}, + 'version': {'key': 'version', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(Plan, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.publisher = kwargs.get('publisher', None) + self.product = kwargs.get('product', None) + self.promotion_code = kwargs.get('promotion_code', None) + self.version = kwargs.get('version', None) + + +class Provider(msrest.serialization.Model): + """Resource provider information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The provider ID. + :vartype id: str + :param namespace: The namespace of the resource provider. + :type namespace: str + :ivar registration_state: The registration state of the resource provider. + :vartype registration_state: str + :ivar registration_policy: The registration policy of the resource provider. + :vartype registration_policy: str + :ivar resource_types: The collection of provider resource types. + :vartype resource_types: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceType] + """ + + _validation = { + 'id': {'readonly': True}, + 'registration_state': {'readonly': True}, + 'registration_policy': {'readonly': True}, + 'resource_types': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'namespace': {'key': 'namespace', 'type': 'str'}, + 'registration_state': {'key': 'registrationState', 'type': 'str'}, + 'registration_policy': {'key': 'registrationPolicy', 'type': 'str'}, + 'resource_types': {'key': 'resourceTypes', 'type': '[ProviderResourceType]'}, + } + + def __init__( + self, + **kwargs + ): + super(Provider, self).__init__(**kwargs) + self.id = None + self.namespace = kwargs.get('namespace', None) + self.registration_state = None + self.registration_policy = None + self.resource_types = None + + +class ProviderExtendedLocation(msrest.serialization.Model): + """The provider extended location. + + :param location: The azure location. + :type location: str + :param type: The extended location type. + :type type: str + :param extended_locations: The extended locations for the azure location. + :type extended_locations: list[str] + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'extended_locations': {'key': 'extendedLocations', 'type': '[str]'}, + } + + def __init__( + self, + **kwargs + ): + super(ProviderExtendedLocation, self).__init__(**kwargs) + self.location = kwargs.get('location', None) + self.type = kwargs.get('type', None) + self.extended_locations = kwargs.get('extended_locations', None) + + +class ProviderListResult(msrest.serialization.Model): + """List of resource providers. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource providers. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.Provider] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Provider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProviderListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ProviderResourceType(msrest.serialization.Model): + """Resource type managed by the resource provider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param resource_type: The resource type. + :type resource_type: str + :param locations: The collection of locations where this resource type can be created. + :type locations: list[str] + :param location_mappings: The location mappings that are supported by this resource type. + :type location_mappings: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderExtendedLocation] + :param aliases: The aliases that are supported by this resource type. + :type aliases: list[~azure.mgmt.resource.resources.v2020_10_01.models.Alias] + :param api_versions: The API version. + :type api_versions: list[str] + :ivar default_api_version: The default API version. + :vartype default_api_version: str + :ivar api_profiles: The API profiles for the resource provider. + :vartype api_profiles: list[~azure.mgmt.resource.resources.v2020_10_01.models.ApiProfile] + :param capabilities: The additional capabilities offered by this resource type. + :type capabilities: str + :param properties: The properties. + :type properties: dict[str, str] + """ + + _validation = { + 'default_api_version': {'readonly': True}, + 'api_profiles': {'readonly': True}, + } + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'location_mappings': {'key': 'locationMappings', 'type': '[ProviderExtendedLocation]'}, + 'aliases': {'key': 'aliases', 'type': '[Alias]'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'default_api_version': {'key': 'defaultApiVersion', 'type': 'str'}, + 'api_profiles': {'key': 'apiProfiles', 'type': '[ApiProfile]'}, + 'capabilities': {'key': 'capabilities', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ProviderResourceType, self).__init__(**kwargs) + self.resource_type = kwargs.get('resource_type', None) + self.locations = kwargs.get('locations', None) + self.location_mappings = kwargs.get('location_mappings', None) + self.aliases = kwargs.get('aliases', None) + self.api_versions = kwargs.get('api_versions', None) + self.default_api_version = None + self.api_profiles = None + self.capabilities = kwargs.get('capabilities', None) + self.properties = kwargs.get('properties', None) + + +class ProviderResourceTypeListResult(msrest.serialization.Model): + """List of resource types of a resource provider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource types. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceType] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProviderResourceType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ProviderResourceTypeListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ResourceGroup(msrest.serialization.Model): + """Resource group information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: The ID of the resource group. + :vartype id: str + :ivar name: The name of the resource group. + :vartype name: str + :ivar type: The type of the resource group. + :vartype type: str + :param properties: The resource group properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupProperties + :param location: Required. The location of the resource group. It cannot be changed after the + resource group has been created. It must be one of the supported Azure locations. + :type location: str + :param managed_by: The ID of the resource that manages this resource group. + :type managed_by: str + :param tags: A set of tags. The tags attached to the resource group. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, + 'location': {'key': 'location', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroup, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.properties = kwargs.get('properties', None) + self.location = kwargs['location'] + self.managed_by = kwargs.get('managed_by', None) + self.tags = kwargs.get('tags', None) + + +class ResourceGroupExportResult(msrest.serialization.Model): + """Resource group export result. + + :param template: The template content. + :type template: object + :param error: The template export error. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupExportResult, self).__init__(**kwargs) + self.template = kwargs.get('template', None) + self.error = kwargs.get('error', None) + + +class ResourceGroupFilter(msrest.serialization.Model): + """Resource group filter. + + :param tag_name: The tag name. + :type tag_name: str + :param tag_value: The tag value. + :type tag_value: str + """ + + _attribute_map = { + 'tag_name': {'key': 'tagName', 'type': 'str'}, + 'tag_value': {'key': 'tagValue', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupFilter, self).__init__(**kwargs) + self.tag_name = kwargs.get('tag_name', None) + self.tag_value = kwargs.get('tag_value', None) + + +class ResourceGroupListResult(msrest.serialization.Model): + """List of resource groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource groups. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ResourceGroupPatchable(msrest.serialization.Model): + """Resource group information. + + :param name: The name of the resource group. + :type name: str + :param properties: The resource group properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupProperties + :param managed_by: The ID of the resource that manages this resource group. + :type managed_by: str + :param tags: A set of tags. The tags attached to the resource group. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupPatchable, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.properties = kwargs.get('properties', None) + self.managed_by = kwargs.get('managed_by', None) + self.tags = kwargs.get('tags', None) + + +class ResourceGroupProperties(msrest.serialization.Model): + """The resource group properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: The provisioning state. + :vartype provisioning_state: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupProperties, self).__init__(**kwargs) + self.provisioning_state = None + + +class ResourceListResult(msrest.serialization.Model): + """List of resource groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resources. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResourceExpanded] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GenericResourceExpanded]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class ResourceProviderOperationDisplayProperties(msrest.serialization.Model): + """Resource provider operation's display properties. + + :param publisher: Operation description. + :type publisher: str + :param provider: Operation provider. + :type provider: str + :param resource: Operation resource. + :type resource: str + :param operation: Resource provider operation. + :type operation: str + :param description: Operation description. + :type description: str + """ + + _attribute_map = { + 'publisher': {'key': 'publisher', 'type': 'str'}, + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceProviderOperationDisplayProperties, self).__init__(**kwargs) + self.publisher = kwargs.get('publisher', None) + self.provider = kwargs.get('provider', None) + self.resource = kwargs.get('resource', None) + self.operation = kwargs.get('operation', None) + self.description = kwargs.get('description', None) + + +class ResourceReference(msrest.serialization.Model): + """The resource Id model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The fully qualified resource Id. + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceReference, self).__init__(**kwargs) + self.id = None + + +class ResourcesMoveInfo(msrest.serialization.Model): + """Parameters of move resources. + + :param resources: The IDs of the resources. + :type resources: list[str] + :param target_resource_group: The target resource group. + :type target_resource_group: str + """ + + _attribute_map = { + 'resources': {'key': 'resources', 'type': '[str]'}, + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourcesMoveInfo, self).__init__(**kwargs) + self.resources = kwargs.get('resources', None) + self.target_resource_group = kwargs.get('target_resource_group', None) + + +class ScopedDeployment(msrest.serialization.Model): + """Deployment operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: Required. The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentProperties + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'location': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentProperties'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(ScopedDeployment, self).__init__(**kwargs) + self.location = kwargs['location'] + self.properties = kwargs['properties'] + self.tags = kwargs.get('tags', None) + + +class ScopedDeploymentWhatIf(msrest.serialization.Model): + """Deployment What-if operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: Required. The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfProperties + """ + + _validation = { + 'location': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentWhatIfProperties'}, + } + + def __init__( + self, + **kwargs + ): + super(ScopedDeploymentWhatIf, self).__init__(**kwargs) + self.location = kwargs['location'] + self.properties = kwargs['properties'] + + +class Sku(msrest.serialization.Model): + """SKU for the resource. + + :param name: The SKU name. + :type name: str + :param tier: The SKU tier. + :type tier: str + :param size: The SKU size. + :type size: str + :param family: The SKU family. + :type family: str + :param model: The SKU model. + :type model: str + :param capacity: The SKU capacity. + :type capacity: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'model': {'key': 'model', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(Sku, self).__init__(**kwargs) + self.name = kwargs.get('name', None) + self.tier = kwargs.get('tier', None) + self.size = kwargs.get('size', None) + self.family = kwargs.get('family', None) + self.model = kwargs.get('model', None) + self.capacity = kwargs.get('capacity', None) + + +class StatusMessage(msrest.serialization.Model): + """Operation status message object. + + :param status: Status of the deployment operation. + :type status: str + :param error: The error reported by the operation. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + **kwargs + ): + super(StatusMessage, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.error = kwargs.get('error', None) + + +class SubResource(msrest.serialization.Model): + """Sub-resource. + + :param id: Resource ID. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(SubResource, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + + +class TagCount(msrest.serialization.Model): + """Tag count. + + :param type: Type of count. + :type type: str + :param value: Value of count. + :type value: int + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'int'}, + } + + def __init__( + self, + **kwargs + ): + super(TagCount, self).__init__(**kwargs) + self.type = kwargs.get('type', None) + self.value = kwargs.get('value', None) + + +class TagDetails(msrest.serialization.Model): + """Tag details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The tag name ID. + :vartype id: str + :param tag_name: The tag name. + :type tag_name: str + :param count: The total number of resources that use the resource tag. When a tag is initially + created and has no associated resources, the value is 0. + :type count: ~azure.mgmt.resource.resources.v2020_10_01.models.TagCount + :param values: The list of tag values. + :type values: list[~azure.mgmt.resource.resources.v2020_10_01.models.TagValue] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'tag_name': {'key': 'tagName', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'TagCount'}, + 'values': {'key': 'values', 'type': '[TagValue]'}, + } + + def __init__( + self, + **kwargs + ): + super(TagDetails, self).__init__(**kwargs) + self.id = None + self.tag_name = kwargs.get('tag_name', None) + self.count = kwargs.get('count', None) + self.values = kwargs.get('values', None) + + +class Tags(msrest.serialization.Model): + """A dictionary of name and value pairs. + + :param tags: A set of tags. Dictionary of :code:``. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + **kwargs + ): + super(Tags, self).__init__(**kwargs) + self.tags = kwargs.get('tags', None) + + +class TagsListResult(msrest.serialization.Model): + """List of subscription tags. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of tags. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.TagDetails] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TagDetails]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TagsListResult, self).__init__(**kwargs) + self.value = kwargs.get('value', None) + self.next_link = None + + +class TagsPatchResource(msrest.serialization.Model): + """Wrapper resource for tags patch API request only. + + :param operation: The operation type for the patch API. Possible values include: "Replace", + "Merge", "Delete". + :type operation: str or ~azure.mgmt.resource.resources.v2020_10_01.models.TagsPatchOperation + :param properties: The set of tags. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.Tags + """ + + _attribute_map = { + 'operation': {'key': 'operation', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'Tags'}, + } + + def __init__( + self, + **kwargs + ): + super(TagsPatchResource, self).__init__(**kwargs) + self.operation = kwargs.get('operation', None) + self.properties = kwargs.get('properties', None) + + +class TagsResource(msrest.serialization.Model): + """Wrapper resource for tags API requests and responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: The ID of the tags wrapper resource. + :vartype id: str + :ivar name: The name of the tags wrapper resource. + :vartype name: str + :ivar type: The type of the tags wrapper resource. + :vartype type: str + :param properties: Required. The set of tags. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.Tags + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'Tags'}, + } + + def __init__( + self, + **kwargs + ): + super(TagsResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.properties = kwargs['properties'] + + +class TagValue(msrest.serialization.Model): + """Tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The tag value ID. + :vartype id: str + :param tag_value: The tag value. + :type tag_value: str + :param count: The tag value count. + :type count: ~azure.mgmt.resource.resources.v2020_10_01.models.TagCount + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'tag_value': {'key': 'tagValue', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'TagCount'}, + } + + def __init__( + self, + **kwargs + ): + super(TagValue, self).__init__(**kwargs) + self.id = None + self.tag_value = kwargs.get('tag_value', None) + self.count = kwargs.get('count', None) + + +class TargetResource(msrest.serialization.Model): + """Target resource. + + :param id: The ID of the resource. + :type id: str + :param resource_name: The name of the resource. + :type resource_name: str + :param resource_type: The type of the resource. + :type resource_type: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TargetResource, self).__init__(**kwargs) + self.id = kwargs.get('id', None) + self.resource_name = kwargs.get('resource_name', None) + self.resource_type = kwargs.get('resource_type', None) + + +class TemplateHashResult(msrest.serialization.Model): + """Result of the request to calculate template hash. It contains a string of minified template and its hash. + + :param minified_template: The minified template string. + :type minified_template: str + :param template_hash: The template hash. + :type template_hash: str + """ + + _attribute_map = { + 'minified_template': {'key': 'minifiedTemplate', 'type': 'str'}, + 'template_hash': {'key': 'templateHash', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TemplateHashResult, self).__init__(**kwargs) + self.minified_template = kwargs.get('minified_template', None) + self.template_hash = kwargs.get('template_hash', None) + + +class TemplateLink(msrest.serialization.Model): + """Entity representing the reference to the template. + + :param uri: The URI of the template to deploy. Use either the uri or id property, but not both. + :type uri: str + :param id: The resource id of a Template Spec. Use either the id or uri property, but not both. + :type id: str + :param relative_path: The relativePath property can be used to deploy a linked template at a + location relative to the parent. If the parent template was linked with a TemplateSpec, this + will reference an artifact in the TemplateSpec. If the parent was linked with a URI, the child + deployment will be a combination of the parent and relativePath URIs. + :type relative_path: str + :param content_version: If included, must match the ContentVersion in the template. + :type content_version: str + :param query_string: The query string (for example, a SAS token) to be used with the + templateLink URI. + :type query_string: str + """ + + _attribute_map = { + 'uri': {'key': 'uri', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'relative_path': {'key': 'relativePath', 'type': 'str'}, + 'content_version': {'key': 'contentVersion', 'type': 'str'}, + 'query_string': {'key': 'queryString', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(TemplateLink, self).__init__(**kwargs) + self.uri = kwargs.get('uri', None) + self.id = kwargs.get('id', None) + self.relative_path = kwargs.get('relative_path', None) + self.content_version = kwargs.get('content_version', None) + self.query_string = kwargs.get('query_string', None) + + +class WhatIfChange(msrest.serialization.Model): + """Information about a single resource change predicted by What-If operation. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. Resource ID. + :type resource_id: str + :param change_type: Required. Type of change that will be made to the resource when the + deployment is executed. Possible values include: "Create", "Delete", "Ignore", "Deploy", + "NoChange", "Modify". + :type change_type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.ChangeType + :param before: The snapshot of the resource before the deployment is executed. + :type before: object + :param after: The predicted snapshot of the resource after the deployment is executed. + :type after: object + :param delta: The predicted changes to resource properties. + :type delta: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfPropertyChange] + """ + + _validation = { + 'resource_id': {'required': True}, + 'change_type': {'required': True}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'change_type': {'key': 'changeType', 'type': 'str'}, + 'before': {'key': 'before', 'type': 'object'}, + 'after': {'key': 'after', 'type': 'object'}, + 'delta': {'key': 'delta', 'type': '[WhatIfPropertyChange]'}, + } + + def __init__( + self, + **kwargs + ): + super(WhatIfChange, self).__init__(**kwargs) + self.resource_id = kwargs['resource_id'] + self.change_type = kwargs['change_type'] + self.before = kwargs.get('before', None) + self.after = kwargs.get('after', None) + self.delta = kwargs.get('delta', None) + + +class WhatIfOperationResult(msrest.serialization.Model): + """Result of the What-If operation. Contains a list of predicted changes and a URL link to get to the next set of results. + + :param status: Status of the What-If operation. + :type status: str + :param error: Error when What-If operation fails. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + :param changes: List of resource changes predicted by What-If operation. + :type changes: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfChange] + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + 'changes': {'key': 'properties.changes', 'type': '[WhatIfChange]'}, + } + + def __init__( + self, + **kwargs + ): + super(WhatIfOperationResult, self).__init__(**kwargs) + self.status = kwargs.get('status', None) + self.error = kwargs.get('error', None) + self.changes = kwargs.get('changes', None) + + +class WhatIfPropertyChange(msrest.serialization.Model): + """The predicted change to the resource property. + + All required parameters must be populated in order to send to Azure. + + :param path: Required. The path of the property. + :type path: str + :param property_change_type: Required. The type of property change. Possible values include: + "Create", "Delete", "Modify", "Array". + :type property_change_type: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.PropertyChangeType + :param before: The value of the property before the deployment is executed. + :type before: object + :param after: The value of the property after the deployment is executed. + :type after: object + :param children: Nested property changes. + :type children: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfPropertyChange] + """ + + _validation = { + 'path': {'required': True}, + 'property_change_type': {'required': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'property_change_type': {'key': 'propertyChangeType', 'type': 'str'}, + 'before': {'key': 'before', 'type': 'object'}, + 'after': {'key': 'after', 'type': 'object'}, + 'children': {'key': 'children', 'type': '[WhatIfPropertyChange]'}, + } + + def __init__( + self, + **kwargs + ): + super(WhatIfPropertyChange, self).__init__(**kwargs) + self.path = kwargs['path'] + self.property_change_type = kwargs['property_change_type'] + self.before = kwargs.get('before', None) + self.after = kwargs.get('after', None) + self.children = kwargs.get('children', None) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models_py3.py new file mode 100644 index 000000000000..d136237f7278 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_models_py3.py @@ -0,0 +1,2795 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from typing import Dict, List, Optional, Union + +import msrest.serialization + +from ._resource_management_client_enums import * + + +class Alias(msrest.serialization.Model): + """The alias type. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param name: The alias name. + :type name: str + :param paths: The paths for an alias. + :type paths: list[~azure.mgmt.resource.resources.v2020_10_01.models.AliasPath] + :param type: The type of the alias. Possible values include: "NotSpecified", "PlainText", + "Mask". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasType + :param default_path: The default path for an alias. + :type default_path: str + :param default_pattern: The default pattern for an alias. + :type default_pattern: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPattern + :ivar default_metadata: The default alias path metadata. Applies to the default path and to any + alias path that doesn't have metadata. + :vartype default_metadata: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathMetadata + """ + + _validation = { + 'default_metadata': {'readonly': True}, + } + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'paths': {'key': 'paths', 'type': '[AliasPath]'}, + 'type': {'key': 'type', 'type': 'str'}, + 'default_path': {'key': 'defaultPath', 'type': 'str'}, + 'default_pattern': {'key': 'defaultPattern', 'type': 'AliasPattern'}, + 'default_metadata': {'key': 'defaultMetadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + paths: Optional[List["AliasPath"]] = None, + type: Optional[Union[str, "AliasType"]] = None, + default_path: Optional[str] = None, + default_pattern: Optional["AliasPattern"] = None, + **kwargs + ): + super(Alias, self).__init__(**kwargs) + self.name = name + self.paths = paths + self.type = type + self.default_path = default_path + self.default_pattern = default_pattern + self.default_metadata = None + + +class AliasPath(msrest.serialization.Model): + """The type of the paths for alias. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param path: The path of an alias. + :type path: str + :param api_versions: The API versions. + :type api_versions: list[str] + :param pattern: The pattern for an alias path. + :type pattern: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPattern + :ivar metadata: The metadata of the alias path. If missing, fall back to the default metadata + of the alias. + :vartype metadata: ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathMetadata + """ + + _validation = { + 'metadata': {'readonly': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'pattern': {'key': 'pattern', 'type': 'AliasPattern'}, + 'metadata': {'key': 'metadata', 'type': 'AliasPathMetadata'}, + } + + def __init__( + self, + *, + path: Optional[str] = None, + api_versions: Optional[List[str]] = None, + pattern: Optional["AliasPattern"] = None, + **kwargs + ): + super(AliasPath, self).__init__(**kwargs) + self.path = path + self.api_versions = api_versions + self.pattern = pattern + self.metadata = None + + +class AliasPathMetadata(msrest.serialization.Model): + """AliasPathMetadata. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The type of the token that the alias path is referring to. Possible values include: + "NotSpecified", "Any", "String", "Object", "Array", "Integer", "Number", "Boolean". + :vartype type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathTokenType + :ivar attributes: The attributes of the token that the alias path is referring to. Possible + values include: "None", "Modifiable". + :vartype attributes: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPathAttributes + """ + + _validation = { + 'type': {'readonly': True}, + 'attributes': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'attributes': {'key': 'attributes', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(AliasPathMetadata, self).__init__(**kwargs) + self.type = None + self.attributes = None + + +class AliasPattern(msrest.serialization.Model): + """The type of the pattern for an alias path. + + :param phrase: The alias pattern phrase. + :type phrase: str + :param variable: The alias pattern variable. + :type variable: str + :param type: The type of alias pattern. Possible values include: "NotSpecified", "Extract". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.AliasPatternType + """ + + _attribute_map = { + 'phrase': {'key': 'phrase', 'type': 'str'}, + 'variable': {'key': 'variable', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + } + + def __init__( + self, + *, + phrase: Optional[str] = None, + variable: Optional[str] = None, + type: Optional[Union[str, "AliasPatternType"]] = None, + **kwargs + ): + super(AliasPattern, self).__init__(**kwargs) + self.phrase = phrase + self.variable = variable + self.type = type + + +class ApiProfile(msrest.serialization.Model): + """ApiProfile. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar profile_version: The profile version. + :vartype profile_version: str + :ivar api_version: The API version. + :vartype api_version: str + """ + + _validation = { + 'profile_version': {'readonly': True}, + 'api_version': {'readonly': True}, + } + + _attribute_map = { + 'profile_version': {'key': 'profileVersion', 'type': 'str'}, + 'api_version': {'key': 'apiVersion', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ApiProfile, self).__init__(**kwargs) + self.profile_version = None + self.api_version = None + + +class BasicDependency(msrest.serialization.Model): + """Deployment dependency information. + + :param id: The ID of the dependency. + :type id: str + :param resource_type: The dependency resource type. + :type resource_type: str + :param resource_name: The dependency resource name. + :type resource_name: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + resource_type: Optional[str] = None, + resource_name: Optional[str] = None, + **kwargs + ): + super(BasicDependency, self).__init__(**kwargs) + self.id = id + self.resource_type = resource_type + self.resource_name = resource_name + + +class DebugSetting(msrest.serialization.Model): + """The debug setting. + + :param detail_level: Specifies the type of information to log for debugging. The permitted + values are none, requestContent, responseContent, or both requestContent and responseContent + separated by a comma. The default is none. When setting this value, carefully consider the type + of information you are passing in during deployment. By logging information about the request + or response, you could potentially expose sensitive data that is retrieved through the + deployment operations. + :type detail_level: str + """ + + _attribute_map = { + 'detail_level': {'key': 'detailLevel', 'type': 'str'}, + } + + def __init__( + self, + *, + detail_level: Optional[str] = None, + **kwargs + ): + super(DebugSetting, self).__init__(**kwargs) + self.detail_level = detail_level + + +class Dependency(msrest.serialization.Model): + """Deployment dependency information. + + :param depends_on: The list of dependencies. + :type depends_on: list[~azure.mgmt.resource.resources.v2020_10_01.models.BasicDependency] + :param id: The ID of the dependency. + :type id: str + :param resource_type: The dependency resource type. + :type resource_type: str + :param resource_name: The dependency resource name. + :type resource_name: str + """ + + _attribute_map = { + 'depends_on': {'key': 'dependsOn', 'type': '[BasicDependency]'}, + 'id': {'key': 'id', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + } + + def __init__( + self, + *, + depends_on: Optional[List["BasicDependency"]] = None, + id: Optional[str] = None, + resource_type: Optional[str] = None, + resource_name: Optional[str] = None, + **kwargs + ): + super(Dependency, self).__init__(**kwargs) + self.depends_on = depends_on + self.id = id + self.resource_type = resource_type + self.resource_name = resource_name + + +class Deployment(msrest.serialization.Model): + """Deployment operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentProperties + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentProperties'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + properties: "DeploymentProperties", + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Deployment, self).__init__(**kwargs) + self.location = location + self.properties = properties + self.tags = tags + + +class DeploymentExportResult(msrest.serialization.Model): + """The deployment export result. + + :param template: The template content. + :type template: object + """ + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + } + + def __init__( + self, + *, + template: Optional[object] = None, + **kwargs + ): + super(DeploymentExportResult, self).__init__(**kwargs) + self.template = template + + +class DeploymentExtended(msrest.serialization.Model): + """Deployment information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The ID of the deployment. + :vartype id: str + :ivar name: The name of the deployment. + :vartype name: str + :ivar type: The type of the deployment. + :vartype type: str + :param location: the location of the deployment. + :type location: str + :param properties: Deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentPropertiesExtended + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + properties: Optional["DeploymentPropertiesExtended"] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(DeploymentExtended, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = location + self.properties = properties + self.tags = tags + + +class DeploymentExtendedFilter(msrest.serialization.Model): + """Deployment filter. + + :param provisioning_state: The provisioning state. + :type provisioning_state: str + """ + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + provisioning_state: Optional[str] = None, + **kwargs + ): + super(DeploymentExtendedFilter, self).__init__(**kwargs) + self.provisioning_state = provisioning_state + + +class DeploymentListResult(msrest.serialization.Model): + """List of deployments. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of deployments. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeploymentExtended]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["DeploymentExtended"]] = None, + **kwargs + ): + super(DeploymentListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DeploymentOperation(msrest.serialization.Model): + """Deployment operation information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Full deployment operation ID. + :vartype id: str + :ivar operation_id: Deployment operation ID. + :vartype operation_id: str + :param properties: Deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationProperties + """ + + _validation = { + 'id': {'readonly': True}, + 'operation_id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'operation_id': {'key': 'operationId', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentOperationProperties'}, + } + + def __init__( + self, + *, + properties: Optional["DeploymentOperationProperties"] = None, + **kwargs + ): + super(DeploymentOperation, self).__init__(**kwargs) + self.id = None + self.operation_id = None + self.properties = properties + + +class DeploymentOperationProperties(msrest.serialization.Model): + """Deployment operation properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_operation: The name of the current provisioning operation. Possible values + include: "NotSpecified", "Create", "Delete", "Waiting", "AzureAsyncOperationWaiting", + "ResourceCacheWaiting", "Action", "Read", "EvaluateDeploymentOutput", "DeploymentCleanup". + :vartype provisioning_operation: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ProvisioningOperation + :ivar provisioning_state: The state of the provisioning. + :vartype provisioning_state: str + :ivar timestamp: The date and time of the operation. + :vartype timestamp: ~datetime.datetime + :ivar duration: The duration of the operation. + :vartype duration: str + :ivar service_request_id: Deployment operation service request id. + :vartype service_request_id: str + :ivar status_code: Operation status code from the resource provider. This property may not be + set if a response has not yet been received. + :vartype status_code: str + :ivar status_message: Operation status message from the resource provider. This property is + optional. It will only be provided if an error was received from the resource provider. + :vartype status_message: ~azure.mgmt.resource.resources.v2020_10_01.models.StatusMessage + :ivar target_resource: The target resource. + :vartype target_resource: ~azure.mgmt.resource.resources.v2020_10_01.models.TargetResource + :ivar request: The HTTP request message. + :vartype request: ~azure.mgmt.resource.resources.v2020_10_01.models.HttpMessage + :ivar response: The HTTP response message. + :vartype response: ~azure.mgmt.resource.resources.v2020_10_01.models.HttpMessage + """ + + _validation = { + 'provisioning_operation': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + 'timestamp': {'readonly': True}, + 'duration': {'readonly': True}, + 'service_request_id': {'readonly': True}, + 'status_code': {'readonly': True}, + 'status_message': {'readonly': True}, + 'target_resource': {'readonly': True}, + 'request': {'readonly': True}, + 'response': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_operation': {'key': 'provisioningOperation', 'type': 'str'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'duration': {'key': 'duration', 'type': 'str'}, + 'service_request_id': {'key': 'serviceRequestId', 'type': 'str'}, + 'status_code': {'key': 'statusCode', 'type': 'str'}, + 'status_message': {'key': 'statusMessage', 'type': 'StatusMessage'}, + 'target_resource': {'key': 'targetResource', 'type': 'TargetResource'}, + 'request': {'key': 'request', 'type': 'HttpMessage'}, + 'response': {'key': 'response', 'type': 'HttpMessage'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentOperationProperties, self).__init__(**kwargs) + self.provisioning_operation = None + self.provisioning_state = None + self.timestamp = None + self.duration = None + self.service_request_id = None + self.status_code = None + self.status_message = None + self.target_resource = None + self.request = None + self.response = None + + +class DeploymentOperationsListResult(msrest.serialization.Model): + """List of deployment operations. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of deployment operations. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[DeploymentOperation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["DeploymentOperation"]] = None, + **kwargs + ): + super(DeploymentOperationsListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class DeploymentProperties(msrest.serialization.Model): + """Deployment properties. + + All required parameters must be populated in order to send to Azure. + + :param template: The template content. You use this element when you want to pass the template + syntax directly in the request rather than link to an existing template. It can be a JObject or + well-formed JSON string. Use either the templateLink property or the template property, but not + both. + :type template: object + :param template_link: The URI of the template. Use either the templateLink property or the + template property, but not both. + :type template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :param parameters: Name and value pairs that define the deployment parameters for the template. + You use this element when you want to provide the parameter values directly in the request + rather than link to an existing parameter file. Use either the parametersLink property or the + parameters property, but not both. It can be a JObject or a well formed JSON string. + :type parameters: object + :param parameters_link: The URI of parameters file. You use this element to link to an existing + parameters file. Use either the parametersLink property or the parameters property, but not + both. + :type parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :param mode: Required. The mode that is used to deploy resources. This value can be either + Incremental or Complete. In Incremental mode, resources are deployed without deleting existing + resources that are not included in the template. In Complete mode, resources are deployed and + existing resources in the resource group that are not included in the template are deleted. Be + careful when using Complete mode as you may unintentionally delete resources. Possible values + include: "Incremental", "Complete". + :type mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :param debug_setting: The debug setting of the deployment. + :type debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :param on_error_deployment: The deployment on error behavior. + :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptions + """ + + _validation = { + 'mode': {'required': True}, + } + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, + } + + def __init__( + self, + *, + mode: Union[str, "DeploymentMode"], + template: Optional[object] = None, + template_link: Optional["TemplateLink"] = None, + parameters: Optional[object] = None, + parameters_link: Optional["ParametersLink"] = None, + debug_setting: Optional["DebugSetting"] = None, + on_error_deployment: Optional["OnErrorDeployment"] = None, + expression_evaluation_options: Optional["ExpressionEvaluationOptions"] = None, + **kwargs + ): + super(DeploymentProperties, self).__init__(**kwargs) + self.template = template + self.template_link = template_link + self.parameters = parameters + self.parameters_link = parameters_link + self.mode = mode + self.debug_setting = debug_setting + self.on_error_deployment = on_error_deployment + self.expression_evaluation_options = expression_evaluation_options + + +class DeploymentPropertiesExtended(msrest.serialization.Model): + """Deployment properties with additional details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: Denotes the state of provisioning. Possible values include: + "NotSpecified", "Accepted", "Running", "Ready", "Creating", "Created", "Deleting", "Deleted", + "Canceled", "Failed", "Succeeded", "Updating". + :vartype provisioning_state: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ProvisioningState + :ivar correlation_id: The correlation ID of the deployment. + :vartype correlation_id: str + :ivar timestamp: The timestamp of the template deployment. + :vartype timestamp: ~datetime.datetime + :ivar duration: The duration of the template deployment. + :vartype duration: str + :ivar outputs: Key/value pairs that represent deployment output. + :vartype outputs: object + :ivar providers: The list of resource providers needed for the deployment. + :vartype providers: list[~azure.mgmt.resource.resources.v2020_10_01.models.Provider] + :ivar dependencies: The list of deployment dependencies. + :vartype dependencies: list[~azure.mgmt.resource.resources.v2020_10_01.models.Dependency] + :ivar template_link: The URI referencing the template. + :vartype template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :ivar parameters: Deployment parameters. + :vartype parameters: object + :ivar parameters_link: The URI referencing the parameters. + :vartype parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :ivar mode: The deployment mode. Possible values are Incremental and Complete. Possible values + include: "Incremental", "Complete". + :vartype mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :ivar debug_setting: The debug setting of the deployment. + :vartype debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :ivar on_error_deployment: The deployment on error behavior. + :vartype on_error_deployment: + ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentExtended + :ivar template_hash: The hash produced for the template. + :vartype template_hash: str + :ivar output_resources: Array of provisioned resources. + :vartype output_resources: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceReference] + :ivar validated_resources: Array of validated resources. + :vartype validated_resources: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceReference] + :ivar error: The deployment error. + :vartype error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + 'correlation_id': {'readonly': True}, + 'timestamp': {'readonly': True}, + 'duration': {'readonly': True}, + 'outputs': {'readonly': True}, + 'providers': {'readonly': True}, + 'dependencies': {'readonly': True}, + 'template_link': {'readonly': True}, + 'parameters': {'readonly': True}, + 'parameters_link': {'readonly': True}, + 'mode': {'readonly': True}, + 'debug_setting': {'readonly': True}, + 'on_error_deployment': {'readonly': True}, + 'template_hash': {'readonly': True}, + 'output_resources': {'readonly': True}, + 'validated_resources': {'readonly': True}, + 'error': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'correlation_id': {'key': 'correlationId', 'type': 'str'}, + 'timestamp': {'key': 'timestamp', 'type': 'iso-8601'}, + 'duration': {'key': 'duration', 'type': 'str'}, + 'outputs': {'key': 'outputs', 'type': 'object'}, + 'providers': {'key': 'providers', 'type': '[Provider]'}, + 'dependencies': {'key': 'dependencies', 'type': '[Dependency]'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeploymentExtended'}, + 'template_hash': {'key': 'templateHash', 'type': 'str'}, + 'output_resources': {'key': 'outputResources', 'type': '[ResourceReference]'}, + 'validated_resources': {'key': 'validatedResources', 'type': '[ResourceReference]'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + **kwargs + ): + super(DeploymentPropertiesExtended, self).__init__(**kwargs) + self.provisioning_state = None + self.correlation_id = None + self.timestamp = None + self.duration = None + self.outputs = None + self.providers = None + self.dependencies = None + self.template_link = None + self.parameters = None + self.parameters_link = None + self.mode = None + self.debug_setting = None + self.on_error_deployment = None + self.template_hash = None + self.output_resources = None + self.validated_resources = None + self.error = None + + +class DeploymentValidateResult(msrest.serialization.Model): + """Information from validate template deployment response. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar error: The deployment validation error. + :vartype error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + :param properties: The template deployment properties. + :type properties: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentPropertiesExtended + """ + + _validation = { + 'error': {'readonly': True}, + } + + _attribute_map = { + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + 'properties': {'key': 'properties', 'type': 'DeploymentPropertiesExtended'}, + } + + def __init__( + self, + *, + properties: Optional["DeploymentPropertiesExtended"] = None, + **kwargs + ): + super(DeploymentValidateResult, self).__init__(**kwargs) + self.error = None + self.properties = properties + + +class DeploymentWhatIf(msrest.serialization.Model): + """Deployment What-if operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfProperties + """ + + _validation = { + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentWhatIfProperties'}, + } + + def __init__( + self, + *, + properties: "DeploymentWhatIfProperties", + location: Optional[str] = None, + **kwargs + ): + super(DeploymentWhatIf, self).__init__(**kwargs) + self.location = location + self.properties = properties + + +class DeploymentWhatIfProperties(DeploymentProperties): + """Deployment What-if properties. + + All required parameters must be populated in order to send to Azure. + + :param template: The template content. You use this element when you want to pass the template + syntax directly in the request rather than link to an existing template. It can be a JObject or + well-formed JSON string. Use either the templateLink property or the template property, but not + both. + :type template: object + :param template_link: The URI of the template. Use either the templateLink property or the + template property, but not both. + :type template_link: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateLink + :param parameters: Name and value pairs that define the deployment parameters for the template. + You use this element when you want to provide the parameter values directly in the request + rather than link to an existing parameter file. Use either the parametersLink property or the + parameters property, but not both. It can be a JObject or a well formed JSON string. + :type parameters: object + :param parameters_link: The URI of parameters file. You use this element to link to an existing + parameters file. Use either the parametersLink property or the parameters property, but not + both. + :type parameters_link: ~azure.mgmt.resource.resources.v2020_10_01.models.ParametersLink + :param mode: Required. The mode that is used to deploy resources. This value can be either + Incremental or Complete. In Incremental mode, resources are deployed without deleting existing + resources that are not included in the template. In Complete mode, resources are deployed and + existing resources in the resource group that are not included in the template are deleted. Be + careful when using Complete mode as you may unintentionally delete resources. Possible values + include: "Incremental", "Complete". + :type mode: str or ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentMode + :param debug_setting: The debug setting of the deployment. + :type debug_setting: ~azure.mgmt.resource.resources.v2020_10_01.models.DebugSetting + :param on_error_deployment: The deployment on error behavior. + :type on_error_deployment: ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeployment + :param expression_evaluation_options: Specifies whether template expressions are evaluated + within the scope of the parent template or nested template. Only applicable to nested + templates. If not specified, default value is outer. + :type expression_evaluation_options: + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptions + :param what_if_settings: Optional What-If operation settings. + :type what_if_settings: + ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfSettings + """ + + _validation = { + 'mode': {'required': True}, + } + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'template_link': {'key': 'templateLink', 'type': 'TemplateLink'}, + 'parameters': {'key': 'parameters', 'type': 'object'}, + 'parameters_link': {'key': 'parametersLink', 'type': 'ParametersLink'}, + 'mode': {'key': 'mode', 'type': 'str'}, + 'debug_setting': {'key': 'debugSetting', 'type': 'DebugSetting'}, + 'on_error_deployment': {'key': 'onErrorDeployment', 'type': 'OnErrorDeployment'}, + 'expression_evaluation_options': {'key': 'expressionEvaluationOptions', 'type': 'ExpressionEvaluationOptions'}, + 'what_if_settings': {'key': 'whatIfSettings', 'type': 'DeploymentWhatIfSettings'}, + } + + def __init__( + self, + *, + mode: Union[str, "DeploymentMode"], + template: Optional[object] = None, + template_link: Optional["TemplateLink"] = None, + parameters: Optional[object] = None, + parameters_link: Optional["ParametersLink"] = None, + debug_setting: Optional["DebugSetting"] = None, + on_error_deployment: Optional["OnErrorDeployment"] = None, + expression_evaluation_options: Optional["ExpressionEvaluationOptions"] = None, + what_if_settings: Optional["DeploymentWhatIfSettings"] = None, + **kwargs + ): + super(DeploymentWhatIfProperties, self).__init__(template=template, template_link=template_link, parameters=parameters, parameters_link=parameters_link, mode=mode, debug_setting=debug_setting, on_error_deployment=on_error_deployment, expression_evaluation_options=expression_evaluation_options, **kwargs) + self.what_if_settings = what_if_settings + + +class DeploymentWhatIfSettings(msrest.serialization.Model): + """Deployment What-If operation settings. + + :param result_format: The format of the What-If results. Possible values include: + "ResourceIdOnly", "FullResourcePayloads". + :type result_format: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfResultFormat + """ + + _attribute_map = { + 'result_format': {'key': 'resultFormat', 'type': 'str'}, + } + + def __init__( + self, + *, + result_format: Optional[Union[str, "WhatIfResultFormat"]] = None, + **kwargs + ): + super(DeploymentWhatIfSettings, self).__init__(**kwargs) + self.result_format = result_format + + +class ErrorAdditionalInfo(msrest.serialization.Model): + """The resource management error additional info. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar type: The additional info type. + :vartype type: str + :ivar info: The additional info. + :vartype info: object + """ + + _validation = { + 'type': {'readonly': True}, + 'info': {'readonly': True}, + } + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'info': {'key': 'info', 'type': 'object'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorAdditionalInfo, self).__init__(**kwargs) + self.type = None + self.info = None + + +class ErrorResponse(msrest.serialization.Model): + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar code: The error code. + :vartype code: str + :ivar message: The error message. + :vartype message: str + :ivar target: The error target. + :vartype target: str + :ivar details: The error details. + :vartype details: list[~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse] + :ivar additional_info: The error additional info. + :vartype additional_info: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ErrorAdditionalInfo] + """ + + _validation = { + 'code': {'readonly': True}, + 'message': {'readonly': True}, + 'target': {'readonly': True}, + 'details': {'readonly': True}, + 'additional_info': {'readonly': True}, + } + + _attribute_map = { + 'code': {'key': 'code', 'type': 'str'}, + 'message': {'key': 'message', 'type': 'str'}, + 'target': {'key': 'target', 'type': 'str'}, + 'details': {'key': 'details', 'type': '[ErrorResponse]'}, + 'additional_info': {'key': 'additionalInfo', 'type': '[ErrorAdditionalInfo]'}, + } + + def __init__( + self, + **kwargs + ): + super(ErrorResponse, self).__init__(**kwargs) + self.code = None + self.message = None + self.target = None + self.details = None + self.additional_info = None + + +class ExportTemplateRequest(msrest.serialization.Model): + """Export resource group template request parameters. + + :param resources: The IDs of the resources to filter the export by. To export all resources, + supply an array with single entry '*'. + :type resources: list[str] + :param options: The export template options. A CSV-formatted list containing zero or more of + the following: 'IncludeParameterDefaultValue', 'IncludeComments', + 'SkipResourceNameParameterization', 'SkipAllParameterization'. + :type options: str + """ + + _attribute_map = { + 'resources': {'key': 'resources', 'type': '[str]'}, + 'options': {'key': 'options', 'type': 'str'}, + } + + def __init__( + self, + *, + resources: Optional[List[str]] = None, + options: Optional[str] = None, + **kwargs + ): + super(ExportTemplateRequest, self).__init__(**kwargs) + self.resources = resources + self.options = options + + +class ExpressionEvaluationOptions(msrest.serialization.Model): + """Specifies whether template expressions are evaluated within the scope of the parent template or nested template. + + :param scope: The scope to be used for evaluation of parameters, variables and functions in a + nested template. Possible values include: "NotSpecified", "Outer", "Inner". + :type scope: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.ExpressionEvaluationOptionsScopeType + """ + + _attribute_map = { + 'scope': {'key': 'scope', 'type': 'str'}, + } + + def __init__( + self, + *, + scope: Optional[Union[str, "ExpressionEvaluationOptionsScopeType"]] = None, + **kwargs + ): + super(ExpressionEvaluationOptions, self).__init__(**kwargs) + self.scope = scope + + +class Resource(msrest.serialization.Model): + """Specified resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Resource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.location = location + self.tags = tags + + +class GenericResource(Resource): + """Resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param plan: The plan of the resource. + :type plan: ~azure.mgmt.resource.resources.v2020_10_01.models.Plan + :param properties: The resource properties. + :type properties: object + :param kind: The kind of the resource. + :type kind: str + :param managed_by: ID of the resource that manages this resource. + :type managed_by: str + :param sku: The SKU of the resource. + :type sku: ~azure.mgmt.resource.resources.v2020_10_01.models.Sku + :param identity: The identity of the resource. + :type identity: ~azure.mgmt.resource.resources.v2020_10_01.models.Identity + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'plan': {'key': 'plan', 'type': 'Plan'}, + 'properties': {'key': 'properties', 'type': 'object'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + plan: Optional["Plan"] = None, + properties: Optional[object] = None, + kind: Optional[str] = None, + managed_by: Optional[str] = None, + sku: Optional["Sku"] = None, + identity: Optional["Identity"] = None, + **kwargs + ): + super(GenericResource, self).__init__(location=location, tags=tags, **kwargs) + self.plan = plan + self.properties = properties + self.kind = kind + self.managed_by = managed_by + self.sku = sku + self.identity = identity + + +class GenericResourceExpanded(GenericResource): + """Resource information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: Resource ID. + :vartype id: str + :ivar name: Resource name. + :vartype name: str + :ivar type: Resource type. + :vartype type: str + :param location: Resource location. + :type location: str + :param tags: A set of tags. Resource tags. + :type tags: dict[str, str] + :param plan: The plan of the resource. + :type plan: ~azure.mgmt.resource.resources.v2020_10_01.models.Plan + :param properties: The resource properties. + :type properties: object + :param kind: The kind of the resource. + :type kind: str + :param managed_by: ID of the resource that manages this resource. + :type managed_by: str + :param sku: The SKU of the resource. + :type sku: ~azure.mgmt.resource.resources.v2020_10_01.models.Sku + :param identity: The identity of the resource. + :type identity: ~azure.mgmt.resource.resources.v2020_10_01.models.Identity + :ivar created_time: The created time of the resource. This is only present if requested via the + $expand query parameter. + :vartype created_time: ~datetime.datetime + :ivar changed_time: The changed time of the resource. This is only present if requested via the + $expand query parameter. + :vartype changed_time: ~datetime.datetime + :ivar provisioning_state: The provisioning state of the resource. This is only present if + requested via the $expand query parameter. + :vartype provisioning_state: str + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'kind': {'pattern': r'^[-\w\._,\(\)]+$'}, + 'created_time': {'readonly': True}, + 'changed_time': {'readonly': True}, + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'location': {'key': 'location', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + 'plan': {'key': 'plan', 'type': 'Plan'}, + 'properties': {'key': 'properties', 'type': 'object'}, + 'kind': {'key': 'kind', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'sku': {'key': 'sku', 'type': 'Sku'}, + 'identity': {'key': 'identity', 'type': 'Identity'}, + 'created_time': {'key': 'createdTime', 'type': 'iso-8601'}, + 'changed_time': {'key': 'changedTime', 'type': 'iso-8601'}, + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + plan: Optional["Plan"] = None, + properties: Optional[object] = None, + kind: Optional[str] = None, + managed_by: Optional[str] = None, + sku: Optional["Sku"] = None, + identity: Optional["Identity"] = None, + **kwargs + ): + super(GenericResourceExpanded, self).__init__(location=location, tags=tags, plan=plan, properties=properties, kind=kind, managed_by=managed_by, sku=sku, identity=identity, **kwargs) + self.created_time = None + self.changed_time = None + self.provisioning_state = None + + +class GenericResourceFilter(msrest.serialization.Model): + """Resource filter. + + :param resource_type: The resource type. + :type resource_type: str + :param tagname: The tag name. + :type tagname: str + :param tagvalue: The tag value. + :type tagvalue: str + """ + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'tagname': {'key': 'tagname', 'type': 'str'}, + 'tagvalue': {'key': 'tagvalue', 'type': 'str'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + tagname: Optional[str] = None, + tagvalue: Optional[str] = None, + **kwargs + ): + super(GenericResourceFilter, self).__init__(**kwargs) + self.resource_type = resource_type + self.tagname = tagname + self.tagvalue = tagvalue + + +class HttpMessage(msrest.serialization.Model): + """HTTP message. + + :param content: HTTP message content. + :type content: object + """ + + _attribute_map = { + 'content': {'key': 'content', 'type': 'object'}, + } + + def __init__( + self, + *, + content: Optional[object] = None, + **kwargs + ): + super(HttpMessage, self).__init__(**kwargs) + self.content = content + + +class Identity(msrest.serialization.Model): + """Identity for the resource. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal ID of resource identity. + :vartype principal_id: str + :ivar tenant_id: The tenant ID of resource. + :vartype tenant_id: str + :param type: The identity type. Possible values include: "SystemAssigned", "UserAssigned", + "SystemAssigned, UserAssigned", "None". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceIdentityType + :param user_assigned_identities: The list of user identities associated with the resource. The + user identity dictionary key references will be ARM resource ids in the form: + '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. + :type user_assigned_identities: dict[str, + ~azure.mgmt.resource.resources.v2020_10_01.models.IdentityUserAssignedIdentitiesValue] + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'tenant_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'tenant_id': {'key': 'tenantId', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'user_assigned_identities': {'key': 'userAssignedIdentities', 'type': '{IdentityUserAssignedIdentitiesValue}'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "ResourceIdentityType"]] = None, + user_assigned_identities: Optional[Dict[str, "IdentityUserAssignedIdentitiesValue"]] = None, + **kwargs + ): + super(Identity, self).__init__(**kwargs) + self.principal_id = None + self.tenant_id = None + self.type = type + self.user_assigned_identities = user_assigned_identities + + +class IdentityUserAssignedIdentitiesValue(msrest.serialization.Model): + """IdentityUserAssignedIdentitiesValue. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar principal_id: The principal id of user assigned identity. + :vartype principal_id: str + :ivar client_id: The client id of user assigned identity. + :vartype client_id: str + """ + + _validation = { + 'principal_id': {'readonly': True}, + 'client_id': {'readonly': True}, + } + + _attribute_map = { + 'principal_id': {'key': 'principalId', 'type': 'str'}, + 'client_id': {'key': 'clientId', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(IdentityUserAssignedIdentitiesValue, self).__init__(**kwargs) + self.principal_id = None + self.client_id = None + + +class OnErrorDeployment(msrest.serialization.Model): + """Deployment on error behavior. + + :param type: The deployment on error behavior type. Possible values are LastSuccessful and + SpecificDeployment. Possible values include: "LastSuccessful", "SpecificDeployment". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentType + :param deployment_name: The deployment to be used on error case. + :type deployment_name: str + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'deployment_name': {'key': 'deploymentName', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "OnErrorDeploymentType"]] = None, + deployment_name: Optional[str] = None, + **kwargs + ): + super(OnErrorDeployment, self).__init__(**kwargs) + self.type = type + self.deployment_name = deployment_name + + +class OnErrorDeploymentExtended(msrest.serialization.Model): + """Deployment on error behavior with additional details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: The state of the provisioning for the on error deployment. + :vartype provisioning_state: str + :param type: The deployment on error behavior type. Possible values are LastSuccessful and + SpecificDeployment. Possible values include: "LastSuccessful", "SpecificDeployment". + :type type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.OnErrorDeploymentType + :param deployment_name: The deployment to be used on error case. + :type deployment_name: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'deployment_name': {'key': 'deploymentName', 'type': 'str'}, + } + + def __init__( + self, + *, + type: Optional[Union[str, "OnErrorDeploymentType"]] = None, + deployment_name: Optional[str] = None, + **kwargs + ): + super(OnErrorDeploymentExtended, self).__init__(**kwargs) + self.provisioning_state = None + self.type = type + self.deployment_name = deployment_name + + +class Operation(msrest.serialization.Model): + """Microsoft.Resources operation. + + :param name: Operation name: {provider}/{resource}/{operation}. + :type name: str + :param display: The object that represents the operation. + :type display: ~azure.mgmt.resource.resources.v2020_10_01.models.OperationDisplay + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'display': {'key': 'display', 'type': 'OperationDisplay'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + display: Optional["OperationDisplay"] = None, + **kwargs + ): + super(Operation, self).__init__(**kwargs) + self.name = name + self.display = display + + +class OperationDisplay(msrest.serialization.Model): + """The object that represents the operation. + + :param provider: Service provider: Microsoft.Resources. + :type provider: str + :param resource: Resource on which the operation is performed: Profile, endpoint, etc. + :type resource: str + :param operation: Operation type: Read, write, delete, etc. + :type operation: str + :param description: Description of the operation. + :type description: str + """ + + _attribute_map = { + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(OperationDisplay, self).__init__(**kwargs) + self.provider = provider + self.resource = resource + self.operation = operation + self.description = description + + +class OperationListResult(msrest.serialization.Model): + """Result of the request to list Microsoft.Resources operations. It contains a list of operations and a URL link to get the next set of results. + + :param value: List of Microsoft.Resources operations. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.Operation] + :param next_link: URL to get the next set of operation list results if there are any. + :type next_link: str + """ + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Operation]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Operation"]] = None, + next_link: Optional[str] = None, + **kwargs + ): + super(OperationListResult, self).__init__(**kwargs) + self.value = value + self.next_link = next_link + + +class ParametersLink(msrest.serialization.Model): + """Entity representing the reference to the deployment parameters. + + All required parameters must be populated in order to send to Azure. + + :param uri: Required. The URI of the parameters file. + :type uri: str + :param content_version: If included, must match the ContentVersion in the template. + :type content_version: str + """ + + _validation = { + 'uri': {'required': True}, + } + + _attribute_map = { + 'uri': {'key': 'uri', 'type': 'str'}, + 'content_version': {'key': 'contentVersion', 'type': 'str'}, + } + + def __init__( + self, + *, + uri: str, + content_version: Optional[str] = None, + **kwargs + ): + super(ParametersLink, self).__init__(**kwargs) + self.uri = uri + self.content_version = content_version + + +class Plan(msrest.serialization.Model): + """Plan for the resource. + + :param name: The plan ID. + :type name: str + :param publisher: The publisher ID. + :type publisher: str + :param product: The offer ID. + :type product: str + :param promotion_code: The promotion code. + :type promotion_code: str + :param version: The plan's version. + :type version: str + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'publisher': {'key': 'publisher', 'type': 'str'}, + 'product': {'key': 'product', 'type': 'str'}, + 'promotion_code': {'key': 'promotionCode', 'type': 'str'}, + 'version': {'key': 'version', 'type': 'str'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + publisher: Optional[str] = None, + product: Optional[str] = None, + promotion_code: Optional[str] = None, + version: Optional[str] = None, + **kwargs + ): + super(Plan, self).__init__(**kwargs) + self.name = name + self.publisher = publisher + self.product = product + self.promotion_code = promotion_code + self.version = version + + +class Provider(msrest.serialization.Model): + """Resource provider information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The provider ID. + :vartype id: str + :param namespace: The namespace of the resource provider. + :type namespace: str + :ivar registration_state: The registration state of the resource provider. + :vartype registration_state: str + :ivar registration_policy: The registration policy of the resource provider. + :vartype registration_policy: str + :ivar resource_types: The collection of provider resource types. + :vartype resource_types: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceType] + """ + + _validation = { + 'id': {'readonly': True}, + 'registration_state': {'readonly': True}, + 'registration_policy': {'readonly': True}, + 'resource_types': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'namespace': {'key': 'namespace', 'type': 'str'}, + 'registration_state': {'key': 'registrationState', 'type': 'str'}, + 'registration_policy': {'key': 'registrationPolicy', 'type': 'str'}, + 'resource_types': {'key': 'resourceTypes', 'type': '[ProviderResourceType]'}, + } + + def __init__( + self, + *, + namespace: Optional[str] = None, + **kwargs + ): + super(Provider, self).__init__(**kwargs) + self.id = None + self.namespace = namespace + self.registration_state = None + self.registration_policy = None + self.resource_types = None + + +class ProviderExtendedLocation(msrest.serialization.Model): + """The provider extended location. + + :param location: The azure location. + :type location: str + :param type: The extended location type. + :type type: str + :param extended_locations: The extended locations for the azure location. + :type extended_locations: list[str] + """ + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'extended_locations': {'key': 'extendedLocations', 'type': '[str]'}, + } + + def __init__( + self, + *, + location: Optional[str] = None, + type: Optional[str] = None, + extended_locations: Optional[List[str]] = None, + **kwargs + ): + super(ProviderExtendedLocation, self).__init__(**kwargs) + self.location = location + self.type = type + self.extended_locations = extended_locations + + +class ProviderListResult(msrest.serialization.Model): + """List of resource providers. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource providers. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.Provider] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[Provider]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["Provider"]] = None, + **kwargs + ): + super(ProviderListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ProviderResourceType(msrest.serialization.Model): + """Resource type managed by the resource provider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param resource_type: The resource type. + :type resource_type: str + :param locations: The collection of locations where this resource type can be created. + :type locations: list[str] + :param location_mappings: The location mappings that are supported by this resource type. + :type location_mappings: + list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderExtendedLocation] + :param aliases: The aliases that are supported by this resource type. + :type aliases: list[~azure.mgmt.resource.resources.v2020_10_01.models.Alias] + :param api_versions: The API version. + :type api_versions: list[str] + :ivar default_api_version: The default API version. + :vartype default_api_version: str + :ivar api_profiles: The API profiles for the resource provider. + :vartype api_profiles: list[~azure.mgmt.resource.resources.v2020_10_01.models.ApiProfile] + :param capabilities: The additional capabilities offered by this resource type. + :type capabilities: str + :param properties: The properties. + :type properties: dict[str, str] + """ + + _validation = { + 'default_api_version': {'readonly': True}, + 'api_profiles': {'readonly': True}, + } + + _attribute_map = { + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + 'locations': {'key': 'locations', 'type': '[str]'}, + 'location_mappings': {'key': 'locationMappings', 'type': '[ProviderExtendedLocation]'}, + 'aliases': {'key': 'aliases', 'type': '[Alias]'}, + 'api_versions': {'key': 'apiVersions', 'type': '[str]'}, + 'default_api_version': {'key': 'defaultApiVersion', 'type': 'str'}, + 'api_profiles': {'key': 'apiProfiles', 'type': '[ApiProfile]'}, + 'capabilities': {'key': 'capabilities', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': '{str}'}, + } + + def __init__( + self, + *, + resource_type: Optional[str] = None, + locations: Optional[List[str]] = None, + location_mappings: Optional[List["ProviderExtendedLocation"]] = None, + aliases: Optional[List["Alias"]] = None, + api_versions: Optional[List[str]] = None, + capabilities: Optional[str] = None, + properties: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ProviderResourceType, self).__init__(**kwargs) + self.resource_type = resource_type + self.locations = locations + self.location_mappings = location_mappings + self.aliases = aliases + self.api_versions = api_versions + self.default_api_version = None + self.api_profiles = None + self.capabilities = capabilities + self.properties = properties + + +class ProviderResourceTypeListResult(msrest.serialization.Model): + """List of resource types of a resource provider. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource types. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceType] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ProviderResourceType]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ProviderResourceType"]] = None, + **kwargs + ): + super(ProviderResourceTypeListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceGroup(msrest.serialization.Model): + """Resource group information. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: The ID of the resource group. + :vartype id: str + :ivar name: The name of the resource group. + :vartype name: str + :ivar type: The type of the resource group. + :vartype type: str + :param properties: The resource group properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupProperties + :param location: Required. The location of the resource group. It cannot be changed after the + resource group has been created. It must be one of the supported Azure locations. + :type location: str + :param managed_by: The ID of the resource that manages this resource group. + :type managed_by: str + :param tags: A set of tags. The tags attached to the resource group. + :type tags: dict[str, str] + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'location': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, + 'location': {'key': 'location', 'type': 'str'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + location: str, + properties: Optional["ResourceGroupProperties"] = None, + managed_by: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ResourceGroup, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.properties = properties + self.location = location + self.managed_by = managed_by + self.tags = tags + + +class ResourceGroupExportResult(msrest.serialization.Model): + """Resource group export result. + + :param template: The template content. + :type template: object + :param error: The template export error. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _attribute_map = { + 'template': {'key': 'template', 'type': 'object'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + *, + template: Optional[object] = None, + error: Optional["ErrorResponse"] = None, + **kwargs + ): + super(ResourceGroupExportResult, self).__init__(**kwargs) + self.template = template + self.error = error + + +class ResourceGroupFilter(msrest.serialization.Model): + """Resource group filter. + + :param tag_name: The tag name. + :type tag_name: str + :param tag_value: The tag value. + :type tag_value: str + """ + + _attribute_map = { + 'tag_name': {'key': 'tagName', 'type': 'str'}, + 'tag_value': {'key': 'tagValue', 'type': 'str'}, + } + + def __init__( + self, + *, + tag_name: Optional[str] = None, + tag_value: Optional[str] = None, + **kwargs + ): + super(ResourceGroupFilter, self).__init__(**kwargs) + self.tag_name = tag_name + self.tag_value = tag_value + + +class ResourceGroupListResult(msrest.serialization.Model): + """List of resource groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resource groups. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[ResourceGroup]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["ResourceGroup"]] = None, + **kwargs + ): + super(ResourceGroupListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceGroupPatchable(msrest.serialization.Model): + """Resource group information. + + :param name: The name of the resource group. + :type name: str + :param properties: The resource group properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupProperties + :param managed_by: The ID of the resource that manages this resource group. + :type managed_by: str + :param tags: A set of tags. The tags attached to the resource group. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'ResourceGroupProperties'}, + 'managed_by': {'key': 'managedBy', 'type': 'str'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + properties: Optional["ResourceGroupProperties"] = None, + managed_by: Optional[str] = None, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ResourceGroupPatchable, self).__init__(**kwargs) + self.name = name + self.properties = properties + self.managed_by = managed_by + self.tags = tags + + +class ResourceGroupProperties(msrest.serialization.Model): + """The resource group properties. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar provisioning_state: The provisioning state. + :vartype provisioning_state: str + """ + + _validation = { + 'provisioning_state': {'readonly': True}, + } + + _attribute_map = { + 'provisioning_state': {'key': 'provisioningState', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceGroupProperties, self).__init__(**kwargs) + self.provisioning_state = None + + +class ResourceListResult(msrest.serialization.Model): + """List of resource groups. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of resources. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResourceExpanded] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[GenericResourceExpanded]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["GenericResourceExpanded"]] = None, + **kwargs + ): + super(ResourceListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class ResourceProviderOperationDisplayProperties(msrest.serialization.Model): + """Resource provider operation's display properties. + + :param publisher: Operation description. + :type publisher: str + :param provider: Operation provider. + :type provider: str + :param resource: Operation resource. + :type resource: str + :param operation: Resource provider operation. + :type operation: str + :param description: Operation description. + :type description: str + """ + + _attribute_map = { + 'publisher': {'key': 'publisher', 'type': 'str'}, + 'provider': {'key': 'provider', 'type': 'str'}, + 'resource': {'key': 'resource', 'type': 'str'}, + 'operation': {'key': 'operation', 'type': 'str'}, + 'description': {'key': 'description', 'type': 'str'}, + } + + def __init__( + self, + *, + publisher: Optional[str] = None, + provider: Optional[str] = None, + resource: Optional[str] = None, + operation: Optional[str] = None, + description: Optional[str] = None, + **kwargs + ): + super(ResourceProviderOperationDisplayProperties, self).__init__(**kwargs) + self.publisher = publisher + self.provider = provider + self.resource = resource + self.operation = operation + self.description = description + + +class ResourceReference(msrest.serialization.Model): + """The resource Id model. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The fully qualified resource Id. + :vartype id: str + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + **kwargs + ): + super(ResourceReference, self).__init__(**kwargs) + self.id = None + + +class ResourcesMoveInfo(msrest.serialization.Model): + """Parameters of move resources. + + :param resources: The IDs of the resources. + :type resources: list[str] + :param target_resource_group: The target resource group. + :type target_resource_group: str + """ + + _attribute_map = { + 'resources': {'key': 'resources', 'type': '[str]'}, + 'target_resource_group': {'key': 'targetResourceGroup', 'type': 'str'}, + } + + def __init__( + self, + *, + resources: Optional[List[str]] = None, + target_resource_group: Optional[str] = None, + **kwargs + ): + super(ResourcesMoveInfo, self).__init__(**kwargs) + self.resources = resources + self.target_resource_group = target_resource_group + + +class ScopedDeployment(msrest.serialization.Model): + """Deployment operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: Required. The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentProperties + :param tags: A set of tags. Deployment tags. + :type tags: dict[str, str] + """ + + _validation = { + 'location': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentProperties'}, + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + location: str, + properties: "DeploymentProperties", + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(ScopedDeployment, self).__init__(**kwargs) + self.location = location + self.properties = properties + self.tags = tags + + +class ScopedDeploymentWhatIf(msrest.serialization.Model): + """Deployment What-if operation parameters. + + All required parameters must be populated in order to send to Azure. + + :param location: Required. The location to store the deployment data. + :type location: str + :param properties: Required. The deployment properties. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIfProperties + """ + + _validation = { + 'location': {'required': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'location': {'key': 'location', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'DeploymentWhatIfProperties'}, + } + + def __init__( + self, + *, + location: str, + properties: "DeploymentWhatIfProperties", + **kwargs + ): + super(ScopedDeploymentWhatIf, self).__init__(**kwargs) + self.location = location + self.properties = properties + + +class Sku(msrest.serialization.Model): + """SKU for the resource. + + :param name: The SKU name. + :type name: str + :param tier: The SKU tier. + :type tier: str + :param size: The SKU size. + :type size: str + :param family: The SKU family. + :type family: str + :param model: The SKU model. + :type model: str + :param capacity: The SKU capacity. + :type capacity: int + """ + + _attribute_map = { + 'name': {'key': 'name', 'type': 'str'}, + 'tier': {'key': 'tier', 'type': 'str'}, + 'size': {'key': 'size', 'type': 'str'}, + 'family': {'key': 'family', 'type': 'str'}, + 'model': {'key': 'model', 'type': 'str'}, + 'capacity': {'key': 'capacity', 'type': 'int'}, + } + + def __init__( + self, + *, + name: Optional[str] = None, + tier: Optional[str] = None, + size: Optional[str] = None, + family: Optional[str] = None, + model: Optional[str] = None, + capacity: Optional[int] = None, + **kwargs + ): + super(Sku, self).__init__(**kwargs) + self.name = name + self.tier = tier + self.size = size + self.family = family + self.model = model + self.capacity = capacity + + +class StatusMessage(msrest.serialization.Model): + """Operation status message object. + + :param status: Status of the deployment operation. + :type status: str + :param error: The error reported by the operation. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + error: Optional["ErrorResponse"] = None, + **kwargs + ): + super(StatusMessage, self).__init__(**kwargs) + self.status = status + self.error = error + + +class SubResource(msrest.serialization.Model): + """Sub-resource. + + :param id: Resource ID. + :type id: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + **kwargs + ): + super(SubResource, self).__init__(**kwargs) + self.id = id + + +class TagCount(msrest.serialization.Model): + """Tag count. + + :param type: Type of count. + :type type: str + :param value: Value of count. + :type value: int + """ + + _attribute_map = { + 'type': {'key': 'type', 'type': 'str'}, + 'value': {'key': 'value', 'type': 'int'}, + } + + def __init__( + self, + *, + type: Optional[str] = None, + value: Optional[int] = None, + **kwargs + ): + super(TagCount, self).__init__(**kwargs) + self.type = type + self.value = value + + +class TagDetails(msrest.serialization.Model): + """Tag details. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The tag name ID. + :vartype id: str + :param tag_name: The tag name. + :type tag_name: str + :param count: The total number of resources that use the resource tag. When a tag is initially + created and has no associated resources, the value is 0. + :type count: ~azure.mgmt.resource.resources.v2020_10_01.models.TagCount + :param values: The list of tag values. + :type values: list[~azure.mgmt.resource.resources.v2020_10_01.models.TagValue] + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'tag_name': {'key': 'tagName', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'TagCount'}, + 'values': {'key': 'values', 'type': '[TagValue]'}, + } + + def __init__( + self, + *, + tag_name: Optional[str] = None, + count: Optional["TagCount"] = None, + values: Optional[List["TagValue"]] = None, + **kwargs + ): + super(TagDetails, self).__init__(**kwargs) + self.id = None + self.tag_name = tag_name + self.count = count + self.values = values + + +class Tags(msrest.serialization.Model): + """A dictionary of name and value pairs. + + :param tags: A set of tags. Dictionary of :code:``. + :type tags: dict[str, str] + """ + + _attribute_map = { + 'tags': {'key': 'tags', 'type': '{str}'}, + } + + def __init__( + self, + *, + tags: Optional[Dict[str, str]] = None, + **kwargs + ): + super(Tags, self).__init__(**kwargs) + self.tags = tags + + +class TagsListResult(msrest.serialization.Model): + """List of subscription tags. + + Variables are only populated by the server, and will be ignored when sending a request. + + :param value: An array of tags. + :type value: list[~azure.mgmt.resource.resources.v2020_10_01.models.TagDetails] + :ivar next_link: The URL to use for getting the next set of results. + :vartype next_link: str + """ + + _validation = { + 'next_link': {'readonly': True}, + } + + _attribute_map = { + 'value': {'key': 'value', 'type': '[TagDetails]'}, + 'next_link': {'key': 'nextLink', 'type': 'str'}, + } + + def __init__( + self, + *, + value: Optional[List["TagDetails"]] = None, + **kwargs + ): + super(TagsListResult, self).__init__(**kwargs) + self.value = value + self.next_link = None + + +class TagsPatchResource(msrest.serialization.Model): + """Wrapper resource for tags patch API request only. + + :param operation: The operation type for the patch API. Possible values include: "Replace", + "Merge", "Delete". + :type operation: str or ~azure.mgmt.resource.resources.v2020_10_01.models.TagsPatchOperation + :param properties: The set of tags. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.Tags + """ + + _attribute_map = { + 'operation': {'key': 'operation', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'Tags'}, + } + + def __init__( + self, + *, + operation: Optional[Union[str, "TagsPatchOperation"]] = None, + properties: Optional["Tags"] = None, + **kwargs + ): + super(TagsPatchResource, self).__init__(**kwargs) + self.operation = operation + self.properties = properties + + +class TagsResource(msrest.serialization.Model): + """Wrapper resource for tags API requests and responses. + + Variables are only populated by the server, and will be ignored when sending a request. + + All required parameters must be populated in order to send to Azure. + + :ivar id: The ID of the tags wrapper resource. + :vartype id: str + :ivar name: The name of the tags wrapper resource. + :vartype name: str + :ivar type: The type of the tags wrapper resource. + :vartype type: str + :param properties: Required. The set of tags. + :type properties: ~azure.mgmt.resource.resources.v2020_10_01.models.Tags + """ + + _validation = { + 'id': {'readonly': True}, + 'name': {'readonly': True}, + 'type': {'readonly': True}, + 'properties': {'required': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'name': {'key': 'name', 'type': 'str'}, + 'type': {'key': 'type', 'type': 'str'}, + 'properties': {'key': 'properties', 'type': 'Tags'}, + } + + def __init__( + self, + *, + properties: "Tags", + **kwargs + ): + super(TagsResource, self).__init__(**kwargs) + self.id = None + self.name = None + self.type = None + self.properties = properties + + +class TagValue(msrest.serialization.Model): + """Tag information. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar id: The tag value ID. + :vartype id: str + :param tag_value: The tag value. + :type tag_value: str + :param count: The tag value count. + :type count: ~azure.mgmt.resource.resources.v2020_10_01.models.TagCount + """ + + _validation = { + 'id': {'readonly': True}, + } + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'tag_value': {'key': 'tagValue', 'type': 'str'}, + 'count': {'key': 'count', 'type': 'TagCount'}, + } + + def __init__( + self, + *, + tag_value: Optional[str] = None, + count: Optional["TagCount"] = None, + **kwargs + ): + super(TagValue, self).__init__(**kwargs) + self.id = None + self.tag_value = tag_value + self.count = count + + +class TargetResource(msrest.serialization.Model): + """Target resource. + + :param id: The ID of the resource. + :type id: str + :param resource_name: The name of the resource. + :type resource_name: str + :param resource_type: The type of the resource. + :type resource_type: str + """ + + _attribute_map = { + 'id': {'key': 'id', 'type': 'str'}, + 'resource_name': {'key': 'resourceName', 'type': 'str'}, + 'resource_type': {'key': 'resourceType', 'type': 'str'}, + } + + def __init__( + self, + *, + id: Optional[str] = None, + resource_name: Optional[str] = None, + resource_type: Optional[str] = None, + **kwargs + ): + super(TargetResource, self).__init__(**kwargs) + self.id = id + self.resource_name = resource_name + self.resource_type = resource_type + + +class TemplateHashResult(msrest.serialization.Model): + """Result of the request to calculate template hash. It contains a string of minified template and its hash. + + :param minified_template: The minified template string. + :type minified_template: str + :param template_hash: The template hash. + :type template_hash: str + """ + + _attribute_map = { + 'minified_template': {'key': 'minifiedTemplate', 'type': 'str'}, + 'template_hash': {'key': 'templateHash', 'type': 'str'}, + } + + def __init__( + self, + *, + minified_template: Optional[str] = None, + template_hash: Optional[str] = None, + **kwargs + ): + super(TemplateHashResult, self).__init__(**kwargs) + self.minified_template = minified_template + self.template_hash = template_hash + + +class TemplateLink(msrest.serialization.Model): + """Entity representing the reference to the template. + + :param uri: The URI of the template to deploy. Use either the uri or id property, but not both. + :type uri: str + :param id: The resource id of a Template Spec. Use either the id or uri property, but not both. + :type id: str + :param relative_path: The relativePath property can be used to deploy a linked template at a + location relative to the parent. If the parent template was linked with a TemplateSpec, this + will reference an artifact in the TemplateSpec. If the parent was linked with a URI, the child + deployment will be a combination of the parent and relativePath URIs. + :type relative_path: str + :param content_version: If included, must match the ContentVersion in the template. + :type content_version: str + :param query_string: The query string (for example, a SAS token) to be used with the + templateLink URI. + :type query_string: str + """ + + _attribute_map = { + 'uri': {'key': 'uri', 'type': 'str'}, + 'id': {'key': 'id', 'type': 'str'}, + 'relative_path': {'key': 'relativePath', 'type': 'str'}, + 'content_version': {'key': 'contentVersion', 'type': 'str'}, + 'query_string': {'key': 'queryString', 'type': 'str'}, + } + + def __init__( + self, + *, + uri: Optional[str] = None, + id: Optional[str] = None, + relative_path: Optional[str] = None, + content_version: Optional[str] = None, + query_string: Optional[str] = None, + **kwargs + ): + super(TemplateLink, self).__init__(**kwargs) + self.uri = uri + self.id = id + self.relative_path = relative_path + self.content_version = content_version + self.query_string = query_string + + +class WhatIfChange(msrest.serialization.Model): + """Information about a single resource change predicted by What-If operation. + + All required parameters must be populated in order to send to Azure. + + :param resource_id: Required. Resource ID. + :type resource_id: str + :param change_type: Required. Type of change that will be made to the resource when the + deployment is executed. Possible values include: "Create", "Delete", "Ignore", "Deploy", + "NoChange", "Modify". + :type change_type: str or ~azure.mgmt.resource.resources.v2020_10_01.models.ChangeType + :param before: The snapshot of the resource before the deployment is executed. + :type before: object + :param after: The predicted snapshot of the resource after the deployment is executed. + :type after: object + :param delta: The predicted changes to resource properties. + :type delta: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfPropertyChange] + """ + + _validation = { + 'resource_id': {'required': True}, + 'change_type': {'required': True}, + } + + _attribute_map = { + 'resource_id': {'key': 'resourceId', 'type': 'str'}, + 'change_type': {'key': 'changeType', 'type': 'str'}, + 'before': {'key': 'before', 'type': 'object'}, + 'after': {'key': 'after', 'type': 'object'}, + 'delta': {'key': 'delta', 'type': '[WhatIfPropertyChange]'}, + } + + def __init__( + self, + *, + resource_id: str, + change_type: Union[str, "ChangeType"], + before: Optional[object] = None, + after: Optional[object] = None, + delta: Optional[List["WhatIfPropertyChange"]] = None, + **kwargs + ): + super(WhatIfChange, self).__init__(**kwargs) + self.resource_id = resource_id + self.change_type = change_type + self.before = before + self.after = after + self.delta = delta + + +class WhatIfOperationResult(msrest.serialization.Model): + """Result of the What-If operation. Contains a list of predicted changes and a URL link to get to the next set of results. + + :param status: Status of the What-If operation. + :type status: str + :param error: Error when What-If operation fails. + :type error: ~azure.mgmt.resource.resources.v2020_10_01.models.ErrorResponse + :param changes: List of resource changes predicted by What-If operation. + :type changes: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfChange] + """ + + _attribute_map = { + 'status': {'key': 'status', 'type': 'str'}, + 'error': {'key': 'error', 'type': 'ErrorResponse'}, + 'changes': {'key': 'properties.changes', 'type': '[WhatIfChange]'}, + } + + def __init__( + self, + *, + status: Optional[str] = None, + error: Optional["ErrorResponse"] = None, + changes: Optional[List["WhatIfChange"]] = None, + **kwargs + ): + super(WhatIfOperationResult, self).__init__(**kwargs) + self.status = status + self.error = error + self.changes = changes + + +class WhatIfPropertyChange(msrest.serialization.Model): + """The predicted change to the resource property. + + All required parameters must be populated in order to send to Azure. + + :param path: Required. The path of the property. + :type path: str + :param property_change_type: Required. The type of property change. Possible values include: + "Create", "Delete", "Modify", "Array". + :type property_change_type: str or + ~azure.mgmt.resource.resources.v2020_10_01.models.PropertyChangeType + :param before: The value of the property before the deployment is executed. + :type before: object + :param after: The value of the property after the deployment is executed. + :type after: object + :param children: Nested property changes. + :type children: list[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfPropertyChange] + """ + + _validation = { + 'path': {'required': True}, + 'property_change_type': {'required': True}, + } + + _attribute_map = { + 'path': {'key': 'path', 'type': 'str'}, + 'property_change_type': {'key': 'propertyChangeType', 'type': 'str'}, + 'before': {'key': 'before', 'type': 'object'}, + 'after': {'key': 'after', 'type': 'object'}, + 'children': {'key': 'children', 'type': '[WhatIfPropertyChange]'}, + } + + def __init__( + self, + *, + path: str, + property_change_type: Union[str, "PropertyChangeType"], + before: Optional[object] = None, + after: Optional[object] = None, + children: Optional[List["WhatIfPropertyChange"]] = None, + **kwargs + ): + super(WhatIfPropertyChange, self).__init__(**kwargs) + self.path = path + self.property_change_type = property_change_type + self.before = before + self.after = after + self.children = children diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_resource_management_client_enums.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_resource_management_client_enums.py new file mode 100644 index 000000000000..0870d71c7b06 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/models/_resource_management_client_enums.py @@ -0,0 +1,166 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from enum import Enum, EnumMeta +from six import with_metaclass + +class _CaseInsensitiveEnumMeta(EnumMeta): + def __getitem__(self, name): + return super().__getitem__(name.upper()) + + def __getattr__(cls, name): + """Return the enum member matching `name` + We use __getattr__ instead of descriptors or inserting into the enum + class' __dict__ in order to support `name` and `value` being both + properties for enum members (which live in the class' __dict__) and + enum members themselves. + """ + try: + return cls._member_map_[name.upper()] + except KeyError: + raise AttributeError(name) + + +class AliasPathAttributes(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The attributes of the token that the alias path is referring to. + """ + + NONE = "None" #: The token that the alias path is referring to has no attributes. + MODIFIABLE = "Modifiable" #: The token that the alias path is referring to is modifiable by policies with 'modify' effect. + +class AliasPathTokenType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of the token that the alias path is referring to. + """ + + NOT_SPECIFIED = "NotSpecified" #: The token type is not specified. + ANY = "Any" #: The token type can be anything. + STRING = "String" #: The token type is string. + OBJECT = "Object" #: The token type is object. + ARRAY = "Array" #: The token type is array. + INTEGER = "Integer" #: The token type is integer. + NUMBER = "Number" #: The token type is number. + BOOLEAN = "Boolean" #: The token type is boolean. + +class AliasPatternType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of alias pattern + """ + + NOT_SPECIFIED = "NotSpecified" #: NotSpecified is not allowed. + EXTRACT = "Extract" #: Extract is the only allowed value. + +class AliasType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of the alias. + """ + + NOT_SPECIFIED = "NotSpecified" #: Alias type is unknown (same as not providing alias type). + PLAIN_TEXT = "PlainText" #: Alias value is not secret. + MASK = "Mask" #: Alias value is secret. + +class ChangeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Type of change that will be made to the resource when the deployment is executed. + """ + + CREATE = "Create" #: The resource does not exist in the current state but is present in the desired state. The resource will be created when the deployment is executed. + DELETE = "Delete" #: The resource exists in the current state and is missing from the desired state. The resource will be deleted when the deployment is executed. + IGNORE = "Ignore" #: The resource exists in the current state and is missing from the desired state. The resource will not be deployed or modified when the deployment is executed. + DEPLOY = "Deploy" #: The resource exists in the current state and the desired state and will be redeployed when the deployment is executed. The properties of the resource may or may not change. + NO_CHANGE = "NoChange" #: The resource exists in the current state and the desired state and will be redeployed when the deployment is executed. The properties of the resource will not change. + MODIFY = "Modify" #: The resource exists in the current state and the desired state and will be redeployed when the deployment is executed. The properties of the resource will change. + +class DeploymentMode(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The mode that is used to deploy resources. This value can be either Incremental or Complete. In + Incremental mode, resources are deployed without deleting existing resources that are not + included in the template. In Complete mode, resources are deployed and existing resources in + the resource group that are not included in the template are deleted. Be careful when using + Complete mode as you may unintentionally delete resources. + """ + + INCREMENTAL = "Incremental" + COMPLETE = "Complete" + +class ExpressionEvaluationOptionsScopeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The scope to be used for evaluation of parameters, variables and functions in a nested + template. + """ + + NOT_SPECIFIED = "NotSpecified" + OUTER = "Outer" + INNER = "Inner" + +class OnErrorDeploymentType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The deployment on error behavior type. Possible values are LastSuccessful and + SpecificDeployment. + """ + + LAST_SUCCESSFUL = "LastSuccessful" + SPECIFIC_DEPLOYMENT = "SpecificDeployment" + +class PropertyChangeType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The type of property change. + """ + + CREATE = "Create" #: The property does not exist in the current state but is present in the desired state. The property will be created when the deployment is executed. + DELETE = "Delete" #: The property exists in the current state and is missing from the desired state. It will be deleted when the deployment is executed. + MODIFY = "Modify" #: The property exists in both current and desired state and is different. The value of the property will change when the deployment is executed. + ARRAY = "Array" #: The property is an array and contains nested changes. + +class ProvisioningOperation(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The name of the current provisioning operation. + """ + + NOT_SPECIFIED = "NotSpecified" #: The provisioning operation is not specified. + CREATE = "Create" #: The provisioning operation is create. + DELETE = "Delete" #: The provisioning operation is delete. + WAITING = "Waiting" #: The provisioning operation is waiting. + AZURE_ASYNC_OPERATION_WAITING = "AzureAsyncOperationWaiting" #: The provisioning operation is waiting Azure async operation. + RESOURCE_CACHE_WAITING = "ResourceCacheWaiting" #: The provisioning operation is waiting for resource cache. + ACTION = "Action" #: The provisioning operation is action. + READ = "Read" #: The provisioning operation is read. + EVALUATE_DEPLOYMENT_OUTPUT = "EvaluateDeploymentOutput" #: The provisioning operation is evaluate output. + DEPLOYMENT_CLEANUP = "DeploymentCleanup" #: The provisioning operation is cleanup. This operation is part of the 'complete' mode deployment. + +class ProvisioningState(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """Denotes the state of provisioning. + """ + + NOT_SPECIFIED = "NotSpecified" + ACCEPTED = "Accepted" + RUNNING = "Running" + READY = "Ready" + CREATING = "Creating" + CREATED = "Created" + DELETING = "Deleting" + DELETED = "Deleted" + CANCELED = "Canceled" + FAILED = "Failed" + SUCCEEDED = "Succeeded" + UPDATING = "Updating" + +class ResourceIdentityType(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The identity type. + """ + + SYSTEM_ASSIGNED = "SystemAssigned" + USER_ASSIGNED = "UserAssigned" + SYSTEM_ASSIGNED_USER_ASSIGNED = "SystemAssigned, UserAssigned" + NONE = "None" + +class TagsPatchOperation(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The operation type for the patch API. + """ + + REPLACE = "Replace" #: The 'replace' option replaces the entire set of existing tags with a new set. + MERGE = "Merge" #: The 'merge' option allows adding tags with new names and updating the values of tags with existing names. + DELETE = "Delete" #: The 'delete' option allows selectively deleting tags based on given names or name/value pairs. + +class WhatIfResultFormat(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + """The format of the What-If results + """ + + RESOURCE_ID_ONLY = "ResourceIdOnly" + FULL_RESOURCE_PAYLOADS = "FullResourcePayloads" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/__init__.py new file mode 100644 index 000000000000..b5dcba5d6d4b --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/__init__.py @@ -0,0 +1,27 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- + +from ._operations import Operations +from ._deployments_operations import DeploymentsOperations +from ._providers_operations import ProvidersOperations +from ._provider_resource_types_operations import ProviderResourceTypesOperations +from ._resources_operations import ResourcesOperations +from ._resource_groups_operations import ResourceGroupsOperations +from ._tags_operations import TagsOperations +from ._deployment_operations_operations import DeploymentOperationsOperations + +__all__ = [ + 'Operations', + 'DeploymentsOperations', + 'ProvidersOperations', + 'ProviderResourceTypesOperations', + 'ResourcesOperations', + 'ResourceGroupsOperations', + 'TagsOperations', + 'DeploymentOperationsOperations', +] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployment_operations_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployment_operations_operations.py new file mode 100644 index 000000000000..bfca9dd4420f --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployment_operations_operations.py @@ -0,0 +1,739 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DeploymentOperationsOperations(object): + """DeploymentOperationsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def get_at_scope( + self, + scope, # type: str + deployment_name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentOperation" + """Gets a deployments operation. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_scope( + self, + scope, # type: str + deployment_name, # type: str + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] + """Gets all deployments operations for a deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + def get_at_tenant_scope( + self, + deployment_name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentOperation" + """Gets a deployments operation. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_tenant_scope( + self, + deployment_name, # type: str + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] + """Gets all deployments operations for a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + def get_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentOperation" + """Gets a deployments operation. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] + """Gets all deployments operations for a deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + def get_at_subscription_scope( + self, + deployment_name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentOperation" + """Gets a deployments operation. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list_at_subscription_scope( + self, + deployment_name, # type: str + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] + """Gets all deployments operations for a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/operations'} # type: ignore + + def get( + self, + resource_group_name, # type: str + deployment_name, # type: str + operation_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentOperation" + """Gets a deployments operation. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param operation_id: The ID of the operation to get. + :type operation_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentOperation, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperation + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperation"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'operationId': self._serialize.url("operation_id", operation_id, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentOperation', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/deployments/{deploymentName}/operations/{operationId}'} # type: ignore + + def list( + self, + resource_group_name, # type: str + deployment_name, # type: str + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentOperationsListResult"] + """Gets all deployments operations for a deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param top: The number of results to return. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentOperationsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentOperationsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentOperationsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentOperationsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/deployments/{deploymentName}/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployments_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployments_operations.py new file mode 100644 index 000000000000..56454555aecf --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_deployments_operations.py @@ -0,0 +1,4010 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class DeploymentsOperations(object): + """DeploymentsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def _delete_at_scope_initial( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_delete_at_scope( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def check_existence_at_scope( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether the deployment exists. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def _create_or_update_at_scope_initial( + self, + scope, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_create_or_update_at_scope( + self, + scope, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentExtended"] + """Deploys resources at a given scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def get_at_scope( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + """Gets a deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def cancel_at_scope( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + def _validate_at_scope_initial( + self, + scope, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_scope_initial.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def begin_validate_at_scope( + self, + scope, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_at_scope_initial( + scope=scope, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def export_template_at_scope( + self, + scope, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExportResult" + """Exports the template used for specified deployment. + + :param scope: The resource scope. + :type scope: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_scope( + self, + scope, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentListResult"] + """Get all the deployments at the given scope. + + :param scope: The resource scope. + :type scope: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/deployments/'} # type: ignore + + def _delete_at_tenant_scope_initial( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_delete_at_tenant_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_at_tenant_scope_initial( + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def check_existence_at_tenant_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether the deployment exists. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def _create_or_update_at_tenant_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_create_or_update_at_tenant_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentExtended"] + """Deploys resources at tenant scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def get_at_tenant_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + """Gets a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def cancel_at_tenant_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + def _validate_at_tenant_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def begin_validate_at_tenant_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def _what_if_at_tenant_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_tenant_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_tenant_scope_initial.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def begin_what_if_at_tenant_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.ScopedDeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] + """Returns changes that will be made by the deployment if executed at the scope of the tenant + group. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._what_if_at_tenant_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def export_template_at_tenant_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExportResult" + """Exports the template used for specified deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_tenant_scope( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentListResult"] + """Get all the deployments at the tenant scope. + + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers/Microsoft.Resources/deployments/'} # type: ignore + + def _delete_at_management_group_scope_initial( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_delete_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def check_existence_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether the deployment exists. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def _create_or_update_at_management_group_scope_initial( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_create_or_update_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentExtended"] + """Deploys resources at management group scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def get_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + """Gets a deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def cancel_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + def _validate_at_management_group_scope_initial( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def begin_validate_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def _what_if_at_management_group_scope_initial( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_management_group_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ScopedDeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_management_group_scope_initial.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def begin_what_if_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + parameters, # type: "_models.ScopedDeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] + """Returns changes that will be made by the deployment if executed at the scope of the management + group. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ScopedDeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._what_if_at_management_group_scope_initial( + group_id=group_id, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def export_template_at_management_group_scope( + self, + group_id, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExportResult" + """Exports the template used for specified deployment. + + :param group_id: The management group ID. + :type group_id: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_management_group_scope( + self, + group_id, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentListResult"] + """Get all the deployments for a management group. + + :param group_id: The management group ID. + :type group_id: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/Microsoft.Resources/deployments/'} # type: ignore + + def _delete_at_subscription_scope_initial( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_delete_at_subscription_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. This is an asynchronous operation that + returns a status of 202 until the template deployment is successfully deleted. The Location + response header contains the URI that is used to obtain the status of the process. While the + process is running, a call to the URI in the Location header returns a status of 202. When the + process finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_at_subscription_scope_initial( + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def check_existence_at_subscription_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether the deployment exists. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def _create_or_update_at_subscription_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_create_or_update_at_subscription_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentExtended"] + """Deploys resources at subscription scope. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def get_at_subscription_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + """Gets a deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def cancel_at_subscription_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resources partially + deployed. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + def _validate_at_subscription_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def begin_validate_at_subscription_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def _what_if_at_subscription_scope_initial( + self, + deployment_name, # type: str + parameters, # type: "_models.DeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_at_subscription_scope_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_at_subscription_scope_initial.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def begin_what_if_at_subscription_scope( + self, + deployment_name, # type: str + parameters, # type: "_models.DeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] + """Returns changes that will be made by the deployment if executed at the scope of the + subscription. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to What If. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._what_if_at_subscription_scope_initial( + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def export_template_at_subscription_scope( + self, + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExportResult" + """Exports the template used for specified deployment. + + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_at_subscription_scope( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentListResult"] + """Get all the deployments for a subscription. + + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_subscription_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_subscription_scope.metadata = {'url': '/subscriptions/{subscriptionId}/providers/Microsoft.Resources/deployments/'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a deployment from the deployment history. + + A template deployment that is currently running cannot be deleted. Deleting a template + deployment removes the associated deployment operations. Deleting a template deployment does + not affect the state of the resource group. This is an asynchronous operation that returns a + status of 202 until the template deployment is successfully deleted. The Location response + header contains the URI that is used to obtain the status of the process. While the process is + running, a call to the URI in the Location header returns a status of 202. When the process + finishes, the URI in the Location header returns a status of 204 on success. If the + asynchronous request failed, the URI in the Location header returns an error-level status code. + + :param resource_group_name: The name of the resource group with the deployment to delete. The + name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def check_existence( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether the deployment exists. + + :param resource_group_name: The name of the resource group with the deployment to check. The + name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentExtended"] + """Deploys resources to a resource group. + + You can provide the template and parameters directly in the request or link to JSON files. + + :param resource_group_name: The name of the resource group to deploy the resources to. The name + is case insensitive. The resource group must already exist. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Additional parameters supplied to the operation. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentExtended or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExtended" + """Gets a deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExtended, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExtended + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExtended"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExtended', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}'} # type: ignore + + def cancel( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Cancels a currently running template deployment. + + You can cancel a deployment only if the provisioningState is Accepted or Running. After the + deployment is canceled, the provisioningState is set to Canceled. Canceling a template + deployment stops the currently running template deployment and leaves the resource group + partially deployed. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.cancel.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + cancel.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/cancel'} # type: ignore + + def _validate_initial( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.DeploymentValidateResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.DeploymentValidateResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'Deployment') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 400]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if response.status_code == 400: + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _validate_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def begin_validate( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.Deployment" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.DeploymentValidateResult"] + """Validates whether the specified template is syntactically correct and will be accepted by Azure + Resource Manager.. + + :param resource_group_name: The name of the resource group the template will be deployed to. + The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.Deployment + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either DeploymentValidateResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentValidateResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentValidateResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('DeploymentValidateResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/validate'} # type: ignore + + def _what_if_initial( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.DeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.WhatIfOperationResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.WhatIfOperationResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._what_if_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'DeploymentWhatIf') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + response_headers = {} + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if response.status_code == 202: + response_headers['Location']=self._deserialize('str', response.headers.get('Location')) + response_headers['Retry-After']=self._deserialize('str', response.headers.get('Retry-After')) + + if cls: + return cls(pipeline_response, deserialized, response_headers) + + return deserialized + _what_if_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def begin_what_if( + self, + resource_group_name, # type: str + deployment_name, # type: str + parameters, # type: "_models.DeploymentWhatIf" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.WhatIfOperationResult"] + """Returns changes that will be made by the deployment if executed at the scope of the resource + group. + + :param resource_group_name: The name of the resource group the template will be deployed to. + The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :param parameters: Parameters to validate. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentWhatIf + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either WhatIfOperationResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.WhatIfOperationResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.WhatIfOperationResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._what_if_initial( + resource_group_name=resource_group_name, + deployment_name=deployment_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('WhatIfOperationResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_what_if.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/whatIf'} # type: ignore + + def export_template( + self, + resource_group_name, # type: str + deployment_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.DeploymentExportResult" + """Exports the template used for specified deployment. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param deployment_name: The name of the deployment. + :type deployment_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: DeploymentExportResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentExportResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentExportResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.export_template.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'deploymentName': self._serialize.url("deployment_name", deployment_name, 'str', max_length=64, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('DeploymentExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + export_template.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/{deploymentName}/exportTemplate'} # type: ignore + + def list_by_resource_group( + self, + resource_group_name, # type: str + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.DeploymentListResult"] + """Get all the deployments for a resource group. + + :param resource_group_name: The name of the resource group with the deployments to get. The + name is case insensitive. + :type resource_group_name: str + :param filter: The filter to apply on the operation. For example, you can use + $filter=provisioningState eq '{state}'. + :type filter: str + :param top: The number of results to get. If null is passed, returns all deployments. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either DeploymentListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.DeploymentListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.DeploymentListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('DeploymentListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Resources/deployments/'} # type: ignore + + def calculate_template_hash( + self, + template, # type: object + **kwargs # type: Any + ): + # type: (...) -> "_models.TemplateHashResult" + """Calculate the hash of the given template. + + :param template: The template provided to calculate hash. + :type template: object + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TemplateHashResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TemplateHashResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateHashResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.calculate_template_hash.metadata['url'] # type: ignore + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(template, 'object') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TemplateHashResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + calculate_template_hash.metadata = {'url': '/providers/Microsoft.Resources/calculateTemplateHash'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_operations.py new file mode 100644 index 000000000000..ac983f0b63dd --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_operations.py @@ -0,0 +1,109 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class Operations(object): + """Operations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.OperationListResult"] + """Lists all of the available Microsoft.Resources REST API operations. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either OperationListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.OperationListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('OperationListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/providers/Microsoft.Resources/operations'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_provider_resource_types_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_provider_resource_types_operations.py new file mode 100644 index 000000000000..8155c82d7029 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_provider_resource_types_operations.py @@ -0,0 +1,106 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ProviderResourceTypesOperations(object): + """ProviderResourceTypesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list( + self, + resource_provider_namespace, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.ProviderResourceTypeListResult" + """List the resource types for a specified resource provider. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ProviderResourceTypeListResult, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ProviderResourceTypeListResult + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderResourceTypeListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ProviderResourceTypeListResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/resourceTypes'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_providers_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_providers_operations.py new file mode 100644 index 000000000000..567794b0732a --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_providers_operations.py @@ -0,0 +1,486 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ProvidersOperations(object): + """ProvidersOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def unregister( + self, + resource_provider_namespace, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Provider" + """Unregisters a subscription from a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to unregister. + :type resource_provider_namespace: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.unregister.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + unregister.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/unregister'} # type: ignore + + def register_at_management_group_scope( + self, + resource_provider_namespace, # type: str + group_id, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Registers a management group with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :param group_id: The management group ID. + :type group_id: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.register_at_management_group_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'groupId': self._serialize.url("group_id", group_id, 'str', max_length=90, min_length=1), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + register_at_management_group_scope.metadata = {'url': '/providers/Microsoft.Management/managementGroups/{groupId}/providers/{resourceProviderNamespace}/register'} # type: ignore + + def register( + self, + resource_provider_namespace, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.Provider" + """Registers a subscription with a resource provider. + + :param resource_provider_namespace: The namespace of the resource provider to register. + :type resource_provider_namespace: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.register.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.post(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + register.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}/register'} # type: ignore + + def list( + self, + top=None, # type: Optional[int] + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProviderListResult"] + """Gets all resource providers for a subscription. + + :param top: The number of results to return. If null is passed returns all deployments. + :type top: int + :param expand: The properties to include in the results. For example, use &$expand=metadata in + the query string to retrieve resource provider metadata. To include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProviderListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/providers'} # type: ignore + + def list_at_tenant_scope( + self, + top=None, # type: Optional[int] + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ProviderListResult"] + """Gets all resource providers for the tenant. + + :param top: The number of results to return. If null is passed returns all providers. + :type top: int + :param expand: The properties to include in the results. For example, use &$expand=metadata in + the query string to retrieve resource provider metadata. To include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ProviderListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ProviderListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ProviderListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_at_tenant_scope.metadata['url'] # type: ignore + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ProviderListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_at_tenant_scope.metadata = {'url': '/providers'} # type: ignore + + def get( + self, + resource_provider_namespace, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.Provider" + """Gets the specified resource provider. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/providers/{resourceProviderNamespace}'} # type: ignore + + def get_at_tenant_scope( + self, + resource_provider_namespace, # type: str + expand=None, # type: Optional[str] + **kwargs # type: Any + ): + # type: (...) -> "_models.Provider" + """Gets the specified resource provider at the tenant level. + + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param expand: The $expand query parameter. For example, to include property aliases in + response, use $expand=resourceTypes/aliases. + :type expand: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: Provider, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.Provider + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.Provider"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_tenant_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('Provider', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_tenant_scope.metadata = {'url': '/providers/{resourceProviderNamespace}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resource_groups_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resource_groups_operations.py new file mode 100644 index 000000000000..34e07247739c --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resource_groups_operations.py @@ -0,0 +1,602 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ResourceGroupsOperations(object): + """ResourceGroupsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def check_existence( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether a resource group exists. + + :param resource_group_name: The name of the resource group to check. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def create_or_update( + self, + resource_group_name, # type: str + parameters, # type: "_models.ResourceGroup" + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceGroup" + """Creates or updates a resource group. + + :param resource_group_name: The name of the resource group to create or update. Can include + alphanumeric, underscore, parentheses, hyphen, period (except at end), and Unicode characters + that match the allowed characters. + :type resource_group_name: str + :param parameters: Parameters supplied to the create or update a resource group. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourceGroup') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a resource group. + + When you delete a resource group, all of its resources are also deleted. Deleting a resource + group deletes all of its template deployments and currently stored operations. + + :param resource_group_name: The name of the resource group to delete. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceGroup" + """Gets a resource group. + + :param resource_group_name: The name of the resource group to get. The name is case + insensitive. + :type resource_group_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def update( + self, + resource_group_name, # type: str + parameters, # type: "_models.ResourceGroupPatchable" + **kwargs # type: Any + ): + # type: (...) -> "_models.ResourceGroup" + """Updates a resource group. + + Resource groups can be updated through a simple PATCH operation to a group address. The format + of the request is the same as that for creating a resource group. If a field is unspecified, + the current value is retained. + + :param resource_group_name: The name of the resource group to update. The name is case + insensitive. + :type resource_group_name: str + :param parameters: Parameters supplied to update a resource group. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupPatchable + :keyword callable cls: A custom type or function that will be passed the direct response + :return: ResourceGroup, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroup + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroup"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourceGroupPatchable') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('ResourceGroup', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}'} # type: ignore + + def _export_template_initial( + self, + resource_group_name, # type: str + parameters, # type: "_models.ExportTemplateRequest" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.ResourceGroupExportResult"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.ResourceGroupExportResult"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._export_template_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ExportTemplateRequest') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('ResourceGroupExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _export_template_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/exportTemplate'} # type: ignore + + def begin_export_template( + self, + resource_group_name, # type: str + parameters, # type: "_models.ExportTemplateRequest" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.ResourceGroupExportResult"] + """Captures the specified resource group as a template. + + :param resource_group_name: The name of the resource group. The name is case insensitive. + :type resource_group_name: str + :param parameters: Parameters for exporting the template. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ExportTemplateRequest + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either ResourceGroupExportResult or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupExportResult] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupExportResult"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._export_template_initial( + resource_group_name=resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('ResourceGroupExportResult', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, lro_options={'final-state-via': 'location'}, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_export_template.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/exportTemplate'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceGroupListResult"] + """Gets all the resource groups for a subscription. + + :param filter: The filter to apply on the operation.:code:`
`:code:`
`You can filter by + tag names and values. For example, to filter for a tag name and value, use $filter=tagName eq + 'tag1' and tagValue eq 'Value1'. + :type filter: str + :param top: The number of results to return. If null is passed, returns all resource groups. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceGroupListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceGroupListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceGroupListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceGroupListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resources_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resources_operations.py new file mode 100644 index 000000000000..b0ecec9cd94f --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_resources_operations.py @@ -0,0 +1,1553 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.core.polling import LROPoller, NoPolling, PollingMethod +from azure.mgmt.core.exceptions import ARMErrorFormat +from azure.mgmt.core.polling.arm_polling import ARMPolling + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class ResourcesOperations(object): + """ResourcesOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def list_by_resource_group( + self, + resource_group_name, # type: str + filter=None, # type: Optional[str] + expand=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceListResult"] + """Get all the resources for a resource group. + + :param resource_group_name: The resource group with the resources to get. + :type resource_group_name: str + :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you + can use for eq (equals) or ne (not equals) are: location, resourceType, name, resourceGroup, + identity, identity/principalId, plan, plan/publisher, plan/product, plan/name, plan/version, + and plan/promotionCode.:code:`
`:code:`
`For example, to filter by a resource type, use: + $filter=resourceType eq 'Microsoft.Network/virtualNetworks':code:`
`:code:`
`You can use + substringof(value, property) in the filter. The properties you can use for substring are: name + and resourceGroup.:code:`
`:code:`
`For example, to get all resources with 'demo' + anywhere in the name, use: $filter=substringof('demo', name):code:`
`:code:`
`You can + link more than one substringof together by adding and/or operators.:code:`
`:code:`
`You + can filter by tag names and values. For example, to filter for a tag name and value, use + $filter=tagName eq 'tag1' and tagValue eq 'Value1'. When you filter by a tag name and value, + the tags for each resource are not returned in the results.:code:`
`:code:`
`You can use + some properties together when filtering. The combinations you can use are: substringof and/or + resourceType, plan and plan/publisher and plan/name, identity and identity/principalId. + :type filter: str + :param expand: Comma-separated list of additional properties to be included in the response. + Valid values include ``createdTime``\ , ``changedTime`` and ``provisioningState``. For example, + ``$expand=createdTime,changedTime``. + :type expand: str + :param top: The number of results to return. If null is passed, returns all resources. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list_by_resource_group.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list_by_resource_group.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/resources'} # type: ignore + + def _move_resources_initial( + self, + source_resource_group_name, # type: str + parameters, # type: "_models.ResourcesMoveInfo" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._move_resources_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourcesMoveInfo') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _move_resources_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/moveResources'} # type: ignore + + def begin_move_resources( + self, + source_resource_group_name, # type: str + parameters, # type: "_models.ResourcesMoveInfo" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Moves resources from one resource group to another resource group. + + The resources to move must be in the same source resource group. The target resource group may + be in a different subscription. When moving resources, both the source group and the target + group are locked for the duration of the operation. Write and delete operations are blocked on + the groups until the move completes. + + :param source_resource_group_name: The name of the resource group containing the resources to + move. + :type source_resource_group_name: str + :param parameters: Parameters for moving resources. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourcesMoveInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._move_resources_initial( + source_resource_group_name=source_resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_move_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/moveResources'} # type: ignore + + def _validate_move_resources_initial( + self, + source_resource_group_name, # type: str + parameters, # type: "_models.ResourcesMoveInfo" + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._validate_move_resources_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'ResourcesMoveInfo') + body_content_kwargs['content'] = body_content + request = self._client.post(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _validate_move_resources_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/validateMoveResources'} # type: ignore + + def begin_validate_move_resources( + self, + source_resource_group_name, # type: str + parameters, # type: "_models.ResourcesMoveInfo" + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Validates whether resources can be moved from one resource group to another resource group. + + This operation checks whether the specified resources can be moved to the target. The resources + to move must be in the same source resource group. The target resource group may be in a + different subscription. If validation succeeds, it returns HTTP response code 204 (no content). + If validation fails, it returns HTTP response code 409 (Conflict) with an error message. + Retrieve the URL in the Location header value to check the result of the long-running + operation. + + :param source_resource_group_name: The name of the resource group containing the resources to + validate for move. + :type source_resource_group_name: str + :param parameters: Parameters for moving resources. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.ResourcesMoveInfo + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._validate_move_resources_initial( + source_resource_group_name=source_resource_group_name, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'sourceResourceGroupName': self._serialize.url("source_resource_group_name", source_resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_validate_move_resources.metadata = {'url': '/subscriptions/{subscriptionId}/resourceGroups/{sourceResourceGroupName}/validateMoveResources'} # type: ignore + + def list( + self, + filter=None, # type: Optional[str] + expand=None, # type: Optional[str] + top=None, # type: Optional[int] + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.ResourceListResult"] + """Get all the resources in a subscription. + + :param filter: The filter to apply on the operation.:code:`
`:code:`
`The properties you + can use for eq (equals) or ne (not equals) are: location, resourceType, name, resourceGroup, + identity, identity/principalId, plan, plan/publisher, plan/product, plan/name, plan/version, + and plan/promotionCode.:code:`
`:code:`
`For example, to filter by a resource type, use: + $filter=resourceType eq 'Microsoft.Network/virtualNetworks':code:`
`:code:`
`You can use + substringof(value, property) in the filter. The properties you can use for substring are: name + and resourceGroup.:code:`
`:code:`
`For example, to get all resources with 'demo' + anywhere in the name, use: $filter=substringof('demo', name):code:`
`:code:`
`You can + link more than one substringof together by adding and/or operators.:code:`
`:code:`
`You + can filter by tag names and values. For example, to filter for a tag name and value, use + $filter=tagName eq 'tag1' and tagValue eq 'Value1'. When you filter by a tag name and value, + the tags for each resource are not returned in the results.:code:`
`:code:`
`You can use + some properties together when filtering. The combinations you can use are: substringof and/or + resourceType, plan and plan/publisher and plan/name, identity and identity/principalId. + :type filter: str + :param expand: Comma-separated list of additional properties to be included in the response. + Valid values include ``createdTime``\ , ``changedTime`` and ``provisioningState``. For example, + ``$expand=createdTime,changedTime``. + :type expand: str + :param top: The number of results to return. If null is passed, returns all resource groups. + :type top: int + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either ResourceListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.ResourceListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.ResourceListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + if filter is not None: + query_parameters['$filter'] = self._serialize.query("filter", filter, 'str') + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') + if top is not None: + query_parameters['$top'] = self._serialize.query("top", top, 'int') + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('ResourceListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/resources'} # type: ignore + + def check_existence( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks whether a resource exists. + + :param resource_group_name: The name of the resource group containing the resource to check. + The name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The resource provider of the resource to check. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type. + :type resource_type: str + :param resource_name: The name of the resource to check whether it exists. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.check_existence.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def _delete_initial( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self._delete_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def begin_delete( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a resource. + + :param resource_group_name: The name of the resource group that contains the resource to + delete. The name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type. + :type resource_type: str + :param resource_name: The name of the resource to delete. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def _create_or_update_initial( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def begin_create_or_update( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GenericResource"] + """Creates a resource. + + :param resource_group_name: The name of the resource group for the resource. The name is case + insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource to create. + :type resource_type: str + :param resource_name: The name of the resource to create. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Parameters for creating or updating the resource. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def _update_initial( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_initial.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def begin_update( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GenericResource"] + """Updates a resource. + + :param resource_group_name: The name of the resource group for the resource. The name is case + insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource to update. + :type resource_type: str + :param resource_name: The name of the resource to update. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Parameters for updating the resource. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._update_initial( + resource_group_name=resource_group_name, + resource_provider_namespace=resource_provider_namespace, + parent_resource_path=parent_resource_path, + resource_type=resource_type, + resource_name=resource_name, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_update.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def get( + self, + resource_group_name, # type: str + resource_provider_namespace, # type: str + parent_resource_path, # type: str + resource_type, # type: str + resource_name, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.GenericResource" + """Gets a resource. + + :param resource_group_name: The name of the resource group containing the resource to get. The + name is case insensitive. + :type resource_group_name: str + :param resource_provider_namespace: The namespace of the resource provider. + :type resource_provider_namespace: str + :param parent_resource_path: The parent resource identity. + :type parent_resource_path: str + :param resource_type: The resource type of the resource. + :type resource_type: str + :param resource_name: The name of the resource to get. + :type resource_name: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenericResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.get.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceGroupName': self._serialize.url("resource_group_name", resource_group_name, 'str', max_length=90, min_length=1, pattern=r'^[-\w\._\(\)]+$'), + 'resourceProviderNamespace': self._serialize.url("resource_provider_namespace", resource_provider_namespace, 'str'), + 'parentResourcePath': self._serialize.url("parent_resource_path", parent_resource_path, 'str', skip_quote=True), + 'resourceType': self._serialize.url("resource_type", resource_type, 'str', skip_quote=True), + 'resourceName': self._serialize.url("resource_name", resource_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get.metadata = {'url': '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}'} # type: ignore + + def check_existence_by_id( + self, + resource_id, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> bool + """Checks by ID whether a resource exists. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: bool, or the result of cls(response) + :rtype: bool + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.check_existence_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.head(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [204, 404]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + return 200 <= response.status_code <= 299 + check_existence_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + def _delete_by_id_initial( + self, + resource_id, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self._delete_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + _delete_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + def begin_delete_by_id( + self, + resource_id, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> LROPoller[None] + """Deletes a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either None or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[None] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType[None] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._delete_by_id_initial( + resource_id=resource_id, + api_version=api_version, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + if cls: + return cls(pipeline_response, None, {}) + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_delete_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + def _create_or_update_by_id_initial( + self, + resource_id, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._create_or_update_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _create_or_update_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + def begin_create_or_update_by_id( + self, + resource_id, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GenericResource"] + """Create a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Create or update resource parameters. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._create_or_update_by_id_initial( + resource_id=resource_id, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_create_or_update_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + def _update_by_id_initial( + self, + resource_id, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> Optional["_models.GenericResource"] + cls = kwargs.pop('cls', None) # type: ClsType[Optional["_models.GenericResource"]] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self._update_by_id_initial.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'GenericResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 202]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = None + if response.status_code == 200: + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + _update_by_id_initial.metadata = {'url': '/{resourceId}'} # type: ignore + + def begin_update_by_id( + self, + resource_id, # type: str + api_version, # type: str + parameters, # type: "_models.GenericResource" + **kwargs # type: Any + ): + # type: (...) -> LROPoller["_models.GenericResource"] + """Updates a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :param parameters: Update resource parameters. + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :keyword callable cls: A custom type or function that will be passed the direct response + :keyword str continuation_token: A continuation token to restart a poller from a saved state. + :keyword polling: True for ARMPolling, False for no polling, or a + polling object for personal polling strategy + :paramtype polling: bool or ~azure.core.polling.PollingMethod + :keyword int polling_interval: Default waiting time between two polls for LRO operations if no Retry-After header is present. + :return: An instance of LROPoller that returns either GenericResource or the result of cls(response) + :rtype: ~azure.core.polling.LROPoller[~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource] + :raises ~azure.core.exceptions.HttpResponseError: + """ + polling = kwargs.pop('polling', True) # type: Union[bool, PollingMethod] + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + lro_delay = kwargs.pop( + 'polling_interval', + self._config.polling_interval + ) + cont_token = kwargs.pop('continuation_token', None) # type: Optional[str] + if cont_token is None: + raw_result = self._update_by_id_initial( + resource_id=resource_id, + api_version=api_version, + parameters=parameters, + cls=lambda x,y,z: x, + **kwargs + ) + + kwargs.pop('error_map', None) + kwargs.pop('content_type', None) + + def get_long_running_output(pipeline_response): + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + return deserialized + + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + + if polling is True: polling_method = ARMPolling(lro_delay, path_format_arguments=path_format_arguments, **kwargs) + elif polling is False: polling_method = NoPolling() + else: polling_method = polling + if cont_token: + return LROPoller.from_continuation_token( + polling_method=polling_method, + continuation_token=cont_token, + client=self._client, + deserialization_callback=get_long_running_output + ) + else: + return LROPoller(self._client, raw_result, get_long_running_output, polling_method) + begin_update_by_id.metadata = {'url': '/{resourceId}'} # type: ignore + + def get_by_id( + self, + resource_id, # type: str + api_version, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.GenericResource" + """Gets a resource by ID. + + :param resource_id: The fully qualified ID of the resource, including the resource name and + resource type. Use the format, /subscriptions/{guid}/resourceGroups/{resource-group- + name}/{resource-provider-namespace}/{resource-type}/{resource-name}. + :type resource_id: str + :param api_version: The API version to use for the operation. + :type api_version: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: GenericResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.GenericResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.GenericResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + accept = "application/json" + + # Construct URL + url = self.get_by_id.metadata['url'] # type: ignore + path_format_arguments = { + 'resourceId': self._serialize.url("resource_id", resource_id, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('GenericResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_by_id.metadata = {'url': '/{resourceId}'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_tags_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_tags_operations.py new file mode 100644 index 000000000000..0e7358b4f68a --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/operations/_tags_operations.py @@ -0,0 +1,607 @@ +# coding=utf-8 +# -------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# Code generated by Microsoft (R) AutoRest Code Generator. +# Changes may cause incorrect behavior and will be lost if the code is regenerated. +# -------------------------------------------------------------------------- +from typing import TYPE_CHECKING +import warnings + +from azure.core.exceptions import ClientAuthenticationError, HttpResponseError, ResourceExistsError, ResourceNotFoundError, map_error +from azure.core.paging import ItemPaged +from azure.core.pipeline import PipelineResponse +from azure.core.pipeline.transport import HttpRequest, HttpResponse +from azure.mgmt.core.exceptions import ARMErrorFormat + +from .. import models as _models + +if TYPE_CHECKING: + # pylint: disable=unused-import,ungrouped-imports + from typing import Any, Callable, Dict, Generic, Iterable, Optional, TypeVar, Union + + T = TypeVar('T') + ClsType = Optional[Callable[[PipelineResponse[HttpRequest, HttpResponse], T, Dict[str, Any]], Any]] + +class TagsOperations(object): + """TagsOperations operations. + + You should not instantiate this class directly. Instead, you should create a Client instance that + instantiates it for you and attaches it as an attribute. + + :ivar models: Alias to model classes used in this operation group. + :type models: ~azure.mgmt.resource.resources.v2020_10_01.models + :param client: Client for service requests. + :param config: Configuration of service client. + :param serializer: An object model serializer. + :param deserializer: An object model deserializer. + """ + + models = _models + + def __init__(self, client, config, serializer, deserializer): + self._client = client + self._serialize = serializer + self._deserialize = deserializer + self._config = config + + def delete_value( + self, + tag_name, # type: str + tag_value, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a predefined tag value for a predefined tag name. + + This operation allows deleting a value from the list of predefined values for an existing + predefined tag name. The value being deleted must not be in use as a tag value for the given + tag name for any resource. + + :param tag_name: The name of the tag. + :type tag_name: str + :param tag_value: The value of the tag to delete. + :type tag_value: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete_value.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'tagValue': self._serialize.url("tag_value", tag_value, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_value.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}/tagValues/{tagValue}'} # type: ignore + + def create_or_update_value( + self, + tag_name, # type: str + tag_value, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.TagValue" + """Creates a predefined value for a predefined tag name. + + This operation allows adding a value to the list of predefined values for an existing + predefined tag name. A tag value can have a maximum of 256 characters. + + :param tag_name: The name of the tag. + :type tag_name: str + :param tag_value: The value of the tag to create. + :type tag_value: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagValue, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagValue + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagValue"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update_value.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'tagValue': self._serialize.url("tag_value", tag_value, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TagValue', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('TagValue', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_value.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}/tagValues/{tagValue}'} # type: ignore + + def create_or_update( + self, + tag_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.TagDetails" + """Creates a predefined tag name. + + This operation allows adding a name to the list of predefined tag names for the given + subscription. A tag name can have a maximum of 512 characters and is case-insensitive. Tag + names cannot have the following prefixes which are reserved for Azure use: 'microsoft', + 'azure', 'windows'. + + :param tag_name: The name of the tag to create. + :type tag_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagDetails, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagDetails + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagDetails"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.create_or_update.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.put(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 201]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if response.status_code == 200: + deserialized = self._deserialize('TagDetails', pipeline_response) + + if response.status_code == 201: + deserialized = self._deserialize('TagDetails', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}'} # type: ignore + + def delete( + self, + tag_name, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes a predefined tag name. + + This operation allows deleting a name from the list of predefined tag names for the given + subscription. The name being deleted must not be in use as a tag name for any resource. All + predefined values for the given name must have already been deleted. + + :param tag_name: The name of the tag. + :type tag_name: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete.metadata['url'] # type: ignore + path_format_arguments = { + 'tagName': self._serialize.url("tag_name", tag_name, 'str'), + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200, 204]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames/{tagName}'} # type: ignore + + def list( + self, + **kwargs # type: Any + ): + # type: (...) -> Iterable["_models.TagsListResult"] + """Gets a summary of tag usage under the subscription. + + This operation performs a union of predefined tags, resource tags, resource group tags and + subscription tags, and returns a summary of usage for each tag name and value under the given + subscription. In case of a large number of tags, this operation may return a previously cached + result. + + :keyword callable cls: A custom type or function that will be passed the direct response + :return: An iterator like instance of either TagsListResult or the result of cls(response) + :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.resources.v2020_10_01.models.TagsListResult] + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsListResult"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + def prepare_request(next_link=None): + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + if not next_link: + # Construct URL + url = self.list.metadata['url'] # type: ignore + path_format_arguments = { + 'subscriptionId': self._serialize.url("self._config.subscription_id", self._config.subscription_id, 'str'), + } + url = self._client.format_url(url, **path_format_arguments) + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + else: + url = next_link + query_parameters = {} # type: Dict[str, Any] + request = self._client.get(url, query_parameters, header_parameters) + return request + + def extract_data(pipeline_response): + deserialized = self._deserialize('TagsListResult', pipeline_response) + list_of_elem = deserialized.value + if cls: + list_of_elem = cls(list_of_elem) + return deserialized.next_link or None, iter(list_of_elem) + + def get_next(next_link=None): + request = prepare_request(next_link) + + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + return pipeline_response + + return ItemPaged( + get_next, extract_data + ) + list.metadata = {'url': '/subscriptions/{subscriptionId}/tagNames'} # type: ignore + + def create_or_update_at_scope( + self, + scope, # type: str + parameters, # type: "_models.TagsResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.TagsResource" + """Creates or updates the entire set of tags on a resource or subscription. + + This operation allows adding or replacing the entire set of tags on the specified resource or + subscription. The specified entity can have a maximum of 50 tags. + + :param scope: The resource scope. + :type scope: str + :param parameters: + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.create_or_update_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'TagsResource') + body_content_kwargs['content'] = body_content + request = self._client.put(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + create_or_update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + def update_at_scope( + self, + scope, # type: str + parameters, # type: "_models.TagsPatchResource" + **kwargs # type: Any + ): + # type: (...) -> "_models.TagsResource" + """Selectively updates the set of tags on a resource or subscription. + + This operation allows replacing, merging or selectively deleting tags on the specified resource + or subscription. The specified entity can have a maximum of 50 tags at the end of the + operation. The 'replace' option replaces the entire set of existing tags with a new set. The + 'merge' option allows adding tags with new names and updating the values of tags with existing + names. The 'delete' option allows selectively deleting tags based on given names or name/value + pairs. + + :param scope: The resource scope. + :type scope: str + :param parameters: + :type parameters: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsPatchResource + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + content_type = kwargs.pop("content_type", "application/json") + accept = "application/json" + + # Construct URL + url = self.update_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Content-Type'] = self._serialize.header("content_type", content_type, 'str') + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + body_content_kwargs = {} # type: Dict[str, Any] + body_content = self._serialize.body(parameters, 'TagsPatchResource') + body_content_kwargs['content'] = body_content + request = self._client.patch(url, query_parameters, header_parameters, **body_content_kwargs) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + update_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + def get_at_scope( + self, + scope, # type: str + **kwargs # type: Any + ): + # type: (...) -> "_models.TagsResource" + """Gets the entire set of tags on a resource or subscription. + + Gets the entire set of tags on a resource or subscription. + + :param scope: The resource scope. + :type scope: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: TagsResource, or the result of cls(response) + :rtype: ~azure.mgmt.resource.resources.v2020_10_01.models.TagsResource + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType["_models.TagsResource"] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.get_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.get(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + deserialized = self._deserialize('TagsResource', pipeline_response) + + if cls: + return cls(pipeline_response, deserialized, {}) + + return deserialized + get_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore + + def delete_at_scope( + self, + scope, # type: str + **kwargs # type: Any + ): + # type: (...) -> None + """Deletes the entire set of tags on a resource or subscription. + + Deletes the entire set of tags on a resource or subscription. + + :param scope: The resource scope. + :type scope: str + :keyword callable cls: A custom type or function that will be passed the direct response + :return: None, or the result of cls(response) + :rtype: None + :raises: ~azure.core.exceptions.HttpResponseError + """ + cls = kwargs.pop('cls', None) # type: ClsType[None] + error_map = { + 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError + } + error_map.update(kwargs.pop('error_map', {})) + api_version = "2020-10-01" + accept = "application/json" + + # Construct URL + url = self.delete_at_scope.metadata['url'] # type: ignore + path_format_arguments = { + 'scope': self._serialize.url("scope", scope, 'str', skip_quote=True), + } + url = self._client.format_url(url, **path_format_arguments) + + # Construct parameters + query_parameters = {} # type: Dict[str, Any] + query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') + + # Construct headers + header_parameters = {} # type: Dict[str, Any] + header_parameters['Accept'] = self._serialize.header("accept", accept, 'str') + + request = self._client.delete(url, query_parameters, header_parameters) + pipeline_response = self._client._pipeline.run(request, stream=False, **kwargs) + response = pipeline_response.http_response + + if response.status_code not in [200]: + map_error(status_code=response.status_code, response=response, error_map=error_map) + raise HttpResponseError(response=response, error_format=ARMErrorFormat) + + if cls: + return cls(pipeline_response, None, {}) + + delete_at_scope.metadata = {'url': '/{scope}/providers/Microsoft.Resources/tags/default'} # type: ignore diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/py.typed b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/py.typed new file mode 100644 index 000000000000..e5aff4f83af8 --- /dev/null +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/resources/v2020_10_01/py.typed @@ -0,0 +1 @@ +# Marker file for PEP 561. \ No newline at end of file diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_operations_mixin.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_operations_mixin.py index 1bce276b8fc8..b9311724fccc 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_operations_mixin.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_operations_mixin.py @@ -26,7 +26,7 @@ class SubscriptionClientOperationsMixin(object): def check_resource_name( self, - resource_name_definition=None, # type: Optional["models.ResourceName"] + resource_name_definition=None, # type: Optional["_models.ResourceName"] **kwargs # type: Any ): """Checks resource name validity. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/aio/_operations_mixin.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/aio/_operations_mixin.py index 79ba7d1cd2dd..c136641097f2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/aio/_operations_mixin.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/aio/_operations_mixin.py @@ -22,9 +22,9 @@ class SubscriptionClientOperationsMixin(object): async def check_resource_name( self, - resource_name_definition: Optional["models.ResourceName"] = None, + resource_name_definition: Optional["_models.ResourceName"] = None, **kwargs - ) -> "models.CheckResourceNameResult": + ) -> "_models.CheckResourceNameResult": """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_metadata.json index 82aa0c625bb4..01ce9663a643 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_metadata.json @@ -8,20 +8,21 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true @@ -46,12 +47,12 @@ "operation_mixins": { "check_resource_name" : { "sync": { - "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"models.ResourceName\"]\n **kwargs # type: Any\n):\n", + "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"_models.ResourceName\"]\n **kwargs # type: Any\n):\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "async": { "coroutine": true, - "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"models.CheckResourceNameResult\":\n", + "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"_models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"_models.CheckResourceNameResult\":\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "call": "resource_name_definition" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_subscription_client.py index 4ea5a929ebe6..c81c291aaea3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/_subscription_client.py @@ -53,7 +53,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/_subscription_client.py index 6dd814071c6e..d32ea1bc8bf6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/_subscription_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_operations.py index 79a97b3cff38..a8fac6890b8f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscription_client_operations.py index d9614d6ec24d..e38936146b32 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -22,9 +22,9 @@ class SubscriptionClientOperationsMixin: async def check_resource_name( self, - resource_name_definition: Optional["models.ResourceName"] = None, + resource_name_definition: Optional["_models.ResourceName"] = None, **kwargs - ) -> "models.CheckResourceNameResult": + ) -> "_models.CheckResourceNameResult": """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -38,7 +38,7 @@ async def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -71,7 +71,7 @@ async def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscriptions_operations.py index 3afeddc430bc..f6140982d6f6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class SubscriptionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ def list_locations( self, subscription_id: str, **kwargs - ) -> AsyncIterable["models.LocationListResult"]: + ) -> AsyncIterable["_models.LocationListResult"]: """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -58,7 +58,7 @@ def list_locations( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,7 +117,7 @@ async def get( self, subscription_id: str, **kwargs - ) -> "models.Subscription": + ) -> "_models.Subscription": """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -127,7 +127,7 @@ async def get( :rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def get( def list( self, **kwargs - ) -> AsyncIterable["models.SubscriptionListResult"]: + ) -> AsyncIterable["_models.SubscriptionListResult"]: """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -177,7 +177,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_tenants_operations.py index ee13e72c0e71..2cd9ace83f3f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/aio/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TenantsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.TenantListResult"]: + ) -> AsyncIterable["_models.TenantListResult"]: """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_operations.py index 5ecdee7b607e..e74467ae8609 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscription_client_operations.py index 48bf0371300c..3cd1c3a3c76e 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -26,10 +26,10 @@ class SubscriptionClientOperationsMixin(object): def check_resource_name( self, - resource_name_definition=None, # type: Optional["models.ResourceName"] + resource_name_definition=None, # type: Optional["_models.ResourceName"] **kwargs # type: Any ): - # type: (...) -> "models.CheckResourceNameResult" + # type: (...) -> "_models.CheckResourceNameResult" """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -43,7 +43,7 @@ def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -76,7 +76,7 @@ def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscriptions_operations.py index 97e7851ece63..c8c457fd00b3 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class SubscriptionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def list_locations( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.LocationListResult"] + # type: (...) -> Iterable["_models.LocationListResult"] """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -63,7 +63,7 @@ def list_locations( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -123,7 +123,7 @@ def get( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Subscription" + # type: (...) -> "_models.Subscription" """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -133,7 +133,7 @@ def get( :rtype: ~azure.mgmt.resource.subscriptions.v2016_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.SubscriptionListResult"] + # type: (...) -> Iterable["_models.SubscriptionListResult"] """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -184,7 +184,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_tenants_operations.py index 3a4ec17c755a..4d90432ece48 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2016_06_01/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TenantsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TenantListResult"] + # type: (...) -> Iterable["_models.TenantListResult"] """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2016_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_metadata.json index a9b7fbf364bf..951f787c1ae5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_metadata.json @@ -8,20 +8,21 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true @@ -46,12 +47,12 @@ "operation_mixins": { "check_resource_name" : { "sync": { - "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"models.ResourceName\"]\n **kwargs # type: Any\n):\n", + "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"_models.ResourceName\"]\n **kwargs # type: Any\n):\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "async": { "coroutine": true, - "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"models.CheckResourceNameResult\":\n", + "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"_models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"_models.CheckResourceNameResult\":\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "call": "resource_name_definition" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_subscription_client.py index 8720f19331ad..e69f20a76a4a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/_subscription_client.py @@ -53,7 +53,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/_subscription_client.py index 661f9572726f..21dfc2a09b64 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/_subscription_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_operations.py index 871caa4e83f1..49671f17a2b5 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscription_client_operations.py index 7ef0546f0094..185749db733f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -22,9 +22,9 @@ class SubscriptionClientOperationsMixin: async def check_resource_name( self, - resource_name_definition: Optional["models.ResourceName"] = None, + resource_name_definition: Optional["_models.ResourceName"] = None, **kwargs - ) -> "models.CheckResourceNameResult": + ) -> "_models.CheckResourceNameResult": """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -38,7 +38,7 @@ async def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -71,7 +71,7 @@ async def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscriptions_operations.py index 11a3c2bb503c..fd0dfe094886 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class SubscriptionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ def list_locations( self, subscription_id: str, **kwargs - ) -> AsyncIterable["models.LocationListResult"]: + ) -> AsyncIterable["_models.LocationListResult"]: """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -58,7 +58,7 @@ def list_locations( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,7 +117,7 @@ async def get( self, subscription_id: str, **kwargs - ) -> "models.Subscription": + ) -> "_models.Subscription": """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -127,7 +127,7 @@ async def get( :rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def get( def list( self, **kwargs - ) -> AsyncIterable["models.SubscriptionListResult"]: + ) -> AsyncIterable["_models.SubscriptionListResult"]: """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -177,7 +177,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_tenants_operations.py index 32c40c32f1e6..5d5724c9c7f4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/aio/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TenantsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.TenantListResult"]: + ) -> AsyncIterable["_models.TenantListResult"]: """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_operations.py index a654caa6c062..c99cf978c098 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscription_client_operations.py index f43b9a9a8806..4c93c67e7fa0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -26,10 +26,10 @@ class SubscriptionClientOperationsMixin(object): def check_resource_name( self, - resource_name_definition=None, # type: Optional["models.ResourceName"] + resource_name_definition=None, # type: Optional["_models.ResourceName"] **kwargs # type: Any ): - # type: (...) -> "models.CheckResourceNameResult" + # type: (...) -> "_models.CheckResourceNameResult" """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -43,7 +43,7 @@ def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -76,7 +76,7 @@ def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscriptions_operations.py index 3062a750e691..612fee5574c7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class SubscriptionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def list_locations( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.LocationListResult"] + # type: (...) -> Iterable["_models.LocationListResult"] """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -63,7 +63,7 @@ def list_locations( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -123,7 +123,7 @@ def get( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Subscription" + # type: (...) -> "_models.Subscription" """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -133,7 +133,7 @@ def get( :rtype: ~azure.mgmt.resource.subscriptions.v2018_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.SubscriptionListResult"] + # type: (...) -> Iterable["_models.SubscriptionListResult"] """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -184,7 +184,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_tenants_operations.py index ba68b8c7e4fa..5da05238bbb0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2018_06_01/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TenantsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TenantListResult"] + # type: (...) -> Iterable["_models.TenantListResult"] """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2018_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_metadata.json index eb91cd1a1458..edc966f06952 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_metadata.json @@ -8,20 +8,21 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true @@ -46,12 +47,12 @@ "operation_mixins": { "check_resource_name" : { "sync": { - "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"models.ResourceName\"]\n **kwargs # type: Any\n):\n", + "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"_models.ResourceName\"]\n **kwargs # type: Any\n):\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "async": { "coroutine": true, - "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"models.CheckResourceNameResult\":\n", + "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"_models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"_models.CheckResourceNameResult\":\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "call": "resource_name_definition" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_subscription_client.py index 5d72fa825979..8923aee174f7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/_subscription_client.py @@ -53,7 +53,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/_subscription_client.py index 771cb77eac39..846a1ac3ff0d 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/_subscription_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_operations.py index c2bd4e487d46..b7f336a16620 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscription_client_operations.py index b781a886fdea..74ece9aab0e2 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -22,9 +22,9 @@ class SubscriptionClientOperationsMixin: async def check_resource_name( self, - resource_name_definition: Optional["models.ResourceName"] = None, + resource_name_definition: Optional["_models.ResourceName"] = None, **kwargs - ) -> "models.CheckResourceNameResult": + ) -> "_models.CheckResourceNameResult": """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -38,7 +38,7 @@ async def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -71,7 +71,7 @@ async def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscriptions_operations.py index 3c9d13f4f060..900311d4832b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class SubscriptionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ def list_locations( self, subscription_id: str, **kwargs - ) -> AsyncIterable["models.LocationListResult"]: + ) -> AsyncIterable["_models.LocationListResult"]: """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -58,7 +58,7 @@ def list_locations( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,7 +117,7 @@ async def get( self, subscription_id: str, **kwargs - ) -> "models.Subscription": + ) -> "_models.Subscription": """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -127,7 +127,7 @@ async def get( :rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def get( def list( self, **kwargs - ) -> AsyncIterable["models.SubscriptionListResult"]: + ) -> AsyncIterable["_models.SubscriptionListResult"]: """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -177,7 +177,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_tenants_operations.py index 1cf2211d3bd2..5f18815b8c94 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/aio/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TenantsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.TenantListResult"]: + ) -> AsyncIterable["_models.TenantListResult"]: """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_operations.py index 653786462442..be368fc44470 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscription_client_operations.py index 108314fb8f80..2fbb0539fc11 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -26,10 +26,10 @@ class SubscriptionClientOperationsMixin(object): def check_resource_name( self, - resource_name_definition=None, # type: Optional["models.ResourceName"] + resource_name_definition=None, # type: Optional["_models.ResourceName"] **kwargs # type: Any ): - # type: (...) -> "models.CheckResourceNameResult" + # type: (...) -> "_models.CheckResourceNameResult" """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -43,7 +43,7 @@ def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -76,7 +76,7 @@ def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscriptions_operations.py index 964156397dc4..c104334b4c8a 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class SubscriptionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def list_locations( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.LocationListResult"] + # type: (...) -> Iterable["_models.LocationListResult"] """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -63,7 +63,7 @@ def list_locations( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -123,7 +123,7 @@ def get( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Subscription" + # type: (...) -> "_models.Subscription" """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -133,7 +133,7 @@ def get( :rtype: ~azure.mgmt.resource.subscriptions.v2019_06_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.SubscriptionListResult"] + # type: (...) -> Iterable["_models.SubscriptionListResult"] """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -184,7 +184,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_tenants_operations.py index fe5804617e2b..d2bf4bfe45f4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_06_01/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TenantsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TenantListResult"] + # type: (...) -> Iterable["_models.TenantListResult"] """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_06_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_metadata.json index f156f87e3526..0cf2d7e42358 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_metadata.json @@ -8,20 +8,21 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true @@ -46,12 +47,12 @@ "operation_mixins": { "check_resource_name" : { "sync": { - "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"models.ResourceName\"]\n **kwargs # type: Any\n):\n", + "signature": "def check_resource_name(\n self,\n resource_name_definition=None, # type: Optional[\"_models.ResourceName\"]\n **kwargs # type: Any\n):\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "async": { "coroutine": true, - "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"models.CheckResourceNameResult\":\n", + "signature": "async def check_resource_name(\n self,\n resource_name_definition: Optional[\"_models.ResourceName\"] = None,\n **kwargs\n) -\u003e \"_models.CheckResourceNameResult\":\n", "doc": "\"\"\"Checks resource name validity.\n\nA resource name is valid if it is not a reserved word, does not contains a reserved word and\ndoes not start with a reserved word.\n\n:param resource_name_definition: Resource object with values for resource name and resource\n type.\n:type resource_name_definition: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.ResourceName\n:keyword callable cls: A custom type or function that will be passed the direct response\n:return: CheckResourceNameResult, or the result of cls(response)\n:rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.CheckResourceNameResult\n:raises: ~azure.core.exceptions.HttpResponseError\n\"\"\"" }, "call": "resource_name_definition" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_subscription_client.py index c5a657890a89..e10cb9bcdb29 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/_subscription_client.py @@ -53,7 +53,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/_subscription_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/_subscription_client.py index aa1e8a2bdfea..5a884aa2b5a8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/_subscription_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/_subscription_client.py @@ -50,7 +50,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.operations = Operations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_operations.py index d2311754ea16..908806a4a172 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class Operations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.OperationListResult"]: + ) -> AsyncIterable["_models.OperationListResult"]: """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscription_client_operations.py index 679c2ab2fd56..8c1ff60e5aae 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -22,9 +22,9 @@ class SubscriptionClientOperationsMixin: async def check_resource_name( self, - resource_name_definition: Optional["models.ResourceName"] = None, + resource_name_definition: Optional["_models.ResourceName"] = None, **kwargs - ) -> "models.CheckResourceNameResult": + ) -> "_models.CheckResourceNameResult": """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -38,7 +38,7 @@ async def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -71,7 +71,7 @@ async def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscriptions_operations.py index 95883e6835da..dd3a18b1d83b 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class SubscriptionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,7 +45,7 @@ def list_locations( self, subscription_id: str, **kwargs - ) -> AsyncIterable["models.LocationListResult"]: + ) -> AsyncIterable["_models.LocationListResult"]: """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -58,7 +58,7 @@ def list_locations( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -117,7 +117,7 @@ async def get( self, subscription_id: str, **kwargs - ) -> "models.Subscription": + ) -> "_models.Subscription": """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -127,7 +127,7 @@ async def get( :rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -169,7 +169,7 @@ async def get( def list( self, **kwargs - ) -> AsyncIterable["models.SubscriptionListResult"]: + ) -> AsyncIterable["_models.SubscriptionListResult"]: """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -177,7 +177,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_tenants_operations.py index 2007d467330e..b53010ae50b7 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/aio/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TenantsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -44,7 +44,7 @@ def __init__(self, client, config, serializer, deserializer) -> None: def list( self, **kwargs - ) -> AsyncIterable["models.TenantListResult"]: + ) -> AsyncIterable["_models.TenantListResult"]: """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -52,7 +52,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_operations.py index 3cbc9139d460..199a5274f6af 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class Operations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.OperationListResult"] + # type: (...) -> Iterable["_models.OperationListResult"] """Lists all of the available Microsoft.Resources REST API operations. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.OperationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.OperationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.OperationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscription_client_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscription_client_operations.py index bef87f0e3526..e99863785958 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscription_client_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscription_client_operations.py @@ -13,7 +13,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -26,10 +26,10 @@ class SubscriptionClientOperationsMixin(object): def check_resource_name( self, - resource_name_definition=None, # type: Optional["models.ResourceName"] + resource_name_definition=None, # type: Optional["_models.ResourceName"] **kwargs # type: Any ): - # type: (...) -> "models.CheckResourceNameResult" + # type: (...) -> "_models.CheckResourceNameResult" """Checks resource name validity. A resource name is valid if it is not a reserved word, does not contains a reserved word and @@ -43,7 +43,7 @@ def check_resource_name( :rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.CheckResourceNameResult :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.CheckResourceNameResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.CheckResourceNameResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -76,7 +76,7 @@ def check_resource_name( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.ErrorResponse, response) + error = self._deserialize(_models.ErrorResponse, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('CheckResourceNameResult', pipeline_response) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscriptions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscriptions_operations.py index 28409e8836c1..44a1d6b996b4 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscriptions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_subscriptions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class SubscriptionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,7 +50,7 @@ def list_locations( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.LocationListResult"] + # type: (...) -> Iterable["_models.LocationListResult"] """Gets all available geo-locations. This operation provides all the locations that are available for resource providers; however, @@ -63,7 +63,7 @@ def list_locations( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.LocationListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.LocationListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.LocationListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -123,7 +123,7 @@ def get( subscription_id, # type: str **kwargs # type: Any ): - # type: (...) -> "models.Subscription" + # type: (...) -> "_models.Subscription" """Gets details about a specified subscription. :param subscription_id: The ID of the target subscription. @@ -133,7 +133,7 @@ def get( :rtype: ~azure.mgmt.resource.subscriptions.v2019_11_01.models.Subscription :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.Subscription"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.Subscription"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -176,7 +176,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.SubscriptionListResult"] + # type: (...) -> Iterable["_models.SubscriptionListResult"] """Gets all subscriptions for a tenant. :keyword callable cls: A custom type or function that will be passed the direct response @@ -184,7 +184,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.SubscriptionListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.SubscriptionListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.SubscriptionListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_tenants_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_tenants_operations.py index 70e257db0f17..8de73b1b9882 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_tenants_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/subscriptions/v2019_11_01/operations/_tenants_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TenantsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,7 +49,7 @@ def list( self, **kwargs # type: Any ): - # type: (...) -> Iterable["models.TenantListResult"] + # type: (...) -> Iterable["_models.TenantListResult"] """Gets the tenants for your account. :keyword callable cls: A custom type or function that will be passed the direct response @@ -57,7 +57,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.subscriptions.v2019_11_01.models.TenantListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TenantListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TenantListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/_version.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/_version.py index a30a458f8b5b..04e1465e7930 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/_version.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/_version.py @@ -5,4 +5,4 @@ # license information. # -------------------------------------------------------------------------- -VERSION = "0.1.0" \ No newline at end of file +VERSION = "16.0.0" diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_metadata.json b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_metadata.json index 3c959500db35..328ccbc408ad 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_metadata.json +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_metadata.json @@ -8,32 +8,33 @@ "base_url": "\u0027https://management.azure.com\u0027", "custom_base_url": null, "azure_arm": true, - "has_lro_operations": false + "has_lro_operations": false, + "client_side_validation": true }, "global_parameters": { - "sync_method": { + "sync": { "credential": { - "method_signature": "credential, # type: \"TokenCredential\"", + "signature": "credential, # type: \"TokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials.TokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true } }, - "async_method": { + "async": { "credential": { - "method_signature": "credential, # type: \"AsyncTokenCredential\"", + "signature": "credential, # type: \"AsyncTokenCredential\"", "description": "Credential needed for the client to connect to Azure.", "docstring_type": "~azure.core.credentials_async.AsyncTokenCredential", "required": true }, "subscription_id": { - "method_signature": "subscription_id, # type: str", + "signature": "subscription_id, # type: str", "description": "Subscription Id which forms part of the URI for every service call.", "docstring_type": "str", "required": true diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_template_specs_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_template_specs_client.py index 5b45581830d3..fa643184eb14 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_template_specs_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/_template_specs_client.py @@ -52,7 +52,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.template_specs = TemplateSpecsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/_template_specs_client.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/_template_specs_client.py index 5d412b17b6fc..2f4ef973fa4f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/_template_specs_client.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/_template_specs_client.py @@ -49,7 +49,6 @@ def __init__( client_models = {k: v for k, v in models.__dict__.items() if isinstance(v, type)} self._serialize = Serializer(client_models) - self._serialize.client_side_validation = False self._deserialize = Deserializer(client_models) self.template_specs = TemplateSpecsOperations( diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_spec_versions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_spec_versions_operations.py index 9653e3c04882..2dd54422ebe6 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_spec_versions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_spec_versions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TemplateSpecVersionsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -46,9 +46,9 @@ async def create_or_update( resource_group_name: str, template_spec_name: str, template_spec_version: str, - template_spec_version_model: "models.TemplateSpecVersion", + template_spec_version_model: "_models.TemplateSpecVersion", **kwargs - ) -> "models.TemplateSpecVersion": + ) -> "_models.TemplateSpecVersion": """Creates or updates a Template Spec version. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -64,7 +64,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -101,7 +101,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -121,9 +121,9 @@ async def update( resource_group_name: str, template_spec_name: str, template_spec_version: str, - template_spec_version_update_model: Optional["models.TemplateSpecVersionUpdateModel"] = None, + template_spec_version_update_model: Optional["_models.TemplateSpecVersionUpdateModel"] = None, **kwargs - ) -> "models.TemplateSpecVersion": + ) -> "_models.TemplateSpecVersion": """Updates Template Spec Version tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -140,7 +140,7 @@ async def update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -180,7 +180,7 @@ async def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpecVersion', pipeline_response) @@ -197,7 +197,7 @@ async def get( template_spec_name: str, template_spec_version: str, **kwargs - ) -> "models.TemplateSpecVersion": + ) -> "_models.TemplateSpecVersion": """Gets a Template Spec version from a specific Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -211,7 +211,7 @@ async def get( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -243,7 +243,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpecVersion', pipeline_response) @@ -307,7 +307,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -320,7 +320,7 @@ def list( resource_group_name: str, template_spec_name: str, **kwargs - ) -> AsyncIterable["models.TemplateSpecVersionsListResult"]: + ) -> AsyncIterable["_models.TemplateSpecVersionsListResult"]: """Lists all the Template Spec versions in the specified Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -332,7 +332,7 @@ def list( :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersionsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersionsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersionsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -379,7 +379,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_specs_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_specs_operations.py index 6f89fa6b1928..5f4ee6d544d8 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_specs_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/aio/operations/_template_specs_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import AsyncHttpResponse, HttpRequest from azure.mgmt.core.exceptions import ARMErrorFormat -from ... import models +from ... import models as _models T = TypeVar('T') ClsType = Optional[Callable[[PipelineResponse[HttpRequest, AsyncHttpResponse], T, Dict[str, Any]], Any]] @@ -33,7 +33,7 @@ class TemplateSpecsOperations: :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer) -> None: self._client = client @@ -45,9 +45,9 @@ async def create_or_update( self, resource_group_name: str, template_spec_name: str, - template_spec: "models.TemplateSpec", + template_spec: "_models.TemplateSpec", **kwargs - ) -> "models.TemplateSpec": + ) -> "_models.TemplateSpec": """Creates or updates a Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -61,7 +61,7 @@ async def create_or_update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -97,7 +97,7 @@ async def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -116,9 +116,9 @@ async def update( self, resource_group_name: str, template_spec_name: str, - template_spec: Optional["models.TemplateSpecUpdateModel"] = None, + template_spec: Optional["_models.TemplateSpecUpdateModel"] = None, **kwargs - ) -> "models.TemplateSpec": + ) -> "_models.TemplateSpec": """Updates Template Spec tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -132,7 +132,7 @@ async def update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -171,7 +171,7 @@ async def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpec', pipeline_response) @@ -186,20 +186,24 @@ async def get( self, resource_group_name: str, template_spec_name: str, + expand: Optional[Union[str, "_models.TemplateSpecExpandKind"]] = None, **kwargs - ) -> "models.TemplateSpec": + ) -> "_models.TemplateSpec": """Gets a Template Spec with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. :type resource_group_name: str :param template_spec_name: Name of the Template Spec. :type template_spec_name: str + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: TemplateSpec, or the result of cls(response) :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -218,6 +222,8 @@ async def get( # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') # Construct headers @@ -230,7 +236,7 @@ async def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpec', pipeline_response) @@ -290,7 +296,7 @@ async def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -300,16 +306,20 @@ async def delete( def list_by_subscription( self, + expand: Optional[Union[str, "_models.TemplateSpecExpandKind"]] = None, **kwargs - ) -> AsyncIterable["models.TemplateSpecsListResult"]: + ) -> AsyncIterable["_models.TemplateSpecsListResult"]: """Lists all the Template Specs within the specified subscriptions. + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either TemplateSpecsListResult or the result of cls(response) :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -331,6 +341,8 @@ def prepare_request(next_link=None): url = self._client.format_url(url, **path_format_arguments) # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') request = self._client.get(url, query_parameters, header_parameters) @@ -354,7 +366,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -368,18 +380,22 @@ async def get_next(next_link=None): def list_by_resource_group( self, resource_group_name: str, + expand: Optional[Union[str, "_models.TemplateSpecExpandKind"]] = None, **kwargs - ) -> AsyncIterable["models.TemplateSpecsListResult"]: + ) -> AsyncIterable["_models.TemplateSpecsListResult"]: """Lists all the Template Specs within the specified resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. :type resource_group_name: str + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either TemplateSpecsListResult or the result of cls(response) :rtype: ~azure.core.async_paging.AsyncItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -402,6 +418,8 @@ def prepare_request(next_link=None): url = self._client.format_url(url, **path_format_arguments) # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') request = self._client.get(url, query_parameters, header_parameters) @@ -425,7 +443,7 @@ async def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/__init__.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/__init__.py index 338850279b8c..3ac7fb678a3f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/__init__.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/__init__.py @@ -16,6 +16,7 @@ from ._models_py3 import TemplateSpecTemplateArtifact from ._models_py3 import TemplateSpecUpdateModel from ._models_py3 import TemplateSpecVersion + from ._models_py3 import TemplateSpecVersionInfo from ._models_py3 import TemplateSpecVersionUpdateModel from ._models_py3 import TemplateSpecVersionsListResult from ._models_py3 import TemplateSpecsError @@ -30,6 +31,7 @@ from ._models import TemplateSpecTemplateArtifact # type: ignore from ._models import TemplateSpecUpdateModel # type: ignore from ._models import TemplateSpecVersion # type: ignore + from ._models import TemplateSpecVersionInfo # type: ignore from ._models import TemplateSpecVersionUpdateModel # type: ignore from ._models import TemplateSpecVersionsListResult # type: ignore from ._models import TemplateSpecsError # type: ignore @@ -38,6 +40,7 @@ from ._template_specs_client_enums import ( CreatedByType, TemplateSpecArtifactKind, + TemplateSpecExpandKind, ) __all__ = [ @@ -50,10 +53,12 @@ 'TemplateSpecTemplateArtifact', 'TemplateSpecUpdateModel', 'TemplateSpecVersion', + 'TemplateSpecVersionInfo', 'TemplateSpecVersionUpdateModel', 'TemplateSpecVersionsListResult', 'TemplateSpecsError', 'TemplateSpecsListResult', 'CreatedByType', 'TemplateSpecArtifactKind', + 'TemplateSpecExpandKind', ] diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models.py index 956e590543d3..6c74c45497ba 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models.py @@ -82,7 +82,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -145,7 +145,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -196,6 +196,10 @@ class TemplateSpec(AzureResourceBase): :type description: str :param display_name: Template Spec display name. :type display_name: str + :ivar versions: High-level information about the versions within this Template Spec. The keys + are the version names. Only populated if the $expand query parameter is set to 'versions'. + :vartype versions: dict[str, + ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersionInfo] """ _validation = { @@ -206,6 +210,7 @@ class TemplateSpec(AzureResourceBase): 'location': {'required': True}, 'description': {'max_length': 4096, 'min_length': 0}, 'display_name': {'max_length': 64, 'min_length': 0}, + 'versions': {'readonly': True}, } _attribute_map = { @@ -217,6 +222,7 @@ class TemplateSpec(AzureResourceBase): 'tags': {'key': 'tags', 'type': '{str}'}, 'description': {'key': 'properties.description', 'type': 'str'}, 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'versions': {'key': 'properties.versions', 'type': '{TemplateSpecVersionInfo}'}, } def __init__( @@ -228,6 +234,7 @@ def __init__( self.tags = kwargs.get('tags', None) self.description = kwargs.get('description', None) self.display_name = kwargs.get('display_name', None) + self.versions = None class TemplateSpecArtifact(msrest.serialization.Model): @@ -272,7 +279,8 @@ def __init__( class TemplateSpecsError(msrest.serialization.Model): """Template Specs error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.ErrorResponse """ @@ -457,6 +465,41 @@ def __init__( self.template = kwargs.get('template', None) +class TemplateSpecVersionInfo(msrest.serialization.Model): + """High-level information about a Template Spec version. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Template Spec version description. + :vartype description: str + :ivar time_created: The timestamp of when the version was created. + :vartype time_created: ~datetime.datetime + :ivar time_modified: The timestamp of when the version was last modified. + :vartype time_modified: ~datetime.datetime + """ + + _validation = { + 'description': {'readonly': True}, + 'time_created': {'readonly': True}, + 'time_modified': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'time_created': {'key': 'timeCreated', 'type': 'iso-8601'}, + 'time_modified': {'key': 'timeModified', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(TemplateSpecVersionInfo, self).__init__(**kwargs) + self.description = None + self.time_created = None + self.time_modified = None + + class TemplateSpecVersionsListResult(msrest.serialization.Model): """List of Template Specs versions. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models_py3.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models_py3.py index 3c2f0da58a4c..3b2a4000c133 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models_py3.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_models_py3.py @@ -87,7 +87,7 @@ def __init__( class ErrorResponse(msrest.serialization.Model): - """The resource management error response. + """Common error response for all Azure Resource Manager APIs to return error details for failed operations. (This also follows the OData error response format.). Variables are only populated by the server, and will be ignored when sending a request. @@ -150,7 +150,7 @@ class SystemData(msrest.serialization.Model): values include: "User", "Application", "ManagedIdentity", "Key". :type last_modified_by_type: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.CreatedByType - :param last_modified_at: The type of identity that last modified the resource. + :param last_modified_at: The timestamp of resource last modification (UTC). :type last_modified_at: ~datetime.datetime """ @@ -208,6 +208,10 @@ class TemplateSpec(AzureResourceBase): :type description: str :param display_name: Template Spec display name. :type display_name: str + :ivar versions: High-level information about the versions within this Template Spec. The keys + are the version names. Only populated if the $expand query parameter is set to 'versions'. + :vartype versions: dict[str, + ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersionInfo] """ _validation = { @@ -218,6 +222,7 @@ class TemplateSpec(AzureResourceBase): 'location': {'required': True}, 'description': {'max_length': 4096, 'min_length': 0}, 'display_name': {'max_length': 64, 'min_length': 0}, + 'versions': {'readonly': True}, } _attribute_map = { @@ -229,6 +234,7 @@ class TemplateSpec(AzureResourceBase): 'tags': {'key': 'tags', 'type': '{str}'}, 'description': {'key': 'properties.description', 'type': 'str'}, 'display_name': {'key': 'properties.displayName', 'type': 'str'}, + 'versions': {'key': 'properties.versions', 'type': '{TemplateSpecVersionInfo}'}, } def __init__( @@ -245,6 +251,7 @@ def __init__( self.tags = tags self.description = description self.display_name = display_name + self.versions = None class TemplateSpecArtifact(msrest.serialization.Model): @@ -291,7 +298,8 @@ def __init__( class TemplateSpecsError(msrest.serialization.Model): """Template Specs error response. - :param error: The resource management error response. + :param error: Common error response for all Azure Resource Manager APIs to return error details + for failed operations. (This also follows the OData error response format.). :type error: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.ErrorResponse """ @@ -491,6 +499,41 @@ def __init__( self.template = template +class TemplateSpecVersionInfo(msrest.serialization.Model): + """High-level information about a Template Spec version. + + Variables are only populated by the server, and will be ignored when sending a request. + + :ivar description: Template Spec version description. + :vartype description: str + :ivar time_created: The timestamp of when the version was created. + :vartype time_created: ~datetime.datetime + :ivar time_modified: The timestamp of when the version was last modified. + :vartype time_modified: ~datetime.datetime + """ + + _validation = { + 'description': {'readonly': True}, + 'time_created': {'readonly': True}, + 'time_modified': {'readonly': True}, + } + + _attribute_map = { + 'description': {'key': 'description', 'type': 'str'}, + 'time_created': {'key': 'timeCreated', 'type': 'iso-8601'}, + 'time_modified': {'key': 'timeModified', 'type': 'iso-8601'}, + } + + def __init__( + self, + **kwargs + ): + super(TemplateSpecVersionInfo, self).__init__(**kwargs) + self.description = None + self.time_created = None + self.time_modified = None + + class TemplateSpecVersionsListResult(msrest.serialization.Model): """List of Template Specs versions. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_template_specs_client_enums.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_template_specs_client_enums.py index 3290920f0424..9adffe4c9f0f 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_template_specs_client_enums.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/models/_template_specs_client_enums.py @@ -40,3 +40,7 @@ class TemplateSpecArtifactKind(with_metaclass(_CaseInsensitiveEnumMeta, str, Enu """ TEMPLATE = "template" #: The artifact represents an embedded Azure Resource Manager template. + +class TemplateSpecExpandKind(with_metaclass(_CaseInsensitiveEnumMeta, str, Enum)): + + VERSIONS = "versions" #: Includes version information with the Template Spec. diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_spec_versions_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_spec_versions_operations.py index af8be09dfa96..2fa824c742a0 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_spec_versions_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_spec_versions_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TemplateSpecVersionsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -50,10 +50,10 @@ def create_or_update( resource_group_name, # type: str template_spec_name, # type: str template_spec_version, # type: str - template_spec_version_model, # type: "models.TemplateSpecVersion" + template_spec_version_model, # type: "_models.TemplateSpecVersion" **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpecVersion" + # type: (...) -> "_models.TemplateSpecVersion" """Creates or updates a Template Spec version. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -69,7 +69,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -106,7 +106,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -126,10 +126,10 @@ def update( resource_group_name, # type: str template_spec_name, # type: str template_spec_version, # type: str - template_spec_version_update_model=None, # type: Optional["models.TemplateSpecVersionUpdateModel"] + template_spec_version_update_model=None, # type: Optional["_models.TemplateSpecVersionUpdateModel"] **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpecVersion" + # type: (...) -> "_models.TemplateSpecVersion" """Updates Template Spec Version tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -146,7 +146,7 @@ def update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -186,7 +186,7 @@ def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpecVersion', pipeline_response) @@ -204,7 +204,7 @@ def get( template_spec_version, # type: str **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpecVersion" + # type: (...) -> "_models.TemplateSpecVersion" """Gets a Template Spec version from a specific Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -218,7 +218,7 @@ def get( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersion :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersion"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersion"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -250,7 +250,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpecVersion', pipeline_response) @@ -315,7 +315,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -329,7 +329,7 @@ def list( template_spec_name, # type: str **kwargs # type: Any ): - # type: (...) -> Iterable["models.TemplateSpecVersionsListResult"] + # type: (...) -> Iterable["_models.TemplateSpecVersionsListResult"] """Lists all the Template Spec versions in the specified Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -341,7 +341,7 @@ def list( :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecVersionsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecVersionsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecVersionsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -388,7 +388,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_specs_operations.py b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_specs_operations.py index 2459ff296d17..7450fa47f96c 100644 --- a/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_specs_operations.py +++ b/sdk/resources/azure-mgmt-resource/azure/mgmt/resource/templatespecs/v2019_06_01_preview/operations/_template_specs_operations.py @@ -14,7 +14,7 @@ from azure.core.pipeline.transport import HttpRequest, HttpResponse from azure.mgmt.core.exceptions import ARMErrorFormat -from .. import models +from .. import models as _models if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports @@ -37,7 +37,7 @@ class TemplateSpecsOperations(object): :param deserializer: An object model deserializer. """ - models = models + models = _models def __init__(self, client, config, serializer, deserializer): self._client = client @@ -49,10 +49,10 @@ def create_or_update( self, resource_group_name, # type: str template_spec_name, # type: str - template_spec, # type: "models.TemplateSpec" + template_spec, # type: "_models.TemplateSpec" **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpec" + # type: (...) -> "_models.TemplateSpec" """Creates or updates a Template Spec. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -66,7 +66,7 @@ def create_or_update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -102,7 +102,7 @@ def create_or_update( if response.status_code not in [200, 201]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if response.status_code == 200: @@ -121,10 +121,10 @@ def update( self, resource_group_name, # type: str template_spec_name, # type: str - template_spec=None, # type: Optional["models.TemplateSpecUpdateModel"] + template_spec=None, # type: Optional["_models.TemplateSpecUpdateModel"] **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpec" + # type: (...) -> "_models.TemplateSpec" """Updates Template Spec tags with specified values. :param resource_group_name: The name of the resource group. The name is case insensitive. @@ -138,7 +138,7 @@ def update( :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -177,7 +177,7 @@ def update( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpec', pipeline_response) @@ -192,21 +192,25 @@ def get( self, resource_group_name, # type: str template_spec_name, # type: str + expand=None, # type: Optional[Union[str, "_models.TemplateSpecExpandKind"]] **kwargs # type: Any ): - # type: (...) -> "models.TemplateSpec" + # type: (...) -> "_models.TemplateSpec" """Gets a Template Spec with a given name. :param resource_group_name: The name of the resource group. The name is case insensitive. :type resource_group_name: str :param template_spec_name: Name of the Template Spec. :type template_spec_name: str + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: TemplateSpec, or the result of cls(response) :rtype: ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpec :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpec"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpec"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -225,6 +229,8 @@ def get( # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') # Construct headers @@ -237,7 +243,7 @@ def get( if response.status_code not in [200]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) deserialized = self._deserialize('TemplateSpec', pipeline_response) @@ -298,7 +304,7 @@ def delete( if response.status_code not in [200, 204]: map_error(status_code=response.status_code, response=response, error_map=error_map) - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) if cls: @@ -308,17 +314,21 @@ def delete( def list_by_subscription( self, + expand=None, # type: Optional[Union[str, "_models.TemplateSpecExpandKind"]] **kwargs # type: Any ): - # type: (...) -> Iterable["models.TemplateSpecsListResult"] + # type: (...) -> Iterable["_models.TemplateSpecsListResult"] """Lists all the Template Specs within the specified subscriptions. + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either TemplateSpecsListResult or the result of cls(response) :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -340,6 +350,8 @@ def prepare_request(next_link=None): url = self._client.format_url(url, **path_format_arguments) # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') request = self._client.get(url, query_parameters, header_parameters) @@ -363,7 +375,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) @@ -377,19 +389,23 @@ def get_next(next_link=None): def list_by_resource_group( self, resource_group_name, # type: str + expand=None, # type: Optional[Union[str, "_models.TemplateSpecExpandKind"]] **kwargs # type: Any ): - # type: (...) -> Iterable["models.TemplateSpecsListResult"] + # type: (...) -> Iterable["_models.TemplateSpecsListResult"] """Lists all the Template Specs within the specified resource group. :param resource_group_name: The name of the resource group. The name is case insensitive. :type resource_group_name: str + :param expand: Allows for expansion of additional Template Spec details in the response. + Optional. + :type expand: str or ~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecExpandKind :keyword callable cls: A custom type or function that will be passed the direct response :return: An iterator like instance of either TemplateSpecsListResult or the result of cls(response) :rtype: ~azure.core.paging.ItemPaged[~azure.mgmt.resource.templatespecs.v2019_06_01_preview.models.TemplateSpecsListResult] :raises: ~azure.core.exceptions.HttpResponseError """ - cls = kwargs.pop('cls', None) # type: ClsType["models.TemplateSpecsListResult"] + cls = kwargs.pop('cls', None) # type: ClsType["_models.TemplateSpecsListResult"] error_map = { 401: ClientAuthenticationError, 404: ResourceNotFoundError, 409: ResourceExistsError } @@ -412,6 +428,8 @@ def prepare_request(next_link=None): url = self._client.format_url(url, **path_format_arguments) # Construct parameters query_parameters = {} # type: Dict[str, Any] + if expand is not None: + query_parameters['$expand'] = self._serialize.query("expand", expand, 'str') query_parameters['api-version'] = self._serialize.query("api_version", api_version, 'str') request = self._client.get(url, query_parameters, header_parameters) @@ -435,7 +453,7 @@ def get_next(next_link=None): response = pipeline_response.http_response if response.status_code not in [200]: - error = self._deserialize(models.TemplateSpecsError, response) + error = self._deserialize(_models.TemplateSpecsError, response) map_error(status_code=response.status_code, response=response, error_map=error_map) raise HttpResponseError(response=response, model=error, error_format=ARMErrorFormat) diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_management_group.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_management_group.yaml deleted file mode 100644 index 411f05167594..000000000000 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_management_group.yaml +++ /dev/null @@ -1,55 +0,0 @@ -interactions: -- request: - body: '{"name": "20000000-0001-0000-0000-000000000123456"}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Cache-Control: - - no-cache - Connection: - - keep-alive - Content-Length: - - '51' - Content-Type: - - application/json; charset=utf-8 - User-Agent: - - python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) msrest/0.6.10 - msrest_azure/0.6.2 azure-mgmt-managementgroups/0.2.0 Azure-SDK-For-Python - accept-language: - - en-US - method: PUT - uri: https://management.azure.com/providers/Microsoft.Management/managementGroups/20000000-0001-0000-0000-000000000123456?api-version=2018-03-01-preview - response: - body: - string: '{"error":{"code":"InvalidAuthenticationToken","message":"The access - token is invalid."}}' - headers: - cache-control: - - no-cache - connection: - - close - content-length: - - '88' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:06:22 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - www-authenticate: - - Bearer authorization_uri="https://login.windows.net/", error="invalid_token", - error_description="The access token is invalid." - x-content-type-options: - - nosniff - x-ms-failure-cause: - - gateway - status: - code: 401 - message: Unauthorized -version: 1 diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_scope.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_scope.yaml index 83a84a86df97..23d74cd2c92b 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_scope.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_scope.yaml @@ -9,9 +9,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-10-01 response: body: string: '' @@ -23,7 +23,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:08 GMT + - Fri, 26 Feb 2021 06:40:49 GMT expires: - '-1' pragma: @@ -57,16 +57,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a","name":"pytestdeployment9c41124a","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2020-09-17T07:38:13.9643548Z","duration":"PT2.8987267S","correlationId":"47098937-a05e-4b41-90cc-34d5290803a3","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[]}}' + US"}},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2021-02-26T06:40:54.1100003Z","duration":"PT2.6806251S","correlationId":"f7bcfeb0-ee1b-404c-83c5-25f809b154b1","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[]}}' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operationStatuses/08586012785944119822?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operationStatuses/08585872852340482434?api-version=2020-10-01 cache-control: - no-cache content-length: @@ -74,7 +74,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:14 GMT + - Fri, 26 Feb 2021 06:40:55 GMT expires: - '-1' pragma: @@ -98,9 +98,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operationStatuses/08586012785944119822?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operationStatuses/08585872852340482434?api-version=2020-10-01 response: body: string: '{"status":"Succeeded"}' @@ -112,7 +112,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:45 GMT + - Fri, 26 Feb 2021 06:41:25 GMT expires: - '-1' pragma: @@ -136,13 +136,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a","name":"pytestdeployment9c41124a","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:23.1291095Z","duration":"PT12.0634814S","correlationId":"47098937-a05e-4b41-90cc-34d5290803a3","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:09.1425137Z","duration":"PT17.7131385S","correlationId":"f7bcfeb0-ee1b-404c-83c5-25f809b154b1","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache @@ -151,7 +151,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:46 GMT + - Fri, 26 Feb 2021 06:41:26 GMT expires: - '-1' pragma: @@ -175,13 +175,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/?api-version=2020-10-01 response: body: string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a","name":"pytestdeployment9c41124a","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:23.1291095Z","duration":"PT12.0634814S","correlationId":"47098937-a05e-4b41-90cc-34d5290803a3","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}]}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:09.1425137Z","duration":"PT17.7131385S","correlationId":"f7bcfeb0-ee1b-404c-83c5-25f809b154b1","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}]}' headers: cache-control: - no-cache @@ -190,7 +190,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:46 GMT + - Fri, 26 Feb 2021 06:41:26 GMT expires: - '-1' pragma: @@ -214,13 +214,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a","name":"pytestdeployment9c41124a","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:23.1291095Z","duration":"PT12.0634814S","correlationId":"47098937-a05e-4b41-90cc-34d5290803a3","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:09.1425137Z","duration":"PT17.7131385S","correlationId":"f7bcfeb0-ee1b-404c-83c5-25f809b154b1","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache @@ -229,7 +229,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:47 GMT + - Fri, 26 Feb 2021 06:41:27 GMT expires: - '-1' pragma: @@ -253,21 +253,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/2F40490619D3C233","operationId":"2F40490619D3C233","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:22.9854661Z","duration":"PT7.4711496S","trackingId":"44ad98de-699a-4847-b33d-00ef053fa262","serviceRequestId":"0628169a-bdd5-4cd1-b37b-9073205010d0","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/08586012785944119822","operationId":"08586012785944119822","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:23.1114426Z","duration":"PT7.5971261S","trackingId":"8ed4605c-465e-4e08-afc5-2e03df731868","statusCode":"OK"}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/8F8992B9CB2D19E7","operationId":"8F8992B9CB2D19E7","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:08.1919818Z","duration":"PT11.1603647S","trackingId":"37864ba9-9307-45e6-8688-589b5c0f3d83","serviceRequestId":"88803319-5916-433c-8c73-c89b2261fc59","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/08585872852340482434","operationId":"08585872852340482434","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:08.9342872Z","duration":"PT11.9026701S","trackingId":"4e3b9b30-6950-4224-a9f8-c5af21d56787","statusCode":"OK"}}]}' headers: cache-control: - no-cache content-length: - - '1410' + - '1412' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:47 GMT + - Fri, 26 Feb 2021 06:41:27 GMT expires: - '-1' pragma: @@ -291,21 +291,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/2F40490619D3C233?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/8F8992B9CB2D19E7?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/2F40490619D3C233","operationId":"2F40490619D3C233","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:22.9854661Z","duration":"PT7.4711496S","trackingId":"44ad98de-699a-4847-b33d-00ef053fa262","serviceRequestId":"0628169a-bdd5-4cd1-b37b-9073205010d0","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/operations/8F8992B9CB2D19E7","operationId":"8F8992B9CB2D19E7","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:08.1919818Z","duration":"PT11.1603647S","trackingId":"37864ba9-9307-45e6-8688-589b5c0f3d83","serviceRequestId":"88803319-5916-433c-8c73-c89b2261fc59","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}}' headers: cache-control: - no-cache content-length: - - '873' + - '874' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:48 GMT + - Fri, 26 Feb 2021 06:41:28 GMT expires: - '-1' pragma: @@ -331,24 +331,24 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/cancel?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/cancel?api-version=2020-10-01 response: body: string: '{"error":{"code":"DeploymentCannotBeCancelled","message":"The deployment ''pytestdeployment9c41124a'' cannot be cancelled because it has provisioning - state ''Succeeded'' or it has already expired (expiration time is ''9/24/2020 - 7:38:11 AM'')."}}' + state ''Succeeded'' or it has already expired (expiration time is ''3/5/2021 + 6:40:51 AM'')."}}' headers: cache-control: - no-cache content-length: - - '239' + - '238' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:49 GMT + - Fri, 26 Feb 2021 06:41:29 GMT expires: - '-1' pragma: @@ -384,13 +384,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/validate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/validate?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a","name":"pytestdeployment9c41124a","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:38:50.7162955Z","duration":"PT0S","correlationId":"cbc9cf67-2160-42cc-87d3-c6070d59271b","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"validatedResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:30.4969636Z","duration":"PT0S","correlationId":"1b537b46-1166-4e58-a3f2-7fed498ea034","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"validatedResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache @@ -399,7 +399,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:50 GMT + - Fri, 26 Feb 2021 06:41:30 GMT expires: - '-1' pragma: @@ -429,9 +429,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/exportTemplate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a/exportTemplate?api-version=2020-10-01 response: body: string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"location":{"allowedValues":["East @@ -445,7 +445,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:38:51 GMT + - Fri, 26 Feb 2021 06:41:31 GMT expires: - '-1' pragma: @@ -475,9 +475,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment9c41124a?api-version=2020-10-01 response: body: string: '' @@ -487,11 +487,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:38:53 GMT + - Fri, 26 Feb 2021 06:41:33 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtUFdUNDNURkdXSkUyTVpaSDNQQkpFRUNRQzZJU0VQVDNXSUlHT1VOTFBCVU43Nk18MDRFQjFDNkMwM0JGQjQ4MS1QWVRFU1RERVBMT1lNRU5UOUM0MTEyNEEtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtQkdCVFdPNVRNNTY3QUdFQ05JU0NMRUdXSzI3NzRMMklBRURDRTVLTjdUUlVDTkR8RTlCQTkwQjM4RDg0QUE2QS1QWVRFU1RERVBMT1lNRU5UOUM0MTEyNEEtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -513,9 +513,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtUFdUNDNURkdXSkUyTVpaSDNQQkpFRUNRQzZJU0VQVDNXSUlHT1VOTFBCVU43Nk18MDRFQjFDNkMwM0JGQjQ4MS1QWVRFU1RERVBMT1lNRU5UOUM0MTEyNEEtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtQkdCVFdPNVRNNTY3QUdFQ05JU0NMRUdXSzI3NzRMMklBRURDRTVLTjdUUlVDTkR8RTlCQTkwQjM4RDg0QUE2QS1QWVRFU1RERVBMT1lNRU5UOUM0MTEyNEEtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -523,7 +523,7 @@ interactions: cache-control: - no-cache date: - - Thu, 17 Sep 2020 07:39:09 GMT + - Fri, 26 Feb 2021 06:41:48 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_subscription.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_subscription.yaml index 39a1363ce9cb..7539454d6df4 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_subscription.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_at_subscription.yaml @@ -9,9 +9,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-10-01 response: body: string: '' @@ -19,9 +19,11 @@ interactions: cache-control: - no-cache content-length: - - '0' + - '105' + content-type: + - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:07:48 GMT + - Fri, 26 Feb 2021 06:41:50 GMT expires: - '-1' pragma: @@ -30,9 +32,11 @@ interactions: - max-age=31536000; includeSubDomains x-content-type-options: - nosniff + x-ms-failure-cause: + - gateway status: - code: 204 - message: No Content + code: 404 + message: Not Found - request: body: '{"location": "West US", "properties": {"templateLink": {"uri": "https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"}, "parametersLink": {"uri": "https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"}, @@ -49,15 +53,15 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2020-09-17T08:07:53.9671561Z","duration":"PT3.5832626S","correlationId":"d90d6ad1-66b2-4ac7-85aa-0b78eabec8ed","providers":[],"dependencies":[]}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2021-02-26T06:41:54.4172548Z","duration":"PT3.0800312S","correlationId":"baaaab81-8375-4ff3-b53a-1857b585b6c3","providers":[],"dependencies":[]}}' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operationStatuses/08586012768150937053?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operationStatuses/08585872851741403700?api-version=2020-10-01 cache-control: - no-cache content-length: @@ -65,24 +69,20 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:07:53 GMT + - Fri, 26 Feb 2021 06:41:54 GMT expires: - '-1' pragma: - no-cache strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - '1199' status: - code: 200 - message: OK + code: 201 + message: Created - request: body: null headers: @@ -93,9 +93,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operationStatuses/08586012768150937053?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operationStatuses/08585872851741403700?api-version=2020-10-01 response: body: string: '{"status":"Succeeded"}' @@ -107,7 +107,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:25 GMT + - Fri, 26 Feb 2021 06:42:24 GMT expires: - '-1' pragma: @@ -131,12 +131,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T08:07:54.8836206Z","duration":"PT4.4997271S","correlationId":"d90d6ad1-66b2-4ac7-85aa-0b78eabec8ed","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:55.2238788Z","duration":"PT3.8866552S","correlationId":"baaaab81-8375-4ff3-b53a-1857b585b6c3","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}' headers: cache-control: - no-cache @@ -145,7 +145,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:25 GMT + - Fri, 26 Feb 2021 06:42:25 GMT expires: - '-1' pragma: @@ -169,21 +169,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T08:07:54.8836206Z","duration":"PT4.4997271S","correlationId":"d90d6ad1-66b2-4ac7-85aa-0b78eabec8ed","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/ASC_EnableAzureDefender_KubernetesService","name":"ASC_EnableAzureDefender_KubernetesService","type":"Microsoft.Resources/deployments","location":"centralus","properties":{"templateHash":"7481118601119032709","parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-11-06T06:53:08.8290651Z","duration":"PT6.6951329S","correlationId":"2c17c568-33af-4ba4-a249-076ef2b71541","providers":[{"namespace":"Microsoft.Security","resourceTypes":[{"resourceType":"pricings","locations":[null]}]}],"dependencies":[],"outputs":{},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Security/pricings/KubernetesService"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/ASC_EnableAzureDefender_SqlServerVirtualMachines","name":"ASC_EnableAzureDefender_SqlServerVirtualMachines","type":"Microsoft.Resources/deployments","location":"centralus","properties":{"templateHash":"12442521553927789228","parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-11-06T06:48:44.7007613Z","duration":"PT7.3434559S","correlationId":"24b752a0-d194-4e57-b3ae-32ba3c3c1150","providers":[{"namespace":"Microsoft.Security","resourceTypes":[{"resourceType":"pricings","locations":[null]}]}],"dependencies":[],"outputs":{},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Security/pricings/SqlServerVirtualMachines"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:55.2238788Z","duration":"PT3.8866552S","correlationId":"baaaab81-8375-4ff3-b53a-1857b585b6c3","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}]}' headers: cache-control: - no-cache content-length: - - '836' + - '2432' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:26 GMT + - Fri, 26 Feb 2021 06:42:25 GMT expires: - '-1' pragma: @@ -207,12 +207,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T08:07:54.8836206Z","duration":"PT4.4997271S","correlationId":"d90d6ad1-66b2-4ac7-85aa-0b78eabec8ed","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:55.2238788Z","duration":"PT3.8866552S","correlationId":"baaaab81-8375-4ff3-b53a-1857b585b6c3","providers":[],"dependencies":[],"outputs":{},"outputResources":[]}}' headers: cache-control: - no-cache @@ -221,7 +221,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:26 GMT + - Fri, 26 Feb 2021 06:42:26 GMT expires: - '-1' pragma: @@ -251,9 +251,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/whatIf?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/whatIf?api-version=2020-10-01 response: body: string: '' @@ -263,11 +263,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:08:27 GMT + - Fri, 26 Feb 2021 06:42:27 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItLVBZVEVTVExJTktFRDI4QzAxNTU1LUNFRUE1ODk3OjJEQUFDQjoyRDQ5MkE6MkQ5QUQ1OjJERTBEOTdDMTRFRkE5Iiwiam9iTG9jYXRpb24iOiJXZXN0IFVTIn0?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItLVBZVEVTVExJTktFRDI4QzAxNTU1LUU0MDVBRTU4OjJEOTJBOToyRDRBNUI6MkRCMDQzOjJENTEwNUQ1MjBGMUQ5Iiwiam9iTG9jYXRpb24iOiJXZXN0IFVTIn0?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -289,12 +289,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItLVBZVEVTVExJTktFRDI4QzAxNTU1LUNFRUE1ODk3OjJEQUFDQjoyRDQ5MkE6MkQ5QUQ1OjJERTBEOTdDMTRFRkE5Iiwiam9iTG9jYXRpb24iOiJXZXN0IFVTIn0?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItLVBZVEVTVExJTktFRDI4QzAxNTU1LUU0MDVBRTU4OjJEOTJBOToyRDRBNUI6MkRCMDQzOjJENTEwNUQ1MjBGMUQ5Iiwiam9iTG9jYXRpb24iOiJXZXN0IFVTIn0?api-version=2020-10-01 response: body: - string: '{"status":"Succeeded","properties":{"correlationId":"ceea5897-aacb-492a-9ad5-e0d97c14efa9","changes":[]}}' + string: '{"status":"Succeeded","properties":{"correlationId":"e405ae58-92a9-4a5b-b043-5105d520f1d9","changes":[]}}' headers: cache-control: - no-cache @@ -303,7 +303,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:43 GMT + - Fri, 26 Feb 2021 06:42:43 GMT expires: - '-1' pragma: @@ -327,12 +327,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08586012768150937053","operationId":"08586012768150937053","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2020-09-17T08:07:54.8354512Z","duration":"PT0.031771S","trackingId":"61bb0b11-76bc-4ff6-b7b3-5edfea055d98","statusCode":"OK"}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08585872851741403700","operationId":"08585872851741403700","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:55.191911Z","duration":"PT0.0341425S","trackingId":"09763f4d-413a-4835-a07f-6f7e9f351709","statusCode":"OK"}}]}' headers: cache-control: - no-cache @@ -341,7 +341,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:43 GMT + - Fri, 26 Feb 2021 06:42:43 GMT expires: - '-1' pragma: @@ -365,12 +365,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08586012768150937053?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08585872851741403700?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08586012768150937053","operationId":"08586012768150937053","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2020-09-17T08:07:54.8354512Z","duration":"PT0.031771S","trackingId":"61bb0b11-76bc-4ff6-b7b3-5edfea055d98","statusCode":"OK"}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/operations/08585872851741403700","operationId":"08585872851741403700","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2021-02-26T06:41:55.191911Z","duration":"PT0.0341425S","trackingId":"09763f4d-413a-4835-a07f-6f7e9f351709","statusCode":"OK"}}' headers: cache-control: - no-cache @@ -379,7 +379,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:44 GMT + - Fri, 26 Feb 2021 06:42:44 GMT expires: - '-1' pragma: @@ -405,24 +405,24 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/cancel?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/cancel?api-version=2020-10-01 response: body: string: '{"error":{"code":"DeploymentCannotBeCancelled","message":"The deployment ''pytestlinked28c01555'' cannot be cancelled because it has provisioning state - ''Succeeded'' or it has already expired (expiration time is ''9/24/2020 8:07:50 + ''Succeeded'' or it has already expired (expiration time is ''3/5/2021 6:41:51 AM'')."}}' headers: cache-control: - no-cache content-length: - - '235' + - '234' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:45 GMT + - Fri, 26 Feb 2021 06:42:44 GMT expires: - '-1' pragma: @@ -454,12 +454,12 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/validate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/validate?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T08:08:45.9520773Z","duration":"PT0S","correlationId":"f23f856c-ed26-44bc-b089-1272fa7d00b6","providers":[],"dependencies":[],"validatedResources":[]}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555","name":"pytestlinked28c01555","type":"Microsoft.Resources/deployments","location":"westus","properties":{"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json","contentVersion":"1.0.0.0"},"templateHash":"653051900461279848","parametersLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/100-blank-template/azuredeploy.json"},"parameters":{},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:42:46.3022762Z","duration":"PT0S","correlationId":"a2b2d78e-68d7-4ec7-a9fe-7330deb95983","providers":[],"dependencies":[],"validatedResources":[]}}' headers: cache-control: - no-cache @@ -468,7 +468,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:45 GMT + - Fri, 26 Feb 2021 06:42:45 GMT expires: - '-1' pragma: @@ -498,9 +498,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/exportTemplate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555/exportTemplate?api-version=2020-10-01 response: body: string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[],"outputs":{}}}' @@ -512,7 +512,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:08:46 GMT + - Fri, 26 Feb 2021 06:42:45 GMT expires: - '-1' pragma: @@ -542,9 +542,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/deployments/pytestlinked28c01555?api-version=2020-10-01 response: body: string: '' @@ -554,11 +554,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:08:48 GMT + - Fri, 26 Feb 2021 06:42:48 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtLVBZVEVTVExJTktFRDI4QzAxNTU1LSIsImpvYkxvY2F0aW9uIjoid2VzdHVzIn0?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtLVBZVEVTVExJTktFRDI4QzAxNTU1LSIsImpvYkxvY2F0aW9uIjoid2VzdHVzIn0?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -580,9 +580,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtLVBZVEVTVExJTktFRDI4QzAxNTU1LSIsImpvYkxvY2F0aW9uIjoid2VzdHVzIn0?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtLVBZVEVTVExJTktFRDI4QzAxNTU1LSIsImpvYkxvY2F0aW9uIjoid2VzdHVzIn0?api-version=2020-10-01 response: body: string: '' @@ -590,7 +590,7 @@ interactions: cache-control: - no-cache date: - - Thu, 17 Sep 2020 08:09:04 GMT + - Fri, 26 Feb 2021 06:43:04 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_basic.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_basic.yaml index 3a21399224c4..15b1ed4eb0fc 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_basic.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_deployments_basic.yaml @@ -9,9 +9,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-10-01 response: body: string: '' @@ -23,7 +23,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:18 GMT + - Fri, 26 Feb 2021 06:43:09 GMT expires: - '-1' pragma: @@ -57,16 +57,16 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe","name":"pytestdeployment667e10fe","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2020-09-17T07:39:23.1575068Z","duration":"PT2.6296603S","correlationId":"bc152935-67ed-4c5e-95be-6bfc2fd3098f","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[]}}' + US"}},"mode":"Incremental","provisioningState":"Accepted","timestamp":"2021-02-26T06:43:14.1674707Z","duration":"PT2.6732347S","correlationId":"9490b1b2-c985-4595-b5e1-35179690121c","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[]}}' headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operationStatuses/08586012785249497645?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operationStatuses/08585872850939833756?api-version=2020-10-01 cache-control: - no-cache content-length: @@ -74,7 +74,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:24 GMT + - Fri, 26 Feb 2021 06:43:14 GMT expires: - '-1' pragma: @@ -84,7 +84,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1199' status: code: 201 message: Created @@ -98,9 +98,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operationStatuses/08586012785249497645?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operationStatuses/08585872850939833756?api-version=2020-10-01 response: body: string: '{"status":"Succeeded"}' @@ -112,7 +112,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:54 GMT + - Fri, 26 Feb 2021 06:43:45 GMT expires: - '-1' pragma: @@ -136,22 +136,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe","name":"pytestdeployment667e10fe","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.4101582Z","duration":"PT9.8823117S","correlationId":"bc152935-67ed-4c5e-95be-6bfc2fd3098f","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.3961722Z","duration":"PT11.9019362S","correlationId":"9490b1b2-c985-4595-b5e1-35179690121c","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache content-length: - - '1075' + - '1076' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:54 GMT + - Fri, 26 Feb 2021 06:43:46 GMT expires: - '-1' pragma: @@ -175,22 +175,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/?api-version=2020-10-01 response: body: string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe","name":"pytestdeployment667e10fe","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.4101582Z","duration":"PT9.8823117S","correlationId":"bc152935-67ed-4c5e-95be-6bfc2fd3098f","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}]}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.3961722Z","duration":"PT11.9019362S","correlationId":"9490b1b2-c985-4595-b5e1-35179690121c","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}]}' headers: cache-control: - no-cache content-length: - - '1087' + - '1088' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:55 GMT + - Fri, 26 Feb 2021 06:43:46 GMT expires: - '-1' pragma: @@ -214,22 +214,22 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe","name":"pytestdeployment667e10fe","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.4101582Z","duration":"PT9.8823117S","correlationId":"bc152935-67ed-4c5e-95be-6bfc2fd3098f","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.3961722Z","duration":"PT11.9019362S","correlationId":"9490b1b2-c985-4595-b5e1-35179690121c","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"outputs":{"myparameter":{"type":"Object","value":{"platformUpdateDomainCount":5,"platformFaultDomainCount":3}}},"outputResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache content-length: - - '1075' + - '1076' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:39:55 GMT + - Fri, 26 Feb 2021 06:43:47 GMT expires: - '-1' pragma: @@ -263,9 +263,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/whatIf?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/whatIf?api-version=2020-10-01 response: body: string: '' @@ -275,11 +275,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:39:57 GMT + - Fri, 26 Feb 2021 06:43:48 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItNDJKWks2Mk9HR0FJUTRPTjY1V1BKM1NQVktMUzZBVjVUQ1NZWU9RT09LSFhKUEN8MDc0OUVENENFMTUyQjc2My1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtRUQwNDg2MEU6MkQ2RUE4OjJENDkyMzoyRDk4RkQ6MkRCMjA3MzkzN0FFMUEiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItM0ZSM0VPS0JOUVRLN1BJMjVBSlVJWk9KT05JQ1pGUkY2MjU2Q1dZQkVVNkxSTEh8OEVCMUYzNTA4NDA0RUU1RS1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtNkVDOEVEMTc6MkQ2RTk1OjJENDlGMjoyREJEODU6MkQyMkVENkVEMjlDQkYiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -301,9 +301,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItNDJKWks2Mk9HR0FJUTRPTjY1V1BKM1NQVktMUzZBVjVUQ1NZWU9RT09LSFhKUEN8MDc0OUVENENFMTUyQjc2My1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtRUQwNDg2MEU6MkQ2RUE4OjJENDkyMzoyRDk4RkQ6MkRCMjA3MzkzN0FFMUEiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnRXaGF0SWZKb2ItM0ZSM0VPS0JOUVRLN1BJMjVBSlVJWk9KT05JQ1pGUkY2MjU2Q1dZQkVVNkxSTEh8OEVCMUYzNTA4NDA0RUU1RS1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtNkVDOEVEMTc6MkQ2RTk1OjJENDlGMjoyREJEODU6MkQyMkVENkVEMjlDQkYiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '{"status":"Failed","error":{"code":"InvalidTemplate","message":"Deployment @@ -318,7 +318,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:12 GMT + - Fri, 26 Feb 2021 06:44:03 GMT expires: - '-1' pragma: @@ -342,12 +342,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/deployments/pytestdeployment667e10fe/operations?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/deployments/pytestdeployment667e10fe/operations?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/6514AFC1A20148BF","operationId":"6514AFC1A20148BF","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.3318286Z","duration":"PT5.7415098S","trackingId":"69e72fcc-101b-4129-bcf2-afc9d7839886","serviceRequestId":"1e138a1d-999e-4a9f-bff1-c291cd7db5a0","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/08586012785249497645","operationId":"08586012785249497645","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.3911266Z","duration":"PT5.8008078S","trackingId":"ef2c67e6-de08-43bc-b0c3-b966eb834f1b","statusCode":"OK"}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/4E7B58566D970EF5","operationId":"4E7B58566D970EF5","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.2627594Z","duration":"PT7.6661711S","trackingId":"b75abde2-b64d-4741-a3bd-2418a31d9f60","serviceRequestId":"a6b1c97b-76e0-4bbd-bfd9-3b4abf7d25e1","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/08585872850939833756","operationId":"08585872850939833756","properties":{"provisioningOperation":"EvaluateDeploymentOutput","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.3807522Z","duration":"PT7.7841639S","trackingId":"555ef510-f988-4d89-a95f-c4bab554e63c","statusCode":"OK"}}]}' headers: cache-control: - no-cache @@ -356,7 +356,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:13 GMT + - Fri, 26 Feb 2021 06:44:04 GMT expires: - '-1' pragma: @@ -380,12 +380,12 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/deployments/pytestdeployment667e10fe/operations/6514AFC1A20148BF?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/deployments/pytestdeployment667e10fe/operations/4E7B58566D970EF5?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/6514AFC1A20148BF","operationId":"6514AFC1A20148BF","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2020-09-17T07:39:30.3318286Z","duration":"PT5.7415098S","trackingId":"69e72fcc-101b-4129-bcf2-afc9d7839886","serviceRequestId":"1e138a1d-999e-4a9f-bff1-c291cd7db5a0","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/operations/4E7B58566D970EF5","operationId":"4E7B58566D970EF5","properties":{"provisioningOperation":"Create","provisioningState":"Succeeded","timestamp":"2021-02-26T06:43:23.2627594Z","duration":"PT7.6661711S","trackingId":"b75abde2-b64d-4741-a3bd-2418a31d9f60","serviceRequestId":"a6b1c97b-76e0-4bbd-bfd9-3b4abf7d25e1","statusCode":"OK","targetResource":{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1","resourceType":"Microsoft.Compute/availabilitySets","resourceName":"availabilitySet1"}}}' headers: cache-control: - no-cache @@ -394,7 +394,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:14 GMT + - Fri, 26 Feb 2021 06:44:05 GMT expires: - '-1' pragma: @@ -420,24 +420,24 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/cancel?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/cancel?api-version=2020-10-01 response: body: string: '{"error":{"code":"DeploymentCannotBeCancelled","message":"The deployment ''pytestdeployment667e10fe'' cannot be cancelled because it has provisioning - state ''Succeeded'' or it has already expired (expiration time is ''9/24/2020 - 7:39:20 AM'')."}}' + state ''Succeeded'' or it has already expired (expiration time is ''3/5/2021 + 6:43:11 AM'')."}}' headers: cache-control: - no-cache content-length: - - '239' + - '238' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:15 GMT + - Fri, 26 Feb 2021 06:44:05 GMT expires: - '-1' pragma: @@ -473,13 +473,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/validate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/validate?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe","name":"pytestdeployment667e10fe","type":"Microsoft.Resources/deployments","properties":{"templateHash":"16604828588493152528","parameters":{"location":{"type":"String","value":"West - US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2020-09-17T07:40:16.8732657Z","duration":"PT0S","correlationId":"accb97f1-dd48-4929-a5fd-7e5e2c40624a","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"validatedResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' + US"}},"mode":"Incremental","provisioningState":"Succeeded","timestamp":"2021-02-26T06:44:07.4073605Z","duration":"PT0S","correlationId":"8c4acf94-474b-4fc3-9463-623683f06c50","providers":[{"namespace":"Microsoft.Compute","resourceTypes":[{"resourceType":"availabilitySets","locations":["westus"]}]}],"dependencies":[],"validatedResources":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/availabilitySet1"}]}}' headers: cache-control: - no-cache @@ -488,7 +488,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:16 GMT + - Fri, 26 Feb 2021 06:44:08 GMT expires: - '-1' pragma: @@ -518,9 +518,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/exportTemplate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe/exportTemplate?api-version=2020-10-01 response: body: string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"location":{"allowedValues":["East @@ -534,7 +534,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:17 GMT + - Fri, 26 Feb 2021 06:44:08 GMT expires: - '-1' pragma: @@ -564,9 +564,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deployments/pytestdeployment667e10fe?api-version=2020-10-01 response: body: string: '' @@ -576,11 +576,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:40:19 GMT + - Fri, 26 Feb 2021 06:44:11 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtNDJKWks2Mk9HR0FJUTRPTjY1V1BKM1NQVktMUzZBVjVUQ1NZWU9RT09LSFhKUEN8MDc0OUVENENFMTUyQjc2My1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtM0ZSM0VPS0JOUVRLN1BJMjVBSlVJWk9KT05JQ1pGUkY2MjU2Q1dZQkVVNkxSTEh8OEVCMUYzNTA4NDA0RUU1RS1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -588,7 +588,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 202 message: Accepted @@ -602,9 +602,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtNDJKWks2Mk9HR0FJUTRPTjY1V1BKM1NQVktMUzZBVjVUQ1NZWU9RT09LSFhKUEN8MDc0OUVENENFMTUyQjc2My1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IkRlcGxveW1lbnREZWxldGlvbkpvYi1HTlMtM0ZSM0VPS0JOUVRLN1BJMjVBSlVJWk9KT05JQ1pGUkY2MjU2Q1dZQkVVNkxSTEh8OEVCMUYzNTA4NDA0RUU1RS1QWVRFU1RERVBMT1lNRU5UNjY3RTEwRkUtIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -612,7 +612,7 @@ interactions: cache-control: - no-cache date: - - Thu, 17 Sep 2020 07:40:35 GMT + - Fri, 26 Feb 2021 06:44:26 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_locations.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_locations.yaml index 51a98d7c2cfa..865fb30bd814 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_locations.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_locations.yaml @@ -9,9 +9,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web","namespace":"Microsoft.Web","authorization":{"applicationId":"abfa0a7c-a6b6-4736-8310-5855508787cd","roleDefinitionId":"f47ed98b-b063-4a5b-9e10-4b9b44fa7735"},"resourceTypes":[{"resourceType":"publishingUsers","locations":["Central @@ -22,7 +22,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -30,7 +30,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -38,7 +38,7 @@ interactions: Central US","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central + North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -46,7 +46,32 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"generateGithubAccessTokenForAppserviceCLI","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway East","UAE North","Switzerland North","North Central US","UK + West","Australia Southeast","Korea South","Canada Central","West Europe","South + India","West Central US","East Asia (Stage)","North Central US (Stage)","East + Asia","Japan East"],"apiVersions":["2020-10-01","2020-09-01"],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"webAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -54,7 +79,16 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/webAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan + East","Australia East","Brazil South","Southeast Asia","Japan West","Central + India","UK South","Canada East","Korea Central","France Central","North Europe","East + US","West India","East US 2","Australia Central","Germany West Central","Norway + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"functionAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -62,9 +96,19 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"staticSites","locations":["West - US 2","Central US","East US 2","West Europe","East Asia","West US"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"listSitesAssignedToHostName","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/functionAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan + East","Australia East","Brazil South","Southeast Asia","Japan West","Central + India","UK South","Canada East","Korea Central","France Central","North Europe","East + US","West India","East US 2","Australia Central","Germany West Central","Norway + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"staticSites","locations":["West + US 2","Central US","East US 2","West Europe","East Asia"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/previewStaticSiteWorkflowFile","locations":["West + US 2","Central US","East US 2","West Europe","East Asia"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"listSitesAssignedToHostName","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -72,64 +116,68 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West India","Central India","South India","Canada Central","Canada East","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","France Central","West Central - US","East Asia (Stage)","North Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["South + US","East Asia (Stage)","North Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West - India","Australia Central","Germany West Central","Norway East","Switzerland + India","Australia Central","Germany West Central","Norway East","UAE North","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South + US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West - India","Australia Central","Germany West Central","Norway East","Switzerland + India","Australia Central","Germany West Central","Norway East","UAE North","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South + US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -137,87 +185,84 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossSubscriptionResourceMove, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"serverFarms","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"sites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"sites/slots","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"runtimes","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":[],"apiVersions":["2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/premieraddons","locations":["South + SupportsLocation"},{"resourceType":"runtimes","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":[],"apiVersions":["2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/premieraddons","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["South - Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East - US 2 (Stage)","Central US (Stage)","South Africa North","East US 2","East - US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East - Asia","Australia East","Brazil South","Japan West","Central India","Canada - East","Korea Central","France Central","West India","Australia Central","Germany - West Central","Norway East","Switzerland North","North Central US","UK West","Australia - Southeast","Korea South","Canada Central","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"zoneMappings":[{"location":"East - US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West - Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast - Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North - Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK - South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia - East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]}],"capabilities":"SupportsTags, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["MSFT + West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central + US (Stage)","South Central US","South Africa North","East US 2","East US","UK + South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","Australia + East","Brazil South","Japan West","Central India","Canada East","Korea Central","France + Central","West India","Australia Central","Germany West Central","Norway East","UAE + North","Switzerland North","North Central US","UK West","Australia Southeast","Korea + South","Canada Central","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments/multiRolePools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North - Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North + Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"deploymentLocations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central @@ -226,88 +271,108 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South + North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-11-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"connections","locations":["North + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-11-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"connections","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"customApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/listWsdlInterfaces","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/connectionGatewayInstallations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -315,7 +380,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -323,7 +388,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -331,51 +396,69 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South + Central","Germany West Central","Norway West","Norway East","UAE North","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South + Central","Germany West Central","Norway West","Norway East","UAE North","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["North + Central","Germany West Central","Norway West","Norway East","Switzerland North","UAE + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["North Central US","South Central US","Brazil South","Canada East","UK West","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","Australia East","Japan West","Central India","Korea Central","France Central","West India","Australia - Central","Germany West Central","Norway East","Switzerland North","Australia + Central","Germany West Central","Norway East","Switzerland North","UAE North","Australia Southeast","Korea South","Canada Central","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"}' + Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway West","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps/keyVaultSettings","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway West","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"}' headers: cache-control: - no-cache content-length: - - '53709' + - '61783' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:40 GMT + - Fri, 26 Feb 2021 06:44:29 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_registration.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_registration.yaml index db1760acd63b..599fe3c88757 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_registration.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_registration.yaml @@ -11,33 +11,35 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search/unregister?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search/unregister?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Unregistering","registrationPolicy":"RegistrationRequired"}' + SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Unregistering","registrationPolicy":"RegistrationRequired"}' headers: cache-control: - no-cache content-length: - - '2019' + - '2205' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:45 GMT + - Fri, 26 Feb 2021 06:44:32 GMT expires: - '-1' pragma: @@ -65,33 +67,35 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Unregistering","registrationPolicy":"RegistrationRequired"}' + SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Unregistering","registrationPolicy":"RegistrationRequired"}' headers: cache-control: - no-cache content-length: - - '2019' + - '2205' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:45 GMT + - Fri, 26 Feb 2021 06:44:32 GMT expires: - '-1' pragma: @@ -117,33 +121,35 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search/register?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search/register?api-version=2020-10-01 response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Registering","registrationPolicy":"RegistrationRequired"}' + SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Registering","registrationPolicy":"RegistrationRequired"}' headers: cache-control: - no-cache content-length: - - '2017' + - '2203' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:48 GMT + - Fri, 26 Feb 2021 06:44:35 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_tenant.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_tenant.yaml index 85eb12f459f4..db541bf0675c 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_tenant.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_provider_tenant.yaml @@ -9,9 +9,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/providers/Microsoft.Web?api-version=2020-06-01 + uri: https://management.azure.com/providers/Microsoft.Web?api-version=2020-10-01 response: body: string: '{"namespace":"Microsoft.Web","resourceTypes":[{"resourceType":"publishingUsers","locations":["Central @@ -22,10 +22,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -33,10 +33,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -44,9 +44,9 @@ interactions: Central US","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East","Brazil Southeast","Switzerland + North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East - US 2 EUAP","Central US EUAP","France South","South Africa West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central + US 2 EUAP","Central US EUAP","France South","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -54,10 +54,43 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"generateGithubAccessTokenForAppserviceCLI","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central + 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast + Asia","Central US","Japan West","Central India","UK South","Canada East","Korea + Central","France Central","North Europe","West US 2","East US","West India","East + US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","France South","East Asia","Japan East","South Africa + West"],"apiVersions":["2020-10-01","2020-09-01"],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil + Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia + Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil + Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia + Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"webAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -65,10 +98,20 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central + West"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/webAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","France South","East + Asia","Japan East","West US","Australia East","Brazil South","Southeast Asia","Central + US","Japan West","Central India","UK South","Canada East","Korea Central","France + Central","North Europe","West US 2","East US","West India","East US 2","Australia + Central","Germany West Central","Norway West","Norway East","UAE Central","Germany + North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","Australia + Central 2","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"functionAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -76,13 +119,25 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"staticSites","locations":["West + West"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/functionAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","France South","East + Asia","Japan East","West US","Australia East","Brazil South","Southeast Asia","Central + US","Japan West","Central India","UK South","Canada East","Korea Central","France + Central","North Europe","West US 2","East US","West India","East US 2","Australia + Central","Germany West Central","Norway West","Norway East","UAE Central","Germany + North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","Australia + Central 2","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"staticSites","locations":["West + US 2","Central US","East US 2","West Europe","East Asia","East US 2 EUAP","Central + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/previewStaticSiteWorkflowFile","locations":["West US 2","Central US","East US 2","West Europe","East Asia","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"listSitesAssignedToHostName","locations":["Central + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"listSitesAssignedToHostName","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -90,10 +145,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -101,7 +156,7 @@ interactions: South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","France Central","France South","West Central US","East Asia (Stage)","North Central US (Stage)","East - US 2 EUAP","Central US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["East + US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["East US 2 EUAP","South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan @@ -109,10 +164,10 @@ interactions: Africa West","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West India","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","Central US EUAP"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East + US (Stage)","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East US 2 EUAP","South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan @@ -120,54 +175,54 @@ interactions: Africa West","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West India","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","Central US EUAP"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South + US (Stage)","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","France South","East Asia","Japan East","South Africa West","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","France South","East Asia","Japan East","South Africa West","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","France South","East Asia","Japan East","South Africa West","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East Asia","Japan East","France South","South Africa West","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -175,10 +230,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","France South","East Asia","Japan East","South Africa West","East US 2 @@ -186,10 +241,10 @@ interactions: Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North - Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"serverFarms","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central @@ -197,11 +252,11 @@ interactions: Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"sites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East US 2 EUAP","Central @@ -209,10 +264,10 @@ interactions: US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE Central","Germany - North","Brazil Southeast","Switzerland West","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","France - South","East Asia","Japan East","South Africa West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","France South","East Asia","Japan East","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"sites/slots","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central @@ -220,14 +275,14 @@ interactions: Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"runtimes","locations":["France South"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":["France - South"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["France - South"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":["France + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"runtimes","locations":["France South"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":["France + South"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["France + South"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":["France South"],"apiVersions":["2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/premieraddons","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central @@ -236,21 +291,21 @@ interactions: Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North - Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["South - Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East - US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East - US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West - Europe","Australia Central 2","France South","East Asia","South Africa West","West - US","Australia East","Brazil South","Central US","Japan West","Central India","Canada - East","Korea Central","France Central","West India","Australia Central","Germany - West Central","Norway West","Norway East","UAE Central","Germany North","Brazil - Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia - Southeast","Korea South","Canada Central","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"zoneMappings":[],"capabilities":"SupportsTags, + Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["MSFT + West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central + US (Stage)","South Central US","South Africa North","West US 2","East US 2","East + US","UK South","Southeast Asia","North Europe","Japan East","West Europe","Australia + Central 2","France South","East Asia","South Africa West","West US","Australia + East","Brazil South","Central US","Japan West","Central India","Canada East","Korea + Central","France Central","West India","Australia Central","Germany West Central","Norway + West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland + West","Switzerland North","North Central US","UK West","Australia Southeast","Korea + South","Canada Central","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"zoneMappings":[],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments/multiRolePools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central @@ -258,23 +313,23 @@ interactions: East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","France South","East Asia","Japan East","South Africa West","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West - Central","Norway West","Norway East","UAE Central","Germany North","Brazil + Central","Norway West","Norway East","UAE Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North - Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North + Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"deploymentLocations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central @@ -283,48 +338,48 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East","Brazil Southeast","Switzerland + North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","France - South","South Africa West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South + South","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","France South","East Asia","Japan East","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE Central","Germany - North","Brazil Southeast","Switzerland West","Switzerland North","Australia + North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","Australia Central 2","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North - Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South + Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","France South","East Asia","Japan East","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE Central","Germany - North","Brazil Southeast","Switzerland West","Switzerland North","Australia + North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","Australia Central 2","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North - Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":["France - South"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South + Central US (Stage)","East US 2 EUAP","Central US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":["France + South"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"apiManagementAccounts","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"apiManagementAccounts","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West India","Central India","South India","Canada Central","Canada East","West Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central - US (Stage)","North Central US (Stage)","France Central"],"apiVersions":["2020-06-01","2019-08-01","2015-11-01-rc","2015-11-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-11-01-rc"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2015-11-01-rc"},{"profileVersion":"2018-06-01-profile","apiVersion":"2015-11-01-rc"}],"capabilities":"None"},{"resourceType":"apiManagementAccounts/connections","locations":["South + US (Stage)","North Central US (Stage)","France Central"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2015-11-01-rc","2015-11-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-11-01-rc"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2015-11-01-rc"},{"profileVersion":"2018-06-01-profile","apiVersion":"2015-11-01-rc"}],"capabilities":"None"},{"resourceType":"apiManagementAccounts/connections","locations":["South Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","Central US","Brazil South","Australia East","Australia @@ -390,70 +445,79 @@ interactions: (Stage)","Central US (Stage)","North Central US (Stage)","France Central"],"apiVersions":["2017-12-01","2017-04-01","2015-11-01-rc","2015-11-01-preview"],"capabilities":"None"},{"resourceType":"connections","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"customApis","locations":["North Central + US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast + Asia","West US","East US","East US 2","Japan West","Japan East","Brazil South","Brazil + Southeast","Central US EUAP","East US 2 EUAP","Australia East","Australia Southeast","South India","Central India","West India","West US 2","West Central US","Canada Central","Canada East","UK South","UK West","France Central","France South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"customApis","locations":["North Central - US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast - Asia","West US","East US","East US 2","Japan West","Japan East","Brazil South","Central - US EUAP","East US 2 EUAP","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central","Switzerland - North","Germany North"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, + Central","UAE North","Switzerland North","Switzerland West","Norway East","Germany + North","Germany West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/listWsdlInterfaces","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"locations/connectionGatewayInstallations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Central US EUAP","East US 2 EUAP","Australia East","Australia - Southeast","South India","Central India","West India","West US 2","West Central - US","Canada Central","Canada East","UK South","UK West","France Central","France - South","Korea Central","Korea South","South Africa West","South Africa North","UAE - Central","Switzerland North","Germany North"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central + East","Brazil South","Brazil Southeast","Central US EUAP","East US 2 EUAP","Australia + East","Australia Southeast","South India","Central India","West India","West + US 2","West Central US","Canada Central","Canada East","UK South","UK West","France + Central","France South","Korea Central","Korea South","South Africa West","South + Africa North","UAE Central","UAE North","Switzerland North","Switzerland West","Norway + East","Germany North","Germany West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -461,10 +525,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -472,10 +536,10 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -483,43 +547,43 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East","Brazil + Central","Switzerland North","Germany West Central","Norway East","UAE North","Brazil Southeast","Switzerland West","Norway West","UAE Central","Germany North","Australia Central 2","East US 2 EUAP","Central US EUAP","France South","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Brazil Southeast","Switzerland West","Switzerland + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","West US 2","East US","West India","East US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Switzerland North","Brazil Southeast","Switzerland + Central","Germany North","Switzerland North","UAE North","Brazil Southeast","Switzerland West","North Central US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South India","West Central US","East Asia (Stage)","North Central US (Stage)","France South","East Asia","Japan East","South Africa - West"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["West + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["West US","North Central US","South Central US","Brazil South","Canada East","UK West","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East @@ -527,19 +591,41 @@ interactions: Europe","Australia Central 2","France South","East Asia","South Africa West","Australia East","Central US","Japan West","Central India","Korea Central","France Central","West India","Australia Central","Germany West Central","Norway West","Norway East","UAE - Central","Germany North","Switzerland North","Brazil Southeast","Switzerland + Central","Germany North","Switzerland North","UAE North","Brazil Southeast","Switzerland West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central US (Stage)","East US 2 EUAP","Central - US EUAP"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"}]}' + US EUAP"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central + 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast + Asia","Central US","Japan West","Central India","UK South","Canada East","Korea + Central","France Central","North Europe","West US 2","East US","West India","East + US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","France South","East Asia","Japan East","South Africa + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps/keyVaultSettings","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","Australia Central + 2","East US 2 EUAP","Central US EUAP","West US","Australia East","Brazil South","Southeast + Asia","Central US","Japan West","Central India","UK South","Canada East","Korea + Central","France Central","North Europe","West US 2","East US","West India","East + US 2","Australia Central","Germany West Central","Norway West","Norway East","UAE + Central","Germany North","UAE North","Brazil Southeast","Switzerland West","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","France South","East Asia","Japan East","South Africa + West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"}]}' headers: cache-control: - no-cache content-length: - - '65890' + - '75514' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:49 GMT + - Fri, 26 Feb 2021 06:44:37 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_providers.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_providers.yaml index e2dd337ab976..e6a822ccf58f 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_providers.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_providers.yaml @@ -9,157 +9,206 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AppConfiguration","namespace":"Microsoft.AppConfiguration","authorizations":[{"applicationId":"35ffadb3-7fc1-497e-b61b-381d28e744cc","roleDefinitionId":"fffa409e-a8cc-4cbf-8e1c-6d940b33040e"}],"resourceTypes":[{"resourceType":"configurationStores","locations":["West + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Confluent","namespace":"Microsoft.Confluent","authorizations":[{"applicationId":"1448fd13-7e74-41f4-b6e3-17e485d8ac2e","roleDefinitionId":"4db34280-b0be-4827-aa5b-418391409cee"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"},{"resourceType":"locations/OperationStatuses","locations":["West + US 2","East US 2 EUAP","West Central US","Canada Central","East US","UK South","West + Europe","Central US","East US 2","North Europe","Southeast Asia"],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"},{"resourceType":"organizations","locations":["West + US 2","West Central US","Canada Central","East US","UK South","West Europe","Central + US","East US 2","North Europe","Southeast Asia"],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"},{"resourceType":"agreements","locations":[],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureActiveDirectory","namespace":"Microsoft.AzureActiveDirectory","resourceTypes":[{"resourceType":"guestUsages","locations":["Global","United + States","Europe","Asia Pacific","Australia"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"b2cDirectories","locations":["Global","United + States","Europe","Asia Pacific","Australia"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview","2019-01-01-preview","2017-01-30","2016-12-13-preview","2016-02-10-privatepreview"],"defaultApiVersion":"2017-01-30","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"checkNameAvailability","locations":["Global","United + States","Europe","Asia Pacific","Australia"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview","2019-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Global","United + States","Europe","Asia Pacific","Australia"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview","2019-01-01-preview","2017-01-30","2016-12-13-preview","2016-02-10-privatepreview"],"defaultApiVersion":"2017-01-30","capabilities":"None"},{"resourceType":"b2ctenants","locations":["Global","United + States","Europe","Asia Pacific","Australia"],"apiVersions":["2020-05-01-preview","2016-02-10-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IoTCentral","namespace":"Microsoft.IoTCentral","authorizations":[{"applicationId":"9edfcdd9-0bc5-4bd4-b287-c3afc716aac7"}],"resourceTypes":[{"resourceType":"IoTApps","locations":["West + Europe","West US","East US 2","North Europe","East US","Central US","West + Central US","Australia","Asia Pacific","Europe","Japan","UK","United States"],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"checkSubdomainAvailability","locations":[],"apiVersions":["2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"appTemplates","locations":[],"apiVersions":["2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Attestation","namespace":"Microsoft.Attestation","authorizations":[{"applicationId":"c61423b7-1d1f-430d-b444-0eee53298103","roleDefinitionId":"7299b0b1-11da-4858-8943-7db197005959"}],"resourceTypes":[{"resourceType":"attestationProviders","locations":["East + US 2","Central US","UK South","East US","Canada Central","Canada East","UK + West","West US","North Europe","West Europe"],"apiVersions":["2020-10-01","2018-09-01-preview","2018-09-01"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"defaultProviders","locations":["East US + 2","Central US","UK South","East US","Canada Central","Canada East","UK West","West + US","North Europe","West Europe"],"apiVersions":["2020-10-01","2018-09-01-preview","2018-09-01"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-10-01","2018-09-01-preview","2018-09-01"],"capabilities":"None"},{"resourceType":"locations/defaultProvider","locations":["East + US 2","Central US","UK South","East US","Canada Central","Canada East","UK + West","West US","North Europe","West Europe"],"apiVersions":["2020-10-01","2018-09-01-preview","2018-09-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01","2018-09-01-preview","2018-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Kubernetes","namespace":"Microsoft.Kubernetes","authorizations":[{"applicationId":"64b12d6e-6549-484c-8cc6-6281839ba394","roleDefinitionId":"1d1d44cf-68a1-4def-a2b6-cd7efc3515af"},{"applicationId":"359431ad-ece5-496b-8768-be4bbfd82f36","roleDefinitionId":"1b5c71b7-9814-4b40-b62a-23018af874d8"},{"applicationId":"0000dab9-8b21-4ba2-807f-1743968cef00","roleDefinitionId":"1b5c71b7-9814-4b40-b62a-23018af874d8"},{"applicationId":"8edd93e1-2103-40b4-bd70-6e34e586362d","roleDefinitionId":"eb67887a-31e8-4e4e-bf5b-14ff79351a6f"}],"resourceTypes":[{"resourceType":"connectedClusters","locations":["West + Europe","East US","West Central US","South Central US","Southeast Asia","UK + South","East US 2","West US 2","Australia East","North Europe"],"apiVersions":["2021-04-01-preview","2021-03-01","2020-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2021-04-01-preview","2021-03-01","2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East + US 2 EUAP","West Europe","East US","West Central US","South Central US","Southeast + Asia","UK South","East US 2","West US 2","Australia East","North Europe"],"apiVersions":["2021-04-01-preview","2021-03-01","2020-01-01-preview"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2021-04-01-preview","2021-03-01","2020-01-01-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2021-04-01-preview","2021-03-01","2020-01-01-preview","2019-11-01-preview","2019-09-01-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AppConfiguration","namespace":"Microsoft.AppConfiguration","authorizations":[{"applicationId":"35ffadb3-7fc1-497e-b61b-381d28e744cc","roleDefinitionId":"fffa409e-a8cc-4cbf-8e1c-6d940b33040e"}],"resourceTypes":[{"resourceType":"configurationStores","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"configurationStores/keyValues","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview"],"capabilities":"None"},{"resourceType":"configurationStores/eventGridFilters","locations":["West + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview"],"capabilities":"None"},{"resourceType":"configurationStores/eventGridFilters","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["West + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["West + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West Central US","Central US","West US","East US","West Europe","Southeast Asia","Australia East","Australia Southeast","North Europe","UK South","South Central US","East US 2","West US 2","Brazil South","Canada Central","Central India","East Asia","France - Central","Japan East","Korea Central","North Central US"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataBoxEdge","namespace":"Microsoft.DataBoxEdge","authorizations":[{"applicationId":"2368d027-f996-4edb-bf48-928f98f2ab8c"}],"resourceTypes":[{"resourceType":"DataBoxEdgeDevices","locations":["East - US","West Europe","Southeast Asia"],"apiVersions":["2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Central US","Switzerland North","Germany + West Central","UAE North"],"apiVersions":["2020-07-01-preview","2020-06-01","2019-11-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataBoxEdge","namespace":"Microsoft.DataBoxEdge","authorizations":[{"applicationId":"2368d027-f996-4edb-bf48-928f98f2ab8c"}],"resourceTypes":[{"resourceType":"DataBoxEdgeDevices","locations":["East + US","West Europe","Southeast Asia"],"apiVersions":["2020-12-01","2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"defaultApiVersion":"2020-12-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"DataBoxEdgeDevices/checkNameAvailability","locations":["East - US","West Europe","Southeast Asia"],"apiVersions":["2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataBox","namespace":"Microsoft.DataBox","authorizations":[{"applicationId":"5613cb5c-a7c9-4099-8034-511fd7616cb2","roleDefinitionId":"382D72D1-63DC-4243-9B99-CB69FDD473D8","managedByRoleDefinitionId":"f4c0a4f9-768c-4927-ab83-d319111d6ef4"}],"resourceTypes":[{"resourceType":"jobs","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"SystemAssignedResourceIdentity, - SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/validateAddress","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/availableSkus","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/validateInputs","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/regionConfiguration","locations":["West - US","West Europe","Southeast Asia","East Asia","South India","Brazil South","Australia - East","Canada Central","Korea Central","Japan East","South Africa North"],"apiVersions":["2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StreamAnalytics","namespace":"Microsoft.StreamAnalytics","resourceTypes":[{"resourceType":"streamingjobs","locations":["Central + US","West Europe","Southeast Asia"],"apiVersions":["2020-12-01","2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-12-01","2020-09-01-preview","2020-09-01","2020-07-01-preview","2020-07-01","2020-06-01","2020-05-01-preview","2020-01-01","2019-08-01","2019-07-01","2019-03-01","2018-07-01","2017-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataBox","namespace":"Microsoft.DataBox","authorizations":[{"applicationId":"5613cb5c-a7c9-4099-8034-511fd7616cb2","roleDefinitionId":"382D72D1-63DC-4243-9B99-CB69FDD473D8","managedByRoleDefinitionId":"f4c0a4f9-768c-4927-ab83-d319111d6ef4"}],"resourceTypes":[{"resourceType":"jobs","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/validateAddress","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/availableSkus","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/validateInputs","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"},{"resourceType":"locations/regionConfiguration","locations":["West + US","West Europe","Southeast Asia","East Asia","South India","Australia East","Canada + Central","Korea Central","Japan East","South Africa North","Brazil South","UAE + Central","UK South"],"apiVersions":["2020-11-01","2020-04-01","2019-09-01","2018-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StreamAnalytics","namespace":"Microsoft.StreamAnalytics","resourceTypes":[{"resourceType":"streamingjobs","locations":["Central US","West Europe","East US 2","North Europe","Japan East","West US","Southeast Asia","South Central US","East Asia","Japan West","North Central US","East US","Australia East","Australia Southeast","Brazil South","Central India","West Central US","UK South","UK West","Canada Central","Canada East","West US 2","Korea - Central","France Central"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","France Central","South India"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"locations","locations":["West Europe","Central - US","East US 2","North Europe","Japan East","West US","Southeast Asia","South + SupportsLocation"},{"resourceType":"clusters","locations":["Central US","West + Europe","East US 2","North Europe","Japan East","West US","Southeast Asia","South Central US","East Asia","Japan West","North Central US","East US","Australia East","Australia Southeast","Brazil South","Central India","West Central US","UK - South","West US 2","UK West","Canada Central","Canada East","Korea Central","France - Central"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/quotas","locations":[],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West + South","UK West","Canada Central","Canada East","West US 2","Korea Central","France + Central","South India"],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"clusters/privateEndpoints","locations":["Central + US","West Europe","East US 2","North Europe","Japan East","West US","Southeast + Asia","South Central US","East Asia","Japan West","North Central US","East + US","Australia East","Australia Southeast","Brazil South","Central India","West + Central US","UK South","UK West","Canada Central","Canada East","West US 2","Korea + Central","France Central","South India"],"apiVersions":["2020-03-01-preview","2020-03-01"],"capabilities":"None"},{"resourceType":"locations","locations":["West + Europe","Central US","East US 2","North Europe","Japan East","West US","Southeast + Asia","South Central US","East Asia","Japan West","North Central US","East + US","Australia East","Australia Southeast","Brazil South","Central India","West + Central US","UK South","West US 2","UK West","Canada Central","Canada East","Korea + Central","France Central","South India"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/quotas","locations":[],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01","2015-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West Europe","West US","Central US","East US 2","North Europe","Japan East","Southeast Asia","South Central US","East Asia","Japan West","North Central US","East US","Australia East","Australia Southeast","Brazil South","Central India","West Central US","UK South","UK West","Canada Central","Canada East","West US 2","Korea - Central","France Central"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Logic","namespace":"Microsoft.Logic","authorization":{"applicationId":"7cd684f4-8a78-49b0-91ec-6a35d38739ba","roleDefinitionId":"cb3ef1fb-6e31-49e2-9d87-ed821053fe58"},"resourceTypes":[{"resourceType":"workflows","locations":["North + Central","France Central","South India"],"apiVersions":["2019-06-01","2018-11-01","2017-04-01-preview","2016-03-01","2015-11-01","2015-10-01","2015-09-01","2015-08-01-preview","2015-06-01","2015-05-01","2015-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Logic","namespace":"Microsoft.Logic","authorization":{"applicationId":"7cd684f4-8a78-49b0-91ec-6a35d38739ba","roleDefinitionId":"cb3ef1fb-6e31-49e2-9d87-ed821053fe58"},"resourceTypes":[{"resourceType":"workflows","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","Canada Central","Canada East","West US 2","West Central - US","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa North","South Africa West","UAE Central","Switzerland - North"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Brazil Southeast","Australia East","Australia Southeast","South + India","Central India","West India","Canada Central","Canada East","West US + 2","West Central US","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa North","South Africa West","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"locations/workflows","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","Canada Central","Canada East","West US 2","West Central - US","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa North","South Africa West","UAE Central","Switzerland - North"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["North + East","Brazil South","Brazil Southeast","Australia East","Australia Southeast","South + India","Central India","West India","Canada Central","Canada East","West US + 2","West Central US","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa North","South Africa West","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["North Central US"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","Canada Central","Canada East","West US 2","West Central - US","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa North","South Africa West","UAE Central","Switzerland - North"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"None"},{"resourceType":"integrationAccounts","locations":["North + East","Brazil South","Brazil Southeast","Australia East","Australia Southeast","South + India","Central India","West India","Canada Central","Canada East","West US + 2","West Central US","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa North","South Africa West","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2019-05-01","2018-07-01-preview","2017-07-01","2016-10-01","2016-06-01","2015-08-01-preview","2015-02-01-preview"],"capabilities":"None"},{"resourceType":"integrationAccounts","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","Canada Central","Canada East","West US 2","West Central - US","UK South","UK West","France Central","France South","Korea Central","South - Africa North","South Africa West","UAE Central","Switzerland North"],"apiVersions":["2019-05-01","2018-07-01-preview","2016-06-01","2015-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Brazil Southeast","Australia East","Australia Southeast","South + India","Central India","West India","Canada Central","Canada East","West US + 2","West Central US","UK South","UK West","France Central","France South","Korea + Central","South Africa North","South Africa West","UAE Central","UAE North","Switzerland + North","Switzerland West","Norway East","Germany North","Germany West Central"],"apiVersions":["2019-05-01","2018-07-01-preview","2016-06-01","2015-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"integrationServiceEnvironments","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan East","Australia East","Australia Southeast","South India","Central India","Canada - Central","West US 2","UK South","UK West"],"apiVersions":["2019-06-01-preview","2019-05-01","2018-07-01-preview","2018-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","West US 2","UK South","UK West","France Central","South Africa North","UAE + North"],"apiVersions":["2019-06-01-preview","2019-05-01","2018-07-01-preview","2018-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"integrationServiceEnvironments/managedApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan East","Australia East","Australia Southeast","South India","Central India","Canada - Central","West US 2","West Central US","UK South","UK West"],"apiVersions":["2019-06-01-preview","2019-05-01","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["West - US","West US 2","East US","East US 2","North Europe","West Europe","Southeast - Asia","East Asia","North Central US","South Central US","Central US","Japan - West","Japan East","Korea Central","Australia East","Australia Southeast","Brazil - South","Central India","West Central US","Canada Central","UK South","France - Central","South Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"Registering","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Databricks","namespace":"Microsoft.Databricks","authorizations":[{"applicationId":"d9327919-6775-4843-9037-3fb0fb0473cb","roleDefinitionId":"f31567d0-b61f-43c2-97a5-a98cdc3bfcb6","managedByRoleDefinitionId":"8e3af657-a8ff-443c-a75c-2fe8c4bcb635"},{"applicationId":"2ff814a6-3304-4ab8-85cb-cd0e6f879c1d","roleDefinitionId":"f31567d0-b61f-43c2-97a5-a98cdc3bfcb6","managedByRoleDefinitionId":"8e3af657-a8ff-443c-a75c-2fe8c4bcb635"}],"resourceTypes":[{"resourceType":"workspaces","locations":["West + Central","West US 2","West Central US","UK South","UK West","France Central","South + Africa North","UAE North"],"apiVersions":["2019-06-01-preview","2019-05-01","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Databricks","namespace":"Microsoft.Databricks","authorizations":[{"applicationId":"d9327919-6775-4843-9037-3fb0fb0473cb","roleDefinitionId":"f31567d0-b61f-43c2-97a5-a98cdc3bfcb6","managedByRoleDefinitionId":"8e3af657-a8ff-443c-a75c-2fe8c4bcb635"},{"applicationId":"2ff814a6-3304-4ab8-85cb-cd0e6f879c1d","roleDefinitionId":"f31567d0-b61f-43c2-97a5-a98cdc3bfcb6","managedByRoleDefinitionId":"8e3af657-a8ff-443c-a75c-2fe8c4bcb635"}],"resourceTypes":[{"resourceType":"workspaces","locations":["West US","East US 2","West Europe","East US","North Europe","Southeast Asia","East Asia","South Central US","North Central US","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","Korea Central","Korea South","South Africa - West","South Africa North","Brazil South","France Central","UAE North"],"apiVersions":["2018-04-01"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"workspaces/virtualNetworkPeerings","locations":["West + West","South Africa North","Brazil South","Switzerland North","France Central","UAE + North"],"apiVersions":["2018-04-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"workspaces/virtualNetworkPeerings","locations":["West US","East US 2","West Europe","North Europe","East US","Southeast Asia","East Asia","South Central US","North Central US","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","Korea Central","Korea South","South Africa - North","South Africa West","UAE North","Brazil South","France Central"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"workspaces/dbWorkspaces","locations":["West + North","South Africa West","UAE North","Brazil South","France Central","Switzerland + North"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"workspaces/dbWorkspaces","locations":["West US","East US 2","West Europe","North Europe","East US","Southeast Asia","East Asia","South Central US","North Central US","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","Korea Central","Korea South","South Africa - North","South Africa West","UAE North","Brazil South","France Central"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":["West + North","South Africa West","UAE North","Brazil South","France Central","Switzerland + North"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":["West US","East US 2","West Europe","North Europe","East US","Southeast Asia","East Asia","South Central US","North Central US","Korea South","Korea Central","South Africa North","South Africa West","Switzerland North","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","UAE North","Brazil South","France - Central"],"apiVersions":[],"capabilities":"None"},{"resourceType":"locations","locations":["West + Central"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"locations","locations":["West US","East US 2","West Europe","North Europe","East US","Southeast Asia","East Asia","South Central US","North Central US","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia @@ -172,87 +221,163 @@ interactions: South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","Korea Central","Korea South","South Africa - West","South Africa North","Brazil South","France Central","UAE North"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["West + West","South Africa North","Brazil South","Switzerland North","France Central","UAE + North"],"apiVersions":["2018-04-01"],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["West US","East US 2","West Europe","East US","North Europe","Southeast Asia","East Asia","South Central US","North Central US","West US 2","Central US","UK West","UK South","Australia East","Australia Southeast","Australia Central","Australia Central 2","Japan East","Japan West","Canada Central","Canada East","Central India","South India","West India","Korea Central","Korea South","South Africa - West","South Africa North","Brazil South","France Central","UAE North"],"apiVersions":["2018-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Cdn","namespace":"Microsoft.Cdn","authorizations":[],"resourceTypes":[{"resourceType":"profiles","locations":["global","Australia + West","South Africa North","Brazil South","Switzerland North","France Central","UAE + North"],"apiVersions":["2018-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Cdn","namespace":"Microsoft.Cdn","authorizations":[],"resourceTypes":[{"resourceType":"profiles","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"CrossResourceGroupResourceMove, + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"profiles/endpoints","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"CrossResourceGroupResourceMove, + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"profiles/endpoints/origins","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"profiles/endpoints/origingroups","locations":["global","Australia + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"profiles/endpoints/origingroups","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31"],"defaultApiVersion":"2019-12-31","capabilities":"None"},{"resourceType":"profiles/endpoints/customdomains","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/originresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/origingroupresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31"],"defaultApiVersion":"2019-12-31","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/customdomainresults","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"checkResourceUsage","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"validateProbe","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operations","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"edgenodes","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-09-01","2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"CdnWebApplicationFirewallPolicies","locations":["global"],"apiVersions":["2020-09-01","2020-04-15","2019-06-15-preview"],"defaultApiVersion":"2019-06-15-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"CdnWebApplicationFirewallManagedRuleSets","locations":[],"apiVersions":["2020-09-01","2020-04-15","2019-06-15-preview"],"defaultApiVersion":"2019-06-15-preview","capabilities":"None"},{"resourceType":"profiles/afdendpoints","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"profiles/afdendpoints/routes","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/customdomains","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/origingroups","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/origingroups/origins","locations":["global","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","Japan East","Japan + West","North Central US","North Europe","South Central US","South India","Southeast + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/rulesets","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31"],"defaultApiVersion":"2019-12-31","capabilities":"None"},{"resourceType":"profiles/endpoints/customdomains","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/rulesets/rules","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/secrets","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"profiles/securitypolicies","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/afdendpointresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/originresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/afdendpointresults/routeresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/origingroupresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/customdomainresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31"],"defaultApiVersion":"2019-12-31","capabilities":"None"},{"resourceType":"operationresults/profileresults/endpointresults/customdomainresults","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/origingroupresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/origingroupresults/originresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"checkResourceUsage","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/rulesetresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"validateProbe","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/rulesetresults/ruleresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"operations","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/secretresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"edgenodes","locations":["global","Australia + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"},{"resourceType":"operationresults/profileresults/securitypoliciesresults","locations":["global","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan West","North Central US","North Europe","South Central US","South India","Southeast - Asia","West Europe","West India","West US","West Central US"],"apiVersions":["2020-04-15","2020-03-31","2019-12-31","2019-06-15-preview","2019-04-15","2018-04-02","2017-10-12","2017-04-02","2016-10-02","2016-04-02","2015-06-01"],"defaultApiVersion":"2017-10-12","capabilities":"None"},{"resourceType":"CdnWebApplicationFirewallPolicies","locations":["global"],"apiVersions":["2020-04-15","2019-06-15-preview"],"defaultApiVersion":"2019-06-15-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"CdnWebApplicationFirewallManagedRuleSets","locations":[],"apiVersions":["2020-04-15","2019-06-15-preview"],"defaultApiVersion":"2019-06-15-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Media","namespace":"Microsoft.Media","authorization":{"applicationId":"374b2a64-3b6b-436b-934c-b820eacca870","roleDefinitionId":"aab70789-0cec-44b5-95d7-84b64c9487af"},"resourceTypes":[{"resourceType":"mediaservices","locations":["Japan + Asia","West Europe","West India","West US"],"apiVersions":["2020-09-01"],"defaultApiVersion":"2020-09-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Media","namespace":"Microsoft.Media","authorization":{"applicationId":"374b2a64-3b6b-436b-934c-b820eacca870","roleDefinitionId":"aab70789-0cec-44b5-95d7-84b64c9487af"},"resourceTypes":[{"resourceType":"mediaservices","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview","2015-10-01","2015-04-01"],"defaultApiVersion":"2020-05-01","capabilities":"CrossResourceGroupResourceMove, + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview","2015-10-01","2015-04-01"],"defaultApiVersion":"2020-05-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"mediaservices/assets","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East @@ -260,115 +385,131 @@ interactions: US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/contentKeyPolicies","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/contentKeyPolicies","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingLocators","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingLocators","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingPolicies","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingPolicies","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/eventGridFilters","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/eventGridFilters","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-02-05"],"defaultApiVersion":"2018-02-05","capabilities":"None"},{"resourceType":"mediaservices/transforms","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2018-02-05"],"defaultApiVersion":"2018-02-05","capabilities":"None"},{"resourceType":"mediaservices/transforms","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/transforms/jobs","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/transforms/jobs","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingEndpoints","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingEndpoints","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"CrossResourceGroupResourceMove, + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"mediaservices/liveEvents","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"CrossResourceGroupResourceMove, + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"mediaservices/liveEvents/liveOutputs","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingEndpointOperations","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/streamingEndpointOperations","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/liveEventOperations","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/liveEventOperations","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/liveOutputOperations","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/liveOutputOperations","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/assets/assetFilters","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2019-05-01-preview","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/assets/assetFilters","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/accountFilters","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"mediaservices/accountFilters","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview","2018-02-05","2015-10-01","2015-04-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"checknameavailability","locations":[],"apiVersions":["2015-10-01","2015-04-01"],"defaultApiVersion":"2015-10-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Japan + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview","2018-02-05","2015-10-01","2015-04-01"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"checknameavailability","locations":[],"apiVersions":["2015-10-01","2015-04-01"],"defaultApiVersion":"2015-10-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Japan West","Japan East","East Asia","Southeast Asia","West Europe","North Europe","East US","West US","Australia East","Australia Southeast","East US 2","Central US","Brazil South","Central India","West India","South India","North Central US","South Central US","UK South","UK West","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","France Central","France - South","South Africa North","South Africa West","Germany West Central","Germany - North","Switzerland West","Switzerland North"],"apiVersions":["2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Relay","namespace":"Microsoft.Relay","authorizations":[{"applicationId":"91bb937c-29c2-4275-982f-9465f0caf03d","roleDefinitionId":"6ea9e989-a5f4-4187-8d11-c8db3dd04da1"},{"applicationId":"80369ed6-5f11-4dd9-bef3-692475845e77"}],"resourceTypes":[{"resourceType":"namespaces","locations":["Australia + South","South Africa North","South Africa West","UAE Central","UAE North","Germany + West Central","Germany North","Switzerland West","Switzerland North","Norway + East"],"apiVersions":["2020-05-01","2018-07-01","2018-06-01-preview","2018-03-30-preview"],"defaultApiVersion":"2018-07-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Relay","namespace":"Microsoft.Relay","authorizations":[{"applicationId":"91bb937c-29c2-4275-982f-9465f0caf03d","roleDefinitionId":"6ea9e989-a5f4-4187-8d11-c8db3dd04da1"},{"applicationId":"80369ed6-5f11-4dd9-bef3-692475845e77"}],"resourceTypes":[{"resourceType":"namespaces","locations":["Australia East","Australia Southeast","Central US","East US","East US 2","West US 2","West US","North Central US","South Central US","West Central US","East Asia","Southeast Asia","Brazil South","Japan East","Japan West","North Europe","West Europe","Central @@ -392,30 +533,37 @@ interactions: India","West India","Canada Central","Canada East","UK West","UK South","Korea Central","Korea South","France Central","South Africa North","Australia Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2018-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"namespaces/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/networkrulesets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs/consumergroups","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"checkNamespaceAvailability","locations":[],"apiVersions":["2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-08-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"sku","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs","locations":[],"apiVersions":["2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs/checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"availableClusterRegions","locations":[],"apiVersions":["2018-01-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01-preview"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Devices","namespace":"Microsoft.Devices","authorizations":[{"applicationId":"0cd79364-7a90-4354-9984-6e36c841418d","roleDefinitionId":"C121DF10-FE58-4BC4-97F9-8296879F7BBB"},{"applicationId":"29f411f1-b2cf-4043-8ac8-2185d7316811"},{"applicationId":"89d10474-74af-4874-99a7-c23c2f643083","roleDefinitionId":"7df22794-26e3-4f94-9d50-a4f0f6e1cb41"}],"resourceTypes":[{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"checkProvisioningServiceNameAvailability","locations":[],"apiVersions":["2020-03-01","2020-01-01","2018-01-22","2017-11-15","2017-08-21-preview"],"defaultApiVersion":"2018-01-22","capabilities":"None"},{"resourceType":"usages","locations":[],"apiVersions":["2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2020-01-01","2019-11-04","2019-09-01","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01-preview","2018-04-01","2018-01-22-preview","2018-01-22","2017-11-15","2017-09-25-preview","2017-08-21-preview","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"IotHubs","locations":["West + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"namespaces/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/networkrulesets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventhubs/consumergroups","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"checkNamespaceAvailability","locations":[],"apiVersions":["2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-08-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"sku","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs","locations":[],"apiVersions":["2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs/checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"availableClusterRegions","locations":[],"apiVersions":["2018-01-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01-preview"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Devices","namespace":"Microsoft.Devices","authorizations":[{"applicationId":"0cd79364-7a90-4354-9984-6e36c841418d","roleDefinitionId":"C121DF10-FE58-4BC4-97F9-8296879F7BBB"},{"applicationId":"29f411f1-b2cf-4043-8ac8-2185d7316811"},{"applicationId":"89d10474-74af-4874-99a7-c23c2f643083","roleDefinitionId":"7df22794-26e3-4f94-9d50-a4f0f6e1cb41"}],"resourceTypes":[{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-08-31-preview","2020-08-31","2020-08-01","2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"checkProvisioningServiceNameAvailability","locations":[],"apiVersions":["2020-03-01","2020-01-01","2018-01-22","2017-11-15","2017-08-21-preview"],"defaultApiVersion":"2018-01-22","capabilities":"None"},{"resourceType":"usages","locations":[],"apiVersions":["2020-08-31-preview","2020-08-31","2020-08-01","2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-31-preview","2020-08-31","2020-08-01","2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-08-31-preview","2020-08-31","2020-08-01","2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2020-01-01","2019-11-04","2019-09-01","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01-preview","2018-04-01","2018-01-22-preview","2018-01-22","2017-11-15","2017-09-25-preview","2017-08-21-preview","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2018-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"IotHubs","locations":["West US","North Europe","East Asia","East US","West Europe","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","West US 2","West Central US","East US 2","Central US","UK South","UK West","South India","Central India","Canada Central","Canada East","Brazil South","South Central US","Korea - South","Korea Central","France Central","North Central US"],"apiVersions":["2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2020-01-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2020-01-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, + South","Korea Central","France Central","North Central US","Australia Central","Australia + Central 2","Germany North","Germany West Central","South Africa North","South + Africa West","UAE Central","UAE North"],"apiVersions":["2020-08-31-preview","2020-08-31","2020-08-01","2020-07-10-preview","2020-06-15","2020-04-01","2020-03-01","2020-01-01","2019-11-04","2019-07-01-preview","2019-03-22-preview","2019-03-22","2018-12-01-preview","2018-04-01-preview","2018-04-01","2018-01-22","2017-07-01","2017-01-19","2016-02-03","2015-08-15-preview"],"defaultApiVersion":"2020-01-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"IotHubs/eventGridFilters","locations":["West US","East US","West US 2","West Central US","East US 2","Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","UK South","UK West","South India","Central India","Canada Central","Canada East","Brazil South","South Central US","Korea South","Korea - Central","France Central","North Central US"],"apiVersions":["2018-07-31","2018-01-15-preview"],"capabilities":"None"},{"resourceType":"ProvisioningServices","locations":["East + Central","France Central","North Central US","Australia Central","Australia + Central 2","Germany North","Germany West Central","South Africa North","South + Africa West","UAE Central","UAE North"],"apiVersions":["2018-07-31","2018-01-15-preview"],"capabilities":"None"},{"resourceType":"ProvisioningServices","locations":["East US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","Japan West","Japan East","UK West","UK South","East US 2","Central US","West US 2","West Central US","North Central US","South - Central US"],"apiVersions":["2020-03-01","2020-01-01","2018-01-22","2017-11-15","2017-08-21-preview"],"defaultApiVersion":"2020-01-01","capabilities":"CrossResourceGroupResourceMove, + Central US","Australia Central","Australia Central 2","France Central","France + South","Canada East","Canada Central"],"apiVersions":["2020-03-01","2020-01-01","2018-01-22","2017-11-15","2017-08-21-preview"],"defaultApiVersion":"2020-01-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"IotHubs/securitySettings","locations":["West US","North Europe","East Asia","East US","West Europe","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","West US 2","West Central US","East US 2","Central US","UK South","UK West","South India","Central India","Canada Central","Canada East","Brazil South","South Central US","Korea - South","Korea Central","France Central","North Central US"],"apiVersions":["2019-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DevSpaces","namespace":"Microsoft.DevSpaces","resourceTypes":[{"resourceType":"controllers","locations":["East + South","Korea Central","France Central","North Central US","Australia Central","Australia + Central 2","Germany North","Germany West Central","South Africa North","South + Africa West","UAE Central","UAE North"],"apiVersions":["2019-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DevSpaces","namespace":"Microsoft.DevSpaces","resourceTypes":[{"resourceType":"controllers","locations":["East US","Canada East","West Europe","Canada Central","Central US","West US 2","West Central US","Southeast Asia","East US 2","North Europe","Australia East","UK South","South Central US","East Asia","Japan East","Australia SouthEast"],"apiVersions":["2019-04-01"],"capabilities":"CrossResourceGroupResourceMove, @@ -476,22 +624,25 @@ interactions: US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"CrossResourceGroupResourceMove, + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"clusters/applications","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"clusters/operationresults","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"clusters/operationresults","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations","locations":["East Asia","Southeast Asia","East US","East US 2","West US","North Central US","South Central US","Central US","North Europe","West Europe","Japan East","Japan West","Australia East","Australia Southeast","Brazil South","Central India"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/capabilities","locations":["East @@ -499,74 +650,88 @@ interactions: US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/usages","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/usages","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/billingSpecs","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/billingSpecs","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/azureasyncoperations","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/azureasyncoperations","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/validateCreateRequest","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"locations/validateCreateRequest","locations":["East US 2","South Central US","Australia Southeast","Central India","West Central US","West US 2","Canada East","Canada Central","Brazil South","UK South","UK West","East Asia","Australia East","Japan East","Japan West","North Europe","West Europe","North Central US","Central US","Southeast Asia","East US","Korea - South","Korea Central","West US","South India","France Central","UAE North","Switzerland - North","Switzerland West","South Africa North","Germany West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["East + South","Korea Central","West US","South India","France Central","UAE North","UAE + Central","Switzerland North","Switzerland West","South Africa North","Germany + West Central"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["East Asia","Southeast Asia","East US","East US 2","West US","North Central US","South Central US","Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India"],"apiVersions":["2018-06-01-preview","2015-03-01-preview"],"defaultApiVersion":"2015-03-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ContainerInstance","namespace":"Microsoft.ContainerInstance","authorizations":[{"applicationId":"6bb8e274-af5d-4df2-98a3-4fd78b4cafd9","roleDefinitionId":"3c60422b-a83a-428d-9830-22609c77aa6c"}],"resourceTypes":[{"resourceType":"containerGroups","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"SystemAssignedResourceIdentity, + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"serviceAssociationLinks","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"locations","locations":[],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/capabilities","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"locations","locations":[],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/capabilities","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","West Central US","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","West Central US","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/cachedImages","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-11-01","2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"locations/cachedImages","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["West + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-10-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["West Central US","West US","East US","West Europe","West US 2","North Europe","Southeast Asia","East US 2","Central US","Australia East","UK South","South Central US","Central India","Brazil South","South India","North Central US","East - Asia","Canada Central","Japan East","Korea Central","France Central"],"apiVersions":["2019-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Scheduler","namespace":"Microsoft.Scheduler","resourceTypes":[{"resourceType":"jobcollections","locations":["North + Asia","Canada Central","Japan East","Korea Central","France Central","Switzerland + North","Germany West Central","UAE North"],"apiVersions":["2020-11-01","2019-12-01","2018-12-01","2018-10-01","2018-09-01","2018-07-01","2018-06-01","2018-04-01","2018-02-01-preview","2017-12-01-preview","2017-10-01-preview","2017-08-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Scheduler","namespace":"Microsoft.Scheduler","resourceTypes":[{"resourceType":"jobcollections","locations":["North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","Japan West","Japan East","Brazil South","Central US","East US 2","Australia East","Australia Southeast","South India","Central @@ -589,9 +754,9 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-02-02-preview","2020-02-02","2019-06-15","2019-05-13-preview","2019-05-13","2018-12-20-preview","2018-07-10-preview","2018-07-10","2018-01-10","2017-07-01-preview","2017-07-01","2016-12-01","2016-08-10","2016-06-01","2016-05-01","2015-12-15","2015-12-10","2015-11-10","2015-08-15","2015-08-10","2015-06-10","2015-03-15"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-10"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2021-01-01","2020-12-01","2020-10-01","2020-07-01-preview","2020-07-01","2020-02-02-preview","2020-02-02","2019-06-15","2019-05-13-preview","2019-05-13","2018-12-20-preview","2018-12-20","2018-07-10-preview","2018-07-10","2018-01-10","2017-07-01-preview","2017-07-01","2016-12-01","2016-08-10","2016-06-01","2016-05-01","2015-12-15","2015-12-10","2015-11-10","2015-08-15","2015-08-10","2015-06-10","2015-03-15"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-10"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-02-02-preview","2020-02-02","2019-06-15","2019-05-13-preview","2019-05-13","2018-07-10-preview","2018-07-10","2018-01-10","2017-09-01","2017-07-01-preview","2017-07-01","2016-12-01","2016-08-10","2016-06-01","2015-12-15","2015-12-10","2015-11-10","2015-08-15","2015-08-10","2015-06-10","2015-03-15"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-08-10"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2017-07-01","2016-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"locations/backupStatus","locations":["West + SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2021-01-01","2020-12-01","2020-10-01","2020-07-01-preview","2020-07-01","2020-02-02-preview","2020-02-02","2019-06-15","2019-05-13-preview","2019-05-13","2018-07-10-preview","2018-07-10","2018-01-10","2017-09-01","2017-07-01-preview","2017-07-01","2016-12-01","2016-08-10","2016-06-01","2015-12-15","2015-12-10","2015-11-10","2015-08-15","2015-08-10","2015-06-10","2015-03-15"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-08-10"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2017-07-01","2016-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"locations/backupStatus","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South @@ -640,28 +805,28 @@ interactions: India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-12-20-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrrJob","locations":["West + Central","Norway East"],"apiVersions":["2018-12-20-preview","2018-12-20"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrrJob","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-12-20-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupAadProperties","locations":["West + Central","Norway East"],"apiVersions":["2018-12-20-preview","2018-12-20"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupAadProperties","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-12-20-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrossRegionRestore","locations":["West + Central","Norway East"],"apiVersions":["2018-12-20-preview","2018-12-20"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrossRegionRestore","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-12-20-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrrOperationResults","locations":["West + Central","Norway East"],"apiVersions":["2018-12-20-preview","2018-12-20"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"locations/backupCrrOperationResults","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South @@ -675,7 +840,7 @@ interactions: India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-12-20-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"backupProtectedItems","locations":["West + Central","Norway East"],"apiVersions":["2018-12-20-preview","2018-12-20"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-12-20-preview"}],"capabilities":"None"},{"resourceType":"backupProtectedItems","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","North Central US","South Central US","Japan East","Japan West","Australia East","Australia Southeast","Central US","East US 2","Central India","South @@ -689,68 +854,75 @@ interactions: India","West India","West Central US","Canada Central","Canada East","West US 2","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2018-07-10"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-10"}],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DocumentDB","namespace":"Microsoft.DocumentDB","authorizations":[{"applicationId":"57c0fc58-a83a-41d0-8ae9-08952659bdfd","roleDefinitionId":"FFFD5CF5-FFD3-4B24-B0E2-0715ADD4C282"},{"applicationId":"36e2398c-9dd3-4f29-9a72-d9f2cfc47ad9","roleDefinitionId":"D5A795DE-916D-4818-B015-33C9E103E39B"},{"applicationId":"a232010e-820c-4083-83bb-3ace5fc29d0b"}],"resourceTypes":[{"resourceType":"databaseAccounts","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"databaseAccountNames","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"operations","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"operationResults","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia - Central","Australia East","Australia Southeast","Canada Central","Canada East","Central - India","Central US","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations","locations":["Australia + Central","Norway East"],"apiVersions":["2018-07-10"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-10"}],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DocumentDB","namespace":"Microsoft.DocumentDB","authorizations":[{"applicationId":"57c0fc58-a83a-41d0-8ae9-08952659bdfd","roleDefinitionId":"FFFD5CF5-FFD3-4B24-B0E2-0715ADD4C282"},{"applicationId":"36e2398c-9dd3-4f29-9a72-d9f2cfc47ad9","roleDefinitionId":"D5A795DE-916D-4818-B015-33C9E103E39B"},{"applicationId":"a232010e-820c-4083-83bb-3ace5fc29d0b","roleDefinitionId":"D5A795DE-916D-4818-B015-33C9E103E39B"}],"resourceTypes":[{"resourceType":"databaseAccounts","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"defaultApiVersion":"2020-06-01-preview","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"databaseAccountNames","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["Australia + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"operations","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"capabilities":"None"},{"resourceType":"locations/restorableDatabaseAccounts","locations":["Australia + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"operationResults","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview"],"capabilities":"None"},{"resourceType":"restorableDatabaseAccounts","locations":["Australia + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-04-08"}],"capabilities":"None"},{"resourceType":"locations","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-06-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServiceFabric","namespace":"Microsoft.ServiceFabric","authorization":{"applicationId":"74cb6831-0dbb-4be1-8206-fd4df301cdc2","roleDefinitionId":"e55cc65f-6903-4917-b4ef-f8d4640b57f5","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},"resourceTypes":[{"resourceType":"clusters","locations":["West + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2021-01-15","2020-09-01","2020-06-01-preview","2020-04-01","2020-03-01","2019-12-12","2019-08-01-preview","2019-08-01","2016-03-31","2016-03-19","2015-11-06","2015-04-08","2014-04-01"],"capabilities":"None"},{"resourceType":"locations/restorableDatabaseAccounts","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2020-06-01-preview"],"capabilities":"None"},{"resourceType":"restorableDatabaseAccounts","locations":["East + US","West Central US","North Central US","Central US","Brazil South","Canada + Central","West US 2","East US 2","France Central","Japan East","Southeast + Asia","Central India","South Africa North","Switzerland North","UAE North","UK + West","North Europe","West Europe","Norway East","Korea Central","Australia + East","Canada East","East Asia","Germany West Central","UK South","Australia + Central","Australia Southeast","Japan West","Korea South","South India","West + India","West US","South Central US"],"apiVersions":["2020-06-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServiceFabric","namespace":"Microsoft.ServiceFabric","authorization":{"applicationId":"74cb6831-0dbb-4be1-8206-fd4df301cdc2","roleDefinitionId":"e55cc65f-6903-4917-b4ef-f8d4640b57f5","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},"resourceTypes":[{"resourceType":"clusters","locations":["West US","West US 2","West Central US","East US","East US 2","Central US","West Europe","North Europe","UK West","UK South","Australia East","Australia Southeast","North Central US","East Asia","Southeast Asia","Japan West","Japan East","South @@ -765,46 +937,47 @@ interactions: India","West India","Central India","Brazil South","South Central US","Korea Central","Korea South","Canada Central","Canada East","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"locations","locations":[],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/clusterVersions","locations":["West + Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"locations","locations":[],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/clusterVersions","locations":["West US","West US 2","West Central US","East US","East US 2","Central US","West Europe","North Europe","UK West","UK South","Australia East","Australia Southeast","North Central US","East Asia","Southeast Asia","Japan West","Japan East","South India","West India","Central India","Brazil South","South Central US","Korea Central","Korea South","Canada Central","Canada East","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/environments","locations":["West + Central","Norway East"],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/environments","locations":["West US","West US 2","West Central US","East US","East US 2","Central US","West Europe","North Europe","UK West","UK South","Australia East","Australia Southeast","North Central US","East Asia","Southeast Asia","Japan West","Japan East","South India","West India","Central India","Brazil South","South Central US","Korea Central","Korea South","Canada Central","Canada East","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West + Central","Norway East"],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West US","West US 2","West Central US","East US","East US 2","Central US","West Europe","North Europe","UK West","UK South","Australia East","Australia Southeast","North Central US","East Asia","Southeast Asia","Japan West","Japan East","South India","West India","Central India","Brazil South","South Central US","Korea Central","Korea South","Canada Central","Canada East","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Central","Norway East"],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West US","West US 2","West Central US","East US","East US 2","Central US","West Europe","North Europe","UK West","UK South","Australia East","Australia Southeast","North Central US","East Asia","Southeast Asia","Japan West","Japan East","South India","West India","Central India","Brazil South","South Central US","Korea Central","Korea South","Canada Central","Canada East","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"managedclusters","locations":["East - Asia","North Europe","West Central US","East US 2"],"apiVersions":["2020-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-12-15-privatepreview","2020-12-15-preview","2020-12-01-privatepreview","2020-12-01-preview","2020-03-01","2020-02-01-privatepreview","2020-02-01-preview","2019-11-01-privatepreview","2019-11-01-preview","2019-06-01-preview","2019-03-01-privatepreview","2019-03-01-preview","2019-03-01","2018-02-01-privatepreview","2018-02-01","2017-07-01-privatepreview","2017-07-01-preview","2016-09-01","2016-03-01"],"capabilities":"None"},{"resourceType":"managedclusters","locations":["East + Asia","North Europe","West Central US","East US 2"],"apiVersions":["2021-01-01-preview","2020-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"managedclusters/nodetypes","locations":["East - Asia","North Europe","West Central US","East US 2"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedClusterOperations","locations":["East - Asia","North Europe","West Central US","East US 2"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedClusterOperationResults","locations":["East - Asia","North Europe","West Central US","East US 2"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataLakeAnalytics","namespace":"Microsoft.DataLakeAnalytics","resourceTypes":[{"resourceType":"accounts","locations":["East - US 2","North Europe","Central US","West Europe"],"apiVersions":["2016-11-01","2015-10-01-preview"],"defaultApiVersion":"2016-11-01","capabilities":"CrossResourceGroupResourceMove, + Asia","North Europe","West Central US","East US 2"],"apiVersions":["2021-01-01-preview","2020-01-01-preview"],"capabilities":"None"},{"resourceType":"managedclusters/applications","locations":["East + Asia","North Europe","West Central US","East US 2"],"apiVersions":["2021-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedClusterOperations","locations":["East + Asia","North Europe","West Central US","East US 2"],"apiVersions":["2021-01-01-preview","2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedClusterOperationResults","locations":["East + Asia","North Europe","West Central US","East US 2"],"apiVersions":["2021-01-01-preview","2020-01-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataLakeAnalytics","namespace":"Microsoft.DataLakeAnalytics","resourceTypes":[{"resourceType":"accounts","locations":["East + US 2","North Europe","Central US","West Europe"],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"defaultApiVersion":"2016-11-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"accounts/dataLakeStoreAccounts","locations":["East - US 2","North Europe","Central US","West Europe"],"apiVersions":["2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts","locations":["East - US 2","North Europe","Central US","West Europe"],"apiVersions":["2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts/containers","locations":["East - US 2","North Europe","Central US","West Europe"],"apiVersions":["2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts/containers/listSasTokens","locations":["East - US 2","North Europe","Central US","West Europe"],"apiVersions":["2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/capability","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Maps","namespace":"Microsoft.Maps","authorizations":[{"applicationId":"608f6f31-fed0-4f7b-809f-90f6c9b3de78","roleDefinitionId":"3431F0E6-63BC-482D-A96E-0AB819610A5F"},{"applicationId":"ba1ea022-5807-41d5-bbeb-292c7e1cf5f6","roleDefinitionId":"48195074-b752-4868-be0f-7c324a224aa1"}],"resourceTypes":[{"resourceType":"accounts","locations":["Global"],"apiVersions":["2020-02-01-preview","2018-05-01","2017-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2","North Europe","Central US","West Europe"],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts","locations":["East + US 2","North Europe","Central US","West Europe"],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts/containers","locations":["East + US 2","North Europe","Central US","West Europe"],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"accounts/storageAccounts/containers/listSasTokens","locations":["East + US 2","North Europe","Central US","West Europe"],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/capability","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-11-01-preview","2016-11-01","2015-10-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Maps","namespace":"Microsoft.Maps","authorizations":[{"applicationId":"608f6f31-fed0-4f7b-809f-90f6c9b3de78","roleDefinitionId":"3431F0E6-63BC-482D-A96E-0AB819610A5F"},{"applicationId":"ba1ea022-5807-41d5-bbeb-292c7e1cf5f6","roleDefinitionId":"48195074-b752-4868-be0f-7c324a224aa1"}],"resourceTypes":[{"resourceType":"accounts","locations":["Global"],"apiVersions":["2020-02-01-preview","2018-05-01","2017-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"accounts/privateAtlases","locations":["United States"],"apiVersions":["2020-02-01-preview"],"defaultApiVersion":"2020-02-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"accounts/eventGridFilters","locations":[],"apiVersions":["2020-02-01-preview","2018-05-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-02-01-preview","2018-05-01","2017-01-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServiceBus","namespace":"Microsoft.ServiceBus","authorizations":[{"applicationId":"80a10ef9-8168-493d-abf9-3297c4ef6e3c","roleDefinitionId":"2b7763f7-bbe2-4e19-befe-28c79f1cf7f7"},{"applicationId":"eb070ea5-bd17-41f1-ad68-5851f6e71774"}],"resourceTypes":[{"resourceType":"namespaces","locations":["Australia @@ -816,64 +989,95 @@ interactions: North","Australia Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"defaultApiVersion":"2017-04-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"namespaces/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/networkrulesets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/queues","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/queues/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/subscriptions","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/subscriptions/rules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"checkNamespaceAvailability","locations":[],"apiVersions":["2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-08-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"sku","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"premiumMessagingRegions","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventgridfilters","locations":["Australia + SupportsLocation"},{"resourceType":"namespaces/authorizationrules","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/networkrulesets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/queues","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/queues/authorizationrules","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/authorizationrules","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/subscriptions","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/topics/subscriptions/rules","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"checkNamespaceAvailability","locations":[],"apiVersions":["2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-08-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"sku","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"premiumMessagingRegions","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/eventgridfilters","locations":["Australia East","Australia Southeast","Central US","East US","East US 2","West US 2","West US","North Central US","South Central US","West Central US","East Asia","Southeast Asia","Brazil South","Japan East","Japan West","North Europe","West Europe","Central India","South India","West India","Canada Central","Canada East","UK West","UK South","Korea Central","Korea South","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs","locations":[],"apiVersions":["2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs/checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OperationalInsights","namespace":"Microsoft.OperationalInsights","authorizations":[{"applicationId":"d2a0a418-0aac-4541-82b2-b3142c89da77","roleDefinitionId":"86695298-2eb9-48a7-9ec3-2fdb38b6878b"},{"applicationId":"ca7f3f0b-7d91-482c-8e09-c5d840d0eac5","roleDefinitionId":"5d5a2e56-9835-44aa-93db-d2f19e155438"}],"resourceTypes":[{"resourceType":"workspaces","locations":["East + East"],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"namespaces/disasterrecoveryconfigs/checkNameAvailability","locations":[],"apiVersions":["2017-04-01","2015-08-01","2014-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":[],"apiVersions":["2018-01-01-preview","2017-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OperationalInsights","namespace":"Microsoft.OperationalInsights","authorizations":[{"applicationId":"d2a0a418-0aac-4541-82b2-b3142c89da77","roleDefinitionId":"86695298-2eb9-48a7-9ec3-2fdb38b6878b"},{"applicationId":"ca7f3f0b-7d91-482c-8e09-c5d840d0eac5","roleDefinitionId":"5d5a2e56-9835-44aa-93db-d2f19e155438"}],"resourceTypes":[{"resourceType":"workspaces","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-10-01","2020-08-01","2020-03-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-10-01","2020-08-01","2020-03-01-preview","2019-08-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"workspaces/scopedPrivateLinkProxies","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview","2017-04-26-preview","2017-03-15-preview","2017-03-03-preview","2017-01-01-preview","2015-11-01-preview","2015-03-20"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"workspaces/scopedPrivateLinkProxies","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-03-01-preview","2019-08-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"None"},{"resourceType":"workspaces/query","locations":[],"apiVersions":["2017-10-01"],"capabilities":"None"},{"resourceType":"workspaces/metadata","locations":[],"apiVersions":["2017-10-01"],"capabilities":"None"},{"resourceType":"workspaces/dataSources","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-03-01-preview","2019-08-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"None"},{"resourceType":"workspaces/query","locations":[],"apiVersions":["2017-10-01"],"capabilities":"None"},{"resourceType":"workspaces/metadata","locations":[],"apiVersions":["2017-10-01"],"capabilities":"None"},{"resourceType":"workspaces/dataSources","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"workspaces/linkedStorageAccounts","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"workspaces/linkedStorageAccounts","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"storageInsightConfigs","locations":[],"apiVersions":["2020-08-01","2020-03-01-preview","2014-10-10"],"capabilities":"SupportsExtension"},{"resourceType":"workspaces/linkedServices","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"workspaces/Tables","locations":["East + US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan + East","UK South","Central India","Canada Central","West US 2","Australia East","Australia + Central","France Central","Korea Central","North Europe","Central US","East + Asia","East US 2","South Central US","North Central US","West US","UK West","South + Africa North","Brazil South","Switzerland North","Switzerland West","Germany + West Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2017-04-26-preview"],"capabilities":"None"},{"resourceType":"storageInsightConfigs","locations":[],"apiVersions":["2020-08-01","2020-03-01-preview","2014-10-10"],"capabilities":"SupportsExtension"},{"resourceType":"workspaces/linkedServices","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"linkTargets","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview","2015-11-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"linkTargets","locations":["East US"],"apiVersions":["2020-03-01-preview","2015-03-20"],"capabilities":"None"},{"resourceType":"deletedWorkspaces","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia East","France Central","Korea Central","North Europe","Central US","East Asia","East US 2","South Central US","North Central US","West US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","Germany West - Central","Australia Central 2","UAE Central"],"apiVersions":["2020-08-01","2020-03-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01","2020-03-01-preview","2015-11-01-preview","2014-11-10"],"defaultApiVersion":"2020-08-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OperationsManagement","namespace":"Microsoft.OperationsManagement","authorization":{"applicationId":"d2a0a418-0aac-4541-82b2-b3142c89da77","roleDefinitionId":"aa249101-6816-4966-aafa-08175d795f14"},"resourceTypes":[{"resourceType":"solutions","locations":["East + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01","2020-08-01","2020-03-01-preview","2015-11-01-preview","2014-11-10"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"clusters","locations":["East + US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan + East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia + East","France Central","Korea Central","North Europe","Central US","East Asia","East + US 2","South Central US","North Central US","West US","UK West","South Africa + North","Switzerland North","Switzerland West","Germany West Central","Australia + Central 2","UAE Central","Brazil South","UAE North","Japan West","Brazil Southeast","Norway + East"],"apiVersions":["2020-10-01","2020-08-01","2020-03-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"workspaces/dataExports","locations":["East + US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan + East","UK South","Central India","Canada Central","West US 2","Australia Central","Australia + East","France Central","Korea Central","North Europe","Central US","East Asia","East + US 2","South Central US","North Central US","West US","UK West","South Africa + North","Brazil South","Switzerland North","Switzerland West","Germany West + Central","Australia Central 2","UAE Central","UAE North","Japan West","Brazil + Southeast","Norway East"],"apiVersions":["2020-08-01","2020-03-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-08-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OperationsManagement","namespace":"Microsoft.OperationsManagement","authorization":{"applicationId":"d2a0a418-0aac-4541-82b2-b3142c89da77","roleDefinitionId":"aa249101-6816-4966-aafa-08175d795f14"},"resourceTypes":[{"resourceType":"solutions","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia East","Australia Central","France Central","Korea Central","North Europe","Central Us","East Us 2","East Asia","West Us","South Central Us","North Central US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West","UAE Central","Australia - Central 2","Germany West Central"],"apiVersions":["2015-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central 2","Germany West Central","Japan West","UAE North","Brazil Southeast","Norway + East"],"apiVersions":["2015-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"managementconfigurations","locations":["East US","West Europe","Southeast Asia","Australia Southeast","West Central US","Japan East","UK South","Central India","Canada Central","West US 2","Australia East","Australia @@ -887,52 +1091,70 @@ interactions: Us 2","East Asia","West Us","South Central Us","North Central US","UK West","South Africa North","Brazil South","Switzerland North","Switzerland West"],"apiVersions":["2017-08-21-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2015-11-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Automation","namespace":"Microsoft.Automation","authorizations":[{"applicationId":"fc75330b-179d-49af-87dd-3b1acf6827fa","roleDefinitionId":"95fd5de3-d071-4362-92bf-cf341c1de832"}],"resourceTypes":[{"resourceType":"automationAccounts","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central India","France Central"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"defaultApiVersion":"2018-06-30","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"automationAccounts/runbooks","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","West US","Central US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central - India","France Central"],"apiVersions":["2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + India","France Central"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"automationAccounts/configurations","locations":["Japan - East","East US 2","West Europe","South Africa North","West US","Central US","Southeast + East","East US 2","West Europe","South Africa North","West US","Central US","UK + West","Switzerland North","Brazil Southeast","Norway East","Germany West Central","UAE + North","Switzerland West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","Central India","Australia Southeast","Canada Central","North - Europe","East Asia","France Central"],"apiVersions":["2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Europe","East Asia","France Central"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"automationAccounts/webhooks","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central India","Australia East","France Central"],"apiVersions":["2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["South - Central US"],"apiVersions":["2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/softwareUpdateConfigurations","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + Central US"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/softwareUpdateConfigurations","locations":["Japan + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central - India","France Central"],"apiVersions":["2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/jobs","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + India","France Central"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/jobs","locations":["Japan + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central - India","France Central"],"apiVersions":["2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/privateLinkResources","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + India","France Central"],"apiVersions":["2020-01-13-preview","2019-06-01","2018-06-30","2018-01-15","2017-05-15-preview","2015-10-31","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/privateLinkResources","locations":["Japan + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central India","France Central"],"apiVersions":["2020-01-13-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/privateEndpointConnections","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central India","France Central"],"apiVersions":["2020-01-13-preview"],"capabilities":"None"},{"resourceType":"automationAccounts/privateEndpointConnectionProxies","locations":["Japan - East","East US 2","West Europe","South Africa North","Southeast Asia","South + East","East US 2","West Europe","South Africa North","UK West","Switzerland + North","Brazil Southeast","Norway East","Germany West Central","UAE North","Switzerland + West","Japan West","UAE Central","Australia Central 2","Southeast Asia","South Central US","North Central US","East Asia","Central US","West US","Australia Central","Australia East","Korea Central","East US","West US 2","Brazil South","UK South","West Central US","North Europe","Canada Central","Australia Southeast","Central @@ -942,75 +1164,96 @@ interactions: Africa North","UK West","Brazil South","East Asia","South India","Canada Central","Canada East","Australia Southeast","Japan East","North Central US","Southeast Asia","West US 2","Central US","UK South","Australia East","Japan West","West US","France - Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2019-12-01","capabilities":"CrossResourceGroupResourceMove, + Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2020-06-01-preview","zoneMappings":[{"location":"East + US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West + Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast + Asia","zones":[]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North + Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK + South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia + East","zones":[]},{"location":"South Africa North","zones":[]},{"location":"South + Central US","zones":[]},{"location":"Canada Central","zones":[]},{"location":"Germany + West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"validateServiceName","locations":[],"apiVersions":["2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central + SupportsLocation"},{"resourceType":"deletedServices","locations":["Central + India","UAE North","Australia Central","Germany West Central","West Central + US","Norway East","Switzerland North","Korea South","West India","Korea Central","South + Africa North","UK West","Brazil South","East Asia","South India","Canada Central","Canada + East","Australia Southeast","Japan East","North Central US","Southeast Asia","West + US 2","Central US","UK South","Australia East","Japan West","West US","France + Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview"],"defaultApiVersion":"2020-06-01-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-06-01-preview"],"defaultApiVersion":"2020-06-01-preview","capabilities":"None"},{"resourceType":"locations/deletedServices","locations":["Central + India","UAE North","Australia Central","Germany West Central","West Central + US","Norway East","Switzerland North","Korea South","West India","Korea Central","South + Africa North","UK West","Brazil South","East Asia","South India","Canada Central","Canada + East","Australia Southeast","Japan East","North Central US","Southeast Asia","West + US 2","Central US","UK South","Australia East","Japan West","West US","France + Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview"],"defaultApiVersion":"2020-06-01-preview","capabilities":"None"},{"resourceType":"validateServiceName","locations":[],"apiVersions":["2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central India","UAE North","Australia Central","Germany West Central","West Central US","Norway East","Switzerland North","Korea South","West India","Korea Central","South Africa North","UK West","Brazil South","East Asia","South India","Canada Central","Canada East","Australia Southeast","Japan East","North Central US","Southeast Asia","West US 2","Central US","UK South","Australia East","Japan West","West US","France - Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2019-12-01","capabilities":"None"},{"resourceType":"reportFeedback","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkFeedbackRequired","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2019-12-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Management","namespace":"Microsoft.Management","authorization":{"applicationId":"f2c304cf-8e7e-4c3f-8164-16299ad9d272","roleDefinitionId":"c1cf3708-588a-4647-be7f-f400bbe214cf"},"resourceTypes":[{"resourceType":"resources","locations":[],"apiVersions":["2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"managementGroups","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview","2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"getEntities","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"operationResults/asyncOperation","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview","2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"tenantBackfillStatus","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"startTenantBackfill","locations":[],"apiVersions":["2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CognitiveServices","namespace":"Microsoft.CognitiveServices","authorizations":[{"applicationId":"7d312290-28c8-473c-a0ed-8e53749b6d6d","roleDefinitionId":"5cb87f79-a7c3-4a95-9414-45b65974b51b"}],"resourceTypes":[{"resourceType":"accounts","locations":["Global","Australia + Central","South Central US","East US 2","East US","North Europe","West Europe"],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2020-06-01-preview","capabilities":"None"},{"resourceType":"reportFeedback","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"checkFeedbackRequired","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-01-preview","2019-12-01-preview","2019-12-01","2019-01-01","2018-06-01-preview","2018-01-01","2017-03-01","2016-10-10","2016-07-07","2015-09-15","2014-02-14"],"defaultApiVersion":"2019-12-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Management","namespace":"Microsoft.Management","authorization":{"applicationId":"f2c304cf-8e7e-4c3f-8164-16299ad9d272","roleDefinitionId":"c1cf3708-588a-4647-be7f-f400bbe214cf"},"resourceTypes":[{"resourceType":"resources","locations":[],"apiVersions":["2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"managementGroups","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview","2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"getEntities","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview"],"capabilities":"None"},{"resourceType":"operationResults/asyncOperation","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta","2018-01-01-preview","2017-11-01-preview","2017-08-31-preview","2017-06-30-preview","2017-05-31-preview"],"capabilities":"None"},{"resourceType":"tenantBackfillStatus","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"startTenantBackfill","locations":[],"apiVersions":["2020-10-01","2020-05-01","2020-02-01","2019-11-01","2018-03-01-preview","2018-03-01-beta"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CognitiveServices","namespace":"Microsoft.CognitiveServices","authorizations":[{"applicationId":"7d312290-28c8-473c-a0ed-8e53749b6d6d","roleDefinitionId":"5cb87f79-a7c3-4a95-9414-45b65974b51b"}],"resourceTypes":[{"resourceType":"accounts","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/checkSkuAvailability","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"locations/checkSkuAvailability","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"checkDomainAvailability","locations":[],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateLinkResources","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18","2016-02-01-preview"],"capabilities":"None"},{"resourceType":"checkDomainAvailability","locations":[],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateLinkResources","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateEndpointConnections","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateEndpointConnections","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateEndpointConnectionProxies","locations":["Global","Australia + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18"],"capabilities":"None"},{"resourceType":"accounts/privateEndpointConnectionProxies","locations":["Global","Australia East","Brazil South","West US","West US 2","West Europe","North Europe","Southeast Asia","East Asia","West Central US","South Central US","East US","East US 2","Canada Central","Japan East","Central India","UK South","Japan West","Korea Central","France Central","North Central US","Central US","South Africa North","UAE - North","Switzerland North","Switzerland West"],"apiVersions":["2017-04-18"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ContainerService","namespace":"Microsoft.ContainerService","authorizations":[{"applicationId":"7319c514-987d-4e9b-ac3d-d38c4f427f4c","roleDefinitionId":"1b4a0c7f-2217-416f-acfa-cf73452fdc1c","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"allowManagedByInheritance":true}},{"applicationId":"6dae42f8-4368-4678-94ff-3960e28e3630","roleDefinitionId":"831388fc-33b1-4dd1-b64c-40fdcaf96654"}],"resourceTypes":[{"resourceType":"containerServices","locations":["Japan + North","Switzerland North","Switzerland West","Germany West Central"],"apiVersions":["2017-04-18"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ContainerService","namespace":"Microsoft.ContainerService","authorizations":[{"applicationId":"7319c514-987d-4e9b-ac3d-d38c4f427f4c","roleDefinitionId":"1b4a0c7f-2217-416f-acfa-cf73452fdc1c","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"allowManagedByInheritance":true}},{"applicationId":"6dae42f8-4368-4678-94ff-3960e28e3630","roleDefinitionId":"831388fc-33b1-4dd1-b64c-40fdcaf96654"}],"resourceTypes":[{"resourceType":"containerServices","locations":["Japan East","Central US","East US 2","Japan West","East Asia","South Central US","North Central US","Australia East","Australia Southeast","Brazil South","Southeast Asia","West US","West Europe","North Europe","East US","UK West","UK South","West Central US","West US 2","South India","Central India","West India","Canada East","Canada Central","Korea South","Korea Central","South Africa North"],"apiVersions":["2017-07-01","2017-01-31","2016-09-30","2016-03-30"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"managedClusters","locations":["West Central - US","East US","West Europe","France Central","Central US","Canada Central","Canada - East","UK South","West US","West US 2","Australia East","North Europe","Japan - East","Japan West","East US 2","South Central US","North Central US","Southeast - Asia","Australia Southeast","UK West","South India","Central India","East - Asia","Korea South","Korea Central","South Africa North","Brazil South","Germany - North","Switzerland North","Switzerland West","Germany West Central","UAE - North","UAE Central","Norway East","Norway West"],"apiVersions":["2020-09-01","2020-07-01","2020-06-01","2020-04-01","2020-03-01","2020-02-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-06-01","2019-04-01","2019-02-01","2018-08-01-preview","2018-03-31","2017-08-31"],"defaultApiVersion":"2019-04-01","capabilities":"SystemAssignedResourceIdentity, + US","East US","West Europe","France Central","France South","Central US","Canada + Central","Canada East","UK South","West US","West US 2","Australia East","Australia + Central","North Europe","Japan East","Japan West","East US 2","South Central + US","North Central US","Southeast Asia","Australia Southeast","UK West","South + India","Central India","East Asia","Korea South","Korea Central","South Africa + North","Brazil South","Brazil Southeast","Germany North","Switzerland North","Switzerland + West","Germany West Central","UAE North","UAE Central","Norway East","Norway + West"],"apiVersions":["2021-02-01","2020-12-01","2020-11-01","2020-09-01","2020-07-01","2020-06-01","2020-04-01","2020-03-01","2020-02-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-06-01","2019-04-01","2019-02-01","2018-08-01-preview","2018-03-31","2017-08-31"],"defaultApiVersion":"2019-04-01","capabilities":"SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"openShiftManagedClusters","locations":["East US","East US 2","West US","West US 2","South Central US","Central US","West Europe","North Europe","UK South","UK West","France Central","Canada East","Canada @@ -1037,28 +1280,30 @@ interactions: Africa North","Brazil South","Brazil Southeast","Germany North","Germany West Central","Switzerland North","Switzerland West","UAE North","UAE Central","Norway East","Norway West"],"apiVersions":["2016-03-30"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-10-31","2018-03-31","2017-08-31","2017-07-01","2017-01-31","2016-09-30","2016-03-30","2015-11-01-preview"],"capabilities":"None"},{"resourceType":"locations/orchestrators","locations":["East - US","West Europe","France Central","Central US","Canada East","Canada Central","UK - South","UK West","West Central US","West US","West US 2","Australia East","Australia - Southeast","North Europe","Japan East","Japan West","Korea Central","Korea - South","East US 2","South Central US","North Central US","Southeast Asia","South - India","Central India","East Asia","South Africa North","Brazil South","Germany - North","Germany West Central","Switzerland North","Switzerland West","UAE - North","UAE Central","Norway East","Norway West"],"apiVersions":["2020-09-01","2020-07-01","2020-06-01","2020-04-01","2020-03-01","2020-02-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-06-01","2019-04-01","2017-09-30"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Cache","namespace":"Microsoft.Cache","authorization":{"applicationId":"96231a05-34ce-4eb4-aa6a-70759cbb5e83","roleDefinitionId":"4f731528-ba85-45c7-acfb-cd0a9b3cf31b"},"resourceTypes":[{"resourceType":"Redis","locations":["North + US","West Europe","France Central","France South","Central US","Canada East","Canada + Central","UK South","UK West","West Central US","West US","West US 2","Australia + East","Australia Central","Australia Southeast","North Europe","Japan East","Japan + West","Korea Central","Korea South","East US 2","South Central US","North + Central US","Southeast Asia","South India","Central India","East Asia","South + Africa North","Brazil South","Brazil Southeast","Germany North","Germany West + Central","Switzerland North","Switzerland West","UAE North","UAE Central","Norway + East","Norway West"],"apiVersions":["2021-02-01","2020-12-01","2020-11-01","2020-09-01","2020-07-01","2020-06-01","2020-04-01","2020-03-01","2020-02-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-06-01","2019-04-01","2017-09-30"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Cache","namespace":"Microsoft.Cache","authorization":{"applicationId":"96231a05-34ce-4eb4-aa6a-70759cbb5e83","roleDefinitionId":"4f731528-ba85-45c7-acfb-cd0a9b3cf31b"},"resourceTypes":[{"resourceType":"Redis","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":[]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Redis/privateEndpointConnectionProxies","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast @@ -1066,43 +1311,66 @@ interactions: India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateEndpointConnectionProxies/validate","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateEndpointConnectionProxies/validate","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateEndpointConnections","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateEndpointConnections","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateLinkResources","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"Redis/privateLinkResources","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"locations/asyncOperations","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"locations/asyncOperations","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","South India","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-06-01","2020-04-01-preview","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2021-03-01","2020-12-01","2020-06-01","2020-04-01-preview","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West India","South India","Canada Central","Canada East","UK South","UK West","West US 2","West Central US","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West - Europe","West US","East US 2","West US 2"],"apiVersions":["2020-04-01-preview"],"defaultApiVersion":"2020-04-01-preview","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2020-04-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01-alpha","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01-alpha","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"Redis/EventGridFilters","locations":["North + Central","Norway East"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"defaultApiVersion":"2021-03-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2020-04-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-12-01","2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01-alpha","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2021-03-01","2020-12-01","2020-10-01-preview","2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01-alpha","2014-04-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"None"},{"resourceType":"redisEnterprise","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"defaultApiVersion":"2021-03-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2020-04-01-preview"}],"zoneMappings":[{"location":"East + US 2","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"Southeast + Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North + Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK + South","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South + Central US","zones":["3","1","2"]}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"RedisEnterprise/privateEndpointConnectionProxies","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"RedisEnterprise/privateEndpointConnectionProxies/validate","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"RedisEnterprise/privateEndpointConnectionProxies/operationresults","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"RedisEnterprise/privateEndpointConnections","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"RedisEnterprise/privateEndpointConnections/operationresults","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"RedisEnterprise/privateLinkResources","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["East + US","West Europe","West US","East US 2","West US 2","South Central US","UK + South","Southeast Asia","Australia East","North Europe"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-04-01-preview"],"defaultApiVersion":"2021-03-01","capabilities":"None"},{"resourceType":"Redis/EventGridFilters","locations":["North Central US","South Central US","Central US","West Europe","North Europe","West US","East US","East US 2","Japan East","Japan West","Brazil South","Southeast Asia","East Asia","Australia East","Australia Southeast","Central India","West @@ -1110,7 +1378,7 @@ interactions: US 2","West Central US","Korea Central","Korea South","France South","France Central","Australia Central","Australia Central 2","South Africa North","South Africa West","UAE Central","UAE North","Switzerland North","Switzerland West","Germany - North","Germany West Central","Norway East","Norway West"],"apiVersions":["2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DBforPostgreSQL","namespace":"Microsoft.DBforPostgreSQL","authorizations":[{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"93efed00-6552-4119-833a-422b297199f9","roleDefinitionId":"a864a0a2-ab66-47a6-97a8-223dc1379f87"},{"applicationId":"123cd850-d9df-40bd-94d5-c9f07b7fa203"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia + North","Germany West Central","Norway East","Norway West"],"apiVersions":["2020-12-01","2020-06-01","2019-07-01","2018-03-01","2017-10-01","2017-02-01","2016-04-01","2015-08-01","2015-03-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DBforPostgreSQL","namespace":"Microsoft.DBforPostgreSQL","authorizations":[{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"93efed00-6552-4119-833a-422b297199f9","roleDefinitionId":"a864a0a2-ab66-47a6-97a8-223dc1379f87"},{"applicationId":"123cd850-d9df-40bd-94d5-c9f07b7fa203"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -1130,18 +1398,26 @@ interactions: SupportsLocation"},{"resourceType":"serversv2","locations":["East US 2","East US","North Central US","Canada Central","Australia East","UK South","West Europe","Southeast Asia","West US 2","North Europe"],"apiVersions":["2018-03-29-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"serverGroupsv2","locations":["East + US 2","East US","North Central US","Canada Central","Australia East","UK South","West + Europe","Southeast Asia","West US 2","North Europe"],"apiVersions":["2020-10-05-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"serverGroups","locations":["East US 2","East US","North Central US","Canada Central","Australia East","UK South","West Europe","Southeast Asia","West US 2","North Europe"],"apiVersions":["2018-03-29-privatepreview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"flexibleServers","locations":["West US 2","East US","East US 2","West Europe","North Europe","Japan East","Southeast - Asia","UK South","Central US"],"apiVersions":["2020-02-14-privatepreview"],"zoneMappings":[{"location":"East - US 2","zones":["3","1","2"]},{"location":"Central US","zones":[]},{"location":"West - Europe","zones":["3","1","2"]},{"location":"Southeast Asia","zones":[]},{"location":"West - US 2","zones":["3","1","2"]},{"location":"North Europe","zones":[]},{"location":"East - US","zones":["3","1","2"]},{"location":"UK South","zones":[]},{"location":"Japan - East","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, - SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"servers/recoverableServers","locations":["Australia + Asia","UK South","Central US"],"apiVersions":["2020-11-05-preview","2020-02-14-privatepreview","2020-02-14-preview"],"zoneMappings":[{"location":"East + US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West + Europe","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West + US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East + US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan + East","zones":["3","1","2"]}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"locations/capabilities","locations":["East + US 2","East US","West Europe","West US 2","North Europe","Japan East","Southeast + Asia","UK South","Central US"],"apiVersions":["2020-11-05-preview","2020-02-14-privatepreview","2020-02-14-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["East + US 2","East US","West Europe","West US 2","North Europe","Japan East","Southeast + Asia","UK South","Central US"],"apiVersions":["2020-11-05-preview","2020-02-14-privatepreview","2020-02-14-preview"],"capabilities":"None"},{"resourceType":"servers/recoverableServers","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -1206,7 +1482,7 @@ interactions: US 2"],"apiVersions":["2017-12-01-preview","2017-12-01"],"capabilities":"None"},{"resourceType":"locations/checkVirtualNetworkSubnetUsage","locations":["East US 2","East US","North Central US","Canada Central","Australia East","UK South","West Europe","Southeast Asia","West US 2","North Europe","Japan East","Central - US"],"apiVersions":["2018-03-29-privatepreview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyOperationResults","locations":["Australia + US"],"apiVersions":["2020-11-05-preview","2020-02-14-privatepreview","2020-02-14-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyOperationResults","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -1302,6 +1578,14 @@ interactions: Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Norway East","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/resetQueryPerformanceInsightData","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US 2","East US","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","South Africa North","South Africa West","South Central US","South + India","Southeast Asia","Norway East","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/advisors","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East @@ -1376,10 +1660,17 @@ interactions: US 2"],"apiVersions":["2017-12-01-preview","2017-12-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"flexibleServers","locations":["East US - 2"],"apiVersions":["2020-07-01-privatepreview"],"zoneMappings":[{"location":"East - US 2","zones":["3","1","2"]}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"servers/recoverableServers","locations":["Australia + 2","West US 2","Brazil South","Southeast Asia","North Europe","AUSTRALIA EAST","JAPAN + EAST","KOREA CENTRAL","UK SOUTH","WEST EUROPE","CANADA CENTRAL","CENTRAL US","EAST + US"],"apiVersions":["2020-07-01-privatepreview","2020-07-01-preview"],"zoneMappings":[{"location":"East + US 2","zones":["3","1","2"]},{"location":"CENTRAL US","zones":["3","1","2"]},{"location":"WEST + EUROPE","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West + US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"EAST + US","zones":["3","1","2"]},{"location":"UK SOUTH","zones":["3","1","2"]},{"location":"JAPAN + EAST","zones":["3","1","2"]},{"location":"AUSTRALIA EAST","zones":[]},{"location":"CANADA + CENTRAL","zones":[]},{"location":"Brazil South","zones":[]},{"location":"KOREA + CENTRAL","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, + SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"servers/recoverableServers","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central US","Central India","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -1395,14 +1686,20 @@ interactions: Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Norway East","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2017-12-01-preview","2017-12-01"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Australia + US 2"],"apiVersions":["2017-12-01-preview","2017-12-01"],"capabilities":"None"},{"resourceType":"locations/capabilities","locations":["East + US 2","West US 2","Brazil South","Southeast Asia","North Europe","AUSTRALIA + EAST","JAPAN EAST","KOREA CENTRAL","UK SOUTH","WEST EUROPE","CANADA CENTRAL","CENTRAL + US","EAST US"],"apiVersions":["2020-07-01-privatepreview","2020-07-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK - West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2017-12-01-preview","2017-12-01"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia + West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-07-01-privatepreview","2020-07-01-preview","2017-12-01-preview","2017-12-01"],"capabilities":"None"},{"resourceType":"locations/checkVirtualNetworkSubnetUsage","locations":["East + US 2","West US 2","Brazil South","Southeast Asia","North Europe","AUSTRALIA + EAST","JAPAN EAST","KOREA CENTRAL","UK SOUTH","WEST EUROPE","CANADA CENTRAL","CENTRAL + US","EAST US"],"apiVersions":["2020-07-01-privatepreview","2020-07-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -1537,6 +1834,14 @@ interactions: Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Norway East","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/resetQueryPerformanceInsightData","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US 2","East US","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","South Africa North","South Africa West","South Central US","South + India","Southeast Asia","Norway East","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/advisors","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East @@ -1624,82 +1929,94 @@ interactions: West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Switzerland North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"CrossResourceGroupResourceMove, + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"registries/scopeMaps","locations":["West + SupportsLocation"},{"resourceType":"registries/connectedRegistries","locations":["West + US","East US","South Central US","West Europe","North Europe","UK South","UK + West","Australia East","Australia Southeast","Central India","East Asia","Japan + East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada + Central","Central US","East US 2","North Central US","West Central US","West + US 2","Korea Central","France Central","South Africa North","UAE North","Switzerland + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview"],"capabilities":"None"},{"resourceType":"registries/connectedRegistries/deactivate","locations":["West + US","East US","South Central US","West Europe","North Europe","UK South","UK + West","Australia East","Australia Southeast","Central India","East Asia","Japan + East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada + Central","Central US","East US 2","North Central US","West Central US","West + US 2","Korea Central","France Central","South Africa North","UAE North","Switzerland + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview"],"capabilities":"None"},{"resourceType":"registries/scopeMaps","locations":["West US","East US","South Central US","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/tokens","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/tokens","locations":["West US","East US","South Central US","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/generateCredentials","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/generateCredentials","locations":["West US","East US","South Central US","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnections","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-05-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnections","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnectionProxies","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnectionProxies","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnectionProxies/validate","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateEndpointConnectionProxies/validate","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateLinkResources","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/privateLinkResources","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/importImage","locations":["South + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/importImage","locations":["South Central US","West Central US","East US","West Europe","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","France Central","South Africa North","UAE North","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/exportPipelines","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/exportPipelines","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"registries/importPipelines","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"registries/importPipelines","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"registries/pipelineRuns","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"registries/pipelineRuns","locations":["West US","East US","South Central US","West Europe","Switzerland North","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Korea Central","France Central","South Africa North","UAE North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/listBuildSourceUploadUrl","locations":["East + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview"],"capabilities":"None"},{"resourceType":"registries/listBuildSourceUploadUrl","locations":["East US","West Europe","West US 2","South Central US","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","Japan East","Japan West","North Central US","North @@ -1819,33 +2136,33 @@ interactions: South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"CrossResourceGroupResourceMove, + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"registries/webhooks","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"CrossResourceGroupResourceMove, + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"registries/webhooks/ping","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/webhooks/getCallbackConfig","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/webhooks/getCallbackConfig","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/webhooks/listEvents","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/webhooks/listEvents","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"locations/setupAuth","locations":["East + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"locations/setupAuth","locations":["East US","West Europe","West US 2","South Central US","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","Japan East","Japan West","North Central US","North @@ -1863,7 +2180,7 @@ interactions: South","Australia East","Central India","Korea Central","France Central","Central US","South Africa North","UAE North","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE @@ -1877,20 +2194,20 @@ interactions: West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Switzerland North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"None"},{"resourceType":"registries/regenerateCredential","locations":["South + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"None"},{"resourceType":"registries/regenerateCredential","locations":["South Central US","West US","East US","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","Korea Central","South Africa North","UAE North","France Central","East Asia","Japan East","Japan West","Southeast Asia","South India","Brazil South","Canada East","Canada Central","Central US","East US 2","North Central US","West Central US","West US 2","Switzerland North","UAE Central","Switzerland West","Germany West Central","Brazil - Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"None"},{"resourceType":"registries/listUsages","locations":["West + Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01","2017-03-01"],"capabilities":"None"},{"resourceType":"registries/listUsages","locations":["West Central US","East US","West Europe","South Central US","West US","Japan East","North Europe","Southeast Asia","North Central US","East US 2","West US 2","Brazil South","Australia East","Central India","Korea Central","South Africa North","UAE North","France Central","Central US","Canada East","Canada Central","UK South","UK West","Australia Southeast","East Asia","Japan West","South India","Switzerland - North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/listPolicies","locations":["West + North","UAE Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01"],"capabilities":"None"},{"resourceType":"registries/listPolicies","locations":["West US","East US","South Central US","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","Korea Central","South Africa North","UAE North","France Central","East Asia","Japan East","Japan @@ -1917,114 +2234,137 @@ interactions: Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Korea Central","France Central","South Africa North","UAE North","Switzerland North","UAE - Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01","2017-06-01-preview","2017-03-01","2016-06-27-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["South + Central","Switzerland West","Germany West Central","Brazil Southeast","Norway + East"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01","2017-06-01-preview","2017-03-01","2016-06-27-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["South Central US","East US","West US","Central US","East US 2","North Central US","West Central US","West US 2","Brazil South","Canada East","Canada Central","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Korea Central","France Central","South Africa North","UAE North","Switzerland North","UAE - Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01","2017-10-01","2017-06-01-preview","2017-03-01"],"capabilities":"None"},{"resourceType":"locations","locations":["South + Central","Switzerland West","Germany West Central","Brazil Southeast","Norway + East"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01","2017-10-01","2017-06-01-preview","2017-03-01"],"capabilities":"None"},{"resourceType":"locations","locations":["South Central US","East US","West US","Central US","East US 2","North Central US","West Central US","West US 2","Brazil South","Canada East","Canada Central","West Europe","North Europe","UK South","UK West","Australia East","Australia Southeast","Central India","East Asia","Japan East","Japan West","Southeast Asia","South India","Korea Central","France Central","South Africa North","UAE North","Switzerland North","UAE - Central","Switzerland West","Germany West Central","Brazil Southeast"],"apiVersions":["2019-12-01-preview","2019-05-01-preview","2019-05-01","2017-10-01","2017-06-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureStack","namespace":"Microsoft.AzureStack","resourceTypes":[{"resourceType":"operations","locations":["Global"],"apiVersions":["2017-06-01"],"capabilities":"None"},{"resourceType":"registrations","locations":["West + Central","Switzerland West","Germany West Central","Brazil Southeast","Norway + East"],"apiVersions":["2020-11-01-preview","2019-12-01-preview","2019-05-01-preview","2019-05-01","2017-10-01","2017-06-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureStack","namespace":"Microsoft.AzureStack","resourceTypes":[{"resourceType":"operations","locations":["Global"],"apiVersions":["2017-06-01"],"capabilities":"None"},{"resourceType":"registrations","locations":["West Central US","Global"],"apiVersions":["2020-06-01-preview","2017-06-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"registrations/products","locations":["West Central US","Global"],"apiVersions":["2017-06-01","2016-01-01"],"capabilities":"None"},{"resourceType":"registrations/customerSubscriptions","locations":["West - Central US","Global"],"apiVersions":["2017-06-01"],"capabilities":"None"},{"resourceType":"cloudManifestFiles","locations":["Global"],"apiVersions":["2017-06-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorageSync","namespace":"Microsoft.StorageSync","authorizations":[{"applicationId":"9469b9f5-6722-4481-a2b2-14ed560b706f","roleDefinitionId":"4cd49d82-1f4d-43fc-af0c-1c1203668e5a"}],"resourceTypes":[{"resourceType":"storageSyncServices","locations":["West + Central US","Global"],"apiVersions":["2017-06-01"],"capabilities":"None"},{"resourceType":"cloudManifestFiles","locations":["Global"],"apiVersions":["2017-06-01"],"capabilities":"None"},{"resourceType":"linkedSubscriptions","locations":["East + US","West Europe","Southeast Asia"],"apiVersions":["2020-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorageSync","namespace":"Microsoft.StorageSync","authorizations":[{"applicationId":"9469b9f5-6722-4481-a2b2-14ed560b706f","roleDefinitionId":"4cd49d82-1f4d-43fc-af0c-1c1203668e5a"}],"resourceTypes":[{"resourceType":"storageSyncServices","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2018-04-02","capabilities":"CrossResourceGroupResourceMove, + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2018-04-02","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"storageSyncServices/syncGroups","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/syncGroups/cloudEndpoints","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/syncGroups/cloudEndpoints","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/syncGroups/serverEndpoints","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/syncGroups/serverEndpoints","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/registeredServers","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/registeredServers","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/workflows","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"storageSyncServices/workflows","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"operations","locations":["West + Central US","West US","West Europe","North Europe","Southeast Asia","East + Asia","Australia East","Australia Southeast","East US","Canada Central","Canada + East","Central US","East US 2","UK South","UK West","Central India","South + India","Central US EUAP","North Central US","South Central US","Brazil South","Japan + East","Japan West","West US 2","East US 2 EUAP","Korea Central","Korea South","France + Central","France South","South Africa North","South Africa West","UAE North","UAE + Central","Germany West Central","Germany North","Switzerland North","Switzerland + West","Norway East","Norway West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02","2018-01-01-preview","2017-06-05-preview"],"defaultApiVersion":"2017-06-05-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West Central US","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"defaultApiVersion":"2018-04-02","capabilities":"None"},{"resourceType":"locations/workflows","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"defaultApiVersion":"2018-04-02","capabilities":"None"},{"resourceType":"locations/workflows","locations":["West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","West Central US","West US 2","North Central US","South Central US","Brazil South","Japan East","Japan West","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"defaultApiVersion":"2018-04-02","capabilities":"None"},{"resourceType":"locations/operations","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01","2019-10-01","2019-06-01","2019-03-01","2019-02-01","2018-10-01","2018-07-01","2018-04-02"],"defaultApiVersion":"2018-04-02","capabilities":"None"},{"resourceType":"locations/operations","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West Central US","West US","West Europe","North Europe","Southeast Asia","East Asia","Australia East","Australia Southeast","East US","Canada Central","Canada East","Central US","East US 2","UK South","UK West","Central India","South India","North Central US","South Central US","Brazil South","Japan East","Japan West","West US 2","Korea Central","Korea South","France Central","France South","South - Africa North","South Africa West","UAE North","UAE Central"],"apiVersions":["2020-03-01"],"defaultApiVersion":"2020-03-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ImportExport","namespace":"Microsoft.ImportExport","authorization":{"applicationId":"7de4d5c5-5b32-4235-b8a9-33b34d6bcd2a","roleDefinitionId":"9f7aa6bb-9454-46b6-8c01-a4b0f33ca151"},"resourceTypes":[{"resourceType":"jobs","locations":["Australia + Africa North","South Africa West","UAE North","UAE Central","Germany West + Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2020-03-01"],"defaultApiVersion":"2020-03-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ImportExport","namespace":"Microsoft.ImportExport","authorization":{"applicationId":"7de4d5c5-5b32-4235-b8a9-33b34d6bcd2a","roleDefinitionId":"9f7aa6bb-9454-46b6-8c01-a4b0f33ca151"},"resourceTypes":[{"resourceType":"jobs","locations":["Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan - West","Korea Central","North Central US","North Europe","South Africa North","South - Central US","Southeast Asia","South India","UK South","UK West","West Central - US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"CrossResourceGroupResourceMove, + West","Korea Central","Korea South","North Central US","North Europe","South + Africa North","South Central US","Southeast Asia","South India","UK South","UK + West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":["Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central - US","East Asia","East US","East US 2","Japan East","Japan West","Korea Central","North - Central US","North Europe","South Africa North","South Central US","Southeast - Asia","South India","UK South","UK West","West Central US","West Europe","West - India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia + US","East Asia","East US","East US 2","Japan East","Japan West","Korea Central","Korea + South","North Central US","North Europe","South Africa North","South Central + US","Southeast Asia","South India","UK South","UK West","West Central US","West + Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan - West","Korea Central","North Central US","North Europe","South Africa North","South - Central US","Southeast Asia","South India","UK South","UK West","West Central - US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Australia + West","Korea Central","Korea South","North Central US","North Europe","South + Africa North","South Central US","Southeast Asia","South India","UK South","UK + West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","Japan East","Japan - West","Korea Central","North Central US","North Europe","South Africa North","South - Central US","Southeast Asia","South India","UK South","UK West","West Central - US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BotService","namespace":"Microsoft.BotService","authorizations":[{"applicationId":"f3723d34-6ff5-4ceb-a148-d99dcd2511fc","roleDefinitionId":"71213c26-43ed-41d8-9905-3c12971517a3"},{"applicationId":"27a762be-14e7-4f92-899c-151877d6d497","roleDefinitionId":"aab320d1-5b9b-4748-982e-be803163df77"}],"resourceTypes":[{"resourceType":"botServices","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"botServices/channels","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"None"},{"resourceType":"botServices/connections","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"None"},{"resourceType":"listAuthServiceProviders","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"None"},{"resourceType":"operations","locations":["Global"],"apiVersions":["2018-07-12","2017-12-01"],"defaultApiVersion":"2017-12-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Kusto","namespace":"Microsoft.Kusto","authorizations":[{"applicationId":"2746ea77-4702-4b45-80ca-3c97e680e8b7","roleDefinitionId":"dd9d4347-f397-45f2-b538-85f21c90037c"}],"resourceTypes":[{"resourceType":"clusters","locations":["Australia + West","Korea Central","Korea South","North Central US","North Europe","South + Africa North","South Central US","Southeast Asia","South India","UK South","UK + West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-08-01","2016-11-01","2016-07-01-preview"],"defaultApiVersion":"2020-08-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-11-01"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BotService","namespace":"Microsoft.BotService","authorizations":[{"applicationId":"f3723d34-6ff5-4ceb-a148-d99dcd2511fc","roleDefinitionId":"71213c26-43ed-41d8-9905-3c12971517a3"},{"applicationId":"27a762be-14e7-4f92-899c-151877d6d497","roleDefinitionId":"aab320d1-5b9b-4748-982e-be803163df77"},{"applicationId":"5b404cf4-a79d-4cfe-b866-24bf8e1a4921","roleDefinitionId":"3d07f186-e6fa-4974-ac88-b88eeda6370a"},{"applicationId":"ce48853e-0605-4f77-8746-d70ac63cc6bc","roleDefinitionId":"d5b49851-91ee-42df-9dc4-00b3a3b4d96b"},{"applicationId":"e6650347-047f-4e51-9386-839384472ea5","roleDefinitionId":"a9b54502-e245-45bc-bd0f-aa7e1074afdc"}],"resourceTypes":[{"resourceType":"botServices","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"botServices/channels","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"None"},{"resourceType":"botServices/connections","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"None"},{"resourceType":"listAuthServiceProviders","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"None"},{"resourceType":"operations","locations":["Global"],"apiVersions":["2020-06-02","2018-07-12","2017-12-01"],"defaultApiVersion":"2020-06-02","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-12-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-07-12"},{"profileVersion":"2020-09-01-hybrid","apiVersion":"2020-06-02"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Kusto","namespace":"Microsoft.Kusto","authorizations":[{"applicationId":"2746ea77-4702-4b45-80ca-3c97e680e8b7","roleDefinitionId":"dd9d4347-f397-45f2-b538-85f21c90037c"}],"resourceTypes":[{"resourceType":"clusters","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","zoneMappings":[{"location":"East + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North @@ -2032,7 +2372,8 @@ interactions: South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South Central US","zones":[]},{"location":"Canada Central","zones":[]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + West Central","zones":[]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"clusters/databases","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada @@ -2041,56 +2382,56 @@ interactions: West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"clusters/attacheddatabaseconfigurations","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"clusters/attacheddatabaseconfigurations","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"clusters/principalassignments","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"clusters/principalassignments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09"],"defaultApiVersion":"2019-11-09","capabilities":"None"},{"resourceType":"clusters/databases/eventhubconnections","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"clusters/databases/eventhubconnections","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"clusters/databases/dataconnections","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"clusters/databases/dataconnections","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"clusters/databases/principalassignments","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"clusters/databases/principalassignments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09"],"defaultApiVersion":"2019-11-09","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West - Europe","West India","West US","West US 2"],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2019-05-15","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AnalysisServices","namespace":"Microsoft.AnalysisServices","authorization":{"applicationId":"4ac7d521-0382-477b-b0f8-7e1d95f85ca2","roleDefinitionId":"490d5987-bcf6-4be6-b6b2-056a78cb693a"},"resourceTypes":[{"resourceType":"servers","locations":["West + Europe","West India","West US","West US 2"],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-09-18","2020-06-14","2020-02-15","2019-11-09","2019-09-07","2019-05-15","2019-01-21","2018-09-07-preview","2017-09-07-privatepreview"],"defaultApiVersion":"2020-06-14","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AnalysisServices","namespace":"Microsoft.AnalysisServices","authorization":{"applicationId":"4ac7d521-0382-477b-b0f8-7e1d95f85ca2","roleDefinitionId":"490d5987-bcf6-4be6-b6b2-056a78cb693a"},"resourceTypes":[{"resourceType":"servers","locations":["West US","North Europe","South Central US","West Europe","West Central US","Southeast Asia","East US 2","North Central US","Brazil South","Canada Central","Australia Southeast","Japan East","UK South","West India","West US 2","Central US","East @@ -2115,89 +2456,119 @@ interactions: East","South India","Central India","West India","Canada Central","Canada East","UK South","UK West","West Central US","West US 2","France Central","South Africa North","UAE North","Australia Central","Germany West Central","Switzerland - North","Norway East"],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01","2015-07-01","2014-05-01-privatepreview"],"defaultApiVersion":"2020-05-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"CrossResourceGroupResourceMove, + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01","2015-07-01","2014-05-01-privatepreview"],"defaultApiVersion":"2021-01-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":["West Europe","East - US","East US 2","West US","North Central US","Brazil South","North Europe","Central - US","East Asia","Japan East","Australia Southeast","Japan West","Korea South","Korea - Central","Southeast Asia","South Central US","Australia East","South India","Central - India","West India","Canada Central","Canada East","UK South","UK West","West - Central US","West US 2","France Central","South Africa North","UAE North","Australia - Central","Germany West Central","Switzerland North","Norway East"],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/quotas","locations":["West + SupportsLocation"},{"resourceType":"batchAccounts/pools","locations":["West + Europe","East US","East US 2","West US","North Central US","Brazil South","North + Europe","Central US","East Asia","Japan East","Australia Southeast","Japan + West","Korea South","Korea Central","Southeast Asia","South Central US","Australia + East","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","West Central US","West US 2","France Central","South + Africa North","UAE North","Australia Central","Germany West Central","Switzerland + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01"],"defaultApiVersion":"2021-01-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"batchAccounts/certificates","locations":["West + Europe","East US","East US 2","West US","North Central US","Brazil South","North + Europe","Central US","East Asia","Japan East","Australia Southeast","Japan + West","Korea South","Korea Central","Southeast Asia","South Central US","Australia + East","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","West Central US","West US 2","France Central","South + Africa North","UAE North","Australia Central","Germany West Central","Switzerland + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["West + Europe","East US","East US 2","West US","North Central US","Brazil South","North + Europe","Central US","East Asia","Japan East","Australia Southeast","Japan + West","Korea South","Korea Central","Southeast Asia","South Central US","Australia + East","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","West Central US","West US 2","France Central","South + Africa North","UAE North","Australia Central","Germany West Central","Switzerland + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/quotas","locations":["West Europe","East US","East US 2","West US","North Central US","Brazil South","North Europe","Central US","East Asia","Japan East","Australia Southeast","Japan West","Korea South","Korea Central","Southeast Asia","South Central US","Australia East","South India","Central India","West India","Canada Central","Canada East","UK South","UK West","West Central US","West US 2","France Central","South Africa North","UAE North","Australia Central","Germany West Central","Switzerland - North","Norway East"],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West Europe","East US","East US 2","West US","North Central US","Brazil South","North Europe","Central US","East Asia","Japan East","Australia Southeast","Japan West","Korea South","Korea Central","Southeast Asia","South Central US","Australia East","South India","Central India","West India","Canada Central","Canada East","UK South","UK West","West Central US","West US 2","France Central","South Africa North","UAE North","Australia Central","Germany West Central","Switzerland - North","Norway East"],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01"],"defaultApiVersion":"2017-05-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/accountOperationResults","locations":["West + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01"],"defaultApiVersion":"2021-01-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"}],"capabilities":"None"},{"resourceType":"locations/accountOperationResults","locations":["West Europe","East US","East US 2","West US","North Central US","Brazil South","North Europe","Central US","East Asia","Japan East","Australia Southeast","Japan West","Korea South","Korea Central","Southeast Asia","South Central US","Australia East","South India","Central India","West India","Canada Central","Canada East","UK South","UK West","West Central US","West US 2","France Central","South Africa North","UAE North","Australia Central","Germany West Central","Switzerland - North","Norway East"],"apiVersions":["2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01","2015-07-01","2014-05-01-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataFactory","namespace":"Microsoft.DataFactory","authorizations":[{"applicationId":"0947a342-ab4a-43be-93b3-b8243fc161e5","roleDefinitionId":"f0a6aa2a-e9d8-4bae-bcc2-36b405e8a5da"},{"applicationId":"5d13f7d7-0567-429c-9880-320e9555e5fc","roleDefinitionId":"956a8f20-9168-4c71-8e27-3c0460ac39a4"}],"resourceTypes":[{"resourceType":"dataFactories","locations":["West + North","Norway East","Brazil Southeast"],"apiVersions":["2021-01-01","2020-09-01","2020-05-01","2020-03-01-preview","2020-03-01","2019-08-01","2019-04-01","2018-12-01","2017-09-01","2017-05-01","2017-01-01","2015-12-01","2015-09-01","2015-07-01","2014-05-01-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataFactory","namespace":"Microsoft.DataFactory","authorizations":[{"applicationId":"0947a342-ab4a-43be-93b3-b8243fc161e5","roleDefinitionId":"f0a6aa2a-e9d8-4bae-bcc2-36b405e8a5da"},{"applicationId":"5d13f7d7-0567-429c-9880-320e9555e5fc","roleDefinitionId":"956a8f20-9168-4c71-8e27-3c0460ac39a4"}],"resourceTypes":[{"resourceType":"dataFactories","locations":["West US","North Europe","East US","West Central US"],"apiVersions":["2015-10-01","2015-09-01","2015-08-01","2015-07-01-preview","2015-05-01-preview","2015-01-01-preview","2014-04-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"factories","locations":["East US","East US 2","Central US","South Central US","Japan East","Canada Central","Australia - East","Central India","France Central","Korea Central","Brazil South","West - Europe","North Europe","UK South","West Central US","West US","West US 2","Southeast - Asia","East Asia","North Central US","South Africa North","Australia Southeast"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"CrossResourceGroupResourceMove, + East","Switzerland North","Germany West Central","Central India","France Central","Korea + Central","Brazil South","West Europe","North Europe","UK South","West Central + US","West US","West US 2","Southeast Asia","East Asia","North Central US","South + Africa North","Australia Southeast","South India","Canada East","UK West","Japan + West"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"factories/integrationRuntimes","locations":["East US","East US 2","West US 2","West US","Central US","South Central US","Japan East","Central India","Brazil South","France Central","Korea Central","Australia - East","Canada Central","West Central US","North Europe","UK South","West Europe","Southeast - Asia","East Asia","North Central US","South Africa North","Australia Southeast"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"None"},{"resourceType":"dataFactories/diagnosticSettings","locations":["North + East","Switzerland North","Germany West Central","Canada Central","West Central + US","North Europe","UK South","West Europe","Southeast Asia","East Asia","North + Central US","South Africa North","Australia Southeast","South India","Canada + East","UK West","Japan West"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"None"},{"resourceType":"dataFactories/diagnosticSettings","locations":["North Europe","East US","West US","West Central US"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"dataFactories/metricDefinitions","locations":["North Europe","East US","West US","West Central US"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"checkDataFactoryNameAvailability","locations":[],"apiVersions":["2015-05-01-preview","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"checkAzureDataFactoryNameAvailability","locations":["West US","North Europe","East US","West Central US"],"apiVersions":["2015-10-01","2015-09-01","2015-08-01","2015-07-01-preview","2015-05-01-preview","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"dataFactorySchema","locations":["West US","North Europe","East US","West Central US"],"apiVersions":["2015-10-01","2015-09-01","2015-08-01","2015-07-01-preview","2015-05-01-preview","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West US","North Europe","East US","West Central US"],"apiVersions":["2018-06-01","2017-09-01-preview","2017-03-01-preview","2015-10-01","2015-09-01","2015-08-01","2015-07-01-preview","2015-05-01-preview","2015-01-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"None"},{"resourceType":"locations/configureFactoryRepo","locations":["East US","East US 2","West US 2","West US","Central US","South Central US","Japan - East","Australia East","Canada Central","Central India","Brazil South","France - Central","Korea Central","West Europe","North Europe","UK South","West Central - US","Southeast Asia","East Asia","North Central US","South Africa North","Australia - Southeast"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"None"},{"resourceType":"locations/getFeatureValue","locations":["East - US","East US 2","West Europe","North Europe","UK South","West Central US","West - US","Central US","South Central US","Japan East","Australia East","Canada + East","Australia East","Switzerland North","Germany West Central","Canada Central","Central India","Brazil South","France Central","Korea Central","West - US 2","Southeast Asia","East Asia","North Central US","South Africa North","Australia - Southeast"],"apiVersions":["2018-06-01"],"defaultApiVersion":"2018-06-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HealthcareApis","namespace":"Microsoft.HealthcareApis","authorizations":[{"applicationId":"4f6778d8-5aef-43dc-a1ff-b073724b9495"},{"applicationId":"3274406e-4e0a-4852-ba4f-d7226630abb7","roleDefinitionId":"e39edba5-cde8-4529-ba1f-159138220220"},{"applicationId":"894b1496-c6e0-4001-b69c-81b327564ca4","roleDefinitionId":"c69c1f48-8535-41e7-9667-539790b1c663"}],"resourceTypes":[{"resourceType":"services","locations":["UK + Europe","North Europe","UK South","West Central US","Southeast Asia","East + Asia","North Central US","South Africa North","Australia Southeast","South + India","Canada East","UK West","Japan West"],"apiVersions":["2018-06-01","2017-09-01-preview"],"defaultApiVersion":"2018-06-01","capabilities":"None"},{"resourceType":"locations/getFeatureValue","locations":["East + US","East US 2","West Europe","North Europe","UK South","West Central US","West + US","Central US","South Central US","Japan East","Australia East","Switzerland + North","Germany West Central","Canada Central","Central India","Brazil South","France + Central","Korea Central","West US 2","Southeast Asia","East Asia","North Central + US","South Africa North","Australia Southeast","South India","Canada East","UK + West","Japan West"],"apiVersions":["2018-06-01"],"defaultApiVersion":"2018-06-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HealthcareApis","namespace":"Microsoft.HealthcareApis","authorizations":[{"applicationId":"4f6778d8-5aef-43dc-a1ff-b073724b9495"},{"applicationId":"3274406e-4e0a-4852-ba4f-d7226630abb7","roleDefinitionId":"e39edba5-cde8-4529-ba1f-159138220220"},{"applicationId":"894b1496-c6e0-4001-b69c-81b327564ca4","roleDefinitionId":"c69c1f48-8535-41e7-9667-539790b1c663"},{"applicationId":"75e725bf-66ce-4cea-9b9a-5c4caae57f33"}],"resourceTypes":[{"resourceType":"services","locations":["UK West","North Central US","West US 2","Australia East","Southeast Asia","UK South","East US","West Europe","South Central US","East US 2","North Europe","West - Central US","Japan East"],"apiVersions":["2019-09-16","2018-08-20-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central US","Japan East","Germany West Central"],"apiVersions":["2021-01-11","2020-03-30","2020-03-15","2019-09-16","2018-08-20-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"services/iomtconnectors","locations":["West + SupportsLocation"},{"resourceType":"services/privateEndpointConnectionProxies","locations":["UK + West","North Central US","West US 2","Australia East","Southeast Asia","UK + South","East US","West Europe","South Central US","East US 2","North Europe","West + Central US","Japan East","Germany West Central"],"apiVersions":["2020-03-30"],"capabilities":"None"},{"resourceType":"services/privateEndpointConnections","locations":["UK + West","North Central US","West US 2","Australia East","Southeast Asia","UK + South","East US","West Europe","South Central US","East US 2","North Europe","West + Central US","Japan East","Germany West Central"],"apiVersions":["2020-03-30"],"capabilities":"None"},{"resourceType":"services/privateLinkResources","locations":["UK + West","North Central US","West US 2","Australia East","Southeast Asia","UK + South","East US","West Europe","South Central US","East US 2","North Europe","West + Central US","Japan East","Germany West Central"],"apiVersions":["2020-03-30"],"capabilities":"None"},{"resourceType":"services/iomtconnectors","locations":["West US 2","UK South","East US 2","UK West","North Central US","Australia East","Southeast Asia","East US","West Europe","South Central US","North Europe","West Central - US","Japan East"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"services/iomtconnectors/connections","locations":["West + US","Japan East","Germany West Central"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"services/iomtconnectors/connections","locations":["West US 2","UK South","East US 2","UK West","North Central US","Australia East","Southeast Asia","East US","West Europe","South Central US","North Europe","West Central - US","Japan East"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"services/iomtconnectors/mappings","locations":["West + US","Japan East","Germany West Central"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"services/iomtconnectors/mappings","locations":["West US 2","UK South","East US 2","UK West","North Central US","Australia East","Southeast Asia","East US","West Europe","South Central US","North Europe","West Central - US","Japan East"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["UK + US","Japan East","Germany West Central"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["UK West","North Central US","West US 2","Australia East","Southeast Asia","UK South","East US","West Europe","South Central US","East US 2","North Europe","West - Central US","Japan East"],"apiVersions":["2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["UK + Central US","Japan East","Germany West Central"],"apiVersions":["2021-01-11","2020-03-30","2020-03-15","2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["UK West","North Central US","West US 2","Australia East","Southeast Asia","UK South","East US","West Europe","South Central US","East US 2","North Europe","West - Central US","Japan East"],"apiVersions":["2020-05-01-preview","2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["UK + Central US","Japan East","Germany West Central"],"apiVersions":["2021-01-11","2020-05-01-preview","2020-03-30","2020-03-15","2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["UK West","North Central US","West US 2","Australia East","Southeast Asia","UK South","East US","West Europe","South Central US","East US 2","North Europe","West - Central US","Japan East"],"apiVersions":["2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["UK + Central US","Japan East","Germany West Central"],"apiVersions":["2021-01-11","2020-03-30","2020-03-15","2019-09-16","2018-08-20-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["UK West","North Central US","West US 2","Australia East","Southeast Asia","UK South","East US","West Europe","South Central US","East US 2","North Europe","West - Central US","Japan East"],"apiVersions":["2020-03-30","2019-09-16","2018-08-20-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DBforMariaDB","namespace":"Microsoft.DBforMariaDB","authorizations":[{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"123cd850-d9df-40bd-94d5-c9f07b7fa203"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia + Central US","Japan East","Germany West Central"],"apiVersions":["2021-01-11","2020-03-30","2020-03-15","2019-09-16","2018-08-20-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DBforMariaDB","namespace":"Microsoft.DBforMariaDB","authorizations":[{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"123cd850-d9df-40bd-94d5-c9f07b7fa203"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US 2","East US","France Central","France South","Germany West Central","Japan @@ -2356,6 +2727,14 @@ interactions: Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Norway East","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/resetQueryPerformanceInsightData","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US 2","East US","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","South Africa North","South Africa West","South Central US","South + India","Southeast Asia","Norway East","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2018-06-01-privatepreview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"servers/advisors","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East @@ -2403,46 +2782,71 @@ interactions: East","Japan West","Korea Central","Korea South","North Central US","North Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West - Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-01-01-privatepreview","2020-01-01-preview","2020-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SignalRService","namespace":"Microsoft.SignalRService","authorizations":[{"applicationId":"cdad765c-f191-43ba-b9f5-7aef392f811d","roleDefinitionId":"346b504e-4aec-45d1-be25-a6e10f3cb4fe"}],"resourceTypes":[{"resourceType":"SignalR","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"CrossResourceGroupResourceMove, + Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2020-01-01-privatepreview","2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"servers/start","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US 2","East US","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","South Africa North","South Africa West","South Central US","South + India","Southeast Asia","Norway East","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2020-01-01-privatepreview","2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"servers/stop","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US 2","East US","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","South Africa North","South Africa West","South Central US","South + India","Southeast Asia","Norway East","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2020-01-01-privatepreview","2020-01-01-preview","2020-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SignalRService","namespace":"Microsoft.SignalRService","authorizations":[{"applicationId":"cdad765c-f191-43ba-b9f5-7aef392f811d","roleDefinitionId":"346b504e-4aec-45d1-be25-a6e10f3cb4fe"}],"resourceTypes":[{"resourceType":"SignalR","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["West - US 2","East US","East US 2","West US","Central US"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/usages","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"SignalR/eventGridFilters","locations":["East - US","West US","Southeast Asia","West Europe","West US 2","East US 2","North - Europe","Australia East","Canada East","Central US","Japan East","UK South","South - Central US","Brazil South","France Central","Korea Central"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Migrate","namespace":"Microsoft.Migrate","authorizations":[{"applicationId":"e3bfd6ac-eace-4438-9dc1-eed439e738de","roleDefinitionId":"e88f4159-1d71-4b12-8ef0-38c039cb051e"},{"applicationId":"51df634f-ddb4-4901-8a2d-52f6393a796b","roleDefinitionId":"d7568dc2-2265-41f7-9c0f-1e9c7862ca62"}],"resourceTypes":[{"resourceType":"projects","locations":["West + SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["West + US 2","East US","East US 2","West US","Central US"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"locations/usages","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"},{"resourceType":"SignalR/eventGridFilters","locations":["Australia + East","Brazil South","Canada Central","Canada East","Central US","East Asia","East + US","East US 2","France Central","Germany West Central","Japan East","Korea + Central","North Europe","South Central US","Southeast Asia","Switzerland North","UK + South","West Europe","West US","West US 2"],"apiVersions":["2020-07-01-preview","2020-05-01","2018-10-01","2018-03-01-preview"],"defaultApiVersion":"2020-07-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Migrate","namespace":"Microsoft.Migrate","authorizations":[{"applicationId":"e3bfd6ac-eace-4438-9dc1-eed439e738de","roleDefinitionId":"e88f4159-1d71-4b12-8ef0-38c039cb051e"},{"applicationId":"51df634f-ddb4-4901-8a2d-52f6393a796b","roleDefinitionId":"d7568dc2-2265-41f7-9c0f-1e9c7862ca62"}],"resourceTypes":[{"resourceType":"projects","locations":["West Central US","East US","West Europe","North Europe","Southeast Asia","East Asia"],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"migrateprojects","locations":["Central US","East Asia","Southeast Asia","North Europe","West Europe","West US 2","Australia Southeast","UK South","UK West","Canada Central","Central India","South India","Japan East","Japan West","Brazil South","Korea South","Korea Central","France Central","Switzerland - North"],"apiVersions":["2020-05-01","2019-06-01","2018-09-01-preview"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"assessmentProjects","locations":["Central + North"],"apiVersions":["2020-06-01-preview","2020-05-01","2019-06-01","2018-09-01-preview"],"defaultApiVersion":"2018-09-01-preview","capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"assessmentProjects","locations":["Central US","West Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East Asia","Central India","South India","Canada Central","Australia Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea South","France Central","Switzerland North"],"apiVersions":["2020-05-01-preview","2019-10-01","2019-05-01","2018-06-30-preview"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":["West Central - US"],"apiVersions":["2019-10-01","2019-05-01","2018-06-30-preview","2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + SupportsLocation"},{"resourceType":"moveCollections","locations":["East US + 2","North Europe","UK South","Southeast Asia","Australia East","Japan East"],"apiVersions":["2021-01-01","2019-10-01-preview"],"defaultApiVersion":"2019-10-01-preview","capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["West + Central US"],"apiVersions":["2019-10-01","2019-05-01","2018-06-30-preview","2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West Central US","East US","West Europe","North Europe","Southeast Asia","East Asia"],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations/assessmentOptions","locations":["West Central US","East US","West Europe","North Europe","Southeast Asia","East - Asia"],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataMigration","namespace":"Microsoft.DataMigration","authorization":{"applicationId":"a4bad4aa-bf02-4631-9f78-a64ffdba8150","roleDefinitionId":"b831a21d-db98-4760-89cb-bef871952df1","managedByRoleDefinitionId":"6256fb55-9e59-4018-a9e1-76b11c0a4c89"},"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2018-07-15-preview","2018-04-19","2018-03-31-preview","2018-03-15-preview","2017-11-15-privatepreview","2017-11-15-preview","2017-04-15-privatepreview"],"capabilities":"None"},{"resourceType":"services","locations":["West + Asia"],"apiVersions":["2018-02-02","2017-11-11-preview","2017-09-25-privatepreview"],"capabilities":"None"},{"resourceType":"locations/rmsOperationResults","locations":["East + US 2","North Europe","UK South","Southeast Asia","Australia East","Japan East"],"apiVersions":["2021-01-01","2019-10-01-preview"],"defaultApiVersion":"2019-10-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataMigration","namespace":"Microsoft.DataMigration","authorization":{"applicationId":"a4bad4aa-bf02-4631-9f78-a64ffdba8150","roleDefinitionId":"b831a21d-db98-4760-89cb-bef871952df1","managedByRoleDefinitionId":"6256fb55-9e59-4018-a9e1-76b11c0a4c89"},"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2018-07-15-preview","2018-04-19","2018-03-31-preview","2018-03-15-preview","2017-11-15-privatepreview","2017-11-15-preview","2017-04-15-privatepreview"],"capabilities":"None"},{"resourceType":"services","locations":["West Central US","Brazil South","West Europe","Australia East","East US","East US 2","Canada Central","East Asia","Central India","West India","Japan East","Korea South","North Central US","Australia Southeast","Canada East","Central US","South @@ -2482,92 +2886,124 @@ interactions: Asia","UK West","West US","UK South","West US 2","South Africa North","UAE North","France Central"],"apiVersions":["2018-07-15-preview","2018-04-19","2018-03-31-preview","2018-03-15-preview","2017-11-15-privatepreview","2017-11-15-preview","2017-04-15-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataShare","namespace":"Microsoft.DataShare","authorization":{"applicationId":"799f1985-1517-4fe1-af2b-ba3d87d4996b","roleDefinitionId":"0146496b-e06f-439a-83be-49fac884edf5"},"resourceTypes":[{"resourceType":"accounts","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"CrossResourceGroupResourceMove, + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"accounts/shares","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/datasets","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/datasets","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/synchronizationSettings","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/synchronizationSettings","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/invitations","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/invitations","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/providersharesubscriptions","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/shares/providersharesubscriptions","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/datasetmappings","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/datasetmappings","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/triggers","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/triggers","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/consumerSourceDataSets","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"accounts/sharesubscriptions/consumerSourceDataSets","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"listinvitations","locations":["East + Asia","West US 2","South Central US","Canada Central","Central India","East + Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"listinvitations","locations":["East US 2","East US","Australia East","Southeast Asia","West US 2","North Europe","UK - South","Canada Central","West Central US"],"apiVersions":["2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":["East - US 2"],"apiVersions":["2019-11-01","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East + South","Canada Central","Central India","East Asia","South Africa North","West + Central US"],"apiVersions":["2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":["East + US 2"],"apiVersions":["2020-10-01-preview","2020-09-01","2019-11-01","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East US 2","North Europe","East US","UK South","Australia East","West Europe","Southeast - Asia","West Central US","West US 2","South Central US","Canada Central"],"apiVersions":["2019-11-01"],"capabilities":"None"},{"resourceType":"locations/rejectInvitation","locations":["East + Asia","West Central US","West US 2","South Central US","Canada Central","Central + India","East Asia","South Africa North","West US","Central US"],"apiVersions":["2020-09-01","2019-11-01"],"capabilities":"None"},{"resourceType":"locations/rejectInvitation","locations":["East US 2","East US","Australia East","West US 2","North Europe","UK South","West - Europe","Southeast Asia","West Central US","South Central US","Canada Central"],"apiVersions":["2019-11-01","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations","locations":["East + Europe","Southeast Asia","West Central US","South Central US","Canada Central","Central + India","East Asia","South Africa North","West US","Central US"],"apiVersions":["2020-10-01-preview","2020-09-01","2019-11-01","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations","locations":["East US 2","East US","Australia East","West US 2","North Europe","UK South","West - Europe","Southeast Asia","West Central US","South Central US","Canada Central"],"apiVersions":["2019-11-01","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-11-01","2018-11-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorageCache","namespace":"Microsoft.StorageCache","authorizations":[{"applicationId":"4392ab71-2ce2-4b0d-8770-b352745c73f5","roleDefinitionId":"e27430df-bd6b-4f3a-bd6d-d52ad1a7d075"}],"resourceTypes":[{"resourceType":"caches","locations":["Australia - East","East US","East US 2","Korea Central","North Europe","South Central - US","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"SystemAssignedResourceIdentity, + Europe","Southeast Asia","West Central US","South Central US","Canada Central","Central + India","East Asia","South Africa North","West US","Central US"],"apiVersions":["2020-10-01-preview","2020-09-01","2019-11-01","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01-preview","2020-09-01","2019-11-01","2018-11-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorageCache","namespace":"Microsoft.StorageCache","authorizations":[{"applicationId":"4392ab71-2ce2-4b0d-8770-b352745c73f5","roleDefinitionId":"e27430df-bd6b-4f3a-bd6d-d52ad1a7d075"}],"resourceTypes":[{"resourceType":"caches","locations":["Australia + East","Canada Central","Central US","East US","East US 2","Korea Central","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2"],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"caches/storageTargets","locations":["Australia - East","East US","East US 2","Korea Central","North Europe","South Central - US","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"operations","locations":["Australia - East","East US","East US 2","Korea Central","North Europe","South Central - US","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"usageModels","locations":["Australia - East","East US","East US 2","Korea Central","North Europe","South Central - US","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"locations/ascoperations","locations":["Australia - East","East US","East US 2","Korea Central","North Europe","South Central - US","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CustomProviders","namespace":"Microsoft.CustomProviders","authorization":{"applicationId":"bf8eb16c-7ba7-4b47-86be-ac5e4b2007a5","roleDefinitionId":"FACF09C9-A5D0-4D34-8B1F-B623AC29C6F7"},"resourceTypes":[{"resourceType":"resourceProviders","locations":["Australia + East","Canada Central","Central US","East US","East US 2","Korea Central","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2"],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"None"},{"resourceType":"operations","locations":["Australia + East","Canada Central","Central US","East US","East US 2","Korea Central","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2"],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"None"},{"resourceType":"usageModels","locations":["Australia + East","Canada Central","Central US","East US","East US 2","Korea Central","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2"],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"None"},{"resourceType":"locations/ascoperations","locations":["Australia + East","Canada Central","Central US","East US","East US 2","Korea Central","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2"],"apiVersions":["2020-10-01","2020-03-01","2019-11-01","2019-08-01-preview"],"defaultApiVersion":"2020-10-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CustomProviders","namespace":"Microsoft.CustomProviders","authorization":{"applicationId":"bf8eb16c-7ba7-4b47-86be-ac5e4b2007a5","roleDefinitionId":"FACF09C9-A5D0-4D34-8B1F-B623AC29C6F7"},"resourceTypes":[{"resourceType":"resourceProviders","locations":["Australia East","Australia Southeast","East US","West US 2","West Europe","North Europe","Canada Central","Canada East"],"apiVersions":["2018-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"associations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["Australia East","Australia Southeast","East US","West US 2","West Europe","North Europe","Canada - Central","Canada East"],"apiVersions":["2018-09-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PowerBIDedicated","namespace":"Microsoft.PowerBIDedicated","authorization":{"applicationId":"4ac7d521-0382-477b-b0f8-7e1d95f85ca2","roleDefinitionId":"490d5987-bcf6-4be6-b6b2-056a78cb693a"},"resourceTypes":[{"resourceType":"capacities","locations":["Australia - Southeast","Brazil South","Canada Central","UAE North","UAE Central","Germany - West Central","Germany North","France Central","France South","Korea Central","Korea - South","Japan West","South Africa North","Switzerland North","Switzerland - West","Canada East","South Africa West","UK West","Central US","Central India","Australia - East","East Asia","East US","East US 2","West India","Japan East","West Central - US","North Central US","North Europe","South Central US","Southeast Asia","UK - South","West Europe","West US","West US 2"],"apiVersions":["2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia - Southeast","Brazil South","Canada Central","UAE North","UAE Central","Germany - West Central","Germany North","France Central","France South","Korea Central","Korea - South","Japan West","Switzerland North","Switzerland West","Canada East","UK - West","Central US","Central India","Australia East","East Asia","East US","East - US 2","West India","Japan East","West Central US","North Central US","North - Europe","South Africa North","South Central US","Southeast Asia","South Africa - West","UK South","West Europe","West US","West US 2"],"apiVersions":["2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["Australia - Southeast","Brazil South","Canada Central","UAE North","UAE Central","Germany - West Central","Germany North","France Central","France South","Korea Central","Korea - South","Japan West","Switzerland North","Switzerland West","Canada East","UK - West","Central US","Central India","Australia East","East Asia","East US","East - US 2","West India","Japan East","West Central US","North Central US","North - Europe","South Central US","Southeast Asia","UK South","West Europe","West - US","South Africa North","South Africa West","West US 2"],"apiVersions":["2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["Australia - Southeast","Brazil South","Canada Central","UAE North","UAE Central","Germany - West Central","Germany North","France Central","France South","Korea Central","Korea - South","Japan West","Switzerland North","Switzerland West","Canada East","UK - West","Central US","Central India","Australia East","East Asia","East US","East - US 2","West India","Japan East","West Central US","North Central US","North - Europe","South Central US","Southeast Asia","UK South","West Europe","West - US","West US 2","South Africa North","South Africa West"],"apiVersions":["2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["East - US 2"],"apiVersions":["2018-09-01-preview","2017-10-01","2017-01-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MixedReality","namespace":"Microsoft.MixedReality","authorizations":[{"applicationId":"c7ddd9b4-5172-4e28-bd29-1e0792947d18","roleDefinitionId":"b67ee066-e058-4ddb-92bc-83cdd74bc38a"},{"applicationId":"a15bc1de-f777-408f-9d2b-a27ed19c72ba"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia - East","East US","East US 2","North Europe","South Central US","Southeast Asia","UK - South","West Europe","West US 2"],"apiVersions":["2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"spatialAnchorsAccounts","locations":["Australia - East","East US","East US 2","North Europe","West Europe","South Central US","UK - South","Southeast Asia"],"apiVersions":["2020-05-01","2019-12-02-preview","2019-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Canada East"],"apiVersions":["2018-09-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PowerBIDedicated","namespace":"Microsoft.PowerBIDedicated","authorizations":[{"applicationId":"4ac7d521-0382-477b-b0f8-7e1d95f85ca2","roleDefinitionId":"490d5987-bcf6-4be6-b6b2-056a78cb693a"},{"applicationId":"cb4dc29f-0bf4-402a-8b30-7511498ed654","roleDefinitionId":"e03b0682-208e-4ddd-841f-66fb49a5c930"}],"resourceTypes":[{"resourceType":"capacities","locations":["Australia + Southeast","Brazil South","Canada Central","Norway East","Norway West","UAE + North","UAE Central","Germany West Central","Germany North","France Central","France + South","Korea Central","Korea South","Japan West","South Africa North","Switzerland + North","Switzerland West","Canada East","South Africa West","UK West","Central + US","Central India","Australia East","East Asia","East US","East US 2","West + India","Japan East","West Central US","North Central US","North Europe","South + Central US","Southeast Asia","UK South","West Europe","West US","West US 2"],"apiVersions":["2021-01-01","2018-09-01-preview","2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"autoScaleVCores","locations":["Australia + Southeast","Brazil South","Canada Central","Norway East","Norway West","UAE + North","UAE Central","Germany West Central","Germany North","France Central","France + South","Korea Central","Korea South","Japan West","South Africa North","Switzerland + North","Switzerland West","Canada East","South Africa West","UK West","Central + US","Central India","Australia East","East Asia","East US","East US 2","West + India","Japan East","West Central US","North Central US","North Europe","South + Central US","Southeast Asia","UK South","West Europe","West US","West US 2"],"apiVersions":["2021-01-01"],"defaultApiVersion":"2021-01-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia + Southeast","Brazil South","Canada Central","Norway East","Norway West","UAE + North","UAE Central","Germany West Central","Germany North","France Central","France + South","Korea Central","Korea South","Japan West","Switzerland North","Switzerland + West","Canada East","UK West","Central US","Central India","Australia East","East + Asia","East US","East US 2","West India","Japan East","West Central US","North + Central US","North Europe","South Africa North","South Central US","Southeast + Asia","South Africa West","UK South","West Europe","West US","West US 2"],"apiVersions":["2021-01-01","2018-09-01-preview","2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["Australia + Southeast","Brazil South","Canada Central","Norway East","Norway West","UAE + North","UAE Central","Germany West Central","Germany North","France Central","France + South","Korea Central","Korea South","Japan West","Switzerland North","Switzerland + West","Canada East","UK West","Central US","Central India","Australia East","East + Asia","East US","East US 2","West India","Japan East","West Central US","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","South Africa North","South Africa West","West US 2"],"apiVersions":["2021-01-01","2018-09-01-preview","2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["Australia + Southeast","Brazil South","Canada Central","Norway East","Norway West","UAE + North","UAE Central","Germany West Central","Germany North","France Central","France + South","Korea Central","Korea South","Japan West","Switzerland North","Switzerland + West","Canada East","UK West","Central US","Central India","Australia East","East + Asia","East US","East US 2","West India","Japan East","West Central US","North + Central US","North Europe","South Central US","Southeast Asia","UK South","West + Europe","West US","West US 2","South Africa North","South Africa West"],"apiVersions":["2021-01-01","2018-09-01-preview","2017-10-01","2017-01-01-preview"],"defaultApiVersion":"2017-01-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["East + US 2"],"apiVersions":["2021-01-01","2018-09-01-preview","2017-10-01","2017-01-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MixedReality","namespace":"Microsoft.MixedReality","authorizations":[{"applicationId":"c7ddd9b4-5172-4e28-bd29-1e0792947d18","roleDefinitionId":"b67ee066-e058-4ddb-92bc-83cdd74bc38a"},{"applicationId":"a15bc1de-f777-408f-9d2b-a27ed19c72ba"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2021-03-01-preview","2021-01-01","2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia + East","East US","East US 2","Japan East","Korea Central","North Europe","South + Central US","Southeast Asia","UK South","West Europe","West US 2"],"apiVersions":["2021-03-01-preview","2021-01-01","2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2021-03-01-preview","2021-01-01","2020-05-01","2020-04-06-preview","2019-12-02-preview","2019-02-28-preview"],"capabilities":"None"},{"resourceType":"spatialAnchorsAccounts","locations":["Australia + East","East US","East US 2","Korea Central","North Europe","West Europe","South + Central US","UK South","Southeast Asia"],"apiVersions":["2021-03-01-preview","2021-01-01","2020-05-01","2019-12-02-preview","2019-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"remoteRenderingAccounts","locations":["East - US","East US 2","Southeast Asia","West Europe","West US 2"],"apiVersions":["2020-04-06-preview","2019-12-02-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2","East US","Southeast Asia","West Europe","West US 2","Japan East","Australia + East","North Europe","South Central US","UK South"],"apiVersions":["2021-03-01-preview","2021-01-01","2020-04-06-preview","2019-12-02-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Solutions","namespace":"Microsoft.Solutions","authorization":{"applicationId":"ba4bc2bd-843f-4d61-9d33-199178eae34e","roleDefinitionId":"6cb99a0b-29a8-49bc-b57b-057acc68cd9a","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"managedByResourceRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"}},"resourceTypes":[{"resourceType":"applications","locations":["South + SupportsLocation"},{"resourceType":"objectUnderstandingAccounts","locations":["East + US 2","West US 2"],"apiVersions":["2019-12-02-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"objectAnchorsAccounts","locations":["East + US 2","West US 2"],"apiVersions":["2021-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Solutions","namespace":"Microsoft.Solutions","authorization":{"applicationId":"ba4bc2bd-843f-4d61-9d33-199178eae34e","roleDefinitionId":"6cb99a0b-29a8-49bc-b57b-057acc68cd9a","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"managedByResourceRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"}},"resourceTypes":[{"resourceType":"applications","locations":["South Central US","North Central US","West Central US","West US","West US 2","East US","East US 2","Central US","West Europe","North Europe","East Asia","Southeast Asia","Brazil South","Japan West","Japan East","Australia East","Australia @@ -2599,110 +3035,125 @@ interactions: Southeast","South India","West India","Central India","Canada Central","Canada East","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","UAE North","South Africa North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-08-21-preview","2019-07-01","2018-09-01-preview","2018-06-01","2018-03-01","2018-02-01","2017-12-01","2017-09-01","2016-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-21-preview","2019-07-01","2018-09-01-preview","2018-06-01","2018-03-01","2018-02-01","2017-12-01","2017-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MachineLearningServices","namespace":"Microsoft.MachineLearningServices","authorizations":[{"applicationId":"0736f41a-0425-4b46-bdb5-1563eff02385","roleDefinitionId":"376aa7d7-51a9-463d-bd4d-7e1691345612","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"},{"applicationId":"607ece82-f922-494f-88b8-30effaf12214","roleDefinitionId":"d312a9a6-5102-420b-b8b3-aa6b22670aaa","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"},{"applicationId":"18a66f5f-dbdf-4c17-9dd7-1634712a9cbe","roleDefinitionId":"8b910db7-60f9-4c04-af30-71aab18eda90","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"}],"resourceTypes":[{"resourceType":"workspaces","locations":["Canada - Central","North Central US","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-10-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"defaultApiVersion":"2018-03-01-preview","capabilities":"SystemAssignedResourceIdentity, - SupportsTags, SupportsLocation"},{"resourceType":"workspaces/computes","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"workspaces/eventGridFilters","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["East - US 2"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["East - US 2"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/computeOperationsStatus","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","Australia East","East US 2","West US 2","West Central US","Southeast - Asia","West Europe","South Central US","North Europe","Korea Central","Brazil - South","France Central"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/workspaceOperationsStatus","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19"],"capabilities":"None"},{"resourceType":"locations/vmsizes","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19"],"capabilities":"None"},{"resourceType":"locations/quotas","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01"],"capabilities":"None"},{"resourceType":"locations/updatequotas","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01"],"capabilities":"None"},{"resourceType":"workspaces/linkedServices","locations":["North - Central US","Canada Central","UK South","West US","Central US","East Asia","Japan - East","East US","North Europe","Korea Central","Brazil South","France Central","Australia - East","East US 2","West US 2","West Central US","Southeast Asia","West Europe","South - Central US"],"apiVersions":["2020-05-15-preview","2020-05-01-preview","2020-04-01-preview"],"capabilities":"SystemAssignedResourceIdentity"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WindowsIoT","namespace":"Microsoft.WindowsIoT","resourceTypes":[{"resourceType":"DeviceServices","locations":["West + Central","Norway East"],"apiVersions":["2020-08-21-preview","2019-07-01","2018-09-01-preview","2018-06-01","2018-03-01","2018-02-01","2017-12-01","2017-09-01","2016-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-21-preview","2019-07-01","2018-09-01-preview","2018-06-01","2018-03-01","2018-02-01","2017-12-01","2017-09-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MachineLearningServices","namespace":"Microsoft.MachineLearningServices","authorizations":[{"applicationId":"0736f41a-0425-4b46-bdb5-1563eff02385","roleDefinitionId":"376aa7d7-51a9-463d-bd4d-7e1691345612","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"},{"applicationId":"607ece82-f922-494f-88b8-30effaf12214","roleDefinitionId":"d312a9a6-5102-420b-b8b3-aa6b22670aaa","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"},{"applicationId":"18a66f5f-dbdf-4c17-9dd7-1634712a9cbe","roleDefinitionId":"8b910db7-60f9-4c04-af30-71aab18eda90","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"},{"applicationId":"6608bce8-e060-4e82-bfd2-67ed4f60262f","roleDefinitionId":"344880d0-81ee-4377-b825-b8b79810e492","managedByRoleDefinitionId":"91d00862-cf55-46a5-9dce-260bbd92ce25"}],"resourceTypes":[{"resourceType":"workspaces","locations":["Canada + Central","Central India","North Central US","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-10-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"defaultApiVersion":"2018-03-01-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"workspaces/computes","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"workspaces/datastores","locations":["Canada + Central","Central India","North Central US","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2020-05-01-preview"],"capabilities":"None"},{"resourceType":"workspaces/eventGridFilters","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["East + US 2"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["East + US 2"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/computeOperationsStatus","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","Australia East","East US 2","West + US 2","West Central US","Southeast Asia","West Europe","South Central US","North + Europe","Korea Central","Brazil South","France Central"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/workspaceOperationsStatus","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-09-01","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-10-01","2019-06-01","2019-05-01","2018-11-19","2018-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19"],"capabilities":"None"},{"resourceType":"locations/vmsizes","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01","2019-05-01","2018-11-19"],"capabilities":"None"},{"resourceType":"locations/quotas","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01"],"capabilities":"None"},{"resourceType":"locations/updatequotas","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2021-01-01","2020-09-01-preview","2020-08-01","2020-06-01","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview","2020-04-01","2020-03-01","2020-02-18-preview","2020-02-02","2020-01-01","2019-11-01","2019-06-01"],"capabilities":"None"},{"resourceType":"workspaces/linkedServices","locations":["North + Central US","Canada Central","Central India","UK South","West US","Central + US","East Asia","Japan East","East US","North Europe","Korea Central","Brazil + South","France Central","Australia East","East US 2","West US 2","West Central + US","Southeast Asia","West Europe","South Central US"],"apiVersions":["2020-09-01-preview","2020-05-15-preview","2020-05-01-preview","2020-04-01-preview"],"capabilities":"SystemAssignedResourceIdentity"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WindowsIoT","namespace":"Microsoft.WindowsIoT","resourceTypes":[{"resourceType":"DeviceServices","locations":["West US","East US"],"apiVersions":["2019-06-01","2018-02-16-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["West US","East - US","West Central US"],"apiVersions":["2019-06-01","2018-02-16-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.NetApp","namespace":"Microsoft.NetApp","authorizations":[{"applicationId":"12fb057d-b751-47cd-857c-f2934bb677b4","roleDefinitionId":"e4796bef-6b6d-4cbc-ba1e-27f1a308d860"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia + US","West Central US"],"apiVersions":["2019-06-01","2018-02-16-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.NetApp","namespace":"Microsoft.NetApp","authorizations":[{"applicationId":"12fb057d-b751-47cd-857c-f2934bb677b4","roleDefinitionId":"e4796bef-6b6d-4cbc-ba1e-27f1a308d860"},{"applicationId":"608f9929-9737-432e-860f-4e1c1821052f","roleDefinitionId":"3db66429-be98-4b0c-8ad6-20dc5cb960e4"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan West","North Europe","South Central US","South India","Southeast Asia","UAE Central","UK South","UK West","West Central US","West Europe","West US","West - US 2","West US (Stage)","West US 2 (Stage)","South Central US (Stage)"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"netAppAccounts","locations":["Australia + US 2","West US (Stage)","West US 2 (Stage)","South Central US (Stage)"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"netAppAccounts","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SystemAssignedResourceIdentity, + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"netAppAccounts/capacityPools","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SupportsTags, + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"netAppAccounts/capacityPools/volumes","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SupportsTags, + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"netAppAccounts/capacityPools/volumes/mountTargets","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"netAppAccounts/capacityPools/volumes/snapshots","locations":["Australia + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"netAppAccounts/capacityPools/volumes/snapshots","locations":["Australia + East","Australia Southeast","Canada Central","Canada East","Central India","Central + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West US","West US 2","West Europe"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West US","West US 2","West Europe"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["Australia + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/checkFilePathAvailability","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/checkFilePathAvailability","locations":["Australia + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/checkQuotaAvailability","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central - US","East US","East US 2","Germany West Central","Japan East","Japan West","North - Europe","South Central US","South India","Southeast Asia","UAE Central","UK - South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AppPlatform","namespace":"Microsoft.AppPlatform","authorizations":[{"applicationId":"03b39d0f-4213-4864-a245-b1476ec03169"},{"applicationId":"b61cc489-e138-4a69-8bf3-c2c5855c8784","roleDefinitionId":"462ddd96-910a-44f5-adfa-644d99942778"},{"applicationId":"e8de9221-a19c-4c81-b814-fd37c6caf9d2"}],"resourceTypes":[{"resourceType":"Spring","locations":["West + US","East US","East US 2","Germany North","Germany West Central","Japan East","Japan + West","North Europe","South Central US","South India","Southeast Asia","UAE + Central","UK South","UK West","West Europe","West US","West US 2"],"apiVersions":["2020-11-01","2020-10-01","2020-09-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-03-01","2020-02-01","2019-11-01","2019-10-01","2019-08-01","2019-07-01","2019-06-01","2019-05-01","2017-08-15"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AppPlatform","namespace":"Microsoft.AppPlatform","authorizations":[{"applicationId":"03b39d0f-4213-4864-a245-b1476ec03169"},{"applicationId":"b61cc489-e138-4a69-8bf3-c2c5855c8784","roleDefinitionId":"462ddd96-910a-44f5-adfa-644d99942778"},{"applicationId":"e8de9221-a19c-4c81-b814-fd37c6caf9d2"},{"applicationId":"366cbfa5-46b3-47fb-9d70-55fb923b4833","roleDefinitionId":"d63d711d-1c1a-41d9-905a-fb87b28d47d9"}],"resourceTypes":[{"resourceType":"Spring","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"CrossResourceGroupResourceMove, + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Spring/apps","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"Spring/apps/deployments","locations":["West + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"SystemAssignedResourceIdentity"},{"resourceType":"Spring/apps/deployments","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["West + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["West Europe","East US","West US 2","Southeast Asia","Central US","Australia East","UK - South","North Europe","South Central US","East US 2"],"apiVersions":["2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DevOps","namespace":"Microsoft.DevOps","authorization":{"applicationId":"499b84ac-1321-427f-aa17-267ca6975798","roleDefinitionId":"6a18f445-86f0-4e2e-b8a9-6b9b5677e3d8"},"resourceTypes":[{"resourceType":"pipelines","locations":["East + South","North Europe","South Central US","East US 2","Canada Central","North + Central US","West US","UAE North","Central India","Korea Central","East Asia"],"apiVersions":["2020-11-01-preview","2020-07-01","2019-05-01-preview"],"defaultApiVersion":"2019-05-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DevOps","namespace":"Microsoft.DevOps","authorization":{"applicationId":"499b84ac-1321-427f-aa17-267ca6975798","roleDefinitionId":"6a18f445-86f0-4e2e-b8a9-6b9b5677e3d8"},"resourceTypes":[{"resourceType":"pipelines","locations":["East Asia","Southeast Asia","Australia East","Brazil South","Canada Central","Japan East","Japan West","North Europe","West Europe","West India","Central India","South India","Central US","East US","East US 2","North Central US","South Central @@ -2742,66 +3193,86 @@ interactions: Europe","North Europe","France Central","UK South","UK West","France South","Switzerland North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"entityQueries","locations":["West Europe","North Europe","France Central","UK South","UK West","France South","Switzerland + North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"entityQueryTemplates","locations":["West + Europe","North Europe","France Central","UK South","UK West","France South","Switzerland North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"threatIntelligence","locations":["West Europe","North Europe","France Central","UK South","UK West","France South","Switzerland North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"automationRules","locations":["West Europe","North Europe","France Central","UK South","UK West","France South","Switzerland North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"watchlists","locations":["West Europe","North Europe","France Central","UK South","UK West","France South","Switzerland - North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DesktopVirtualization","namespace":"Microsoft.DesktopVirtualization","authorizations":[{"applicationId":"50e95039-b200-4007-bc97-8d5790743a63","roleDefinitionId":"CAD30215-AD1C-43BF-BE90-7BFA8B493E62"},{"applicationId":"9cdead84-a844-4324-93f2-b2e6bb768d07"},{"applicationId":"a85cf173-4192-42f8-81fa-777a763e6e2c"}],"resourceTypes":[{"resourceType":"workspaces","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationgroups","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationgroups/applications","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"applicationgroups/desktops","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"applicationgroups/startmenuitems","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostpools/sessionhosts","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools/sessionhosts/usersessions","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools/usersessions","locations":["East - US","East US 2","West US","West US 2","North Central US","South Central US","West - Central US","Central US"],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.GuestConfiguration","namespace":"Microsoft.GuestConfiguration","authorizations":[{"applicationId":"e935b4a5-8968-416d-8414-caed51c782a9","roleDefinitionId":"9c6ffa40-421e-4dc0-9739-76b0699a11de"}],"resourceTypes":[{"resourceType":"guestConfigurationAssignments","locations":[],"apiVersions":["2020-06-25","2018-11-20","2018-06-30-preview","2018-01-20-preview"],"capabilities":"SupportsExtension"},{"resourceType":"software","locations":["East + North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DesktopVirtualization","namespace":"Microsoft.DesktopVirtualization","authorizations":[{"applicationId":"50e95039-b200-4007-bc97-8d5790743a63","roleDefinitionId":"CAD30215-AD1C-43BF-BE90-7BFA8B493E62"},{"applicationId":"9cdead84-a844-4324-93f2-b2e6bb768d07"},{"applicationId":"a85cf173-4192-42f8-81fa-777a763e6e2c"}],"resourceTypes":[{"resourceType":"workspaces","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationgroups","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationgroups/applications","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"applicationgroups/desktops","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"applicationgroups/startmenuitems","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostpools/msixpackages","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools/sessionhosts","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools/sessionhosts/usersessions","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"hostpools/usersessions","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"},{"resourceType":"scalingPlans","locations":["North + Europe","West Europe","East US","East US 2","West US","West US 2","North Central + US","South Central US","West Central US","Central US"],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2021-01-14-preview","2020-11-10-preview","2020-11-02-preview","2020-10-19-preview","2020-09-21-preview","2019-12-10-preview","2019-09-24-preview","2019-01-23-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.GuestConfiguration","namespace":"Microsoft.GuestConfiguration","authorizations":[{"applicationId":"e935b4a5-8968-416d-8414-caed51c782a9","roleDefinitionId":"9c6ffa40-421e-4dc0-9739-76b0699a11de"}],"resourceTypes":[{"resourceType":"guestConfigurationAssignments","locations":[],"apiVersions":["2020-06-25","2018-11-20","2018-06-30-preview","2018-01-20-preview"],"capabilities":"SupportsExtension"},{"resourceType":"software","locations":["East US 2","South Central US"],"apiVersions":["2018-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"softwareUpdates","locations":["East US 2","South Central US"],"apiVersions":["2018-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"softwareUpdateProfile","locations":["East - US 2","South Central US"],"apiVersions":["2018-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-25","2018-11-20","2018-06-30-preview","2018-01-20-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridCompute","namespace":"Microsoft.HybridCompute","authorizations":[{"applicationId":"8c420feb-03df-47cc-8a05-55df0cf3064b","roleDefinitionId":"83eeb1c6-47f8-4da2-bbc3-42a7ac767360"}],"resourceTypes":[{"resourceType":"machines","locations":["West - Central US","West US 2","West Europe","Southeast Asia","East US"],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview","2019-03-18-preview"],"defaultApiVersion":"2020-08-02","capabilities":"CrossResourceGroupResourceMove, + US 2","South Central US"],"apiVersions":["2018-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-25","2018-11-20","2018-06-30-preview","2018-01-20-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridCompute","namespace":"Microsoft.HybridCompute","authorizations":[{"applicationId":"8c420feb-03df-47cc-8a05-55df0cf3064b","roleDefinitionId":"83eeb1c6-47f8-4da2-bbc3-42a7ac767360"},{"applicationId":"d2a590e7-6906-4a45-8f41-cecfdca9bca1","roleDefinitionId":"f32ad452-2b05-4296-bee4-fc9056ed85fa"}],"resourceTypes":[{"resourceType":"machines","locations":["West + Central US","West US 2","West Europe","Southeast Asia","East US","Australia + East","South Central US","East US 2","North Europe","France Central","UK South"],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview","2019-03-18-preview"],"defaultApiVersion":"2020-08-02","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"machines/extensions","locations":["West - Central US","West Europe","West US 2","Southeast Asia","East US"],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"CrossResourceGroupResourceMove, + Central US","West Europe","West US 2","Southeast Asia","East US","Australia + East","South Central US","East US 2","North Europe","France Central","UK South"],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":["West - Europe"],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["West - Central US","West Europe","West US 2","Southeast Asia","East US"],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West - Central US","West Europe","West US 2","Southeast Asia","East US"],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview","2019-03-18-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ManagedServices","namespace":"Microsoft.ManagedServices","authorization":{"applicationId":"66c6d0d1-f2e7-4a18-97a9-ed10f3347016","roleDefinitionId":"1e86f807-6ec0-40b3-8b5f-686b7e43a0a2"},"resourceTypes":[{"resourceType":"registrationDefinitions","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"registrationAssignments","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"marketplaceRegistrationDefinitions","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OffAzure","namespace":"Microsoft.OffAzure","authorizations":[{"applicationId":"728a93e3-065d-4678-93b1-3cc281223341","roleDefinitionId":"b9967bf7-a345-4af8-95f0-49916f760fc6"}],"resourceTypes":[{"resourceType":"VMwareSites","locations":["Central + Europe"],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["West + Central US","West Europe","West US 2","Southeast Asia","East US","Australia + East","South Central US","East US 2","North Europe","France Central","UK South"],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Central US","West Europe","West US 2","Southeast Asia","East US","Australia + East","South Central US","East US 2","North Europe","France Central","UK South"],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2021-01-28-preview","2020-08-15-preview","2020-08-02","2020-07-30-preview","2020-03-11-preview","2019-12-12","2019-08-02-preview","2019-03-18-preview"],"defaultApiVersion":"2020-08-02","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ManagedServices","namespace":"Microsoft.ManagedServices","authorization":{"applicationId":"66c6d0d1-f2e7-4a18-97a9-ed10f3347016","roleDefinitionId":"1e86f807-6ec0-40b3-8b5f-686b7e43a0a2"},"resourceTypes":[{"resourceType":"registrationDefinitions","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"registrationAssignments","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"marketplaceRegistrationDefinitions","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2020-02-01-preview","2019-09-01","2019-06-01","2019-04-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OffAzure","namespace":"Microsoft.OffAzure","authorizations":[{"applicationId":"728a93e3-065d-4678-93b1-3cc281223341","roleDefinitionId":"b9967bf7-a345-4af8-95f0-49916f760fc6"}],"resourceTypes":[{"resourceType":"VMwareSites","locations":["Central US","West Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East Asia","Central India","South India","Canada Central","Australia Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea - South","France Central","Switzerland North","Switzerland West"],"apiVersions":["2020-01-01-preview","2020-01-01","2019-06-06","2019-05-01-preview","2018-05-01-preview"],"capabilities":"SupportsTags, + South","France Central","Switzerland North"],"apiVersions":["2020-01-01-preview","2020-01-01","2019-06-06","2019-05-01-preview","2018-05-01-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"HyperVSites","locations":["Central US","West Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East Asia","Central India","South India","Canada Central","Australia Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea South","France Central","Switzerland - North","Switzerland West"],"apiVersions":["2020-01-01","2019-06-06","2018-05-01-preview"],"capabilities":"SupportsTags, + North"],"apiVersions":["2020-01-01","2019-06-06","2018-05-01-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"ServerSites","locations":["Central US","West Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East Asia","Central India","South India","Canada Central","Australia Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea South","France Central","Switzerland - North","Switzerland West"],"apiVersions":["2020-01-01-preview","2019-05-01-preview"],"capabilities":"SupportsTags, + North"],"apiVersions":["2020-01-01-preview","2019-05-01-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"ImportSites","locations":["Central US","West Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East Asia","Central India","South India","Canada Central","Australia Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea South","France Central","Switzerland - North","Switzerland West"],"apiVersions":["2020-02-01","2020-01-01-preview","2019-05-01-preview"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":["Southeast Asia"],"apiVersions":["2020-01-01","2019-06-06","2018-05-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Capacity","namespace":"Microsoft.Capacity","authorization":{"applicationId":"4d0ad6c7-f6c3-46d8-ab0d-1406d5e6c86b","roleDefinitionId":"FD9C0A9A-4DB9-4F41-8A61-98385DEB6E2D"},"resourceTypes":[{"resourceType":"resourceProviders","locations":[],"apiVersions":["2019-07-19-preview"],"capabilities":"None"},{"resourceType":"resources","locations":["South - Central US"],"apiVersions":["2019-04-01","2018-06-01","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders","locations":[],"apiVersions":["2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"listbenefits","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01"],"capabilities":"None"},{"resourceType":"reservations","locations":[],"apiVersions":["2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations/revisions","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"catalogs","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"appliedReservations","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"checkOffers","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"checkScopes","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"calculatePrice","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"calculateExchange","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"exchange","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"reservationOrders/calculateRefund","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/return","locations":[],"apiVersions":["2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/split","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/merge","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/swap","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"validateReservationOrder","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/availableScopes","locations":[],"apiVersions":["2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations/availableScopes","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01"],"capabilities":"None"},{"resourceType":"commercialReservationOrders","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"calculatePurchasePrice","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"},{"resourceType":"placePurchaseOrder","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"},{"resourceType":"checkPurchaseStatus","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SqlVirtualMachine","namespace":"Microsoft.SqlVirtualMachine","authorizations":[{"applicationId":"bd93b475-f9e2-476e-963d-b2daf143ffb9","roleDefinitionId":"f96bd990-ffdf-4c17-8ee3-77454d9c3f5d"}],"resourceTypes":[{"resourceType":"SqlVirtualMachineGroups","locations":["Australia + North"],"apiVersions":["2020-02-01","2020-01-01-preview","2019-05-01-preview"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"MasterSites","locations":["Central US","West + Europe","UK South","UK West","North Europe","West US 2","Southeast Asia","East + Asia","Central India","South India","Canada Central","Australia Southeast","Japan + West","Japan East","Brazil South","Korea Central","Korea South","France Central","Switzerland + North"],"apiVersions":["2020-07-07"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-07-07"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Central + US","West Europe","UK South","UK West","North Europe","West US 2","Southeast + Asia","East Asia","Central India","South India","Canada Central","Australia + Southeast","Japan West","Japan East","Brazil South","Korea Central","Korea + South","France Central","Switzerland North"],"apiVersions":["2020-07-07"],"capabilities":"None"},{"resourceType":"operations","locations":["Southeast + Asia"],"apiVersions":["2020-01-01","2019-06-06","2018-05-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Capacity","namespace":"Microsoft.Capacity","authorizations":[{"applicationId":"4d0ad6c7-f6c3-46d8-ab0d-1406d5e6c86b","roleDefinitionId":"FD9C0A9A-4DB9-4F41-8A61-98385DEB6E2D"},{"applicationId":"fbc197b7-9e9c-4f98-823f-93cb1cb554e6","roleDefinitionId":"941F67D2-083A-4B78-AF91-9B3B30B9B150"}],"resourceTypes":[{"resourceType":"resourceProviders","locations":[],"apiVersions":["2020-10-25","2019-07-19-preview"],"capabilities":"None"},{"resourceType":"resources","locations":["South + Central US"],"apiVersions":["2019-04-01","2018-06-01","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders","locations":[],"apiVersions":["2020-11-15-preview","2020-11-15-beta","2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"listbenefits","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01"],"capabilities":"None"},{"resourceType":"reservations","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations/revisions","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"catalogs","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"appliedReservations","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"checkOffers","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"checkScopes","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"calculatePrice","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"calculateExchange","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"exchange","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"reservationOrders/calculateRefund","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/return","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2020-06-01","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/split","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/merge","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/swap","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"validateReservationOrder","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/availableScopes","locations":[],"apiVersions":["2020-10-01-preview","2020-10-01-beta","2020-06-01-beta","2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01","2017-11-01-beta","2017-11-01"],"capabilities":"None"},{"resourceType":"reservationOrders/reservations/availableScopes","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01"],"capabilities":"None"},{"resourceType":"commercialReservationOrders","locations":[],"apiVersions":["2019-04-01-beta","2019-04-01","2018-06-01-beta","2018-06-01"],"capabilities":"None"},{"resourceType":"calculatePurchasePrice","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"},{"resourceType":"placePurchaseOrder","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"},{"resourceType":"checkPurchaseStatus","locations":[],"apiVersions":["2019-06-01-privatepreview","2019-06-01-beta"],"capabilities":"None"},{"resourceType":"ownReservations","locations":[],"apiVersions":["2020-06-01-beta","2020-06-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SqlVirtualMachine","namespace":"Microsoft.SqlVirtualMachine","authorizations":[{"applicationId":"bd93b475-f9e2-476e-963d-b2daf143ffb9","roleDefinitionId":"f96bd990-ffdf-4c17-8ee3-77454d9c3f5d"}],"resourceTypes":[{"resourceType":"SqlVirtualMachineGroups","locations":["Australia Central","Australia Central 2","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Germany West Central","Japan @@ -2866,21 +3337,28 @@ interactions: East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE Central","UAE North","UK South","UK West","West + Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2017-03-01-preview"],"defaultApiVersion":"2017-03-01-preview","capabilities":"None"},{"resourceType":"Locations/registerSqlVmCandidate","locations":["Australia + Central","Australia Central 2","Australia East","Australia Southeast","Brazil + South","Canada Central","Canada East","Central India","Central US","East Asia","East + US","East US 2","France Central","France South","Germany West Central","Japan + East","Japan West","Korea Central","Korea South","North Central US","North + Europe","Norway East","South Africa North","South Central US","South India","Southeast + Asia","Switzerland North","UAE Central","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2017-03-01-preview"],"defaultApiVersion":"2017-03-01-preview","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Peering","namespace":"Microsoft.Peering","resourceTypes":[{"resourceType":"peerings","locations":["Japan East","Japan West","Korea Central","East Asia","Australia Central","Australia East","Australia Southeast","Brazil South","Southeast Asia","West India","South India","East US","East US 2","North Central US","South Central US","Canada Central","West US","West US 2","West Central US","Canada East","West Europe","UK South","UK West","North Europe","France Central","France South","South Africa - North","South Africa West"],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"peeringLocations","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"legacyPeerings","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peerAsns","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServices","locations":["Japan + North","South Africa West"],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"peeringLocations","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"legacyPeerings","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peerAsns","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServices","locations":["Japan East","Japan West","Korea Central","East Asia","Australia Central","Australia East","Australia Southeast","Brazil South","Southeast Asia","West India","South India","East US","East US 2","North Central US","South Central US","Canada Central","West US","West US 2","West Central US","Canada East","West Europe","UK South","UK West","North Europe","France Central","France South","South Africa - North","South Africa West"],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"peeringServiceCountries","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServiceLocations","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServiceProviders","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"checkServiceProviderAvailability","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Sendgrid.Email","namespace":"Sendgrid.Email","resourceTypes":[{"resourceType":"accounts","locations":["Australia + North","South Africa West"],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"peeringServiceCountries","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServiceLocations","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"peeringServiceProviders","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"checkServiceProviderAvailability","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-10-01","2020-04-01","2020-01-01-preview","2019-09-01-preview","2019-08-01-preview"],"defaultApiVersion":"2020-04-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Sendgrid.Email","namespace":"Sendgrid.Email","resourceTypes":[{"resourceType":"accounts","locations":["Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","France South","Japan East","Japan West","Korea Central","Korea South","North Central @@ -2893,72 +3371,293 @@ interactions: East","Japan West","Korea Central","Korea South","North Central US","North Europe","South Africa North","South Africa West","South Central US","South India","Southeast Asia","UAE Central","UAE North","UK South","UK West","West - Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2015-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ResourceHealth","namespace":"Microsoft.ResourceHealth","authorizations":[{"applicationId":"8bdebf23-c0fe-4187-a378-717ad86f6a53","roleDefinitionId":"cc026344-c8b1-4561-83ba-59eba84b27cc"}],"resourceTypes":[{"resourceType":"availabilityStatuses","locations":[],"apiVersions":["2020-05-01-preview","2020-05-01","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2017-07-01","2015-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"childAvailabilityStatuses","locations":[],"apiVersions":["2018-11-06-beta","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2017-07-01-rc","2017-07-01-preview","2017-07-01-beta","2015-01-01-rc","2015-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"childResources","locations":[],"apiVersions":["2018-11-06-beta","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2017-07-01-rc","2017-07-01-preview","2017-07-01-beta","2015-01-01-rc","2015-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"events","locations":[],"apiVersions":["2018-07-01-rc","2018-07-01"],"capabilities":"SupportsExtension"},{"resourceType":"metadata","locations":[],"apiVersions":["2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2018-07-01-alpha"],"capabilities":"None"},{"resourceType":"emergingissues","locations":[],"apiVersions":["2018-11-06-beta","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2018-07-01-alpha","2018-07-01","2017-07-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-07-01","2015-01-01"],"capabilities":"None"},{"resourceType":"notifications","locations":["Australia + Central US","West Europe","West India","West US","West US 2"],"apiVersions":["2015-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DigitalTwins","namespace":"Microsoft.DigitalTwins","authorizations":[{"applicationId":"0b07f429-9f4b-4714-9392-cc5e8e80c8b0"},{"applicationId":"91ff567f-bb4f-4719-91d7-d983057bc0d6","roleDefinitionId":"fa0ab6ed-58e5-4f2f-81af-0b9ffc364bdc"},{"applicationId":"c115998b-3d59-49b4-b55b-042a9ba1dbfe","roleDefinitionId":"07af60d1-cd6d-4ad4-9b56-ece6c78a3fe1"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"defaultApiVersion":"2020-12-01","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West + Central US","West US 2","North Europe","Australia East","West Europe","East + US","South Central US","Southeast Asia","UK South","East US 2"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"digitalTwinsInstances","locations":["West + Central US","West US 2","North Europe","Australia East","West Europe","East + US","South Central US","Southeast Asia","UK South","East US 2"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"defaultApiVersion":"2020-12-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"digitalTwinsInstances/operationResults","locations":["West + Central US","West US 2","North Europe","Australia East","West Europe","East + US","South Central US","Southeast Asia","UK South","East US 2"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"defaultApiVersion":"2020-12-01","capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Central US","West US 2","North Europe","Australia East","West Europe","East + US","South Central US","Southeast Asia","UK South","East US 2"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"defaultApiVersion":"2020-12-01","capabilities":"None"},{"resourceType":"digitalTwinsInstances/endpoints","locations":["West + Central US","West US 2","North Europe","Australia East","West Europe","East + US","South Central US","Southeast Asia","UK South","East US 2"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"defaultApiVersion":"2020-12-01","capabilities":"None"},{"resourceType":"operations","locations":["West + Central US"],"apiVersions":["2020-12-01","2020-10-31","2020-03-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Communication","namespace":"Microsoft.Communication","authorizations":[{"applicationId":"632ec9eb-fad7-4cbd-993a-e72973ba2acc","roleDefinitionId":"6c5c31b0-3a00-47ea-9555-f233670ba313"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-08-20-preview","2020-08-20"],"capabilities":"None"},{"resourceType":"CommunicationServices","locations":["Global"],"apiVersions":["2020-08-20-preview","2020-08-20"],"defaultApiVersion":"2020-08-20-preview","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"CommunicationServices/eventGridFilters","locations":["Global"],"apiVersions":["2020-08-20-preview","2020-08-20"],"defaultApiVersion":"2020-08-20-preview","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-20-preview","2020-08-20"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-08-20-preview","2020-08-20"],"defaultApiVersion":"2020-08-20-preview","capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West + US 2","North Europe","West US"],"apiVersions":["2020-08-20-preview","2020-08-20"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Global"],"apiVersions":["2020-08-20-preview","2020-08-20"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DomainRegistration","namespace":"Microsoft.DomainRegistration","authorization":{"applicationId":"ea2f600a-4980-45b7-89bf-d34da487bda1","roleDefinitionId":"54d7f2e3-5040-48a7-ae90-eebf629cfa0b"},"resourceTypes":[{"resourceType":"domains","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"domains/domainOwnershipIdentifiers","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"topLevelDomains","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"checkDomainAvailability","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"listDomainRecommendations","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validateDomainRegistrationInformation","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"generateSsoRequest","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.TimeSeriesInsights","namespace":"Microsoft.TimeSeriesInsights","authorizations":[{"applicationId":"120d688d-1518-4cf7-bd38-182f158850b6","roleDefinitionId":"5a43abdf-bb87-42c4-9e56-1c24bf364150"}],"resourceTypes":[{"resourceType":"environments","locations":["France + Central","South Central Us","East US 2","West US","East US","North Europe","West + Europe","West US 2","Central US","Southeast Asia","Australia East","Australia + Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"environments/eventsources","locations":["France + Central","South Central Us","East US 2","West US","East US","North Europe","West + Europe","West US 2","Central US","Southeast Asia","Australia East","Australia + Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"environments/referenceDataSets","locations":["France + Central","South Central Us","East US 2","West US","East US","North Europe","West + Europe","West US 2","Central US","Southeast Asia","Australia East","Australia + Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"environments/accessPolicies","locations":["France + Central","South Central Us","East US 2","West US","East US","North Europe","West + Europe","West US 2","Central US","Southeast Asia","Australia East","Australia + Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Canada + Central","West India","France Central","South Central Us","East US 2","West + US","East US","East US 2 EUAP","North Europe","West Europe","West US 2","Central + US","Southeast Asia","Australia East","Australia Southeast","East Asia","UK + West","North Central US","UK South"],"apiVersions":["2021-03-31-preview","2020-05-15","2018-08-15-preview","2017-11-15","2017-05-31-privatepreview","2017-02-28-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServiceFabricMesh","namespace":"Microsoft.ServiceFabricMesh","authorizations":[{"applicationId":"d10de03d-5ba3-497a-90e6-7ff8c9736059","roleDefinitionId":"BC13595A-E262-4621-929E-56FF90E6BF18"}],"resourceTypes":[{"resourceType":"applications","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"networks","locations":["East US","East + US 2","West US","West US 2","South Central US","Central US","France Central","West + Europe","North Europe","UK South","UK West","Australia East","East Asia","Southeast + Asia","Korea Central","West India","Brazil South","Japan East","Norway East","South + Africa North","Switzerland North","Central India","UAE North","Germany West + Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"volumes","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"secrets","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"gateways","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/applicationOperations","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/networkOperations","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/volumeOperations","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/gatewayOperations","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/secretOperations","locations":["East + US","East US 2","West US","West US 2","South Central US","Central US","France + Central","West Europe","North Europe","UK South","UK West","Australia East","East + Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan + East","Norway East","South Africa North","Switzerland North","Central India","UAE + North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Maintenance","namespace":"Microsoft.Maintenance","authorization":{"applicationId":"f18474f2-a66a-4bb0-a3c9-9b8d892092fa","roleDefinitionId":"2f1ef7b0-d5c4-4d3c-98fa-6a9fa8e74aa5"},"resourceTypes":[{"resourceType":"maintenanceConfigurations","locations":["Central + US","East US","East US 2","West US","West US 2","West Central US","North Central + US","South Central US","North Europe","West Europe","East Asia","Southeast + Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia + Central","Australia Central 2","South Africa North","South Africa West","Brazil + South","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","France + South","UAE North","UAE Central","Germany West Central","Germany North","Switzerland + North","Switzerland West"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"updates","locations":["Central + US","East US","East US 2","West US","West US 2","West Central US","North Central + US","South Central US","North Europe","West Europe","East Asia","Southeast + Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia + Central","Australia Central 2","South Africa North","South Africa West","Brazil + South","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","France + South","UAE North","UAE Central","Germany West Central","Germany North","Switzerland + North","Switzerland West"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"configurationAssignments","locations":["Central + US","East US","East US 2","West US","West US 2","West Central US","North Central + US","South Central US","North Europe","West Europe","East Asia","Southeast + Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia + Central","Australia Central 2","South Africa North","South Africa West","Brazil + South","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","France + South","UAE North","UAE Central","Germany West Central","Germany North","Switzerland + North","Switzerland West"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"applyUpdates","locations":["Central + US","East US","East US 2","West US","West US 2","West Central US","North Central + US","South Central US","North Europe","West Europe","East Asia","Southeast + Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia + Central","Australia Central 2","South Africa North","South Africa West","Brazil + South","South India","Central India","West India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","France + South","UAE North","UAE Central","Germany West Central","Germany North","Switzerland + North","Switzerland West"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Notebooks","namespace":"Microsoft.Notebooks","resourceTypes":[{"resourceType":"NotebookProxies","locations":[],"apiVersions":["2019-10-11-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-10-11-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AAD","namespace":"Microsoft.AAD","authorizations":[{"applicationId":"443155a6-77f3-45e3-882b-22b3a8d431fb","roleDefinitionId":"7389DE79-3180-4F07-B2BA-C5BA1F01B03A"},{"applicationId":"abba844e-bc0e-44b0-947a-dc74e5d09022","roleDefinitionId":"63BC473E-7767-42A5-A3BF-08EB71200E04"},{"applicationId":"d87dcbc6-a371-462e-88e3-28ad15ec4e64","roleDefinitionId":"861776c5-e0df-4f95-be4f-ac1eec193323"}],"resourceTypes":[{"resourceType":"DomainServices","locations":["West + US","Central US","East US","South Central US","West Europe","North Europe","East + Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West + Central US","North Central US","Japan East","Japan West","Brazil South","Central + India","South India","West India","Canada Central","Canada East","West US + 2","Korea Central","France Central","UK South","South Africa North","Switzerland + North","UAE North","Germany West Central"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"DomainServices/oucontainer","locations":["West + US","Central US","East US","South Central US","West Europe","North Europe","East + Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West + Central US","North Central US","Japan East","Japan West","Brazil South","Central + India","South India","West India","Canada Central","Canada East","West US + 2","Korea Central","France Central","UK South","South Africa North","Switzerland + North","UAE North","Germany West Central"],"apiVersions":["2020-01-01","2017-06-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"locations","locations":["West + US","Central US","East US","South Central US","West Europe","North Europe","East + Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West + Central US","North Central US","Japan East","Japan West","Brazil South","Central + India","South India","West India","Canada Central","Canada East","West US + 2","Korea Central","France Central","UK South","South Africa North","Switzerland + North","UAE North","Germany West Central"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West + US","Central US","East US","South Central US","West Europe","North Europe","East + Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West + Central US","North Central US","Japan East","Japan West","Brazil South","Central + India","South India","West India","Canada Central","Canada East","West US + 2","Korea Central","France Central","UK South","South Africa North","Switzerland + North","UAE North","Germany West Central"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"operations","locations":["West + US","Central US","East US","South Central US","West Europe","North Europe","East + Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West + Central US","North Central US","Japan East","Japan West","Brazil South","Central + India","South India","West India","Canada Central","Canada East","West US + 2","Korea Central","France Central","UK South","South Africa North","Switzerland + North","UAE North","Germany West Central"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicCompute","namespace":"Microsoft.ClassicCompute","resourceTypes":[{"resourceType":"domainNames","locations":["East + Asia","Southeast Asia","East US","East US 2","West US","West US 2","North + Central US","South Central US","West Central US","Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia East","Australia + Southeast","South India","Central India","West India","Canada Central","Canada + East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea + Central","Korea South","France Central","South Africa North","UAE North","Australia + Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2021-02-01","2020-02-01","2018-06-01","2017-11-15","2017-11-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"CrossResourceGroupResourceMove, + SupportsLocation"},{"resourceType":"domainNames/internalLoadBalancers","locations":[],"apiVersions":["2017-11-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"None"},{"resourceType":"checkDomainNameAvailability","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots","locations":["East + Asia","Southeast Asia","East US","East US 2","West US","West US 2","North + Central US","South Central US","West Central US","Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia East","Australia + Southeast","South India","Central India","West India","Canada Central","Canada + East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea + Central","Korea South","France Central","South Africa North","UAE North","Australia + Central","Switzerland North","Norway East","Germany West Central"],"apiVersions":["2020-02-01","2018-06-01","2017-11-15","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles","locations":["East + Asia","Southeast Asia","East US","East US 2","West US","West US 2","North + Central US","South Central US","West Central US","Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia East","Australia + Southeast","South India","Central India","West India","Canada Central","Canada + East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea + Central","Korea South","France Central","South Africa North","UAE North","Australia + Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles/metrics","locations":["North + Central US","South Central US","East US","East US 2","Canada Central","Canada + East","West US","West US 2","West Central US","Australia East","Australia + Southeast","South Africa North","UAE North","Australia Central","Switzerland + North","Germany West Central","Norway East","Central US","East Asia","Southeast + Asia","North Europe","West Europe","UK South","UK West","Japan East","Japan + West","Brazil South","South India","Central India","West India","East US 2 + (Stage)","North Central US (Stage)","Korea Central","Korea South","France + Central"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines","locations":["East + Asia","Southeast Asia","East US","East US 2","West US","West US 2","North + Central US","South Central US","West Central US","Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia East","Australia + Southeast","South India","Central India","West India","Canada Central","Canada + East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea + Central","Korea South","France Central","South Africa North","UAE North","Australia + Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2017-04-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"CrossResourceGroupResourceMove, + SupportsLocation"},{"resourceType":"capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"domainNames/capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"domainNames/serviceCertificates","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"quotas","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"virtualMachines/diagnosticSettings","locations":["East + US","East US 2","North Central US","North Europe","West Europe","Brazil South","Canada + Central","Canada East","UK South","UK West","France Central","South Africa + North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway + East","West US","Central US","South Central US","Japan East","Japan West","East + Asia","Southeast Asia","Australia East","Australia Southeast","West US 2","West + Central US","South India","Central India","West India","Korea Central","Korea + South","East US 2 (Stage)","North Central US (Stage)"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines/metricDefinitions","locations":["East + US","East US 2","North Central US","North Europe","West Europe","Brazil South","Canada + Central","Canada East","UK South","UK West","France Central","South Africa + North","UAE North","Switzerland North","West US","Central US","South Central + US","Japan East","Japan West","East Asia","Southeast Asia","Australia East","Australia + Southeast","Australia Central","West US 2","West Central US","Germany West + Central","Norway East","South India","Central India","West India","Korea Central","Korea + South","East US 2 (Stage)","North Central US (Stage)"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines/metrics","locations":["North + Central US","South Central US","East US","East US 2","Canada Central","Canada + East","West US","West US 2","West Central US","Australia East","Australia + Southeast","South Africa North","UAE North","Australia Central","Switzerland + North","Germany West Central","Norway East","Central US","East Asia","Southeast + Asia","North Europe","West Europe","UK South","UK West","Japan East","Japan + West","Brazil South","South India","Central India","West India","East US 2 + (Stage)","North Central US (Stage)","Korea Central","Korea South","France + Central"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"resourceTypes","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"moveSubscriptionResources","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"validateSubscriptionMoveAvailability","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"operatingSystems","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"operatingSystemFamilies","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ResourceHealth","namespace":"Microsoft.ResourceHealth","authorizations":[{"applicationId":"8bdebf23-c0fe-4187-a378-717ad86f6a53","roleDefinitionId":"cc026344-c8b1-4561-83ba-59eba84b27cc"}],"resourceTypes":[{"resourceType":"availabilityStatuses","locations":[],"apiVersions":["2020-05-01-preview","2020-05-01","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2018-07-01","2017-07-01","2015-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"childAvailabilityStatuses","locations":[],"apiVersions":["2018-11-06-beta","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2017-07-01-rc","2017-07-01-preview","2017-07-01-beta","2015-01-01-rc","2015-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"childResources","locations":[],"apiVersions":["2018-11-06-beta","2018-08-01-rc","2018-08-01-preview","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2017-07-01-rc","2017-07-01-preview","2017-07-01-beta","2015-01-01-rc","2015-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"events","locations":[],"apiVersions":["2018-07-01-rc","2018-07-01"],"capabilities":"SupportsExtension"},{"resourceType":"metadata","locations":[],"apiVersions":["2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2018-07-01-alpha","2018-07-01"],"capabilities":"None"},{"resourceType":"emergingissues","locations":[],"apiVersions":["2018-11-06-beta","2018-07-01-rc","2018-07-01-preview","2018-07-01-beta","2018-07-01-alpha","2018-07-01","2017-07-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-07-01","2015-01-01"],"capabilities":"None"},{"resourceType":"notifications","locations":["Australia Southeast"],"apiVersions":["2016-09-01","2016-06-01"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DevTestLab","namespace":"Microsoft.DevTestLab","authorization":{"applicationId":"1a14be2a-e903-4cec-99cf-b2e209259a0f","roleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525","managedByRoleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525"},"resourceTypes":[{"resourceType":"labs/environments","locations":["Southeast Asia","East US","West US","West Europe","East Asia","East US 2","Japan East","Japan West","Central US"],"apiVersions":["2015-05-21-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"labs","locations":["West Central US","South Central US","Central US","Australia Central","Australia Southeast","Canada Central","Central India","East Asia","East US","France - Central","Japan East","Korea Central","North Europe","South Africa North","UK - West","West India","Switzerland North","Australia Central 2","Australia East","Brazil - South","Canada East","East US 2","France South","Japan West","Korea South","North - Central US","South India","Southeast Asia","Switzerland West","UK South","West - Europe","West US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"defaultApiVersion":"2018-10-15-preview","capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Europe","South Africa North","Switzerland + North","UAE North","UK West","West India","Australia Central 2","Australia + East","Brazil South","Canada East","East US 2","France South","Germany West + Central","Japan West","Korea South","North Central US","Norway East","South + India","Southeast Asia","Switzerland West","UK South","West Europe","West + US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"defaultApiVersion":"2018-10-15-preview","capabilities":"CrossResourceGroupResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"schedules","locations":["West Central US","South Central US","Central US","Australia Central","Australia Southeast","Canada Central","Central India","East Asia","East US","France - Central","Japan East","Korea Central","North Europe","South Africa North","UK - West","West India","Switzerland North","Australia Central 2","Australia East","Brazil - South","Canada East","East US 2","France South","Japan West","Korea South","North - Central US","South India","Southeast Asia","Switzerland West","UK South","West - Europe","West US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Europe","South Africa North","Switzerland + North","UAE North","UK West","West India","Australia Central 2","Australia + East","Brazil South","Canada East","East US 2","France South","Germany West + Central","Japan West","Korea South","North Central US","Norway East","South + India","Southeast Asia","Switzerland West","UK South","West Europe","West + US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"labs/virtualMachines","locations":["West Central US","South Central US","Central US","Australia Central","Australia Southeast","Canada Central","Central India","East Asia","East US","France - Central","Japan East","Korea Central","North Europe","South Africa North","UK - West","West India","Switzerland North","Australia Central 2","Australia East","Brazil - South","Canada East","East US 2","France South","Japan West","Korea South","North - Central US","South India","Southeast Asia","Switzerland West","UK South","West - Europe","West US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Europe","South Africa North","Switzerland + North","UAE North","UK West","West India","Australia Central 2","Australia + East","Brazil South","Canada East","East US 2","France South","Germany West + Central","Japan West","Korea South","North Central US","Norway East","South + India","Southeast Asia","Switzerland West","UK South","West Europe","West + US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"CrossResourceGroupResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"labs/serviceRunners","locations":["West Central US","South Central US","Central US","Australia Central","Australia Southeast","Canada Central","Central India","East Asia","East US","France - Central","Japan East","Korea Central","North Europe","South Africa North","UK - West","West India","Switzerland North","Australia Central 2","Australia East","Brazil - South","Canada East","East US 2","France South","Japan West","Korea South","North - Central US","South India","Southeast Asia","Switzerland West","UK South","West - Europe","West US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15"],"defaultApiVersion":"2016-05-15","capabilities":"CrossResourceGroupResourceMove, + Central","Japan East","Korea Central","North Europe","South Africa North","Switzerland + North","UAE North","UK West","West India","Australia Central 2","Australia + East","Brazil South","Canada East","East US 2","France South","Germany West + Central","Japan West","Korea South","North Central US","Norway East","South + India","Southeast Asia","Switzerland West","UK South","West Europe","West + US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15"],"defaultApiVersion":"2016-05-15","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West Central US","South Central US","Central US","Australia Central","Australia Southeast","Canada Central","Central India","East Asia","East US","France - Central","Japan East","Korea Central","North Europe","South Africa North","UK - West","West India","Switzerland North","Australia Central 2","Australia East","Brazil - South","Canada East","East US 2","France South","Japan West","Korea South","North - Central US","South India","Southeast Asia","Switzerland West","UK South","West - Europe","West US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.EventGrid","namespace":"Microsoft.EventGrid","authorizations":[{"applicationId":"4962773b-9cdb-44cf-a8bf-237846a00ab7","roleDefinitionId":"7FE036D8-246F-48BF-A78F-AB3EE699C8F3"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/eventSubscriptions","locations":["West + Central","Japan East","Korea Central","North Europe","South Africa North","Switzerland + North","UAE North","UK West","West India","Australia Central 2","Australia + East","Brazil South","Canada East","East US 2","France South","Germany West + Central","Japan West","Korea South","North Central US","Norway East","South + India","Southeast Asia","Switzerland West","UK South","West Europe","West + US","West US 2"],"apiVersions":["2018-10-15-preview","2018-09-15","2017-04-26-preview","2016-05-15","2015-05-21-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.EventGrid","namespace":"Microsoft.EventGrid","authorizations":[{"applicationId":"4962773b-9cdb-44cf-a8bf-237846a00ab7","roleDefinitionId":"7FE036D8-246F-48BF-A78F-AB3EE699C8F3"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/eventSubscriptions","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"eventSubscriptions","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"eventSubscriptions","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"SupportsExtension"},{"resourceType":"topics","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"SupportsExtension"},{"resourceType":"topics","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"domains","locations":["Central US","West US 2","East US","West US","East US 2","West Central US","Australia East","Australia @@ -2967,7 +3666,7 @@ interactions: South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2018-09-15-preview"],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2018-09-15-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"domains/topics","locations":["Central US","West US 2","East US","West US","East US 2","West Central US","Australia @@ -2976,64 +3675,66 @@ interactions: Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2018-09-15-preview"],"capabilities":"None"},{"resourceType":"topicTypes","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2018-09-15-preview"],"capabilities":"None"},{"resourceType":"topicTypes","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany - West Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West + West Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Brazil Southeast","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany - West Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West + West Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/topicTypes","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"locations/topicTypes","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"extensionTopics","locations":["West + East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"extensionTopics","locations":["West US 2","East US","West US","Central US","East US 2","West Central US","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"operationsStatus","locations":[],"apiVersions":["2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"systemTopics","locations":["global","West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"operationsStatus","locations":[],"apiVersions":["2020-10-15-preview","2020-06-01","2020-04-01-preview","2020-01-01-preview","2019-06-01","2019-02-01-preview","2019-01-01","2018-09-15-preview","2018-05-01-preview","2018-01-01","2017-09-15-preview","2017-06-15-preview"],"capabilities":"None"},{"resourceType":"systemTopics","locations":["global","West Central US","Central US","West US 2","East US","West US","East US 2","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-04-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"systemTopics/eventSubscriptions","locations":["global","West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"systemTopics/eventSubscriptions","locations":["global","West Central US","Central US","West US 2","East US","West US","East US 2","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-04-01-preview"],"capabilities":"None"},{"resourceType":"partnerNamespaces","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"partnerRegistrations","locations":["Global"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"partnerNamespaces","locations":["West Central US","Central US","West US 2","East US","West US","East US 2","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South @@ -3048,7 +3749,7 @@ interactions: Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-04-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"partnerTopics/eventSubscriptions","locations":["West Central US","Central US","West US 2","East US","West US","East US 2","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West @@ -3056,14 +3757,14 @@ interactions: Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-04-01-preview"],"capabilities":"None"},{"resourceType":"partnerNamespaces/eventChannels","locations":["West + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"None"},{"resourceType":"partnerNamespaces/eventChannels","locations":["West Central US","Central US","West US 2","East US","West US","East US 2","Australia East","Australia Southeast","Australia Central","Japan East","Japan West","West Europe","North Europe","Southeast Asia","East Asia","North Central US","South Central US","Brazil South","Canada Central","Canada East","Central India","South India","West India","France Central","UK West","UK South","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-04-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PolicyInsights","namespace":"Microsoft.PolicyInsights","authorizations":[{"applicationId":"1d78a85d-813d-46f0-b496-dd72f50a3ec0","roleDefinitionId":"63d2b225-4c34-4641-8768-21a1f7c68ce8"},{"applicationId":"8cae6e77-e04e-42ce-b5cb-50d82bce26b1","roleDefinitionId":"4a2d3d6b-a6ea-45e2-9882-c9ba3e726ed7"}],"resourceTypes":[{"resourceType":"policyEvents","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"policyStates","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"None"},{"resourceType":"asyncOperationResults","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"remediations","locations":[],"apiVersions":["2019-07-01","2018-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"policyTrackedResources","locations":[],"apiVersions":["2018-07-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.KeyVault","namespace":"Microsoft.KeyVault","authorizations":[{"applicationId":"cfa8b339-82a2-471a-a3c9-0fc0be7a4093","roleDefinitionId":"1cf9858a-28a2-4228-abba-94e606305b95"},{"applicationId":"589d5083-6f11-4d30-a62a-a4b316a14abf"}],"resourceTypes":[{"resourceType":"vaults","locations":["North + Central","Norway East"],"apiVersions":["2020-10-15-preview","2020-04-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PolicyInsights","namespace":"Microsoft.PolicyInsights","authorizations":[{"applicationId":"1d78a85d-813d-46f0-b496-dd72f50a3ec0","roleDefinitionId":"63d2b225-4c34-4641-8768-21a1f7c68ce8"},{"applicationId":"8cae6e77-e04e-42ce-b5cb-50d82bce26b1","roleDefinitionId":"4a2d3d6b-a6ea-45e2-9882-c9ba3e726ed7"}],"resourceTypes":[{"resourceType":"policyEvents","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"policyStates","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview","2018-04-04","2017-12-12-preview","2017-10-17-preview","2017-08-09-preview"],"capabilities":"None"},{"resourceType":"asyncOperationResults","locations":[],"apiVersions":["2019-10-01","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"remediations","locations":[],"apiVersions":["2019-07-01","2018-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"policyTrackedResources","locations":[],"apiVersions":["2018-07-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.KeyVault","namespace":"Microsoft.KeyVault","authorizations":[{"applicationId":"cfa8b339-82a2-471a-a3c9-0fc0be7a4093","roleDefinitionId":"1cf9858a-28a2-4228-abba-94e606305b95"},{"applicationId":"589d5083-6f11-4d30-a62a-a4b316a14abf"}],"resourceTypes":[{"resourceType":"vaults","locations":["North Central US","East US","North Europe","West Europe","East Asia","Southeast Asia","East US 2","Central US","South Central US","West US","Japan East","Japan West","Australia East","Australia Southeast","Brazil South","Central India","South @@ -3121,7 +3822,9 @@ interactions: Central US","West US 2","Korea Central","Korea South","France Central","Australia Central","UAE North","South Africa North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2019-09-01","2018-02-14-preview","2018-02-14"],"defaultApiVersion":"2019-09-01","capabilities":"None"},{"resourceType":"managedHSMs","locations":["East - US 2","South Central US","North Europe","West Europe"],"apiVersions":["2020-04-01-preview"],"defaultApiVersion":"2020-04-01-preview","capabilities":"CrossResourceGroupResourceMove, + US 2","South Central US","North Europe","West Europe","Canada Central","Central + US","Switzerland North","South Africa North","UK South","SouthEast Asia","East + Asia","Korea Central","Australia Central","West US","East US"],"apiVersions":["2020-04-01-preview"],"defaultApiVersion":"2020-04-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MachineLearning","namespace":"Microsoft.MachineLearning","authorization":{"applicationId":"0736f41a-0425-4b46-bdb5-1563eff02385","roleDefinitionId":"1cc297bc-1829-4524-941f-966373421033"},"resourceTypes":[{"resourceType":"Workspaces","locations":["South Central US","West Europe","Southeast Asia","Japan East","West Central US"],"apiVersions":["2016-04-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, @@ -3143,44 +3846,44 @@ interactions: India","West India","South India","Japan West","Japan East","East Asia","Southeast Asia","Korea Central","Korea South","North Europe","West Europe","UK West","UK South","Switzerland North","Germany West Central","Central US","North Central - US","East US","East US 2","South Central US","West US","West US 2","West Central - US","France Central","Norway East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"SupportsExtension"},{"resourceType":"userAssignedIdentities","locations":["South + US","East US","East US 2","South Central US","West US","West US 2","West US + 3","West Central US","France Central","Norway East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"SupportsExtension"},{"resourceType":"userAssignedIdentities","locations":["South Africa North","South Africa West","UAE North","Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Brazil South","Central India","West India","South India","Japan West","Japan East","East Asia","Southeast Asia","Korea Central","Korea South","North Europe","West Europe","UK West","UK South","Switzerland North","Germany West Central","Central US","North Central - US","East US","East US 2","South Central US","West US","West US 2","West Central - US","France Central","Norway East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":["South Africa - North","South Africa West","UAE North","Australia Central","Australia East","Australia - Southeast","Canada Central","Canada East","Brazil South","Central India","West - India","South India","Japan West","Japan East","East Asia","Southeast Asia","Korea - Central","Korea South","North Europe","West Europe","UK West","UK South","Switzerland - North","Germany West Central","Central US","North Central US","East US","East - US 2","South Central US","West US","West US 2","West Central US","France Central","Norway - East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage","namespace":"Microsoft.Storage","authorizations":[{"applicationId":"a6aa9161-5291-40bb-8c5c-923b567bee3b","roleDefinitionId":"070ab87f-0efc-4423-b18b-756f3bdb0236"},{"applicationId":"e406a681-f3d4-42a8-90b6-c2b029497af1"}],"resourceTypes":[{"resourceType":"deletedAccounts","locations":["East + US","East US","East US 2","South Central US","West US","West US 2","West US + 3","West Central US","France Central","Norway East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["South + Africa North","South Africa West","UAE North","Australia Central","Australia + East","Australia Southeast","Canada Central","Canada East","Brazil South","Central + India","West India","South India","Japan West","Japan East","East Asia","Southeast + Asia","Korea Central","Korea South","North Europe","West Europe","UK West","UK + South","Switzerland North","Germany West Central","Central US","North Central + US","East US","East US 2","South Central US","West US","West US 2","West US + 3","West Central US","France Central","Norway East"],"apiVersions":["2018-11-30","2015-08-31-PREVIEW"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Storage","namespace":"Microsoft.Storage","authorizations":[{"applicationId":"a6aa9161-5291-40bb-8c5c-923b567bee3b","roleDefinitionId":"070ab87f-0efc-4423-b18b-756f3bdb0236"},{"applicationId":"e406a681-f3d4-42a8-90b6-c2b029497af1"}],"resourceTypes":[{"resourceType":"deletedAccounts","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"locations/deletedAccounts","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"locations/deletedAccounts","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"storageAccounts","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"storageAccounts","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan @@ -3188,84 +3891,84 @@ interactions: South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South - Africa North","UAE North","Switzerland North","Germany West Central"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/asyncoperations","locations":["East + Africa North","UAE North","Switzerland North","Germany West Central"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/asyncoperations","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/listAccountSas","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/listAccountSas","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/listServiceSas","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/listServiceSas","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/blobServices","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/blobServices","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/tableServices","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/tableServices","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/queueServices","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/queueServices","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/fileServices","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"storageAccounts/fileServices","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-07-01","2016-01-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"locations/usages","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-07-01","2016-01-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"locations/usages","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-07-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"usages","locations":[],"apiVersions":["2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-07-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"usages","locations":[],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["East + Central"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-03-01-preview","2018-02-01","2017-10-01","2017-06-01","2016-12-01","2016-05-01","2016-01-01","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2019-06-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2017-03-09-profile","apiVersion":"2016-01-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-01-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["East US","East US 2","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","Central US","North Europe","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-02-01","2017-10-01","2017-06-01","2016-12-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"storageAccounts/services","locations":["East + Central","Norway East"],"apiVersions":["2021-01-01","2020-08-01-preview","2019-06-01","2019-04-01","2018-11-01","2018-07-01","2018-02-01","2017-10-01","2017-06-01","2016-12-01"],"defaultApiVersion":"2019-06-01","capabilities":"None"},{"resourceType":"storageAccounts/services","locations":["East US","West US","East US 2 (Stage)","West Europe","North Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","East US 2","Central US","Australia East","Australia Southeast","Brazil South","South @@ -3279,13 +3982,13 @@ interactions: India","Central India","West India","Canada East","Canada Central","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Security","namespace":"Microsoft.Security","authorizations":[{"applicationId":"8edd93e1-2103-40b4-bd70-6e34e586362d","roleDefinitionId":"855AF4C4-82F6-414C-B1A2-628025628B9A"},{"applicationId":"fc780465-2017-40d4-a0c5-307022471b92"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"securityStatuses","locations":["Central + Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Security","namespace":"Microsoft.Security","authorizations":[{"applicationId":"8edd93e1-2103-40b4-bd70-6e34e586362d","roleDefinitionId":"855AF4C4-82F6-414C-B1A2-628025628B9A"},{"applicationId":"fc780465-2017-40d4-a0c5-307022471b92"},{"applicationId":"8ee8fdad-f234-4243-8f3b-15c294843740"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"securityStatuses","locations":["Central US","East US","West Europe","West Central US"],"apiVersions":["2015-06-01-preview"],"capabilities":"None"},{"resourceType":"tasks","locations":["Central - US","East US","West Europe","West Central US"],"apiVersions":["2015-06-01-preview"],"capabilities":"None"},{"resourceType":"secureScores","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"secureScores/secureScoreControls","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"secureScoreControls","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"secureScoreControlDefinitions","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"connectors","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"regulatoryComplianceStandards","locations":["Central + US","East US","West Europe","West Central US"],"apiVersions":["2015-06-01-preview"],"capabilities":"None"},{"resourceType":"secureScores","locations":[],"apiVersions":["2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"secureScores/secureScoreControls","locations":[],"apiVersions":["2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"secureScoreControls","locations":[],"apiVersions":["2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"secureScoreControlDefinitions","locations":[],"apiVersions":["2020-01-01-preview","2020-01-01"],"capabilities":"None"},{"resourceType":"connectors","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"regulatoryComplianceStandards","locations":["Central US","East US"],"apiVersions":["2019-01-01-preview","2019-01-01"],"capabilities":"None"},{"resourceType":"regulatoryComplianceStandards/regulatoryComplianceControls","locations":["Central US","East US"],"apiVersions":["2019-01-01-preview","2019-01-01"],"capabilities":"None"},{"resourceType":"regulatoryComplianceStandards/regulatoryComplianceControls/regulatoryComplianceAssessments","locations":["Central US","East US"],"apiVersions":["2019-01-01-preview","2019-01-01"],"capabilities":"None"},{"resourceType":"alerts","locations":["Central - US","East US","West Europe"],"apiVersions":["2020-01-01","2019-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"alertsSuppressionRules","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"autoDismissAlertsRules","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"dataCollectionAgents","locations":["East + US","East US","West Europe"],"apiVersions":["2021-01-01","2020-01-01","2019-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"alertsSuppressionRules","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"autoDismissAlertsRules","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"dataCollectionAgents","locations":["East Asia","Southeast Asia","East US","East US 2","West US","North Central US","South Central US","Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","South India","Central @@ -3319,7 +4022,7 @@ interactions: US","East US","West Europe","West Central US"],"apiVersions":["2015-06-01-preview"],"capabilities":"None"},{"resourceType":"applicationWhitelistings","locations":["Central US","East US","West Central US","West Europe"],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/applicationWhitelistings","locations":["Central US","West Central US","West Europe"],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/alerts","locations":["Central - US","West Europe"],"apiVersions":["2020-01-01","2019-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/tasks","locations":["Central + US","West Europe"],"apiVersions":["2021-01-01","2020-01-01","2019-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/tasks","locations":["Central US","West Europe","West Central US"],"apiVersions":["2015-06-01-preview"],"capabilities":"None"},{"resourceType":"externalSecuritySolutions","locations":["Central US","East US","West Europe","West Central US"],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/externalSecuritySolutions","locations":["Central US","West Europe","West Central US"],"apiVersions":["2020-01-01","2015-06-01-preview"],"capabilities":"None"},{"resourceType":"InformationProtectionPolicies","locations":["Central @@ -3329,9 +4032,14 @@ interactions: US 2","East US","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","South Central US","South India","Southeast Asia","UK South","UK West","West Central US","West Europe","West India","West US 2","West - US","France Central","UAE North","Germany West Central","Switzerland North"],"apiVersions":["2019-01-01","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"sqlVulnerabilityAssessments","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"deviceSecurityGroups","locations":["North - Europe","West Europe","UK South","UK West","France Central","France South","West - Central US"],"apiVersions":["2019-08-01","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions","locations":["East + US","France Central","UAE North","Germany West Central","Switzerland North"],"apiVersions":["2019-01-01","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"sqlVulnerabilityAssessments","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"deviceSecurityGroups","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West Central US","West US 2","Korea Central","Korea + South","Australia Central","Australia Central 2","UAE Central","UAE North","South + Africa North","South Africa West","North Europe","West Europe","UK South","UK + West","France Central","France South"],"apiVersions":["2019-08-01","2017-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada @@ -3339,36 +4047,70 @@ interactions: Central","Australia Central 2","UAE Central","UAE North","South Africa North","South Africa West","North Europe","West Europe","UK South","UK West","France Central","France South","West Central US"],"apiVersions":["2019-08-01","2017-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"iotDefenderSettings","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"iotSensors","locations":["North - Europe","West Europe","UK South","UK West","France Central","France South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions/analyticsModels","locations":["East + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"iotDefenderSettings","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"iotSensors","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West US 2","Korea Central","Korea South","Australia + Central","Australia Central 2","UAE Central","UAE North","South Africa North","South + Africa West","North Europe","West Europe","UK South","UK West","France Central","France + South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"onPremiseIotSensors","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"devices","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West US 2","Korea Central","Korea South","Australia + Central","Australia Central 2","UAE Central","UAE North","South Africa North","South + Africa West","North Europe","West Europe","UK South","UK West","France Central","France + South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSites","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","Australia Central","Australia Central 2","UAE Central","UAE North","South Africa North","South Africa West","North Europe","West Europe","UK South","UK - West","France Central","France South"],"apiVersions":["2019-08-01","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotAlertTypes","locations":["East + West","France Central","France South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions/analyticsModels","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","Australia Central","Australia Central 2","UAE Central","UAE North","South Africa North","South Africa West","North Europe","West Europe","UK South","UK - West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotAlerts","locations":["East + West","France Central","France South"],"apiVersions":["2019-08-01","2017-08-01-preview"],"capabilities":"None"},{"resourceType":"iotAlertTypes","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotAlertTypes","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","Australia Central","Australia Central 2","UAE Central","UAE North","South Africa North","South Africa West","North Europe","West Europe","UK South","UK - West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotRecommendationTypes","locations":["East + West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotAlerts","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada Central","Canada East","West Central US","West US 2","Korea Central","Korea South","Australia Central","Australia Central 2","UAE Central","UAE North","South Africa North","South Africa West","North Europe","West Europe","UK South","UK - West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotRecommendations","locations":["East + West","France Central","France South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions/iotAlerts","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West Central US","West US 2","Korea Central","Korea + South","Australia Central","Australia Central 2","UAE Central","UAE North","South + Africa North","South Africa West","North Europe","West Europe","UK South","UK + West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotRecommendationTypes","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"iotSecuritySolutions/iotRecommendationTypes","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West Central US","West US 2","Korea Central","Korea + South","Australia Central","Australia Central 2","UAE Central","UAE North","South + Africa North","South Africa West","North Europe","West Europe","UK South","UK + West","France Central","France South"],"apiVersions":["2019-08-01"],"capabilities":"None"},{"resourceType":"iotRecommendations","locations":["East + Asia","Southeast Asia","Central US","East US","East US 2","West US","North + Central US","South Central US","Japan West","Japan East","Brazil South","Australia + East","Australia Southeast","South India","Central India","West India","Canada + Central","Canada East","West US 2","Korea Central","Korea South","Australia + Central","Australia Central 2","UAE Central","UAE North","South Africa North","South + Africa West","North Europe","West Europe","UK South","UK West","France Central","France + South"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsExtension"},{"resourceType":"iotSecuritySolutions/iotRecommendations","locations":["East Asia","Southeast Asia","Central US","East US","East US 2","West US","North Central US","South Central US","Japan West","Japan East","Brazil South","Australia East","Australia Southeast","South India","Central India","West India","Canada @@ -3402,17 +4144,18 @@ interactions: East","Japan West","Korea Central","Korea South","South Africa North","South Africa West","UAE Central","UAE North","North Europe","West Europe","France Central","France South","UK South","UK West","Norway East","Norway West","Germany - West Central","Germany North"],"apiVersions":["2019-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Advisor","namespace":"Microsoft.Advisor","authorization":{"applicationId":"c39c9bac-9d1f-4dfb-aa29-27f6365e5cb7","roleDefinitionId":"8a63b04c-3731-409b-9765-f1175c047872"},"resourceTypes":[{"resourceType":"suppressions","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"configurations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"generateRecommendations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AlertsManagement","namespace":"Microsoft.AlertsManagement","authorizations":[{"applicationId":"3af5a1e8-2459-45cb-8683-bcd6cccbcc13","roleDefinitionId":"b1309299-720d-4159-9897-6158a61aee41"}],"resourceTypes":[{"resourceType":"alerts","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01","2018-11-02-privatepreview","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"SupportsExtension"},{"resourceType":"alertsSummary","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"SupportsExtension"},{"resourceType":"smartGroups","locations":[],"apiVersions":["2019-05-05-preview","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"None"},{"resourceType":"smartDetectorAlertRules","locations":["global"],"apiVersions":["2019-06-01","2019-03-01","2018-02-01-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, + West Central","Germany North","Switzerland North","Switzerland West"],"apiVersions":["2019-01-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Advisor","namespace":"Microsoft.Advisor","authorization":{"applicationId":"c39c9bac-9d1f-4dfb-aa29-27f6365e5cb7","roleDefinitionId":"8a63b04c-3731-409b-9765-f1175c047872"},"resourceTypes":[{"resourceType":"suppressions","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"configurations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"SupportsExtension"},{"resourceType":"generateRecommendations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01","2017-04-19","2017-03-31","2016-07-12-preview","2016-05-09-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AlertsManagement","namespace":"Microsoft.AlertsManagement","authorizations":[{"applicationId":"3af5a1e8-2459-45cb-8683-bcd6cccbcc13","roleDefinitionId":"b1309299-720d-4159-9897-6158a61aee41"}],"resourceTypes":[{"resourceType":"resourceHealthAlertRules","locations":["Global"],"apiVersions":["2020-08-04-preview"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"alerts","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01","2018-11-02-privatepreview","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"SupportsExtension"},{"resourceType":"alertsSummary","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"SupportsExtension"},{"resourceType":"smartGroups","locations":[],"apiVersions":["2019-05-05-preview","2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"None"},{"resourceType":"smartDetectorAlertRules","locations":["global"],"apiVersions":["2019-06-01","2019-03-01","2018-02-01-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"actionRules","locations":["global"],"apiVersions":["2019-05-05-preview","2018-11-02-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"alertsList","locations":[],"apiVersions":["2018-11-02-privatepreview"],"capabilities":"None"},{"resourceType":"alertsSummaryList","locations":[],"apiVersions":["2018-11-02-privatepreview"],"capabilities":"None"},{"resourceType":"alertsMetaData","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute","namespace":"Microsoft.Compute","authorizations":[{"applicationId":"60e6cd67-9c8c-4951-9b3c-23c25a2169af","roleDefinitionId":"e4770acb-272e-4dc8-87f3-12f44a612224"},{"applicationId":"a303894e-f1d8-4a37-bf10-67aa654a0596","roleDefinitionId":"903ac751-8ad5-4e5a-bfc2-5e49f450a241"},{"applicationId":"a8b6bf88-1d1a-4626-b040-9a729ea93c65","roleDefinitionId":"45c8267c-80ba-4b96-9a43-115b8f49fccd"},{"applicationId":"184909ca-69f1-4368-a6a7-c558ee6eb0bd","roleDefinitionId":"45c8267c-80ba-4b96-9a43-115b8f49fccd"},{"applicationId":"5e5e43d4-54da-4211-86a4-c6e7f3715801","roleDefinitionId":"ffcd6e5b-8772-457d-bb17-89703c03428f"},{"applicationId":"ce6ff14a-7fdc-4685-bbe0-f6afdfcfa8e0","roleDefinitionId":"cb17cddc-dbac-4ae0-ae79-8db34eddfca0"},{"applicationId":"372140e0-b3b7-4226-8ef9-d57986796201","roleDefinitionId":"cb17cddc-dbac-4ae0-ae79-8db34eddfca0"},{"applicationId":"b9a92e36-2cf8-4f4e-bcb3-9d99e00e14ab","roleDefinitionId":"6efa92ca-56b6-40af-a468-5e3d2b5232f0"}],"resourceTypes":[{"resourceType":"availabilitySets","locations":["East + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"alertsList","locations":[],"apiVersions":["2018-11-02-privatepreview"],"capabilities":"None"},{"resourceType":"alertsSummaryList","locations":[],"apiVersions":["2018-11-02-privatepreview"],"capabilities":"None"},{"resourceType":"alertsMetaData","locations":[],"apiVersions":["2019-05-05-preview","2019-03-01-preview","2019-03-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-05-05-preview","2018-05-05","2017-11-15-privatepreview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Compute","namespace":"Microsoft.Compute","authorizations":[{"applicationId":"60e6cd67-9c8c-4951-9b3c-23c25a2169af","roleDefinitionId":"e4770acb-272e-4dc8-87f3-12f44a612224"},{"applicationId":"a303894e-f1d8-4a37-bf10-67aa654a0596","roleDefinitionId":"903ac751-8ad5-4e5a-bfc2-5e49f450a241"},{"applicationId":"a8b6bf88-1d1a-4626-b040-9a729ea93c65","roleDefinitionId":"45c8267c-80ba-4b96-9a43-115b8f49fccd"},{"applicationId":"184909ca-69f1-4368-a6a7-c558ee6eb0bd","roleDefinitionId":"45c8267c-80ba-4b96-9a43-115b8f49fccd"},{"applicationId":"5e5e43d4-54da-4211-86a4-c6e7f3715801","roleDefinitionId":"ffcd6e5b-8772-457d-bb17-89703c03428f"},{"applicationId":"ce6ff14a-7fdc-4685-bbe0-f6afdfcfa8e0","roleDefinitionId":"cb17cddc-dbac-4ae0-ae79-8db34eddfca0"},{"applicationId":"372140e0-b3b7-4226-8ef9-d57986796201","roleDefinitionId":"cb17cddc-dbac-4ae0-ae79-8db34eddfca0"},{"applicationId":"b9a92e36-2cf8-4f4e-bcb3-9d99e00e14ab","roleDefinitionId":"6efa92ca-56b6-40af-a468-5e3d2b5232f0"},{"applicationId":"579d9c9d-4c83-4efc-8124-7eba65ed3356","roleDefinitionId":"8c99c4ce-d744-4597-a2f0-0a0044d67560"}],"resourceTypes":[{"resourceType":"availabilitySets","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"virtualMachines","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia @@ -3420,15 +4163,16 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"zoneMappings":[{"location":"East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"virtualMachines/extensions","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North @@ -3437,7 +4181,7 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"virtualMachineScaleSets","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia @@ -3445,15 +4189,16 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"zoneMappings":[{"location":"East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"virtualMachineScaleSets/extensions","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North @@ -3462,91 +4207,112 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2015-06-15","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/virtualMachines","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2015-06-15","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/virtualMachines","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/networkInterfaces","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/virtualMachines/extensions","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/virtualMachines/networkInterfaces","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/networkInterfaces","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/publicIPAddresses","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/virtualMachines/networkInterfaces","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"virtualMachineScaleSets/publicIPAddresses","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/vmSizes","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/runCommands","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-10-30-preview","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/vmSizes","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/usages","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/runCommands","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/virtualMachines","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/usages","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/publishers","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/virtualMachines","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/virtualMachineScaleSets","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-03-30","2015-06-15","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"restorePointCollections","locations":["Southeast + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"locations/publishers","locations":["East + US","East US 2","West US","Central US","North Central US","South Central US","North + Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia + East","Australia Southeast","Australia Central","Brazil South","South India","Central + India","West India","Canada Central","Canada East","West US 2","West Central + US","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","UAE North","Switzerland North","Germany West Central","Norway + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["East + US","East US 2","West US","Central US","North Central US","South Central US","North + Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia + East","Australia Southeast","Australia Central","Brazil South","South India","Central + India","West India","Canada Central","Canada East","West US 2","West Central + US","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","UAE North","Switzerland North","Germany West Central","Norway + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-03-30","2015-06-15","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/edgeZones","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"locations/edgeZones/publishers","locations":["East + US","East US 2","West US","Central US","North Central US","South Central US","North + Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia + East","Australia Southeast","Australia Central","Brazil South","South India","Central + India","West India","Canada Central","Canada East","West US 2","West Central + US","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","UAE North","Switzerland North","Germany West Central","Norway + East"],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"restorePointCollections","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West Central US","UK West","UK South","Japan East","Japan West","Canada Central","Canada East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"defaultApiVersion":"2020-06-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"defaultApiVersion":"2020-06-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"restorePointCollections/restorePoints","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West @@ -3554,14 +4320,14 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"capabilities":"None"},{"resourceType":"proximityPlacementGroups","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30"],"capabilities":"None"},{"resourceType":"proximityPlacementGroups","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01"],"defaultApiVersion":"2020-06-01","capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01"],"defaultApiVersion":"2020-06-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"sshPublicKeys","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia @@ -3569,7 +4335,7 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01"],"defaultApiVersion":"2020-06-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01"],"defaultApiVersion":"2020-06-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"virtualMachines/metricDefinitions","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia @@ -3584,14 +4350,21 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"locations/spotPriceHistory","locations":["East + East"],"apiVersions":["2020-12-01","2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"locations/spotPriceHistory","locations":["East + US","East US 2","West US","Central US","North Central US","South Central US","North + Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia + East","Australia Southeast","Australia Central","Brazil South","South India","Central + India","West India","Canada Central","Canada East","West US 2","West Central + US","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","UAE North","Switzerland North","Germany West Central","Norway + East"],"apiVersions":["2020-12-01","2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"locations/sharedGalleries","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia Central","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"sharedVMImages","locations":["West + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview","2016-03-30","2015-06-15","2015-05-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-30"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2017-12-01"}],"capabilities":"None"},{"resourceType":"sharedVMImages","locations":["West Central US","South Central US","East US 2","Southeast Asia","West Europe","West US","East US","Canada Central","North Europe","North Central US","Brazil South","UK West","West India","East Asia","Australia East","Japan East","Korea South","West @@ -3653,15 +4426,16 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-30","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"zoneMappings":[{"location":"East + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-30","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"snapshots","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West @@ -3669,7 +4443,7 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-30","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-30","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/diskoperations","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West @@ -3677,14 +4451,14 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"diskEncryptionSets","locations":["Southeast + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-30","2020-05-01","2019-11-01","2019-07-01","2019-03-01","2018-09-30","2018-06-01","2018-04-01","2017-03-30","2016-04-30-preview"],"apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"None"},{"resourceType":"diskEncryptionSets","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West Central US","UK West","UK South","Japan East","Japan West","Canada Central","Canada East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-30","2020-05-01","2019-11-01","2019-07-01"],"defaultApiVersion":"2020-06-30","capabilities":"SystemAssignedResourceIdentity, + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-30","2020-05-01","2019-11-01","2019-07-01"],"defaultApiVersion":"2020-06-30","capabilities":"SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"diskAccesses","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West @@ -3692,7 +4466,7 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-30","2020-05-01"],"defaultApiVersion":"2020-06-30","capabilities":"SupportsTags, + East"],"apiVersions":["2020-12-01","2020-09-30","2020-06-30","2020-05-01"],"defaultApiVersion":"2020-06-30","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"images","locations":["Southeast Asia","East US 2","Central US","West Europe","East US","North Central US","South Central US","West US","North Europe","East Asia","Brazil South","West US 2","West @@ -3700,7 +4474,7 @@ interactions: East","Central India","South India","Australia East","Australia Southeast","Korea Central","Korea South","West India","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01","2017-03-30","2016-08-30","2016-04-30-preview"],"defaultApiVersion":"2020-06-01","apiProfiles":[{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-30"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-04-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/logAnalytics","locations":["East US","East US 2","West US","Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia @@ -3708,22 +4482,23 @@ interactions: India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01"],"capabilities":"None"},{"resourceType":"hostGroups","locations":["Central + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01","2018-06-01","2018-04-01","2017-12-01"],"capabilities":"None"},{"resourceType":"hostGroups","locations":["Central US","East US 2","West Europe","Southeast Asia","France Central","North Europe","West US 2","East US","UK South","Japan East","Japan West","East Asia","North Central US","South Central US","Canada East","Korea Central","Brazil South","UK West","Canada Central","West US","West Central US","Central India","South India","Australia Southeast","Korea South","West India","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway East","Australia - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"SupportsTags, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"hostGroups/hosts","locations":["Central US","East US 2","West Europe","Southeast Asia","France Central","North Europe","West US 2","East US","UK South","Japan East","Japan West","East Asia","North Central @@ -3731,39 +4506,48 @@ interactions: Central","West US","West Central US","Central India","South India","Australia Southeast","Korea South","West India","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway East","Australia - East"],"apiVersions":["2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East + East"],"apiVersions":["2020-12-01","2020-06-01","2019-12-01","2019-07-01","2019-03-01","2018-10-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"SupportsTags, - SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network","namespace":"Microsoft.Network","authorizations":[{"applicationId":"2cf9eb86-36b5-49dc-86ae-9a63135dfa8c","roleDefinitionId":"13ba9ab4-19f0-4804-adc4-14ece36cc7a1"},{"applicationId":"7c33bfcb-8d33-48d6-8e60-dc6404003489","roleDefinitionId":"ad6261e4-fa9a-4642-aa5f-104f1b67e9e3"},{"applicationId":"1e3e4475-288f-4018-a376-df66fd7fac5f","roleDefinitionId":"1d538b69-3d87-4e56-8ff8-25786fd48261"},{"applicationId":"a0be0c72-870e-46f0-9c49-c98333a996f7","roleDefinitionId":"7ce22727-ffce-45a9-930c-ddb2e56fa131"},{"applicationId":"486c78bf-a0f7-45f1-92fd-37215929e116","roleDefinitionId":"98a9e526-0a60-4c1f-a33a-ae46e1f8dc0d"},{"applicationId":"19947cfd-0303-466c-ac3c-fcc19a7a1570","roleDefinitionId":"d813ab6c-bfb7-413e-9462-005b21f0ce09"},{"applicationId":"341b7f3d-69b3-47f9-9ce7-5b7f4945fdbd","roleDefinitionId":"8141843c-c51c-4c1e-a5bf-0d351594b86c"},{"applicationId":"328fd23b-de6e-462c-9433-e207470a5727","roleDefinitionId":"79e29e06-4056-41e5-a6b2-959f1f47747e"},{"applicationId":"6d057c82-a784-47ae-8d12-ca7b38cf06b4","roleDefinitionId":"c27dd31e-c1e5-4ab0-93e1-a12ba34f182e"}],"resourceTypes":[{"resourceType":"virtualNetworks","locations":["West + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"SupportsTags, + SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Network","namespace":"Microsoft.Network","authorizations":[{"applicationId":"2cf9eb86-36b5-49dc-86ae-9a63135dfa8c","roleDefinitionId":"13ba9ab4-19f0-4804-adc4-14ece36cc7a1"},{"applicationId":"7c33bfcb-8d33-48d6-8e60-dc6404003489","roleDefinitionId":"ad6261e4-fa9a-4642-aa5f-104f1b67e9e3"},{"applicationId":"1e3e4475-288f-4018-a376-df66fd7fac5f","roleDefinitionId":"1d538b69-3d87-4e56-8ff8-25786fd48261"},{"applicationId":"a0be0c72-870e-46f0-9c49-c98333a996f7","roleDefinitionId":"7ce22727-ffce-45a9-930c-ddb2e56fa131"},{"applicationId":"486c78bf-a0f7-45f1-92fd-37215929e116","roleDefinitionId":"98a9e526-0a60-4c1f-a33a-ae46e1f8dc0d"},{"applicationId":"19947cfd-0303-466c-ac3c-fcc19a7a1570","roleDefinitionId":"d813ab6c-bfb7-413e-9462-005b21f0ce09"},{"applicationId":"341b7f3d-69b3-47f9-9ce7-5b7f4945fdbd","roleDefinitionId":"8141843c-c51c-4c1e-a5bf-0d351594b86c"},{"applicationId":"328fd23b-de6e-462c-9433-e207470a5727","roleDefinitionId":"79e29e06-4056-41e5-a6b2-959f1f47747e"},{"applicationId":"6d057c82-a784-47ae-8d12-ca7b38cf06b4","roleDefinitionId":"c27dd31e-c1e5-4ab0-93e1-a12ba34f182e"},{"applicationId":"b4ca0290-4e73-4e31-ade0-c82ecfaabf6a","roleDefinitionId":"18363e25-ff21-4159-ae8d-7dfecb5bd001"},{"applicationId":"79d7fb34-4bef-4417-8184-ff713af7a679","roleDefinitionId":"1c1f11ef-abfa-4abe-a02b-226771d07fc7"}],"resourceTypes":[{"resourceType":"virtualNetworks","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"virtualNetworks/taggedTrafficConsumers","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"natGateways","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"natGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"publicIPAddresses","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3771,15 +4555,16 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"customIpPrefixes","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3787,15 +4572,16 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkInterfaces","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3803,7 +4589,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateEndpoints","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3811,7 +4597,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateEndpointRedirectMaps","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3819,7 +4605,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"loadBalancers","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -3827,7 +4613,7 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkSecurityGroups","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3835,7 +4621,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationSecurityGroups","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3843,7 +4629,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2017-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"serviceEndpointPolicies","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3851,7 +4637,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkIntentPolicies","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3859,7 +4645,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","France South","Australia Central","South Africa North","UAE North","Switzerland North","Germany - West Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + West Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"routeTables","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3867,7 +4653,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"publicIPPrefixes","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3875,31 +4661,16 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"masterCustomIpPrefixes","locations":["West - US","East US","North Europe","West Europe","East Asia","Southeast Asia","North - Central US","South Central US","Central US","East US 2","Japan East","Japan - West","Brazil South","Australia East","Australia Southeast","Central India","South - India","West India","Canada Central","Canada East","West Central US","West - US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia - Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","zoneMappings":[{"location":"East - US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West - Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast - Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North - Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK - South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia - East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"ddosCustomPolicies","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3907,7 +4678,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkWatchers","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3915,7 +4686,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkWatchers/connectionMonitors","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3923,7 +4694,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkWatchers/flowLogs","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3931,7 +4702,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"networkWatchers/pingMeshes","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3939,7 +4710,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"virtualNetworkGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3947,7 +4718,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"localNetworkGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3955,7 +4726,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"connections","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3963,7 +4734,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"applicationGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3971,15 +4742,16 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"SupportsTags, + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"applicationGatewayWebApplicationFirewallPolicies","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -3987,130 +4759,165 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/CheckDnsNameAvailability","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/CheckDnsNameAvailability","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/setLoadBalancerFrontendPublicIpAddresses","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/setLoadBalancerFrontendPublicIpAddresses","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/virtualNetworkAvailableEndpointServices","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2015-06-15"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-10-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2017-10-01"}],"capabilities":"None"},{"resourceType":"locations/virtualNetworkAvailableEndpointServices","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01"],"capabilities":"None"},{"resourceType":"locations/availableDelegations","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01"],"capabilities":"None"},{"resourceType":"locations/availableDelegations","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/serviceTags","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/serviceTags","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"capabilities":"None"},{"resourceType":"locations/availablePrivateEndpointTypes","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"capabilities":"None"},{"resourceType":"locations/availablePrivateEndpointTypes","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"capabilities":"None"},{"resourceType":"locations/availableServiceAliases","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01"],"capabilities":"None"},{"resourceType":"locations/availableServiceAliases","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01"],"capabilities":"None"},{"resourceType":"locations/checkPrivateLinkServiceVisibility","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01"],"capabilities":"None"},{"resourceType":"locations/checkPrivateLinkServiceVisibility","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01"],"capabilities":"None"},{"resourceType":"locations/autoApprovedPrivateLinkServices","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01"],"capabilities":"None"},{"resourceType":"locations/autoApprovedPrivateLinkServices","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01"],"capabilities":"None"},{"resourceType":"locations/batchValidatePrivateEndpointsForResourceMove","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01"],"capabilities":"None"},{"resourceType":"locations/batchValidatePrivateEndpointsForResourceMove","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"capabilities":"None"},{"resourceType":"locations/batchNotifyPrivateEndpointsForResourceMove","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"capabilities":"None"},{"resourceType":"locations/batchNotifyPrivateEndpointsForResourceMove","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"capabilities":"None"},{"resourceType":"locations/supportedVirtualMachineSizes","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"capabilities":"None"},{"resourceType":"locations/supportedVirtualMachineSizes","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/checkAcceleratedNetworkingSupport","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/setAzureNetworkManagerConfiguration","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/validateResourceOwnership","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01"],"capabilities":"None"},{"resourceType":"locations/getAzureNetworkManagerConfiguration","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/setResourceOwnership","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01"],"capabilities":"None"},{"resourceType":"locations/checkAcceleratedNetworkingSupport","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/effectiveResourceOwnership","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/validateResourceOwnership","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"dnszones","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-04-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-04-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-04-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"dnsOperationResults","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnsOperationStatuses","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"getDnsResourceReference","locations":["global"],"apiVersions":["2018-05-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"internalNotify","locations":["global"],"apiVersions":["2018-05-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/A","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/AAAA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/CNAME","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/PTR","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/MX","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/TXT","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/SRV","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/SOA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/NS","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/CAA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/recordsets","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/all","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"privateDnsZones","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateDnsZones/virtualNetworkLinks","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateDnsOperationResults","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsOperationStatuses","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZonesInternal","locations":["global"],"apiVersions":["2020-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"privateDnsZones/A","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/AAAA","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/CNAME","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/PTR","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/MX","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/TXT","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/SRV","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/SOA","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/all","locations":["global"],"apiVersions":["2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"trafficmanagerprofiles","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2018-03-01","2018-02-01","2017-05-01","2017-03-01","2015-11-01","2015-04-28-preview"],"defaultApiVersion":"2018-08-01","capabilities":"CrossResourceGroupResourceMove, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/setResourceOwnership","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"locations/effectiveResourceOwnership","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"dnszones","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-04-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-04-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-04-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"dnsOperationResults","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnsOperationStatuses","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"getDnsResourceReference","locations":["global"],"apiVersions":["2018-05-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"internalNotify","locations":["global"],"apiVersions":["2018-05-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/A","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/AAAA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/CNAME","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/PTR","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/MX","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/TXT","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/SRV","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/SOA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/NS","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/CAA","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/recordsets","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"dnszones/all","locations":["global"],"apiVersions":["2018-05-01","2018-03-01-preview","2017-10-01","2017-09-15-preview","2017-09-01","2016-04-01","2015-05-04-preview"],"defaultApiVersion":"2018-05-01","capabilities":"None"},{"resourceType":"privateDnsZones","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateDnsZones/virtualNetworkLinks","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateDnsOperationResults","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsOperationStatuses","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZonesInternal","locations":["global"],"apiVersions":["2020-06-01","2020-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"privateDnsZones/A","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/AAAA","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/CNAME","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/PTR","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/MX","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/TXT","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/SRV","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/SOA","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"privateDnsZones/all","locations":["global"],"apiVersions":["2020-06-01","2020-01-01","2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"virtualNetworks/privateDnsZoneLinks","locations":["global"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"trafficmanagerprofiles","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2018-03-01","2018-02-01","2017-05-01","2017-03-01","2015-11-01","2015-04-28-preview"],"defaultApiVersion":"2018-08-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"trafficmanagerprofiles/heatMaps","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2018-03-01","2018-02-01","2017-09-01-preview"],"defaultApiVersion":"2018-08-01","capabilities":"None"},{"resourceType":"checkTrafficManagerNameAvailability","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2018-03-01","2018-02-01","2017-05-01","2017-03-01","2015-11-01","2015-04-28-preview"],"defaultApiVersion":"2018-08-01","capabilities":"None"},{"resourceType":"trafficManagerUserMetricsKeys","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2017-09-01-preview"],"defaultApiVersion":"2018-08-01","capabilities":"None"},{"resourceType":"trafficManagerGeographicHierarchies","locations":["global"],"apiVersions":["2018-08-01","2018-04-01","2018-03-01","2018-02-01","2017-05-01","2017-03-01"],"defaultApiVersion":"2018-08-01","capabilities":"None"},{"resourceType":"expressRouteCircuits","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -4118,23 +4925,72 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"expressRouteServiceProviders","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableWafRuleSets","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableSslOptions","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableServerVariables","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableRequestHeaders","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableResponseHeaders","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"routeFilters","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"expressRouteServiceProviders","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01","2016-11-01","2016-10-01","2016-09-01","2016-08-01","2016-07-01","2016-06-01","2016-03-30","2015-06-15","2015-05-01-preview","2014-12-01-preview"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableWafRuleSets","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableSslOptions","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableServerVariables","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableRequestHeaders","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"applicationGatewayAvailableResponseHeaders","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01"],"capabilities":"None"},{"resourceType":"routeFilters","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"bgpServiceCommunities","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01"],"capabilities":"None"},{"resourceType":"virtualWans","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"bgpServiceCommunities","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01","2017-08-01","2017-06-01","2017-04-01","2017-03-01","2016-12-01"],"capabilities":"None"},{"resourceType":"virtualWans","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"vpnSites","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4142,14 +4998,14 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"vpnServerConfigurations","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","South - Africa North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + Africa North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"virtualHubs","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4157,7 +5013,7 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"vpnGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4165,7 +5021,7 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01","2018-01-01","2017-11-01","2017-10-01","2017-09-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"p2sVpnGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4173,7 +5029,7 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","UAE North","South Africa North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"expressRouteGateways","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -4181,7 +5037,7 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"firewallPolicies","locations":["UAE North","Australia Central 2","UAE Central","Germany North","Central India","Korea South","Switzerland North","Switzerland West","Japan West","France South","South Africa West","West @@ -4190,7 +5046,7 @@ interactions: South","Japan East","UK West","West US","East US","North Europe","West Europe","West Central US","South Central US","Australia East","Australia Central","Australia Southeast","UK South","East US 2","West US 2","North Central US","Canada Central","France - Central","Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, + Central","Central US"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"ipGroups","locations":["UAE North","Australia Central 2","UAE Central","Germany North","Central India","Korea South","Switzerland North","Switzerland West","Japan West","France South","South Africa West","West @@ -4199,38 +5055,46 @@ interactions: South","Japan East","UK West","West US","East US","North Europe","West Europe","South Central US","Australia East","Australia Central","Australia Southeast","UK South","East US 2","West US 2","North Central US","Canada Central","France - Central","West Central US","Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01"],"defaultApiVersion":"2019-08-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"locations/nfvOperations","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"capabilities":"None"},{"resourceType":"locations/nfvOperationResults","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"capabilities":"None"},{"resourceType":"securityPartnerProviders","locations":["West + Central","West Central US","Central US"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"azureWebCategories","locations":[],"apiVersions":["2020-11-01","2020-08-01"],"defaultApiVersion":"2020-08-01","capabilities":"None"},{"resourceType":"locations/nfvOperations","locations":[],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"capabilities":"None"},{"resourceType":"locations/nfvOperationResults","locations":[],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01"],"capabilities":"None"},{"resourceType":"securityPartnerProviders","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia - Central","South Africa North","UAE North","Switzerland North"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"azureFirewalls","locations":["West - US","East US","North Europe","West Europe","East Asia","Southeast Asia","North - Central US","South Central US","Central US","East US 2","Brazil South","Australia + Central","South Africa North","UAE North","Switzerland North"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"azureFirewalls","locations":["West US","East + US","North Europe","West Europe","East Asia","Southeast Asia","North Central + US","South Central US","Central US","East US 2","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","France Central","Australia Central","Japan West","Japan East","Korea Central","Korea South","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01"],"defaultApiVersion":"2020-03-01","zoneMappings":[{"location":"East US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany - West Central","zones":[]},{"location":"Brazil South","zones":[]}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"azureFirewallFqdnTags","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"capabilities":"None"},{"resourceType":"virtualNetworkTaps","locations":["West + Central US","zones":["3","1","2"]},{"location":"Canada Central","zones":["3","1","2"]},{"location":"Germany + West Central","zones":["3","1","2"]},{"location":"Brazil South","zones":[]},{"location":"Central + India","zones":[]},{"location":"Korea Central","zones":[]}],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"azureFirewallFqdnTags","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"capabilities":"None"},{"resourceType":"virtualNetworkTaps","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"privateLinkServices","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan @@ -4238,15 +5102,22 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"ddosProtectionPlans","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/privateLinkServices","locations":["West + US","East US","North Europe","West Europe","East Asia","Southeast Asia","North + Central US","South Central US","Central US","East US 2","Japan East","Japan + West","Brazil South","Australia East","Australia Southeast","Central India","South + India","West India","Canada Central","Canada East","West Central US","West + US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia + Central","South Africa North","UAE North","Switzerland North","Germany West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"capabilities":"None"},{"resourceType":"ddosProtectionPlans","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01","2018-04-01","2018-03-01","2018-02-01"],"defaultApiVersion":"2020-03-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"networkProfiles","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4254,8 +5125,8 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"frontdoorOperationResults","locations":["global"],"apiVersions":["2020-07-01","2020-05-01","2020-04-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-05-01","2019-04-01","2019-03-01","2018-08-01"],"defaultApiVersion":"2020-07-01","capabilities":"None"},{"resourceType":"checkFrontdoorNameAvailability","locations":["global","Central + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01","2018-06-01","2018-05-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"frontdoorOperationResults","locations":["global"],"apiVersions":["2020-11-01","2020-07-01","2020-05-01","2020-04-01","2020-01-01","2019-11-01","2019-10-01","2019-08-01","2019-05-01","2019-04-01","2019-03-01","2018-08-01"],"defaultApiVersion":"2020-07-01","capabilities":"None"},{"resourceType":"checkFrontdoorNameAvailability","locations":["global","Central US","East US","East US 2","North Central US","South Central US","West US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil South","Australia East","Australia Southeast"],"apiVersions":["2020-07-01","2020-05-01","2020-01-01","2019-08-01","2019-05-01","2019-04-01","2018-08-01"],"defaultApiVersion":"2020-07-01","capabilities":"None"},{"resourceType":"frontdoors","locations":["global","Central @@ -4271,11 +5142,11 @@ interactions: South","Australia East","Australia Southeast"],"apiVersions":["2020-07-01","2020-05-01","2020-04-01","2020-01-01","2019-08-01","2019-05-01","2019-04-01","2018-08-01"],"defaultApiVersion":"2020-07-01","capabilities":"None"},{"resourceType":"frontdoorWebApplicationFirewallPolicies","locations":["global","Central US","East US","East US 2","North Central US","South Central US","West US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil - South","Australia East","Australia Southeast"],"apiVersions":["2020-04-01","2019-10-01","2019-03-01","2018-08-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, + South","Australia East","Australia Southeast"],"apiVersions":["2020-11-01","2020-04-01","2019-10-01","2019-03-01","2018-08-01"],"defaultApiVersion":"2020-11-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"frontdoorWebApplicationFirewallManagedRuleSets","locations":["global","Central US","East US","East US 2","North Central US","South Central US","West US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil - South","Australia East","Australia Southeast"],"apiVersions":["2020-04-01","2019-10-01","2019-03-01"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"networkExperimentProfiles","locations":["global","Central + South","Australia East","Australia Southeast"],"apiVersions":["2020-11-01","2020-04-01","2019-10-01","2019-03-01"],"defaultApiVersion":"2020-11-01","capabilities":"None"},{"resourceType":"networkExperimentProfiles","locations":["global","Central US","East US","East US 2","North Central US","South Central US","West US","West US 2","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil South","Australia East","Australia Southeast"],"apiVersions":["2019-11-01"],"defaultApiVersion":"2019-11-01","capabilities":"SupportsTags, @@ -4286,14 +5157,14 @@ interactions: India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01"],"capabilities":"None"},{"resourceType":"bastionHosts","locations":["West + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01","2018-08-01","2018-07-01"],"capabilities":"None"},{"resourceType":"bastionHosts","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","South India","West India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West - Central","Norway East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, + Central","Norway East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01","2019-06-01","2019-04-01","2019-02-01","2018-12-01","2018-11-01","2018-10-01"],"defaultApiVersion":"2020-03-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"virtualRouters","locations":["UAE North","Australia Central 2","UAE Central","Germany North","Central India","Korea South","Switzerland North","Switzerland West","Japan West","France South","South Africa West","West @@ -4302,7 +5173,7 @@ interactions: South","Japan East","UK West","West US","East US","North Europe","West Europe","West Central US","South Central US","Australia East","Australia Central","Australia Southeast","UK South","East US 2","West US 2","North Central US","Canada Central","France - Central","Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01"],"defaultApiVersion":"2019-07-01","capabilities":"SupportsTags, + Central","Central US"],"apiVersions":["2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01","2019-11-01","2019-09-01","2019-08-01","2019-07-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"networkVirtualAppliances","locations":["UAE North","Australia Central 2","UAE Central","Germany North","Central India","Korea South","Switzerland North","Switzerland West","Japan West","France South","South @@ -4311,7 +5182,7 @@ interactions: Central","Brazil South","Japan East","UK West","West US","East US","North Europe","West Europe","West Central US","South Central US","Australia East","Australia Central","Australia Southeast","UK South","East US 2","West US 2","North Central - US","Canada Central","France Central","Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01"],"defaultApiVersion":"2019-12-01","capabilities":"SupportsTags, + US","Canada Central","France Central","Central US"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01","2019-12-01"],"defaultApiVersion":"2020-04-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"ipAllocations","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","North Central US","South Central US","Central US","East US 2","Japan East","Japan West","Brazil @@ -4319,10 +5190,12 @@ interactions: India","Canada Central","Canada East","West Central US","West US 2","UK West","UK South","Korea Central","Korea South","France Central","Australia Central","South Africa North","UAE North","Switzerland North","Germany West Central","Norway - East"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, + East"],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2020-01-01"],"defaultApiVersion":"2020-03-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/commitInternalAzureNetworkManagerConfiguration","locations":["West - Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2019-12-01","2019-11-01"],"capabilities":"None"},{"resourceType":"networkVirtualApplianceSkus","locations":[],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"defaultApiVersion":"2020-03-01","capabilities":"None"},{"resourceType":"networkManagers","locations":["East - US 2 EUAP","Central US EUAP","West Central US"],"apiVersions":["2020-06-01","2020-05-01","2020-04-01","2020-03-01","2019-12-01","2019-11-01"],"defaultApiVersion":"2019-11-01","capabilities":"CrossResourceGroupResourceMove, + Central US"],"apiVersions":["2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2019-12-01","2019-11-01"],"capabilities":"None"},{"resourceType":"networkVirtualApplianceSkus","locations":[],"apiVersions":["2020-11-01","2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01"],"defaultApiVersion":"2020-04-01","capabilities":"None"},{"resourceType":"networkManagers","locations":["East + US 2 EUAP","Central US EUAP","West Central US"],"apiVersions":["2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2019-12-01","2019-11-01"],"defaultApiVersion":"2019-11-01","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"virtualNetworks/networkManagerEffectiveConfigurations","locations":["East + US 2 EUAP","Central US EUAP","West Central US"],"apiVersions":["2020-08-01","2020-07-01","2020-06-01","2020-05-01","2020-04-01","2020-03-01","2019-12-01","2019-11-01"],"defaultApiVersion":"2019-11-01","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Web","namespace":"Microsoft.Web","authorization":{"applicationId":"abfa0a7c-a6b6-4736-8310-5855508787cd","roleDefinitionId":"f47ed98b-b063-4a5b-9e10-4b9b44fa7735"},"resourceTypes":[{"resourceType":"publishingUsers","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central @@ -4331,7 +5204,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostnameavailable","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4339,7 +5212,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validate","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4347,7 +5220,24 @@ interactions: Central US","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central + North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"isusernameavailable","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"generateGithubAccessTokenForAppserviceCLI","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway East","UAE North","Switzerland North","North Central US","UK + West","Australia Southeast","Korea South","Canada Central","West Europe","South + India","West Central US","East Asia (Stage)","North Central US (Stage)","East + Asia","Japan East"],"apiVersions":["2020-10-01","2020-09-01"],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4355,7 +5245,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sourceControls","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4363,7 +5253,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"availableStacks","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"webAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4371,9 +5261,16 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"staticSites","locations":["West - US 2","Central US","East US 2","West Europe","East Asia","West US"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"listSitesAssignedToHostName","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/webAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan + East","Australia East","Brazil South","Southeast Asia","Japan West","Central + India","UK South","Canada East","Korea Central","France Central","North Europe","East + US","West India","East US 2","Australia Central","Germany West Central","Norway + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"functionAppStacks","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4381,64 +5278,88 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"locations/functionAppStacks","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan + East","Australia East","Brazil South","Southeast Asia","Japan West","Central + India","UK South","Canada East","Korea Central","France Central","North Europe","East + US","West India","East US 2","Australia Central","Germany West Central","Norway + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01"],"capabilities":"None"},{"resourceType":"staticSites","locations":["West + US 2","Central US","East US 2","West Europe","East Asia"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/previewStaticSiteWorkflowFile","locations":["West + US 2","Central US","East US 2","West Europe","East Asia"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"listSitesAssignedToHostName","locations":["Central + US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West + US","East US","Japan West","Japan East","East Asia","East US 2","North Central + US","South Central US","Brazil South","Australia East","Australia Southeast","West + India","Central India","South India","Canada Central","Canada East","West + Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT + East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central + US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/getNetworkPolicies","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West India","Central India","South India","Canada Central","Canada East","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","France Central","West Central - US","East Asia (Stage)","North Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["South + US","East Asia (Stage)","North Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operations","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West - India","Australia Central","Germany West Central","Norway East","Switzerland + India","Australia Central","Germany West Central","Norway East","UAE North","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South + US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","West US 2","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","West US","Australia East","Brazil South","Central US","Japan West","Central India","Canada East","Korea Central","France Central","West - India","Australia Central","Germany West Central","Norway East","Switzerland + India","Australia Central","Germany West Central","Norway East","UAE North","Switzerland North","North Central US","UK West","Australia Southeast","Korea South","Canada Central","South India","West Central US","East Asia (Stage)","North Central - US (Stage)"],"apiVersions":["2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South + US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-12-01-preview","2019-08-01","2019-01-01","2018-11-01","2018-02-01","2016-08-01"],"defaultApiVersion":"2019-01-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/networkConfig","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/slots/hostNameBindings","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-08-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4446,87 +5367,84 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"certificates","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossSubscriptionResourceMove, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"serverFarms","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"sites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"sites/slots","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-08-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"runtimes","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":[],"apiVersions":["2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/premieraddons","locations":["South + SupportsLocation"},{"resourceType":"runtimes","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"recommendations","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"georegions","locations":[],"apiVersions":["2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"sites/premieraddons","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["South - Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East - US 2 (Stage)","Central US (Stage)","South Africa North","East US 2","East - US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East - Asia","Australia East","Brazil South","Japan West","Central India","Canada - East","Korea Central","France Central","West India","Australia Central","Germany - West Central","Norway East","Switzerland North","North Central US","UK West","Australia - Southeast","Korea South","Canada Central","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"zoneMappings":[{"location":"East - US 2","zones":["3","1","2"]},{"location":"Central US","zones":["3","1","2"]},{"location":"West - Europe","zones":["3","1","2"]},{"location":"France Central","zones":["3","1","2"]},{"location":"Southeast - Asia","zones":["3","1","2"]},{"location":"West US 2","zones":["3","1","2"]},{"location":"North - Europe","zones":["3","1","2"]},{"location":"East US","zones":["3","1","2"]},{"location":"UK - South","zones":["3","1","2"]},{"location":"Japan East","zones":["3","1","2"]},{"location":"Australia - East","zones":["3","1","2"]},{"location":"South Africa North","zones":[]},{"location":"South - Central US","zones":[]},{"location":"Canada Central","zones":["3","1","2"]}],"capabilities":"SupportsTags, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2016-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments","locations":["MSFT + West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central + US (Stage)","South Central US","South Africa North","East US 2","East US","UK + South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","Australia + East","Brazil South","Japan West","Central India","Canada East","Korea Central","France + Central","West India","Australia Central","Germany West Central","Norway East","UAE + North","Switzerland North","North Central US","UK West","Australia Southeast","Korea + South","Canada Central","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"hostingEnvironments/multiRolePools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"hostingEnvironments/workerPools","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North - Central US (Stage)"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2018-11-01","2018-08-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"kubeEnvironments","locations":["North + Central US (Stage)"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-09-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2017-08-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"deploymentLocations","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central @@ -4535,88 +5453,108 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia Central","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South + North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deletedSites","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East Asia","Japan East","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia Central","Germany West Central","Norway - East","Switzerland North","North Central US","UK West","Australia Southeast","Korea - South","Canada Central","West Europe","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":[],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South + East","UAE North","Switzerland North","North Central US","UK West","Australia + Southeast","Korea South","Canada Central","West Europe","South India","West + Central US","East Asia (Stage)","North Central US (Stage)","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"ishostingenvironmentnameavailable","locations":[],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway East","Switzerland North","North Central - US","UK West","Australia Southeast","Korea South","Canada Central","West Europe","South - India","West Central US","East Asia (Stage)","North Central US (Stage)","East - Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-11-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"connections","locations":["North + Central","Germany West Central","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-11-01","2016-08-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"defaultApiVersion":"2018-02-01","apiProfiles":[{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"connections","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"customApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/listWsdlInterfaces","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/extractApiDefinitionFromWsdl","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/managedApis","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/runtimes","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"locations/apiOperations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North + East","Brazil South","Australia East","Brazil Southeast","Australia Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-07-01-preview","2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"connectionGateways","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/connectionGatewayInstallations","locations":["North Central US","Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","West US","East US","East US 2","Japan West","Japan - East","Brazil South","Australia East","Australia Southeast","South India","Central - India","West India","West US 2","West Central US","Canada Central","Canada - East","UK South","UK West","France Central","France South","Korea Central","Korea - South","South Africa West","South Africa North","UAE Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central + East","Brazil South","Australia East","Australia Southeast","Brazil Southeast","South + India","Central India","West India","West US 2","West Central US","Canada + Central","Canada East","UK South","UK West","France Central","France South","Korea + Central","Korea South","South Africa West","South Africa North","UAE Central","UAE + North","Switzerland North","Switzerland West","Norway East","Germany North","Germany + West Central"],"apiVersions":["2018-03-01-preview","2016-06-01","2015-08-01-preview"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-06-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-06-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01-preview"}],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4624,7 +5562,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"billingMeters","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4632,7 +5570,7 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"verifyHostingEnvironmentVnet","locations":["Central US","North Europe","West Europe","Southeast Asia","Korea Central","Korea South","West US","East US","Japan West","Japan East","East Asia","East US 2","North Central US","South Central US","Brazil South","Australia East","Australia Southeast","West @@ -4640,54 +5578,73 @@ interactions: Central US","UK West","UK South","West US 2","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","East Asia (Stage)","Central US (Stage)","North Central US (Stage)","France Central","South Africa North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South + Central","Switzerland North","Germany West Central","Norway East","UAE North"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2016-03-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2016-03-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"serverFarms/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South + Central","Germany West Central","Norway West","Norway East","UAE North","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South + Central","Germany West Central","Norway West","Norway East","UAE North","Switzerland + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01-preview","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"sites/slots/eventGridFilters","locations":["South Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","Australia East","Brazil South","Southeast Asia","Japan West","Central India","UK South","Canada East","Korea Central","France Central","North Europe","East US","West India","East US 2","Australia - Central","Germany West Central","Norway West","Norway East","Switzerland North","North - Central US","UK West","Australia Southeast","Korea South","Canada Central","West - Europe","South India","West Central US","East Asia (Stage)","North Central - US (Stage)","East Asia","Japan East","South Africa West","West US","Central - US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["North + Central","Germany West Central","Norway West","Norway East","Switzerland North","UAE + North","North Central US","UK West","Australia Southeast","Korea South","Canada + Central","West Europe","South India","West Central US","East Asia (Stage)","North + Central US (Stage)","East Asia","Japan East","South Africa West","West US","Central + US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-08-01","2016-03-01","2015-11-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2015-01-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"hostingEnvironments/eventGridFilters","locations":["North Central US","South Central US","Brazil South","Canada East","UK West","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East US 2 (Stage)","Central US (Stage)","South Africa North","East US 2","East US","UK South","Southeast Asia","North Europe","Japan East","West Europe","East Asia","Australia East","Japan West","Central India","Korea Central","France Central","West India","Australia - Central","Germany West Central","Norway East","Switzerland North","Australia + Central","Germany West Central","Norway East","Switzerland North","UAE North","Australia Southeast","Korea South","Canada Central","South India","West Central US","East - Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.insights","namespace":"microsoft.insights","authorizations":[{"applicationId":"6bccf540-eb86-4037-af03-7fa058c2db75","roleDefinitionId":"89dcede2-9219-403a-9723-d3c6473f9472"},{"applicationId":"11c174dc-1945-4a9a-a36b-c79a0f246b9b","roleDefinitionId":"dd9d4347-f397-45f2-b538-85f21c90037b"},{"applicationId":"035f9e1d-4f00-4419-bf50-bf2d87eb4878","roleDefinitionId":"323795fe-ba3d-4f5a-ad42-afb4e1ea9485"},{"applicationId":"f5c26e74-f226-4ae8-85f0-b4af0080ac9e","roleDefinitionId":"529d7ae6-e892-4d43-809d-8547aeb90643"},{"applicationId":"b503eb83-1222-4dcc-b116-b98ed5216e05","roleDefinitionId":"68699c37-c689-44d4-9248-494b782d46ae"},{"applicationId":"ca7f3f0b-7d91-482c-8e09-c5d840d0eac5","roleDefinitionId":"5d5a2e56-9835-44aa-93db-d2f19e155438"},{"applicationId":"3af5a1e8-2459-45cb-8683-bcd6cccbcc13","roleDefinitionId":"b1309299-720d-4159-9897-6158a61aee41"},{"applicationId":"6a0a243c-0886-468a-a4c2-eff52c7445da","roleDefinitionId":"d2eda64b-c5e6-4930-8642-2d80ecd7c2e2"},{"applicationId":"707be275-6b9d-4ee7-88f9-c0c2bd646e0f","roleDefinitionId":"fa027d90-6ba0-4c33-9a54-59edaf2327e7"},{"applicationId":"461e8683-5575-4561-ac7f-899cc907d62a","roleDefinitionId":"68699c37-c689-44d4-9248-494b782d46ae"},{"applicationId":"562db366-1b96-45d2-aa4a-f2148cef2240","roleDefinitionId":"4109c8be-c1c8-4be0-af52-9d3c76c140ab"},{"applicationId":"e933bd07-d2ee-4f1d-933c-3752b819567b","roleDefinitionId":"abbcfd44-e662-419a-9b5a-478f8e2f57c9"},{"applicationId":"f6b60513-f290-450e-a2f3-9930de61c5e7","roleDefinitionId":"4ef11659-08ac-48af-98a7-25fb6b1e1bc4"},{"applicationId":"12743ff8-d3de-49d0-a4ce-6c91a4245ea0","roleDefinitionId":"207b20a7-6802-4ae4-aaa2-1a36dd45bba0"}],"resourceTypes":[{"resourceType":"components","locations":["East + Asia (Stage)","North Central US (Stage)","West US","Central US","West US 2"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2019-02-01","2019-01-01","2018-11-01","2018-08-01","2018-05-01-preview","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway West","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"serverFarms/firstPartyApps/keyVaultSettings","locations":["South + Central US","MSFT West US","MSFT East US","MSFT East Asia","MSFT North Europe","East + US 2 (Stage)","Central US (Stage)","South Africa North","West US","Australia + East","Brazil South","Southeast Asia","Central US","Japan West","Central India","UK + South","Canada East","Korea Central","France Central","North Europe","West + US 2","East US","West India","East US 2","Australia Central","Germany West + Central","Norway West","Norway East","UAE North","Switzerland North","North + Central US","UK West","Australia Southeast","Korea South","Canada Central","West + Europe","South India","West Central US","East Asia (Stage)","North Central + US (Stage)","East Asia","Japan East","South Africa West"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-11-01","2018-02-01","2017-08-01","2016-09-01","2016-03-01","2015-08-01","2015-07-01","2015-06-01","2015-05-01","2015-04-01","2015-02-01","2014-11-01","2014-06-01","2014-04-01-preview","2014-04-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.insights","namespace":"microsoft.insights","authorizations":[{"applicationId":"6bccf540-eb86-4037-af03-7fa058c2db75","roleDefinitionId":"89dcede2-9219-403a-9723-d3c6473f9472"},{"applicationId":"11c174dc-1945-4a9a-a36b-c79a0f246b9b","roleDefinitionId":"dd9d4347-f397-45f2-b538-85f21c90037b"},{"applicationId":"035f9e1d-4f00-4419-bf50-bf2d87eb4878","roleDefinitionId":"323795fe-ba3d-4f5a-ad42-afb4e1ea9485"},{"applicationId":"f5c26e74-f226-4ae8-85f0-b4af0080ac9e","roleDefinitionId":"529d7ae6-e892-4d43-809d-8547aeb90643"},{"applicationId":"b503eb83-1222-4dcc-b116-b98ed5216e05","roleDefinitionId":"68699c37-c689-44d4-9248-494b782d46ae"},{"applicationId":"ca7f3f0b-7d91-482c-8e09-c5d840d0eac5","roleDefinitionId":"5d5a2e56-9835-44aa-93db-d2f19e155438"},{"applicationId":"3af5a1e8-2459-45cb-8683-bcd6cccbcc13","roleDefinitionId":"b1309299-720d-4159-9897-6158a61aee41"},{"applicationId":"6a0a243c-0886-468a-a4c2-eff52c7445da","roleDefinitionId":"d2eda64b-c5e6-4930-8642-2d80ecd7c2e2"},{"applicationId":"707be275-6b9d-4ee7-88f9-c0c2bd646e0f","roleDefinitionId":"fa027d90-6ba0-4c33-9a54-59edaf2327e7"},{"applicationId":"461e8683-5575-4561-ac7f-899cc907d62a","roleDefinitionId":"68699c37-c689-44d4-9248-494b782d46ae"},{"applicationId":"562db366-1b96-45d2-aa4a-f2148cef2240","roleDefinitionId":"4109c8be-c1c8-4be0-af52-9d3c76c140ab"},{"applicationId":"e933bd07-d2ee-4f1d-933c-3752b819567b","roleDefinitionId":"abbcfd44-e662-419a-9b5a-478f8e2f57c9"},{"applicationId":"f6b60513-f290-450e-a2f3-9930de61c5e7","roleDefinitionId":"4ef11659-08ac-48af-98a7-25fb6b1e1bc4"},{"applicationId":"12743ff8-d3de-49d0-a4ce-6c91a4245ea0","roleDefinitionId":"207b20a7-6802-4ae4-aaa2-1a36dd45bba0"}],"resourceTypes":[{"resourceType":"components","locations":["East US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Canada Central","Central India","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West - US","South Africa North","North Central US","Brazil South","Switzerland North","Australia - Southeast","Australia Central 2","Germany West Central","Switzerland West","UK - West"],"apiVersions":["2020-02-02-preview","2018-05-01-preview","2015-05-01","2014-12-01-preview","2014-08-01","2014-04-01"],"capabilities":"CrossResourceGroupResourceMove, + US","South Africa North","North Central US","Brazil South","Switzerland North","Norway + East","Australia Southeast","Australia Central 2","Germany West Central","Switzerland + West","UAE Central","UK West","Japan West","Brazil Southeast","UAE North","Australia + Central"],"apiVersions":["2020-02-02-preview","2018-05-01-preview","2015-05-01","2014-12-01-preview","2014-08-01","2014-04-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"components/query","locations":[],"apiVersions":["2018-04-20"],"capabilities":"None"},{"resourceType":"components/metadata","locations":[],"apiVersions":["2018-04-20"],"capabilities":"None"},{"resourceType":"components/metrics","locations":["East US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Central India","Canada Central","Japan East","Australia East","Korea Central","France Central","East US 2","East Asia","West US","Central US","South Africa North","North Central US","Brazil South","Switzerland North","Australia - Southeast"],"apiVersions":["2018-04-20","2014-04-01"],"capabilities":"None"},{"resourceType":"components/events","locations":["East + Southeast","Norway East","Norway West"],"apiVersions":["2018-04-20"],"capabilities":"None"},{"resourceType":"components/events","locations":["East US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Central India","Canada Central","Japan East","Australia East","Korea Central","France Central","East US 2","East Asia","West US","Central @@ -4695,19 +5652,22 @@ interactions: US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Central India","Canada Central","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West - US","South Africa North","North Central US","Brazil South","Switzerland North","Australia - Southeast","Australia Central 2","Germany West Central","Switzerland West"],"apiVersions":["2018-05-01-preview","2015-05-01","2014-08-01","2014-04-01"],"capabilities":"CrossResourceGroupResourceMove, + US","South Africa North","North Central US","Brazil South","Switzerland North","Norway + East","Australia Southeast","Australia Central 2","Germany West Central","Switzerland + West","UAE Central","UK West","Brazil Southeast","Japan West","UAE North","Australia + Central"],"apiVersions":["2018-05-01-preview","2015-05-01","2014-08-01","2014-04-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"webtests/getTestResultFile","locations":["East US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Central India","Canada Central","Japan East","Australia East","Korea Central","France Central","East US 2","East Asia","West US","Central - US","South Africa North","North Central US"],"apiVersions":["2020-02-10-preview"],"capabilities":"None"},{"resourceType":"scheduledqueryrules","locations":["West - Central US","East US","West Europe","Central India","Canada Central","Australia - Southeast","Japan East","Southeast Asia","UK South","South Central US","North - Europe","West US 2","Australia Central","Australia East","Korea Central","France - Central","Central US","East US 2","East Asia","West US","North Central US","South - Africa North","Brazil South","UK West","Switzerland North","Switzerland West","UAE - Central","Germany West Central","Australia Central 2"],"apiVersions":["2018-04-16","2017-09-01-preview"],"defaultApiVersion":"2018-04-16","capabilities":"CrossResourceGroupResourceMove, + US","South Africa North","North Central US"],"apiVersions":["2020-02-10-preview"],"capabilities":"None"},{"resourceType":"scheduledqueryrules","locations":["Global","West + Central US","Australia East","Central US","East US","East US 2","France Central","Japan + East","North Europe","South Africa North","Southeast Asia","UK South","West + Europe","West US 2","Central India","Canada Central","Australia Southeast","South + Central US","Australia Central","Korea Central","East Asia","West US","North + Central US","Brazil South","UK West","Switzerland North","Switzerland West","UAE + Central","Germany West Central","Australia Central 2","Brazil SouthEast","Norway + East","UAE North","Japan West"],"apiVersions":["2021-02-01-preview","2020-05-01-preview","2018-04-16","2017-09-01-preview"],"defaultApiVersion":"2018-04-16","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"components/pricingPlans","locations":["East US","South Central US","North Europe","West Europe","Southeast Asia","West US 2"],"apiVersions":["2017-10-01"],"capabilities":"None"},{"resourceType":"migrateToNewPricingModel","locations":["East @@ -4760,8 +5720,8 @@ interactions: Central","Central US","Australia East","Australia Southeast","Australia Central","Australia Central 2","Brazil South","Brazil Southeast","South India","Central India","West India","North Europe","West US 2","West Central US","Korea South","Korea Central","UK - South","UK West","France Central","South Africa North","UAE North","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2018-01-01","2017-12-01-preview","2017-09-01-preview","2017-05-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01"}],"capabilities":"SupportsExtension"},{"resourceType":"logDefinitions","locations":["West + South","UK West","France Central","South Africa North","South Africa West","UAE + North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2018-01-01","2017-12-01-preview","2017-09-01-preview","2017-05-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01"}],"capabilities":"SupportsExtension"},{"resourceType":"logDefinitions","locations":["West US","East US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","East US 2","Central US","Australia East","Australia Southeast","Brazil South","UK South","UK West","South @@ -4773,16 +5733,16 @@ interactions: Central","Central US","Australia East","Australia Southeast","Australia Central","Australia Central 2","Brazil South","Brazil Southeast","South India","Central India","West India","North Europe","West US 2","West Central US","Korea South","Korea Central","UK - South","UK West","France Central","South Africa North","UAE North","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2019-07-01","2018-01-01","2017-12-01-preview","2017-09-01-preview","2017-05-01-preview","2016-09-01","2016-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01"}],"capabilities":"SupportsExtension"},{"resourceType":"metricbatch","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"metricNamespaces","locations":["East + South","UK West","France Central","South Africa North","South Africa West","UAE + North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2019-07-01","2018-01-01","2017-12-01-preview","2017-09-01-preview","2017-05-01-preview","2016-09-01","2016-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-01-01"}],"capabilities":"SupportsExtension"},{"resourceType":"metricbatch","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"metricNamespaces","locations":["East US","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","East US 2","Canada East","Canada Central","Central US","Australia East","Australia Southeast","Australia Central","Australia Central 2","Brazil South","Brazil Southeast","South India","Central India","West India","North Europe","West US 2","West Central US","Korea South","Korea Central","UK - South","UK West","France Central","South Africa North","UAE North","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2018-01-01","2017-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"actiongroups","locations":["Global"],"apiVersions":["2019-06-01","2019-03-01","2018-09-01","2018-03-01","2017-04-01","2017-03-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"activityLogAlerts","locations":["Global"],"apiVersions":["2017-04-01","2017-03-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"SupportsTags, + South","UK West","France Central","South Africa North","South Africa West","UAE + North","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2018-01-01","2017-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"actiongroups","locations":["Global"],"apiVersions":["2019-06-01","2019-03-01","2018-09-01","2018-03-01","2017-04-01","2017-03-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"activityLogAlerts","locations":["Global"],"apiVersions":["2020-10-01","2017-04-01","2017-03-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"}],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"baseline","locations":["East US","West US","West Europe","East Asia","Southeast Asia","Japan East","Japan West","North Central US","South Central US","East US 2","Canada East","Canada Central","Central @@ -4801,24 +5761,22 @@ interactions: Europe","South Central US","East US","North Europe","Southeast Asia","West US 2","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West US","Canada Central","Central India","UK - South","South Africa North","North Central US","Brazil South","Switzerland - North","Australia Southeast"],"apiVersions":["2020-02-12","2018-06-17-preview","2018-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"workbooktemplates","locations":["West + South","UK West","South Africa North","North Central US","Brazil South","Switzerland + North","Norway East","Australia Southeast"],"apiVersions":["2020-10-20","2020-02-12","2018-06-17-preview","2018-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"workbooktemplates","locations":["West Europe","South Central US","East US","North Europe","Southeast Asia","West US 2","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West US","Canada Central","Central India","UK - South","South Africa North","North Central US","Brazil South","Switzerland - North","Australia Southeast"],"apiVersions":["2019-10-17-preview"],"capabilities":"CrossResourceGroupResourceMove, + South","UK West","South Africa North","North Central US","Brazil South","Switzerland + North","Norway East","Australia Southeast"],"apiVersions":["2020-11-20","2019-10-17-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"myWorkbooks","locations":["West Europe","South Central US","East US","North Europe","Southeast Asia","West US 2","UK South","Canada Central","Central India","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West - US","South Africa North","North Central US","Brazil South","Switzerland North","Australia - Southeast"],"apiVersions":["2020-02-12","2018-06-17-preview","2018-06-15-preview","2018-06-01-preview","2016-06-15-preview"],"capabilities":"SystemAssignedResourceIdentity, - SupportsExtension"},{"resourceType":"logs","locations":["East US","East US - 2","West US","Central US","North Central US","South Central US","North Europe","West - Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia + US","South Africa North","North Central US","Brazil South","Switzerland North","Norway + East","Australia Southeast"],"apiVersions":["2020-10-20","2020-02-12","2018-06-17-preview","2018-06-15-preview","2018-06-01-preview","2016-06-15-preview"],"capabilities":"SupportsExtension"},{"resourceType":"logs","locations":["East + US","East US 2","West US","Central US","North Central US","South Central US","North + Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Brazil South","South India","Central India","West India","Canada Central","Canada East","West US 2","West Central US","UK South","UK West","Korea Central","Korea South","France Central","France South","Australia @@ -4831,24 +5789,30 @@ interactions: US 2","UK South","Central India","Canada Central","Japan East","Australia East","Korea Central","France Central","East US 2","East Asia","West US","Central US","South Africa North","North Central US"],"apiVersions":["2019-10-17-preview"],"capabilities":"SupportsExtension"},{"resourceType":"generateLiveToken","locations":[],"apiVersions":["2020-06-02-preview"],"capabilities":"SupportsExtension"},{"resourceType":"dataCollectionRules","locations":["Australia - Southeast","East US","Central US","West Europe","West US 2","Southeast Asia","East - US 2","UK South","North Europe","West US"],"apiVersions":["2019-11-01-preview"],"defaultApiVersion":"2019-11-01-preview","capabilities":"CrossResourceGroupResourceMove, + Southeast","Canada Central","Japan East","Australia East","Central India","Germany + West Central","North Central US","South Central US","East US","Central US","West + Europe","West US 2","Southeast Asia","East US 2","UK South","North Europe","West + US","Australia Central","West Central US","East Asia","UK West","Korea Central","France + Central","South Africa North","Switzerland North"],"apiVersions":["2019-11-01-preview"],"defaultApiVersion":"2019-11-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"dataCollectionRuleAssociations","locations":["Australia - Southeast","East US","Central US","West Europe","West US 2","Southeast Asia","East - US 2","UK South","North Europe","West US"],"apiVersions":["2019-11-01-preview"],"defaultApiVersion":"2019-11-01-preview","capabilities":"SupportsExtension"},{"resourceType":"privateLinkScopes","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"CrossResourceGroupResourceMove, + Southeast","Canada Central","Japan East","Australia East","Central India","Germany + West Central","North Central US","South Central US","East US","Central US","West + Europe","West US 2","Southeast Asia","East US 2","UK South","North Europe","West + US","Australia Central","West Central US","East Asia","UK West","Korea Central","France + Central","South Africa North","Switzerland North"],"apiVersions":["2019-11-01-preview"],"defaultApiVersion":"2019-11-01-preview","capabilities":"SupportsExtension"},{"resourceType":"privateLinkScopes","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateLinkScopes/privateEndpointConnections","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"None"},{"resourceType":"privateLinkScopes/privateEndpointConnectionProxies","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"None"},{"resourceType":"privateLinkScopes/scopedResources","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"None"},{"resourceType":"components/linkedstorageaccounts","locations":["East US","West Central US","South Central US","North Europe","West Europe","Southeast Asia","West US 2","UK South","Canada Central","Central India","Japan East","Australia East","Korea Central","France Central","Central US","East US 2","East Asia","West US","South Africa North","North Central US","Brazil South","Switzerland North","Norway - East","Norway West","Australia Southeast"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"privateLinkScopeOperationStatuses","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Sql","namespace":"Microsoft.Sql","authorizations":[{"applicationId":"e4ab13ed-33cb-41b4-9140-6e264582cf85","roleDefinitionId":"ec3ddc95-44dc-47a2-9926-5e9f5ffd44ec"},{"applicationId":"0130cc9f-7ac5-4026-bd5f-80a08a54e6d9","roleDefinitionId":"45e8abf8-0ec4-44f3-9c37-cff4f7779302"},{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"76c7f279-7959-468f-8943-3954880e0d8c","roleDefinitionId":"7f7513a8-73f9-4c5f-97a2-c41f0ea783ef"},{"applicationId":"022907d3-0f1b-48f7-badc-1ba6abab6d66"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia + East","Norway West","Australia Southeast"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"privateLinkScopeOperationStatuses","locations":["Global"],"apiVersions":["2019-10-17-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Sql","namespace":"Microsoft.Sql","authorizations":[{"applicationId":"e4ab13ed-33cb-41b4-9140-6e264582cf85","roleDefinitionId":"ec3ddc95-44dc-47a2-9926-5e9f5ffd44ec"},{"applicationId":"0130cc9f-7ac5-4026-bd5f-80a08a54e6d9","roleDefinitionId":"45e8abf8-0ec4-44f3-9c37-cff4f7779302"},{"applicationId":"76cd24bf-a9fc-4344-b1dc-908275de6d6d","roleDefinitionId":"c13b7b9c-2ed1-4901-b8a8-16f35468da29"},{"applicationId":"76c7f279-7959-468f-8943-3954880e0d8c","roleDefinitionId":"7f7513a8-73f9-4c5f-97a2-c41f0ea783ef","managedByRoleDefinitionId":"f2f79976-90be-4501-89c6-7caf12474683"},{"applicationId":"022907d3-0f1b-48f7-badc-1ba6abab6d66"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -4862,147 +5826,147 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"locations/databaseAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"locations/databaseAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/databaseOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/databaseOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverKeyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverKeyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverKeyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverKeyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/keys","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/keys","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/encryptionProtector","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/encryptionProtector","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/encryptionProtectorOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/encryptionProtectorOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/encryptionProtectorAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/encryptionProtectorAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceKeyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceKeyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceKeyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceKeyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceEncryptionProtectorOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceEncryptionProtectorOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceEncryptionProtectorAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceEncryptionProtectorAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/tdeCertificates","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/tdeCertificates","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/tdeCertAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/tdeCertAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/tdeCertOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/tdeCertOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/usages","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"servers/databases","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada @@ -5011,7 +5975,7 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-01-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-01-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"servers/serviceObjectives","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5033,7 +5997,7 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/administratorOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/administratorOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -5047,203 +6011,224 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverAdministratorOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverAdministratorOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/restorableDroppedDatabases","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/restorableDroppedDatabases","locations":["Australia + Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada + East","Central India","Central US","East Asia","East US","East US 2","France + Central","Germany West Central","Japan East","Japan West","Korea Central","Korea + South","North Central US","North Europe","Norway East","South Africa North","South + Central US","South India","Southeast Asia","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/recoverableDatabases","locations":["Australia + Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada + East","Central India","Central US","East Asia","East US","East US 2","France + Central","Germany West Central","Japan East","Japan West","Korea Central","Korea + South","North Central US","North Europe","Norway East","South Africa North","South + Central US","South India","Southeast Asia","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/geoBackupPolicies","locations":["Australia + Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada + East","Central India","Central US","East Asia","East US","East US 2","France + Central","Germany West Central","Japan East","Japan West","Korea Central","Korea + South","North Central US","North Europe","Norway East","South Africa North","South + Central US","South India","Southeast Asia","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2015-05-01-preview","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"servers/import","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/recoverableDatabases","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/importExportOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/geoBackupPolicies","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/operationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2015-05-01-preview","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"servers/import","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/backupLongTermRetentionPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/importExportOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/backupShortTermRetentionPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/operationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/databaseSecurityPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/backupLongTermRetentionPolicies","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/automaticTuning","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/backupShortTermRetentionPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/automaticTuning","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/databaseSecurityPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/transparentDataEncryption","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/automaticTuning","locations":["Australia + US 2"],"apiVersions":["2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"servers/recommendedElasticPools","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/automaticTuning","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/dataMaskingPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/transparentDataEncryption","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/dataMaskingPolicies/rules","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01"],"capabilities":"None"},{"resourceType":"servers/recommendedElasticPools","locations":["Australia + US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/securityAlertPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/dataMaskingPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/securityAlertPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/dataMaskingPolicies/rules","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/auditingSettings","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/securityAlertPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/auditingSettings","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/securityAlertPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/extendedAuditingSettings","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/auditingSettings","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/devOpsAuditingSettings","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/auditingSettings","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/auditingSettingsAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/extendedAuditingSettings","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/auditingSettingsOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/auditingSettingsAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/extendedAuditingSettingsAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/auditingSettingsOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/extendedAuditingSettingsOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/extendedAuditingSettingsAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/devOpsAuditingSettingsOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/extendedAuditingSettingsOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/devOpsAuditingSettingsAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/elasticPoolAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/elasticPoolAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/elasticPoolOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/elasticPoolOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"servers/elasticpools","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"servers/elasticpools","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-09-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-09-01-preview","2015-05-01-preview","2015-05-01","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"servers/jobAccounts","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5251,7 +6236,7 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"servers/jobAgents","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5259,7 +6244,7 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/jobAgentOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5267,35 +6252,35 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/jobAgentAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/jobAgentAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs/steps","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs/steps","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs/executions","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/jobAgents/jobs/executions","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/disasterRecoveryConfiguration","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/disasterRecoveryConfiguration","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -5309,105 +6294,105 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/dnsAliasAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/dnsAliasAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/dnsAliasOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/dnsAliasOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/failoverGroups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/failoverGroups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/failoverGroupAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/failoverGroupAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/failoverGroupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/failoverGroupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/firewallRulesOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/firewallRulesOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/firewallRulesAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/firewallRulesAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnets","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"servers/virtualNetworkRules","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"servers/virtualNetworkRules","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/virtualNetworkRulesOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/virtualNetworkRulesOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/virtualNetworkRulesAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/virtualNetworkRulesAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnetsOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnetsOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnetsAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/deleteVirtualNetworkOrSubnetsAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/databaseRestoreAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2015-05-01"],"capabilities":"None"},{"resourceType":"locations/databaseRestoreAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/usages","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/usages","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -5470,21 +6455,21 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/elasticPools/advisors","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/elasticPools/advisors","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/advisors","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/advisors","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/extensions","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview","2014-04-01-preview","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"servers/databases/extensions","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -5498,119 +6483,119 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/auditRecords","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/auditRecords","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessmentScans","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessmentScans","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/workloadGroups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/workloadGroups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/vulnerabilityAssessments","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/vulnerabilityAssessments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/vulnerabilityAssessments","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/vulnerabilityAssessments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases/vulnerabilityAssessments","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases/vulnerabilityAssessments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/vulnerabilityAssessments","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/vulnerabilityAssessments","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessmentSettings","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessmentSettings","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessment","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/VulnerabilityAssessment","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/vulnerabilityAssessmentScanAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/vulnerabilityAssessmentScanAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/vulnerabilityAssessmentScanOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/vulnerabilityAssessmentScanOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/recommendedSensitivityLabels","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/recommendedSensitivityLabels","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/syncGroups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/syncGroups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/syncGroups/syncMembers","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/databases/syncGroups/syncMembers","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/syncAgents","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"servers/syncAgents","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"instancePools","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"instancePools","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/importExportOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5618,35 +6603,35 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/importExportAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-08-01","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/importExportAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/instancePoolOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-08-01","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/instancePoolOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/instancePoolAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/instancePoolAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"managedInstances/administrators","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada @@ -5655,14 +6640,14 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"managedInstances/recoverableDatabases","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5677,196 +6662,196 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/metricDefinitions","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/metricDefinitions","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases/backupLongTermRetentionPolicies","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/databases/backupLongTermRetentionPolicies","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/sqlAgent","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/sqlAgent","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionProxyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2018-06-01"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionProxyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionProxyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionProxyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstancePrivateEndpointConnectionAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstances","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstances","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceLongTermRetentionPolicyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceLongTermRetentionPolicyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceLongTermRetentionPolicyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceLongTermRetentionPolicyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackupAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionManagedInstanceBackupAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseRestoreAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseRestoreAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseRestoreOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseRestoreOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseCompleteRestoreAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseCompleteRestoreAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseCompleteRestoreOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedDatabaseCompleteRestoreOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedServerSecurityAlertPoliciesAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedServerSecurityAlertPoliciesAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/tdeCertificates","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"managedInstances/tdeCertificates","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceTdeCertAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceTdeCertAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceTdeCertOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceTdeCertOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedServerSecurityAlertPoliciesOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedServerSecurityAlertPoliciesOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/securityAlertPoliciesAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/securityAlertPoliciesAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/securityAlertPoliciesOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/securityAlertPoliciesOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"virtualClusters","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"virtualClusters","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/virtualClusterAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France @@ -5874,217 +6859,217 @@ interactions: South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/virtualClusterOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/virtualClusterOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedInstanceOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/administratorAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/administratorAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/administratorOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/administratorOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncGroupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncGroupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncMemberOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncMemberOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncAgentOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncAgentOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncDatabaseIds","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/syncDatabaseIds","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionServers","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionServers","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionPolicyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionPolicyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionPolicyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionPolicyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackupAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/longTermRetentionBackupAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/shortTermRetentionPolicyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/shortTermRetentionPolicyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/shortTermRetentionPolicyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/shortTermRetentionPolicyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedShortTermRetentionPolicyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedShortTermRetentionPolicyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedShortTermRetentionPolicyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/managedShortTermRetentionPolicyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroupAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroupAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceFailoverGroupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionProxyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/privateEndpointConnectionAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/notifyAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/notifyAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroups","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview","2019-06-01-preview","2018-06-01-preview","2017-10-01-preview","2017-03-01-preview","2015-05-01-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroups","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroupOperationResults","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroupOperationResults","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroupAzureAsyncOperation","locations":["Australia + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"},{"resourceType":"locations/serverTrustGroupAzureAsyncOperation","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","UAE North","UK South","UK West","West Central US","West Europe","West India","West US","West - US 2"],"apiVersions":["2020-02-02-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/84codes.CloudAMQP","namespace":"84codes.CloudAMQP","resourceTypes":[{"resourceType":"servers","locations":["East + US 2"],"apiVersions":["2020-08-01-preview","2020-02-02-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/84codes.CloudAMQP","namespace":"84codes.CloudAMQP","resourceTypes":[{"resourceType":"servers","locations":["East US 2","Central US","East US","North Central US","South Central US","West US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast"],"apiVersions":["2016-08-01"],"capabilities":"SupportsTags, @@ -6094,33 +7079,7 @@ interactions: US","Southeast Asia","Central US"],"apiVersions":["2016-06-15"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-06-15"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-06-15"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-06-15"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Mailjet.Email","namespace":"Mailjet.Email","resourceTypes":[{"resourceType":"services","locations":["West US","West Europe"],"apiVersions":["2017-10-01","2017-02-03"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2018-07-01","2017-10-01","2017-05-29","2017-02-03","2016-11-01","2016-07-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2017-10-01","2017-02-03","2016-11-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2017-10-01","2017-02-03","2016-11-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AAD","namespace":"Microsoft.AAD","authorizations":[{"applicationId":"443155a6-77f3-45e3-882b-22b3a8d431fb","roleDefinitionId":"7389DE79-3180-4F07-B2BA-C5BA1F01B03A"},{"applicationId":"abba844e-bc0e-44b0-947a-dc74e5d09022","roleDefinitionId":"63BC473E-7767-42A5-A3BF-08EB71200E04"},{"applicationId":"d87dcbc6-a371-462e-88e3-28ad15ec4e64","roleDefinitionId":"861776c5-e0df-4f95-be4f-ac1eec193323"}],"resourceTypes":[{"resourceType":"DomainServices","locations":["West - US","Central US","East US","South Central US","West Europe","North Europe","East - Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West - Central US","North Central US","Japan East","Japan West","Brazil South","Central - India","South India","West India","Canada Central","Canada East","West US - 2","Korea Central","France Central","UK South","South Africa North","UAE North"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"DomainServices/oucontainer","locations":["West - US","Central US","East US","South Central US","West Europe","North Europe","East - Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West - Central US","North Central US","Japan East","Japan West","Brazil South","Central - India","South India","West India","Canada Central","Canada East","West US - 2","Korea Central","France Central","UK South","South Africa North","UAE North"],"apiVersions":["2020-01-01","2017-06-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"locations","locations":["West - US","Central US","East US","South Central US","West Europe","North Europe","East - Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West - Central US","North Central US","Japan East","Japan West","Brazil South","Central - India","South India","West India","Canada Central","Canada East","West US - 2","Korea Central","France Central","UK South","South Africa North","UAE North"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"locations/operationresults","locations":["West - US","Central US","East US","South Central US","West Europe","North Europe","East - Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West - Central US","North Central US","Japan East","Japan West","Brazil South","Central - India","South India","West India","Canada Central","Canada East","West US - 2","Korea Central","France Central","UK South","South Africa North","UAE North"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"},{"resourceType":"operations","locations":["West - US","Central US","East US","South Central US","West Europe","North Europe","East - Asia","Southeast Asia","East US 2","Australia East","Australia Southeast","West - Central US","North Central US","Japan East","Japan West","Brazil South","Central - India","South India","West India","Canada Central","Canada East","West US - 2","Korea Central","France Central","UK South","South Africa North","UAE North"],"apiVersions":["2020-01-01","2017-06-01","2017-01-01"],"defaultApiVersion":"2020-01-01","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.aadiam","namespace":"microsoft.aadiam","authorizations":[{"applicationId":"1b912ec3-a9dd-4c4d-a53e-76aa7adb28d7","roleDefinitionId":"c4cfa0e8-3cb5-4ced-9c3c-efaad3348120"}],"resourceTypes":[{"resourceType":"azureADMetrics","locations":["Australia + SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2018-07-01","2017-10-01","2017-05-29","2017-02-03","2016-11-01","2016-07-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2017-10-01","2017-02-03","2016-11-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2017-10-01","2017-02-03","2016-11-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.aadiam","namespace":"microsoft.aadiam","authorizations":[{"applicationId":"1b912ec3-a9dd-4c4d-a53e-76aa7adb28d7","roleDefinitionId":"c4cfa0e8-3cb5-4ced-9c3c-efaad3348120"}],"resourceTypes":[{"resourceType":"azureADMetrics","locations":["Australia Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","Korea Central","Korea @@ -6152,66 +7111,123 @@ interactions: US"],"apiVersions":["2014-01-01"],"capabilities":"None"},{"resourceType":"servicehealthmetrics","locations":["West US"],"apiVersions":["2014-01-01"],"capabilities":"None"},{"resourceType":"logs","locations":["West US"],"apiVersions":["2014-01-01"],"capabilities":"None"},{"resourceType":"anonymousapiusers","locations":["West - US"],"apiVersions":["2014-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AISupercomputer","namespace":"Microsoft.AISupercomputer","authorizations":[{"applicationId":"349e15d0-1c96-4829-95e5-7fc8fb358ff3","roleDefinitionId":"da5c10f8-3b94-4076-bb95-1421b4518aee"}],"resourceTypes":[{"resourceType":"locations","locations":["Australia + US"],"apiVersions":["2014-01-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AgFoodPlatform","namespace":"Microsoft.AgFoodPlatform","authorizations":[{"applicationId":"e420dc86-d66f-4069-a2d0-be2f937bd272","roleDefinitionId":"c9511e72-16f4-4804-9bed-d3f21cbe122f"}],"resourceTypes":[{"resourceType":"operations","locations":["East + US","West Central US"],"apiVersions":["2020-05-12-preview"],"defaultApiVersion":"2020-05-12-preview","capabilities":"None"},{"resourceType":"checkNameAvailability","locations":["East + US","West Central US"],"apiVersions":["2020-05-12-preview"],"defaultApiVersion":"2020-05-12-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AISupercomputer","namespace":"Microsoft.AISupercomputer","authorizations":[{"applicationId":"349e15d0-1c96-4829-95e5-7fc8fb358ff3","roleDefinitionId":"da5c10f8-3b94-4076-bb95-1421b4518aee"}],"resourceTypes":[{"resourceType":"locations","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries","locations":["Central - US","Australia Central","Australia East","Australia Southeast","Canada Central","Canada - East","Central India","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries/instanceTypes","locations":["Central - US","Australia Central","Australia East","Australia Southeast","Canada Central","Canada - East","Central India","East Asia","East US","East US 2","France Central","Germany - West Central","Japan East","Japan West","North Central US","North Europe","Norway - East","South Africa North","South Central US","South India","Southeast Asia","Switzerland - North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Australia + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-12-01-preview","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries","locations":["Australia + Central","Australia East","Australia Southeast","Canada Central","Canada East","Central + India","East Asia","East US 2","France Central","Germany West Central","Japan + East","Japan West","North Central US","North Europe","Norway East","South + Africa North","South India","Southeast Asia","Switzerland North","West Central + US","West India","West US","West US 2","UAE North","UK West","UK South","Brazil + South","Korea South","Korea Central","East US"],"apiVersions":["2020-12-01-preview","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries/instanceTypes","locations":["Australia + Central","Australia East","Australia Southeast","Canada Central","Canada East","Central + India","East Asia","East US 2","France Central","Germany West Central","Japan + East","Japan West","North Central US","North Europe","Norway East","South + Africa North","South India","Southeast Asia","Switzerland North","West Central + US","West India","West US","West US 2","UAE North","UK West","UK South","Brazil + South","Korea South","Korea Central","East US"],"apiVersions":["2020-12-01-preview","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia + Central","Australia East","Australia Southeast","Canada Central","Canada East","Central + India","East Asia","East US 2","France Central","Germany West Central","Japan + East","Japan West","North Central US","North Europe","Norway East","South + Africa North","South India","Southeast Asia","Switzerland North","West Central + US","West India","West US","West US 2","UAE North","UK West","UK South","Brazil + South","Korea South","Korea Central","East US"],"apiVersions":["2020-12-01-preview","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Australia Central","Australia East","Australia Southeast","Canada Central","Canada East","Central India","Central US","East Asia","East US","East US 2","France Central","Germany West Central","Japan East","Japan West","North Central US","North Europe","Norway East","South Africa North","South Central US","South India","Southeast Asia","Switzerland North","West Central US","West Europe","West India","West US","West US 2","UAE - North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Attestation","namespace":"Microsoft.Attestation","authorizations":[{"applicationId":"c61423b7-1d1f-430d-b444-0eee53298103","roleDefinitionId":"7299b0b1-11da-4858-8943-7db197005959"}],"resourceTypes":[{"resourceType":"attestationProviders","locations":["East - US 2","Central US","UK South","East US","Canada Central","Canada East"],"apiVersions":["2018-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"defaultProviders","locations":["East - US 2","Central US","UK South","East US","Canada Central"],"apiVersions":["2018-09-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"},{"resourceType":"locations/defaultProvider","locations":["East - US 2","Central US","UK South","East US","Canada Central"],"apiVersions":["2018-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization","namespace":"Microsoft.Authorization","authorizations":[{"applicationId":"de926fbf-e23b-41f9-ae15-c943a9cfa630"}],"resourceTypes":[{"resourceType":"roleAssignments","locations":[],"apiVersions":["2020-04-01-preview","2020-03-01-preview","2019-04-01-preview","2018-12-01-preview","2018-09-01-preview","2018-07-01","2018-01-01-preview","2017-10-01-preview","2017-09-01","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"roleDefinitions","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-09-01","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"classicAdministrators","locations":[],"apiVersions":["2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-06-01"}],"capabilities":"None"},{"resourceType":"permissions","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"denyAssignments","locations":[],"apiVersions":["2019-03-01-preview","2018-07-01-preview","2018-07-01"],"capabilities":"SupportsExtension"},{"resourceType":"locks","locations":[],"apiVersions":["2017-04-01","2016-09-01","2015-06-01","2015-05-01-preview","2015-01-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-09-01"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2017-05-01","2016-07-01","2015-07-01","2015-01-01","2014-10-01-preview","2014-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"}],"capabilities":"None"},{"resourceType":"policyDefinitions","locations":[],"apiVersions":["2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2016-12-01","2016-04-01","2015-10-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-12-01"}],"capabilities":"SupportsExtension"},{"resourceType":"policySetDefinitions","locations":[],"apiVersions":["2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2017-06-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"SupportsExtension"},{"resourceType":"policyAssignments","locations":[],"apiVersions":["2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2017-06-01-preview","2016-12-01","2016-04-01","2015-10-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-12-01"}],"capabilities":"SystemAssignedResourceIdentity, - SupportsExtension"},{"resourceType":"policyExemptions","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"dataAliases","locations":[],"apiVersions":["2018-06-01-preview"],"capabilities":"None"},{"resourceType":"providerOperations","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-05-01","2016-07-01","2015-07-01-preview","2015-07-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"None"},{"resourceType":"elevateAccess","locations":[],"apiVersions":["2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"}],"capabilities":"None"},{"resourceType":"checkAccess","locations":[],"apiVersions":["2018-09-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-09-01-preview"}],"capabilities":"SupportsExtension"},{"resourceType":"findOrphanRoleAssignments","locations":[],"apiVersions":["2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"roleAssignmentsUsageMetrics","locations":[],"apiVersions":["2019-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accessReviewScheduleDefinitions","locations":[],"apiVersions":["2018-05-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accessReviewScheduleSettings","locations":[],"apiVersions":["2018-05-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"privateLinkAssociations","locations":[],"apiVersions":["2020-05-01"],"capabilities":"SupportsExtension"},{"resourceType":"resourceManagementPrivateLinks","locations":["global"],"apiVersions":["2020-05-01"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operationStatus","locations":[],"apiVersions":["2020-05-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Automanage","namespace":"Microsoft.Automanage","authorizations":[{"applicationId":"9ae330ab-d710-466b-851c-c828e7340846"}],"resourceTypes":[{"resourceType":"configurationProfileAssignments","locations":["East - US","West US 2","West Central US","West Europe","Canada Central"],"apiVersions":["2020-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accounts","locations":["Central + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-12-01-preview","2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AnyBuild","namespace":"Microsoft.AnyBuild","authorizations":[{"applicationId":"16f9e0a0-ac78-4c2c-a55a-f3855317a63a","roleDefinitionId":"6fc3ed3a-fa07-4e79-9ac0-2db46b294d31"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-08-26"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West + US 2","East US","North Europe"],"apiVersions":["2020-08-26"],"capabilities":"None"},{"resourceType":"clusters","locations":["West + US 2","East US","North Europe"],"apiVersions":["2020-08-26"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-08-26"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AppAssessment","namespace":"Microsoft.AppAssessment","authorizations":[{"applicationId":"f9c691e6-93b3-4d57-944c-afcc737f9abf","roleDefinitionId":"1dc07278-9fb7-4aa4-bf32-bbb5a0a0c0bd"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-09-01-privatepreview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-09-01-privatepreview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US 2 EUAP","West Central US"],"apiVersions":["2020-09-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization","namespace":"Microsoft.Authorization","authorizations":[{"applicationId":"de926fbf-e23b-41f9-ae15-c943a9cfa630"}],"resourceTypes":[{"resourceType":"roleAssignments","locations":[],"apiVersions":["2020-04-01-preview","2020-03-01-preview","2019-04-01-preview","2018-12-01-preview","2018-09-01-preview","2018-07-01","2018-01-01-preview","2017-10-01-preview","2017-09-01","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-09-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"roleDefinitions","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-09-01","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"classicAdministrators","locations":[],"apiVersions":["2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-06-01"}],"capabilities":"None"},{"resourceType":"permissions","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"SupportsExtension"},{"resourceType":"denyAssignments","locations":[],"apiVersions":["2019-03-01-preview","2018-07-01-preview","2018-07-01"],"capabilities":"SupportsExtension"},{"resourceType":"locks","locations":[],"apiVersions":["2017-04-01","2016-09-01","2015-06-01","2015-05-01-preview","2015-01-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-04-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-09-01"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2017-05-01","2016-07-01","2015-07-01","2015-01-01","2014-10-01-preview","2014-06-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"}],"capabilities":"None"},{"resourceType":"policyDefinitions","locations":[],"apiVersions":["2020-09-01","2020-08-01","2020-03-01","2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2016-12-01","2016-04-01","2015-10-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-12-01"}],"capabilities":"SupportsExtension"},{"resourceType":"policySetDefinitions","locations":[],"apiVersions":["2020-09-01","2020-08-01","2020-03-01","2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2017-06-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"}],"capabilities":"SupportsExtension"},{"resourceType":"policyAssignments","locations":[],"apiVersions":["2020-09-01","2020-08-01","2020-03-01","2019-09-01","2019-06-01","2019-01-01","2018-05-01","2018-03-01","2017-06-01-preview","2016-12-01","2016-04-01","2015-10-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-03-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-12-01"}],"capabilities":"SystemAssignedResourceIdentity, + SupportsExtension"},{"resourceType":"policyExemptions","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"dataAliases","locations":[],"apiVersions":["2020-09-01","2020-03-01-preview","2018-06-01-preview"],"capabilities":"None"},{"resourceType":"dataPolicyManifests","locations":[],"apiVersions":["2020-09-01"],"capabilities":"None"},{"resourceType":"providerOperations","locations":[],"apiVersions":["2018-07-01","2018-01-01-preview","2017-05-01","2016-07-01","2015-07-01-preview","2015-07-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2015-07-01"}],"capabilities":"None"},{"resourceType":"elevateAccess","locations":[],"apiVersions":["2017-05-01","2016-07-01","2015-07-01","2015-06-01","2015-05-01-preview","2014-10-01-preview","2014-07-01-preview","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2017-05-01"}],"capabilities":"None"},{"resourceType":"checkAccess","locations":[],"apiVersions":["2018-09-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-09-01-preview"}],"capabilities":"SupportsExtension"},{"resourceType":"findOrphanRoleAssignments","locations":[],"apiVersions":["2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"roleAssignmentsUsageMetrics","locations":[],"apiVersions":["2019-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accessReviewScheduleDefinitions","locations":[],"apiVersions":["2018-05-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accessReviewScheduleSettings","locations":[],"apiVersions":["2018-05-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"roleAssignmentApprovals","locations":[],"apiVersions":["2021-01-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"privateLinkAssociations","locations":[],"apiVersions":["2020-05-01"],"capabilities":"SupportsExtension"},{"resourceType":"resourceManagementPrivateLinks","locations":["global"],"apiVersions":["2020-05-01"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operationStatus","locations":[],"apiVersions":["2020-05-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Automanage","namespace":"Microsoft.Automanage","authorizations":[{"applicationId":"9ae330ab-d710-466b-851c-c828e7340846"},{"applicationId":"d828acde-4b48-47f5-a6e8-52460104a052","roleDefinitionId":"111e90e1-c9ec-40f6-b898-c0964578da58"}],"resourceTypes":[{"resourceType":"configurationProfileAssignments","locations":["Central + US","East US","East US 2","South Central US","West US","West US 2","West Central + US","North Europe","West Europe","Canada Central","Japan East","UK South","Australia + Southeast","Australia East"],"apiVersions":["2020-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"accounts","locations":["Central US","East US 2","East US","North Central US","South Central US","West US 2","West - Central US","West US","West Europe","North Europe","Canada Central"],"apiVersions":["2020-06-30-preview"],"defaultApiVersion":"2020-06-30-preview","capabilities":"CrossResourceGroupResourceMove, + Central US","West US","West Europe","North Europe","Canada Central","Japan + East","UK South","Australia Southeast","Australia East"],"apiVersions":["2020-06-30-preview"],"defaultApiVersion":"2020-06-30-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"configurationProfilePreferences","locations":["Central US","East US 2","East US","North Central US","South Central US","West US 2","West - Central US","West US","West Europe","North Europe","Canada Central"],"apiVersions":["2020-06-30-preview"],"defaultApiVersion":"2020-06-30-preview","capabilities":"CrossResourceGroupResourceMove, + Central US","West US","West Europe","North Europe","Canada Central","Japan + East","UK South","Australia Southeast","Australia East"],"apiVersions":["2020-06-30-preview"],"defaultApiVersion":"2020-06-30-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["Central US","East US 2","East US","North Central US","South Central US","West US 2","West - Central US","West US"],"apiVersions":["2020-06-30-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AutonomousSystems","namespace":"Microsoft.AutonomousSystems","authorizations":[{"applicationId":"a967240f-810b-4f79-85e5-25870cc69cbb","roleDefinitionId":"47b23f55-5e18-4fc7-a69a-f9b79a9811ea","managedByRoleDefinitionId":"6ee14824-e3a8-4536-ad65-346e3406f3c4"}],"resourceTypes":[{"resourceType":"workspaces","locations":["West + Central US","West US"],"apiVersions":["2020-06-30-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AutonomousDevelopmentPlatform","namespace":"Microsoft.AutonomousDevelopmentPlatform","authorizations":[{"applicationId":"dad37da6-229d-4bc0-8b94-fee8600589db","roleDefinitionId":"5cbfe752-1a6e-4926-b68f-0475c305f85e","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},{"applicationId":"150c8903-2280-4ab6-8708-b080044d94c6","roleDefinitionId":"5cbfe752-1a6e-4926-b68f-0475c305f85e"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["East + US 2 EUAP","West Europe"],"apiVersions":["2020-07-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AutonomousSystems","namespace":"Microsoft.AutonomousSystems","authorizations":[{"applicationId":"a967240f-810b-4f79-85e5-25870cc69cbb","roleDefinitionId":"47b23f55-5e18-4fc7-a69a-f9b79a9811ea","managedByRoleDefinitionId":"6ee14824-e3a8-4536-ad65-346e3406f3c4"}],"resourceTypes":[{"resourceType":"workspaces","locations":["West US","West US 2"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"workspaces/validateCreateRequest","locations":["West US","West US 2"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"None"},{"resourceType":"workspaces/operationresults","locations":["West - US","West US 2"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AVS","namespace":"Microsoft.AVS","authorizations":[{"applicationId":"608f9929-9737-432e-860f-4e1c1821052f","roleDefinitionId":"a12e1b40-7eca-4c51-be1d-d8bc564dcfdd","allowedThirdPartyExtensions":[{"name":"VMCP"}]}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"None"},{"resourceType":"locations/checkTrialAvailability","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"None"},{"resourceType":"locations/checkQuotaAvailability","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"None"},{"resourceType":"privateClouds","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"CrossResourceGroupResourceMove, + US","West US 2"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AVS","namespace":"Microsoft.AVS","authorizations":[{"applicationId":"608f9929-9737-432e-860f-4e1c1821052f","roleDefinitionId":"a12e1b40-7eca-4c51-be1d-d8bc564dcfdd","allowedThirdPartyExtensions":[{"name":"VMCP"}]}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"locations/checkTrialAvailability","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"locations/checkQuotaAvailability","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"privateClouds","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2021-01-01-preview","2020-07-17-preview","2020-03-20"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"privateClouds/clusters","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20","2019-08-09-preview"],"capabilities":"None"},{"resourceType":"privateClouds/authorizations","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"privateClouds/hcxEnterpriseSites","locations":["East - US 2","East US","West US","West Europe","Australia East"],"apiVersions":["2020-03-20"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureActiveDirectory","namespace":"Microsoft.AzureActiveDirectory","resourceTypes":[{"resourceType":"guestUsages","locations":["Global","United - States","Europe","Asia Pacific"],"apiVersions":["2020-05-01-preview"],"defaultApiVersion":"2020-05-01-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"b2cDirectories","locations":["Global","United - States","Europe","Asia Pacific"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview","2017-01-30","2016-12-13-preview","2016-02-10-privatepreview"],"defaultApiVersion":"2017-01-30","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"checkNameAvailability","locations":["Global","United - States","Europe","Asia Pacific"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview"],"capabilities":"None"},{"resourceType":"operations","locations":["Global","United - States","Europe","Asia Pacific"],"apiVersions":["2020-05-01-preview","2019-01-01-privatepreview","2017-01-30","2016-12-13-preview","2016-02-10-privatepreview"],"defaultApiVersion":"2017-01-30","capabilities":"None"},{"resourceType":"b2ctenants","locations":["Global","United - States","Europe","Asia Pacific"],"apiVersions":["2020-05-01-preview","2016-02-10-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureData","namespace":"Microsoft.AzureData","authorizations":[{"applicationId":"bb55177b-a7d9-4939-a257-8ab53a3b2bc6","roleDefinitionId":"f83de625-af9e-4458-ac9c-e5d62b05fd06"},{"applicationId":"a12e8ccb-0fcd-46f8-b6a1-b9df7a9d7231","roleDefinitionId":"f83de625-af9e-4458-ac9c-e5d62b05fd06"}],"resourceTypes":[{"resourceType":"sqlServerRegistrations","locations":["Australia + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2021-01-01-preview","2020-03-20"],"capabilities":"None"},{"resourceType":"privateClouds/authorizations","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"privateClouds/hcxEnterpriseSites","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-03-20"],"capabilities":"None"},{"resourceType":"privateClouds/globalReachConnections","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/addons","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/dhcpConfigurations","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/portMirroringProfiles","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/segments","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/vmGroups","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/gateways","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/virtualMachines","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/dnsServices","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"},{"resourceType":"privateClouds/workloadNetworks/dnsZones","locations":["East + US","North Central US","West US","West Europe","Australia East","Japan East","UK + South","Canada Central","North Europe","Southeast Asia"],"apiVersions":["2020-07-17-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureArcData","namespace":"Microsoft.AzureArcData","authorizations":[{"applicationId":"319f651f-7ddb-4fc6-9857-7aef9250bd05","roleDefinitionId":"2e103dbb-6933-4a8b-a358-17ee9ff00b9e"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2021-03-02-preview","2019-01-01"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2021-03-02-preview","2020-12-08-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["Japan + East","Australia East","Korea Central","UK South","France Central","East US + 2","Central US","Central US EUAP","West US 2","East Asia","East US","East + US 2 EUAP","North Europe","Southeast Asia","West Europe"],"apiVersions":["2019-10-01"],"capabilities":"None"},{"resourceType":"dataControllers","locations":["Japan + East","Australia East","Korea Central","UK South","France Central","East US + 2","Central US","West US 2","East US","North Europe","Southeast Asia","West + Europe"],"apiVersions":["2020-12-08-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"sqlManagedInstances","locations":["Japan + East","Australia East","Korea Central","UK South","France Central","East US + 2","Central US","West US 2","East US","North Europe","Southeast Asia","West + Europe"],"apiVersions":["2020-12-08-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"postgresInstances","locations":["Japan + East","Australia East","Korea Central","UK South","France Central","East US + 2","Central US","West US 2","East US","North Europe","Southeast Asia","West + Europe"],"apiVersions":["2020-12-08-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"sqlServerInstances","locations":["Australia + East","UK South","East US 2","Central US","East US","North Europe","Southeast + Asia","West Europe","West US 2"],"apiVersions":["2020-12-08-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureCIS","namespace":"Microsoft.AzureCIS","authorizations":[],"resourceTypes":[{"resourceType":"autopilotEnvironments","locations":["Australia + East","Australia Southeast","Canada Central","Central India","Central US","East + Asia","East US","East US 2","France Central","Japan East","Korea Central","North + Europe","Southeast Asia","South Central US","UAE North","UK South","West Central + US","West Europe","West US","West US 2"],"apiVersions":["2021-02-01"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureData","namespace":"Microsoft.AzureData","authorizations":[{"applicationId":"bb55177b-a7d9-4939-a257-8ab53a3b2bc6","roleDefinitionId":"f83de625-af9e-4458-ac9c-e5d62b05fd06"},{"applicationId":"a12e8ccb-0fcd-46f8-b6a1-b9df7a9d7231","roleDefinitionId":"f83de625-af9e-4458-ac9c-e5d62b05fd06"}],"resourceTypes":[{"resourceType":"sqlServerRegistrations","locations":["Australia East","Australia Southeast","Canada Central","France Central","Japan East","Japan West","Korea Central","Korea South","North Central US","North Europe","South Africa North","South Central US","Southeast Asia","South India","UK South","UK @@ -6240,17 +7256,25 @@ interactions: Central US","Southeast Asia","South India","South Africa North","UK South","UK West","West US","East US","Central US","East Asia","West Europe","West Central US","West US 2","East US 2"],"apiVersions":["2019-05-10-preview"],"defaultApiVersion":"2019-05-10-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.AzureStackHCI","namespace":"Microsoft.AzureStackHCI","authorizations":[{"applicationId":"1412d89f-b8a8-4111-b4fd-e82905cbd85d","roleDefinitionId":"90ffa33f-4875-44d8-b86f-d41c3aa6050e"},{"applicationId":"1322e676-dee7-41ee-a874-ac923822781c","roleDefinitionId":"e91a9804-9f4d-4501-bf85-03bd4ea78451"}],"resourceTypes":[{"resourceType":"clusters","locations":["East - US","West Europe"],"apiVersions":["2020-03-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BatchAI","namespace":"Microsoft.BatchAI","authorization":{"applicationId":"9fcb3732-5f52-4135-8c08-9d4bbaf203ea","roleDefinitionId":"703B89C7-CE2C-431B-BDD8-FA34E39AF696","managedByRoleDefinitionId":"90B8E153-EBFF-4073-A95F-4DAD56B14C78"},"resourceTypes":[{"resourceType":"workspaces","locations":["West + US","West Europe","Southeast Asia"],"apiVersions":["2020-10-01"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-11-01-preview","2020-10-01","2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-11-01-preview","2020-10-01"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East + US","East US 2 EUAP","West Europe","Southeast Asia"],"apiVersions":["2020-10-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BareMetalInfrastructure","namespace":"Microsoft.BareMetalInfrastructure","authorization":{"applicationId":"cc5476ec-3074-44d1-8461-711f5d9b0e39","roleDefinitionId":"4a10987e-dbcf-4c3d-8e3d-7ddcd9c771c2","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},"resourceTypes":[{"resourceType":"bareMetalInstances","locations":["West + US","West US 2","East US","East US 2","South Central US","West Europe","North + Europe","Japan East","Australia East","Australia Southeast"],"apiVersions":["2020-08-06-preview"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"locations/operationsStatus","locations":["West + US","West US 2","East US","East US 2","South Central US","West Europe","North + Europe","Japan East","Australia East","Australia Southeast"],"apiVersions":["2020-08-06-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West + US","West US 2","East US","East US 2","South Central US","West Europe","North + Europe","Japan East","Australia East","Australia Southeast"],"apiVersions":["2020-08-06-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BatchAI","namespace":"Microsoft.BatchAI","authorization":{"applicationId":"9fcb3732-5f52-4135-8c08-9d4bbaf203ea","roleDefinitionId":"703B89C7-CE2C-431B-BDD8-FA34E39AF696","managedByRoleDefinitionId":"90B8E153-EBFF-4073-A95F-4DAD56B14C78"},"resourceTypes":[{"resourceType":"workspaces","locations":["West US"],"apiVersions":["2018-05-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"workspaces/clusters","locations":["West US"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"workspaces/fileservers","locations":["West US"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"workspaces/experiments","locations":["West US"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"workspaces/experiments/jobs","locations":["West US"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"operations","locations":["East US","West US 2","West Europe","East US 2","North Europe","Australia East","West - Central US","Southeast Asia","South Central US","West US"],"apiVersions":["2018-05-01","2018-03-01","2017-09-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Billing","namespace":"Microsoft.Billing","authorizations":[{"applicationId":"80dbdb39-4f33-4799-8b6f-711b5e3e61b6","roleDefinitionId":"acdc79db-513f-461d-a542-61908d543bdc"}],"resourceTypes":[{"resourceType":"billingPeriods","locations":[],"apiVersions":["2018-03-01-preview","2017-04-24-preview"],"capabilities":"SupportsExtension"},{"resourceType":"invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-03-01-preview","2017-04-24-preview","2017-02-27-preview"],"capabilities":"None"},{"resourceType":"enrollmentAccounts","locations":[],"apiVersions":["2018-03-01-preview"],"capabilities":"None"},{"resourceType":"billingRoleDefinitions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingRoleAssignments","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"createBillingRoleAssignment","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingAccounts/createBillingRoleAssignment","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/createBillingRoleAssignment","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/createBillingRoleAssignment","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingPermissions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingAccounts/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-06-30","2018-05-31"],"capabilities":"None"},{"resourceType":"billingAccounts/operationResults","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/customers","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/instructions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/elevate","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/createInvoiceSectionOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/productMoveOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptionMoveOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/listInvoiceSectionsWithCreateSubscriptionPermission","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/BillingProfiles/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"departments","locations":[],"apiVersions":["2018-06-30","2018-05-31"],"capabilities":"None"},{"resourceType":"billingAccounts/departments","locations":[],"apiVersions":["2019-10-01-preview","2018-06-30"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingRoleDefinitions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingRoleAssignments","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingPermissions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts","locations":[],"apiVersions":["2019-10-01-preview","2018-06-30"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingRoleDefinitions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingRoleAssignments","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingPermissions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/paymentMethods","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/availableBalance","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/transactions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/transactions","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/transactions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoices/transactions","locations":[],"apiVersions":["2020-05-01"],"capabilities":"None"},{"resourceType":"billingAccounts/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingSubscriptions/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"operationStatus","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products/updateAutoRenew","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products/updateAutoRenew","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-06-30","2018-03-01-preview","2017-04-24-preview","2017-02-27-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/initiateTransfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/initiateTransfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/transfers","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/transfers","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"transfers/acceptTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/declineTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/validateTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/initiateTransfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/transfers","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingProperty","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/policies","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/policies","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices/pricesheet","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/pricesheet","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/pricesheetDownloadOperations","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptions/transfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products/transfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products/transfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/productTransfersResults","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/operationStatus","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/agreements","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/lineOfCredit","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/paymentMethods","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/reservations","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/reservations","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/validateDetachPaymentMethodEligibility","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"validateAddress","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BingMaps","namespace":"Microsoft.BingMaps","resourceTypes":[{"resourceType":"mapApis","locations":["West - US"],"apiVersions":["2016-08-18","2015-07-02"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-08-18","2015-07-02"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-08-18","2015-07-02"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-08-18","2015-07-02"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Blockchain","namespace":"Microsoft.Blockchain","authorizations":[{"applicationId":"78827f38-7b69-4d5e-a627-d6fdd9c759a0","roleDefinitionId":"9c68eaf3-8315-4e5c-b857-641b16b21f8f"},{"applicationId":"049d4938-2ef2-4274-aa8f-630fc9bc33d1","roleDefinitionId":"c6dd0893-0495-488a-ac21-ee5f1ba89769"},{"applicationId":"911e905a-a50e-4c94-9f7c-48bb12f549ed"}],"resourceTypes":[{"resourceType":"watchers","locations":["East + Central US","Southeast Asia","South Central US","West US"],"apiVersions":["2018-05-01","2018-03-01","2017-09-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Billing","namespace":"Microsoft.Billing","authorizations":[{"applicationId":"80dbdb39-4f33-4799-8b6f-711b5e3e61b6","roleDefinitionId":"acdc79db-513f-461d-a542-61908d543bdc"}],"resourceTypes":[{"resourceType":"billingPeriods","locations":[],"apiVersions":["2018-03-01-preview","2017-04-24-preview"],"capabilities":"SupportsExtension"},{"resourceType":"invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-03-01-preview","2017-04-24-preview","2017-02-27-preview"],"capabilities":"None"},{"resourceType":"enrollmentAccounts","locations":[],"apiVersions":["2018-03-01-preview"],"capabilities":"None"},{"resourceType":"billingRoleDefinitions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingRoleAssignments","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"createBillingRoleAssignment","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingAccounts/createBillingRoleAssignment","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/createBillingRoleAssignment","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/createBillingRoleAssignment","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingPermissions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"billingAccounts/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts","locations":[],"apiVersions":["2020-12-15-privatepreview","2020-11-01-privatepreview","2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-06-30","2018-05-31"],"capabilities":"None"},{"resourceType":"billingAccounts/operationResults","locations":[],"apiVersions":["2020-11-01-privatepreview","2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/customers","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/instructions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections","locations":[],"apiVersions":["2020-11-01-privatepreview","2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/elevate","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/createInvoiceSectionOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/productMoveOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptionMoveOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/listInvoiceSectionsWithCreateSubscriptionPermission","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles","locations":[],"apiVersions":["2020-11-01-privatepreview","2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/BillingProfiles/patchOperations","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"departments","locations":[],"apiVersions":["2018-06-30","2018-05-31"],"capabilities":"None"},{"resourceType":"billingAccounts/departments","locations":[],"apiVersions":["2019-10-01-preview","2018-06-30"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts","locations":[],"apiVersions":["2019-10-01-preview","2018-06-30"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingRoleDefinitions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingRoleAssignments","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingPermissions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/enrollmentAccounts/billingSubscriptions","locations":[],"apiVersions":["2020-12-15-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/departments/billingSubscriptions","locations":[],"apiVersions":["2020-12-15-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/paymentMethods","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/availableBalance","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/transactions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/transactions","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/transactions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices/transactions","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoices/transactions","locations":[],"apiVersions":["2020-05-01"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/validateDeleteBillingProfileEligibility","locations":[],"apiVersions":["2020-11-01-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/validateDeleteInvoiceSectionEligibility","locations":[],"apiVersions":["2020-11-01-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoices/transactionSummary","locations":[],"apiVersions":["2020-11-01-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingSubscriptions","locations":[],"apiVersions":["2020-12-15-privatepreview","2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingSubscriptions/invoices","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptions","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/billingSubscriptions","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"operationStatus","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"operationResults","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products/updateAutoRenew","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products/updateAutoRenew","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/products","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-11-01-privatepreview","2020-09-01-preview","2020-05-01","2019-10-01-preview","2018-11-01-preview","2018-06-30","2018-03-01-preview","2017-04-24-preview","2017-02-27-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/initiateTransfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/initiateTransfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/transfers","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/transfers","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"transfers/acceptTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/declineTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/validateTransfer","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/initiateTransfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/transfers","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingProperty","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/policies","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/customers/policies","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoices/pricesheet","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/pricesheet","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/pricesheetDownloadOperations","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/billingSubscriptions/transfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/products/transfer","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/invoiceSections/products/transfer","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/invoiceSections/productTransfersResults","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"transfers/operationStatus","locations":[],"apiVersions":["2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/agreements","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/lineOfCredit","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/paymentMethods","locations":[],"apiVersions":["2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/payableOverage","locations":[],"apiVersions":["2020-12-15-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/payNow","locations":[],"apiVersions":["2020-12-15-privatepreview"],"capabilities":"None"},{"resourceType":"billingAccounts/reservations","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/reservations","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingProfiles/validateDetachPaymentMethodEligibility","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"validateAddress","locations":[],"apiVersions":["2020-05-01","2019-10-01-preview","2018-11-01-preview"],"capabilities":"None"},{"resourceType":"promotions","locations":[],"apiVersions":["2020-11-01-preview","2020-09-01-preview"],"capabilities":"None"},{"resourceType":"promotions/checkeligibility","locations":[],"apiVersions":["2020-11-01-preview","2020-09-01-preview"],"capabilities":"None"},{"resourceType":"billingAccounts/billingSubscriptions/elevateRole","locations":[],"apiVersions":["2020-12-15-privatepreview","2020-12-15-beta"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Bing","namespace":"Microsoft.Bing","authorizations":[{"applicationId":"c19490b5-c092-426f-b1a2-674b279d4975","roleDefinitionId":"7963cd60-9634-4abc-9a64-2482a3ef6373"}],"resourceTypes":[{"resourceType":"locations","locations":["global"],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"accounts/skus","locations":["global"],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"accounts/usages","locations":["global"],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":["global"],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["West + US","East US","West Europe","Southeast Asia"],"apiVersions":["2020-06-10"],"capabilities":"None"},{"resourceType":"accounts","locations":["global"],"apiVersions":["2020-06-10"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Blockchain","namespace":"Microsoft.Blockchain","authorizations":[{"applicationId":"78827f38-7b69-4d5e-a627-d6fdd9c759a0","roleDefinitionId":"9c68eaf3-8315-4e5c-b857-641b16b21f8f"},{"applicationId":"049d4938-2ef2-4274-aa8f-630fc9bc33d1","roleDefinitionId":"c6dd0893-0495-488a-ac21-ee5f1ba89769"},{"applicationId":"911e905a-a50e-4c94-9f7c-48bb12f549ed"}],"resourceTypes":[{"resourceType":"watchers","locations":["East US","West Europe"],"apiVersions":["2019-06-01-preview"],"defaultApiVersion":"2019-06-01-preview","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"blockchainMembers","locations":["East US","Southeast Asia","West Europe","North Europe","West US 2","Japan East"],"apiVersions":["2018-06-01-preview"],"capabilities":"SupportsTags, @@ -6264,60 +7288,15 @@ interactions: US","Southeast Asia","West Europe","North Europe","West US 2","Japan East","West Central US"],"apiVersions":["2018-06-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.BlockchainTokens","namespace":"Microsoft.BlockchainTokens","resourceTypes":[{"resourceType":"Operations","locations":["West US"],"apiVersions":["2019-07-19-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Blueprint","namespace":"Microsoft.Blueprint","authorizations":[{"applicationId":"f71766dc-90d9-4b7d-bd9d-4499c4331c3f","roleDefinitionId":"cb180127-cf6d-4672-9e75-e29a487f9658"}],"resourceTypes":[{"resourceType":"blueprints","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"SupportsExtension"},{"resourceType":"blueprints/artifacts","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"},{"resourceType":"blueprints/versions","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"},{"resourceType":"blueprints/versions/artifacts","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"},{"resourceType":"blueprintAssignments","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"SystemAssignedResourceIdentity, - SupportsExtension"},{"resourceType":"blueprintAssignments/operations","locations":[],"apiVersions":["2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"},{"resourceType":"blueprintAssignments/assignmentOperations","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CertificateRegistration","namespace":"Microsoft.CertificateRegistration","authorization":{"applicationId":"f3c21649-0979-4721-ac85-b0216b2cf413","roleDefinitionId":"933fba7e-2ed3-4da8-973d-8bd8298a9b40"},"resourceTypes":[{"resourceType":"certificateOrders","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"certificateOrders/certificates","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validateCertificateRegistrationInformation","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ChangeAnalysis","namespace":"Microsoft.ChangeAnalysis","authorizations":[{"applicationId":"2cfc91a4-7baa-4a8f-a6c9-5f3d279060b8","roleDefinitionId":"f5a6bd90-af71-455c-9030-c486e8c42c95"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01-preview","2019-04-01-preview"],"capabilities":"None"},{"resourceType":"resourceChanges","locations":[],"apiVersions":["2020-04-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicCompute","namespace":"Microsoft.ClassicCompute","resourceTypes":[{"resourceType":"domainNames","locations":["East - Asia","Southeast Asia","East US","East US 2","West US","West US 2","North - Central US","South Central US","West Central US","Central US","North Europe","West - Europe","Japan East","Japan West","Brazil South","Australia East","Australia - Southeast","South India","Central India","West India","Canada Central","Canada - East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea - Central","Korea South","France Central","South Africa North","UAE North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2020-02-01","2018-06-01","2017-11-15","2017-11-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"CrossResourceGroupResourceMove, - SupportsLocation"},{"resourceType":"domainNames/internalLoadBalancers","locations":[],"apiVersions":["2017-11-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"None"},{"resourceType":"checkDomainNameAvailability","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots","locations":["East - Asia","Southeast Asia","East US","East US 2","West US","West US 2","North - Central US","South Central US","West Central US","Central US","North Europe","West - Europe","Japan East","Japan West","Brazil South","Australia East","Australia - Southeast","South India","Central India","West India","Canada Central","Canada - East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea - Central","Korea South","France Central","South Africa North","UAE North","Australia - Central","Switzerland North","Norway East","Germany West Central"],"apiVersions":["2020-02-01","2018-06-01","2017-11-15","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles","locations":["East - Asia","Southeast Asia","East US","East US 2","West US","West US 2","North - Central US","South Central US","West Central US","Central US","North Europe","West - Europe","Japan East","Japan West","Brazil South","Australia East","Australia - Southeast","South India","Central India","West India","Canada Central","Canada - East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea - Central","Korea South","France Central","South Africa North","UAE North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"domainNames/slots/roles/metrics","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines","locations":["East - Asia","Southeast Asia","East US","East US 2","West US","West US 2","North - Central US","South Central US","West Central US","Central US","North Europe","West - Europe","Japan East","Japan West","Brazil South","Australia East","Australia - Southeast","South India","Central India","West India","Canada Central","Canada - East","East US 2 (Stage)","North Central US (Stage)","UK South","UK West","Korea - Central","Korea South","France Central","South Africa North","UAE North","Australia - Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2017-04-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"defaultApiVersion":"2014-06-01","capabilities":"CrossResourceGroupResourceMove, - SupportsLocation"},{"resourceType":"capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"domainNames/capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"domainNames/serviceCertificates","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"quotas","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-01-01"],"capabilities":"None"},{"resourceType":"virtualMachines/diagnosticSettings","locations":["East - US","East US 2","North Central US","North Europe","West Europe","Brazil South","Canada - Central","Canada East","UK South","UK West","France Central","South Africa - North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway - East","West US","Central US","South Central US","Japan East","Japan West","East - Asia","Southeast Asia","Australia East","Australia Southeast","West US 2","West - Central US","South India","Central India","West India","Korea Central","Korea - South","East US 2 (Stage)","North Central US (Stage)"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines/metricDefinitions","locations":["East - US","East US 2","North Central US","North Europe","West Europe","Brazil South","Canada - Central","Canada East","UK South","UK West","France Central","South Africa - North","UAE North","Switzerland North","West US","Central US","South Central - US","Japan East","Japan West","East Asia","Southeast Asia","Australia East","Australia - Southeast","Australia Central","West US 2","West Central US","Germany West - Central","Norway East","South India","Central India","West India","Korea Central","Korea - South","East US 2 (Stage)","North Central US (Stage)"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"virtualMachines/metrics","locations":["North - Central US","South Central US","East US","East US 2","Canada Central","Canada - East","West US","West US 2","West Central US","Australia East","Australia - Southeast","South Africa North","UAE North","Australia Central","Switzerland - North","Germany West Central","Norway East","Central US","East Asia","Southeast - Asia","North Europe","West Europe","UK South","UK West","Japan East","Japan - West","Brazil South","South India","Central India","West India","East US 2 - (Stage)","North Central US (Stage)","Korea Central","Korea South","France - Central"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2017-04-01","2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"resourceTypes","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"moveSubscriptionResources","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"validateSubscriptionMoveAvailability","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01"],"capabilities":"None"},{"resourceType":"operatingSystems","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"operatingSystemFamilies","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-10-01","2015-06-01","2014-06-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicInfrastructureMigrate","namespace":"Microsoft.ClassicInfrastructureMigrate","authorization":{"applicationId":"5e5abe2b-83cd-4786-826a-a05653ebb103","roleDefinitionId":"766c4d9b-ef83-4f73-8352-1450a506a69b"},"resourceTypes":[{"resourceType":"classicInfrastructureResources","locations":["East + SupportsExtension"},{"resourceType":"blueprintAssignments/operations","locations":[],"apiVersions":["2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"},{"resourceType":"blueprintAssignments/assignmentOperations","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-11-01-preview","2018-11-01-alpha","2017-11-11-preview","2017-11-11-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Cascade","namespace":"Microsoft.Cascade","authorizations":[],"resourceTypes":[{"resourceType":"sites","locations":["West + US","North Europe"],"apiVersions":["2020-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Locations","locations":[],"apiVersions":["2020-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Locations/operationStatuses","locations":["West + US","Japan East","North Europe"],"apiVersions":["2020-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Operations","locations":["West + US","Japan East","North Europe"],"apiVersions":["2020-11-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CertificateRegistration","namespace":"Microsoft.CertificateRegistration","authorization":{"applicationId":"f3c21649-0979-4721-ac85-b0216b2cf413","roleDefinitionId":"933fba7e-2ed3-4da8-973d-8bd8298a9b40"},"resourceTypes":[{"resourceType":"certificateOrders","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"certificateOrders/certificates","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validateCertificateRegistrationInformation","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2020-10-01","2020-09-01","2020-06-01","2019-08-01","2018-02-01","2015-08-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ChangeAnalysis","namespace":"Microsoft.ChangeAnalysis","authorizations":[{"applicationId":"2cfc91a4-7baa-4a8f-a6c9-5f3d279060b8","roleDefinitionId":"f5a6bd90-af71-455c-9030-c486e8c42c95"},{"applicationId":"3edcf11f-df80-41b2-a5e4-7e213cca30d1","roleDefinitionId":"f5a6bd90-af71-455c-9030-c486e8c42c95"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01-preview","2019-04-01-preview"],"capabilities":"None"},{"resourceType":"resourceChanges","locations":[],"apiVersions":["2020-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"changes","locations":[],"apiVersions":["2020-10-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Chaos","namespace":"Microsoft.Chaos","authorizations":[{"applicationId":"ecad3f28-c75d-4414-94e0-a5e1de4df79e","roleDefinitionId":"16f6458e-a375-4d8d-934e-5c9933967cb4"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2021-02-12-preview","2021-01-21-preview","2020-11-30-preview","2020-09-23-preview","2020-09-14-preview","2020-06-18-preview","2020-05-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicInfrastructureMigrate","namespace":"Microsoft.ClassicInfrastructureMigrate","authorization":{"applicationId":"5e5abe2b-83cd-4786-826a-a05653ebb103","roleDefinitionId":"766c4d9b-ef83-4f73-8352-1450a506a69b"},"resourceTypes":[{"resourceType":"classicInfrastructureResources","locations":["East Asia","Southeast Asia","East US","East US 2","West US","North Central US","South Central US","Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia East","Australia Southeast","Central India","West @@ -6380,32 +7359,76 @@ interactions: US","East US","East US 2","North Central US","North Europe","West Europe","Brazil South","Canada Central","Canada East","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Australia Central","Switzerland - North","Germany West Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/services/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/services/metrics","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/metrics","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/blobServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/tableServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/fileServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/queueServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"disks","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"images","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"vmImages","locations":[],"apiVersions":["2016-11-01"],"capabilities":"None"},{"resourceType":"storageAccounts/vmImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01","2014-04-01-beta","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"publicImages","locations":[],"apiVersions":["2016-11-01","2016-04-01"],"capabilities":"None"},{"resourceType":"osImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"osPlatformImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2016-11-01","2016-04-01-beta","2016-04-01","2015-12-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicSubscription","namespace":"Microsoft.ClassicSubscription","resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2017-09-01","2017-06-01"],"defaultApiVersion":"2017-06-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Codespaces","namespace":"Microsoft.Codespaces","authorizations":[{"applicationId":"9bd5ab7f-4031-4045-ace9-6bebbad202f6","roleDefinitionId":"59cd8abb-1e79-437f-9a05-4bca235c4c35"},{"applicationId":"48ef7923-268f-473d-bcf1-07f0997961f4","roleDefinitionId":"59cd8abb-1e79-437f-9a05-4bca235c4c35"}],"resourceTypes":[{"resourceType":"plans","locations":["West - Europe","East US","West Us 2","Southeast Asia"],"apiVersions":["2020-07-10-beta","2020-07-10-alpha","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-07-10-privatepreview","2020-07-10-beta","2020-07-10-alpha","2020-06-16-privatepreview","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-07-10-privatepreview","2020-07-10-beta","2020-07-10-alpha","2020-06-16-privatepreview","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Commerce","namespace":"Microsoft.Commerce","resourceTypes":[{"resourceType":"UsageAggregates","locations":[],"apiVersions":["2015-06-01-preview","2015-03-31"],"capabilities":"None"},{"resourceType":"RateCard","locations":[],"apiVersions":["2016-08-31-preview","2015-06-01-preview","2015-05-15"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2015-06-01-preview","2015-03-31"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ConnectedCache","namespace":"Microsoft.ConnectedCache","authorizations":[],"resourceTypes":[{"resourceType":"CacheNodes","locations":["West + North","Germany West Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/services/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/services/metrics","locations":["West + US","Central US","South Central US","Japan East","Japan West","East Asia","Southeast + Asia","Australia East","Australia Southeast","South India","Central India","West + India","East US 2 (Stage)","North Central US (Stage)","West US 2","West Central + US","East US","East US 2","North Central US","North Europe","West Europe","Brazil + South","Canada Central","Canada East","UK South","UK West","Korea Central","Korea + South","France Central","South Africa North","UAE North","Australia Central","Switzerland + North","Germany West Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/metricDefinitions","locations":[],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"storageAccounts/metrics","locations":["West + US","Central US","South Central US","Japan East","Japan West","East Asia","Southeast + Asia","Australia East","Australia Southeast","South India","Central India","West + India","East US 2 (Stage)","North Central US (Stage)","West US 2","West Central + US","East US","East US 2","North Central US","North Europe","West Europe","Brazil + South","Canada Central","Canada East","UK South","UK West","Korea Central","Korea + South","France Central","South Africa North","UAE North","Australia Central","Switzerland + North","Germany West Central","Norway East"],"apiVersions":["2014-04-01"],"capabilities":"None"},{"resourceType":"capabilities","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/blobServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/tableServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/fileServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"storageAccounts/queueServices","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"disks","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"images","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"vmImages","locations":[],"apiVersions":["2016-11-01"],"capabilities":"None"},{"resourceType":"storageAccounts/vmImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01","2014-04-01-beta","2014-04-01","2014-01-01"],"capabilities":"None"},{"resourceType":"publicImages","locations":[],"apiVersions":["2016-11-01","2016-04-01"],"capabilities":"None"},{"resourceType":"osImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"osPlatformImages","locations":[],"apiVersions":["2016-11-01","2016-04-01","2015-12-01","2015-06-01","2014-06-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2016-11-01","2016-04-01-beta","2016-04-01","2015-12-01","2015-06-01","2014-06-01","2014-04-01","2014-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ClassicSubscription","namespace":"Microsoft.ClassicSubscription","resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2017-09-01","2017-06-01"],"defaultApiVersion":"2017-06-01","capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Codespaces","namespace":"Microsoft.Codespaces","authorizations":[{"applicationId":"9bd5ab7f-4031-4045-ace9-6bebbad202f6","roleDefinitionId":"59cd8abb-1e79-437f-9a05-4bca235c4c35"},{"applicationId":"48ef7923-268f-473d-bcf1-07f0997961f4","roleDefinitionId":"59cd8abb-1e79-437f-9a05-4bca235c4c35"}],"resourceTypes":[{"resourceType":"plans","locations":["West + Europe","East US","West Us 2","Southeast Asia"],"apiVersions":["2020-07-10-beta","2020-07-10-alpha","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-07-10-privatepreview","2020-07-10-beta","2020-07-10-alpha","2020-06-16-privatepreview","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-07-10-privatepreview","2020-07-10-beta","2020-07-10-alpha","2020-06-16-privatepreview","2020-06-16-beta","2020-06-16-alpha","2020-06-16"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Commerce","namespace":"Microsoft.Commerce","resourceTypes":[{"resourceType":"UsageAggregates","locations":[],"apiVersions":["2015-06-01-preview","2015-03-31"],"capabilities":"None"},{"resourceType":"RateCard","locations":[],"apiVersions":["2016-08-31-preview","2015-06-01-preview","2015-05-15"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2015-06-01-preview","2015-03-31"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ConnectedCache","namespace":"Microsoft.ConnectedCache","authorizations":[],"resourceTypes":[{"resourceType":"CacheNodes","locations":["West US"],"apiVersions":["2019-12-04-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Consumption","namespace":"Microsoft.Consumption","authorizations":[{"applicationId":"c5b17a4f-cc6f-4649-9480-684280a2af3a","roleDefinitionId":"4a2e6ae9-2713-4cc9-a3b3-312899d687c3"}],"resourceTypes":[{"resourceType":"Forecasts","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"AggregatedCost","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30"],"capabilities":"SupportsExtension"},{"resourceType":"tenants","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationRecommendations","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationRecommendationDetails","locations":[],"apiVersions":["2019-10-01"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationSummaries","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationTransactions","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Balances","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Marketplaces","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31"],"capabilities":"SupportsExtension"},{"resourceType":"Pricesheets","locations":[],"apiVersions":["2020-01-01-preview","2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationDetails","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Budgets","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-04-01-preview","2019-03-01-preview","2019-01-01-preview","2019-01-01","2018-12-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-12-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"CostTags","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"Tags","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01","2018-08-31","2018-08-01-preview","2018-06-30","2018-05-31","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"Terms","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-12-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"UsageDetails","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-12-01-preview","2018-11-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview","2017-04-24-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Charges","locations":[],"apiVersions":["2019-10-01","2019-05-01-preview","2019-05-01","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"credits","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"events","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"lots","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"products","locations":[],"apiVersions":["2019-10-01","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"OperationStatus","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"OperationResults","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"Operations","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview","2017-04-24-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CostManagement","namespace":"Microsoft.CostManagement","authorizations":[{"applicationId":"3184af01-7a88-49e0-8b55-8ecdce0aa950"}],"resourceTypes":[{"resourceType":"Connectors","locations":["West + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ConnectedVMwarevSphere","namespace":"Microsoft.ConnectedVMwarevSphere","authorizations":[{"applicationId":"ac9dc5fe-b644-4832-9d03-d9f1ab70c5f7","roleDefinitionId":"a27a5b7c-3d1a-4e97-b0ad-195eef808eb6"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-10-01-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US","East US 2 EUAP","West Europe"],"apiVersions":["2020-10-01-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-10-01-preview"],"capabilities":"None"},{"resourceType":"VCenters/InventoryItems","locations":["East + US","West Europe"],"apiVersions":["2020-10-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Consumption","namespace":"Microsoft.Consumption","authorizations":[{"applicationId":"c5b17a4f-cc6f-4649-9480-684280a2af3a","roleDefinitionId":"4a2e6ae9-2713-4cc9-a3b3-312899d687c3"}],"resourceTypes":[{"resourceType":"Forecasts","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"AggregatedCost","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30"],"capabilities":"SupportsExtension"},{"resourceType":"tenants","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationRecommendations","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationRecommendationDetails","locations":[],"apiVersions":["2019-10-01"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationSummaries","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationTransactions","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Balances","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Marketplaces","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31"],"capabilities":"SupportsExtension"},{"resourceType":"Pricesheets","locations":[],"apiVersions":["2020-01-01-preview","2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationDetails","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01-preview","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Budgets","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-04-01-preview","2019-03-01-preview","2019-01-01-preview","2019-01-01","2018-12-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-12-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"CostTags","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"Tags","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01","2018-08-31","2018-08-01-preview","2018-06-30","2018-05-31","2018-03-31"],"capabilities":"SupportsExtension"},{"resourceType":"Terms","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-10-01","2018-08-31","2018-06-30","2018-03-31","2018-01-31","2017-12-30-preview"],"capabilities":"SupportsExtension"},{"resourceType":"UsageDetails","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-12-01-preview","2018-11-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview","2017-04-24-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Charges","locations":[],"apiVersions":["2019-10-01","2019-05-01-preview","2019-05-01","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"credits","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"events","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"lots","locations":[],"apiVersions":["2019-10-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"products","locations":[],"apiVersions":["2019-10-01","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"OperationStatus","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"OperationResults","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-05-01","2019-04-01-preview","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31"],"capabilities":"SupportsExtension"},{"resourceType":"Operations","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-01-01","2018-11-01-preview","2018-10-01","2018-08-31","2018-06-30","2018-05-31","2018-03-31","2018-01-31","2017-11-30","2017-06-30-preview","2017-04-24-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CostManagement","namespace":"Microsoft.CostManagement","authorizations":[{"applicationId":"3184af01-7a88-49e0-8b55-8ecdce0aa950"},{"applicationId":"6b3368c6-61d2-4a72-854c-42d1c4e71fed"},{"applicationId":"997dc448-eeab-4c93-8811-6b2c80196a16"}],"resourceTypes":[{"resourceType":"Connectors","locations":["West US"],"apiVersions":["2018-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"CloudConnectors","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"CheckConnectorEligibility","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions/Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions/Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ExternalSubscriptions/Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"None"},{"resourceType":"Settings","locations":[],"apiVersions":["2019-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01","2019-01-01","2018-10-01","2018-08-31","2018-08-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"register","locations":[],"apiVersions":["2019-03-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01-preview","2018-08-31","2018-08-01-preview","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01-preview","2018-08-31","2018-08-01-preview","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"Budgets","locations":[],"apiVersions":["2019-10-01","2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ExternalSubscriptions/Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"None"},{"resourceType":"Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"showbackRules","locations":[],"apiVersions":["2019-03-01-preview","2019-02-03-alpha","2019-02-02-alpha","2019-02-01-alpha"],"capabilities":"SupportsExtension"},{"resourceType":"costAllocationRules","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Exports","locations":[],"apiVersions":["2020-06-01","2020-05-01-preview","2019-11-01","2019-10-01","2019-09-01","2019-01-01-preview","2019-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"Reports","locations":[],"apiVersions":["2018-12-01-preview","2018-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Reportconfigs","locations":[],"apiVersions":["2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"BillingAccounts","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"Departments","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"EnrollmentAccounts","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"Views","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Insights","locations":[],"apiVersions":["2020-08-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CostManagementExports","namespace":"Microsoft.CostManagementExports","authorizations":[{"applicationId":"e5408ad0-c4e2-43aa-b6f2-3b4951286d99","roleDefinitionId":"5e4888b3-2747-4e5b-9897-ec0865b91bcf"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2019-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CustomerLockbox","namespace":"Microsoft.CustomerLockbox","authorizations":[{"applicationId":"a0551534-cfc9-4e1f-9a7a-65093b32bb38","roleDefinitionId":"114bcfb6-5524-4d80-948a-d8a9937bc3e5"},{"applicationId":"01fc33a7-78ba-4d2f-a4b7-768e336e890e"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"},{"resourceType":"requests","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.D365CustomerInsights","namespace":"Microsoft.D365CustomerInsights","resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-06-10-privatepreview","2020-06-10-preview","2020-06-10-beta"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataCatalog","namespace":"Microsoft.DataCatalog","authorization":{"applicationId":"213f5f78-fb30-46c7-9e98-91c720a1c026","roleDefinitionId":"D55E2225-A6AB-481C-A5BE-1B7687C293FA"},"resourceTypes":[{"resourceType":"catalogs","locations":["East + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"CloudConnectors","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"CheckConnectorEligibility","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions/Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions/Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview"],"capabilities":"None"},{"resourceType":"ExternalSubscriptions","locations":[],"apiVersions":["2019-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ExternalSubscriptions/Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Forecast","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2018-12-01-preview"],"capabilities":"None"},{"resourceType":"Settings","locations":[],"apiVersions":["2019-11-01","2019-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01","2019-01-01","2018-10-01","2018-08-31","2018-08-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"register","locations":[],"apiVersions":["2019-03-01-preview","2017-10-01-preview"],"capabilities":"None"},{"resourceType":"Query","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01-preview","2018-08-31","2018-08-01-preview","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"Dimensions","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-05-01-preview","2019-04-01-preview","2019-03-01-preview","2019-01-01","2018-12-01-preview","2018-10-01-preview","2018-08-31","2018-08-01-preview","2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"Budgets","locations":[],"apiVersions":["2019-10-01","2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ExternalSubscriptions/Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"None"},{"resourceType":"ExternalBillingAccounts/Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"None"},{"resourceType":"Alerts","locations":[],"apiVersions":["2019-10-01","2018-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"showbackRules","locations":[],"apiVersions":["2019-03-01-preview","2019-02-03-alpha","2019-02-02-alpha","2019-02-01-alpha"],"capabilities":"SupportsExtension"},{"resourceType":"costAllocationRules","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Exports","locations":[],"apiVersions":["2020-06-01","2020-05-01-preview","2019-11-01","2019-10-01","2019-09-01","2019-01-01-preview","2019-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"Reports","locations":[],"apiVersions":["2018-12-01-preview","2018-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Reportconfigs","locations":[],"apiVersions":["2018-05-31"],"capabilities":"SupportsExtension"},{"resourceType":"BillingAccounts","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"Departments","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"EnrollmentAccounts","locations":[],"apiVersions":["2018-03-31"],"capabilities":"None"},{"resourceType":"Views","locations":[],"apiVersions":["2019-11-01","2019-10-01","2019-04-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"ScheduledActions","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"CheckNameAvailability","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"Insights","locations":[],"apiVersions":["2020-08-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"fetchPrices","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"GenerateReservationDetailsReport","locations":[],"apiVersions":["2019-11-01"],"capabilities":"SupportsExtension"},{"resourceType":"ReservationDetailsOperationResults","locations":[],"apiVersions":["2019-11-01"],"capabilities":"SupportsExtension"},{"resourceType":"GenerateDetailedCostReport","locations":[],"apiVersions":["2020-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"OperationStatus","locations":[],"apiVersions":["2020-12-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"OperationResults","locations":[],"apiVersions":["2020-12-01-preview"],"capabilities":"SupportsExtension"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CostManagementExports","namespace":"Microsoft.CostManagementExports","authorizations":[{"applicationId":"e5408ad0-c4e2-43aa-b6f2-3b4951286d99","roleDefinitionId":"5e4888b3-2747-4e5b-9897-ec0865b91bcf"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2019-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.CustomerLockbox","namespace":"Microsoft.CustomerLockbox","authorizations":[{"applicationId":"a0551534-cfc9-4e1f-9a7a-65093b32bb38","roleDefinitionId":"114bcfb6-5524-4d80-948a-d8a9937bc3e5"},{"applicationId":"01fc33a7-78ba-4d2f-a4b7-768e336e890e"},{"applicationId":"d8c767ef-3e9a-48c4-aef9-562696539b39"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"},{"resourceType":"TenantOptedIn","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"},{"resourceType":"EnableLockbox","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"},{"resourceType":"DisableLockbox","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"},{"resourceType":"requests","locations":[],"apiVersions":["2018-02-28-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.D365CustomerInsights","namespace":"Microsoft.D365CustomerInsights","resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-06-10-privatepreview","2020-06-10-preview","2020-06-10-beta"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataCatalog","namespace":"Microsoft.DataCatalog","authorization":{"applicationId":"213f5f78-fb30-46c7-9e98-91c720a1c026","roleDefinitionId":"D55E2225-A6AB-481C-A5BE-1B7687C293FA"},"resourceTypes":[{"resourceType":"catalogs","locations":["East US","West US","Australia East","West Europe","North Europe","Southeast Asia","West Central US"],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"checkNameAvailability","locations":["West Europe"],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West Europe"],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/jobs","locations":["East US","West US","Australia East","West Europe","North Europe","Southeast Asia","West - Central US"],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataCollaboration","namespace":"Microsoft.DataCollaboration","authorization":{"applicationId":"2cc451ba-a8ec-496f-bdff-591f5ae2876c","roleDefinitionId":"fdf757e9-19df-4152-a1ae-5e719161cd12"},"resourceTypes":[{"resourceType":"listinvitations","locations":["Australia - East","East US"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia - East"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Australia - East","East US"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations/reject","locations":["Australia - East","East US"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations","locations":["Australia - East","East US"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Australia + Central US"],"apiVersions":["2016-03-30","2015-07-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataCollaboration","namespace":"Microsoft.DataCollaboration","authorization":{"applicationId":"2cc451ba-a8ec-496f-bdff-591f5ae2876c","roleDefinitionId":"fdf757e9-19df-4152-a1ae-5e719161cd12"},"resourceTypes":[{"resourceType":"listinvitations","locations":["East + US","Australia East","West US 2","UK South","Southeast Asia","East US 2","West + Europe"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Australia + East"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East + US","Australia East","Southeast Asia"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations/reject","locations":["East + US","Australia East","West US 2","UK South","Southeast Asia","East US 2","West + Europe"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"locations/consumerInvitations","locations":["East + US","Australia East","West US 2","UK South","Southeast Asia","East US 2","West + Europe"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Australia East"],"apiVersions":["2020-05-04-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DataProtection","namespace":"Microsoft.DataProtection","resourceTypes":[{"resourceType":"BackupVaults","locations":["South - Central US","East US","East US 2","West US"],"apiVersions":["2020-01-01-alpha"],"capabilities":"SystemAssignedResourceIdentity, - SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South - Central US","East US","East US 2","West US"],"apiVersions":["2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["South - Central US","East US","East US 2","West US"],"apiVersions":["2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["South - Central US","East US","East US 2","West US"],"apiVersions":["2020-01-01-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DeploymentManager","namespace":"Microsoft.DeploymentManager","authorizations":[{"applicationId":"5b306cba-9c71-49db-96c3-d17ca2379c4d"}],"resourceTypes":[{"resourceType":"artifactSources","locations":["Central + Central US","East US","East US 2","West US","UK South","Australia Central","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + US","East Asia","France Central","Germany West Central","Central India","South + India","West India","Japan East","Japan West","Korea Central","Korea South","North + Central US","North Europe","Norway East","South Africa North","Southeast Asia","Switzerland + North","UAE North","UK West","West Central US","West Europe","West US 2"],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["South + Central US","East US","East US 2","West US","UK South","Australia Central","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + US","East Asia","France Central","Germany West Central","Central India","South + India","West India","Japan East","Japan West","Korea Central","Korea South","North + Central US","North Europe","Norway East","South Africa North","Southeast Asia","Switzerland + North","UAE North","UK West","West Central US","West Europe","West US 2"],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/operationStatus","locations":["South + Central US","East US","East US 2","West US","UK South","Australia Central","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + US","East Asia","France Central","Germany West Central","Central India","South + India","West India","Japan East","Japan West","Korea Central","Korea South","North + Central US","North Europe","Norway East","South Africa North","Southeast Asia","Switzerland + North","UAE North","UK West","West Central US","West Europe","West US 2"],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["South + Central US","East US","East US 2","West US","UK South","Australia Central","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + US","East Asia","France Central","Germany West Central","Central India","South + India","West India","Japan East","Japan West","Korea Central","Korea South","North + Central US","North Europe","Norway East","South Africa North","Southeast Asia","Switzerland + North","UAE North","UK West","West Central US","West Europe","West US 2"],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"},{"resourceType":"locations/checkFeatureSupport","locations":["South + Central US","East US","East US 2","West US","UK South","Australia Central","Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + US","East Asia","France Central","Germany West Central","Central India","South + India","West India","Japan East","Japan West","Korea Central","Korea South","North + Central US","North Europe","Norway East","South Africa North","Southeast Asia","Switzerland + North","UAE North","UK West","West Central US","West Europe","West US 2"],"apiVersions":["2021-01-01","2020-01-01-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DeploymentManager","namespace":"Microsoft.DeploymentManager","authorizations":[{"applicationId":"5b306cba-9c71-49db-96c3-d17ca2379c4d"}],"resourceTypes":[{"resourceType":"artifactSources","locations":["Central US","East US","East US 2","West US","West US 2","West Central US","North Central US","South Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia @@ -6454,19 +7477,7 @@ interactions: South","France Central","France South","South Africa North","South Africa West"],"apiVersions":["2019-11-01-preview","2018-09-01-preview"],"defaultApiVersion":"2018-09-01-preview","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-09-01-preview"}],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operationResults","locations":["global"],"apiVersions":["2019-11-01-preview","2018-09-01-preview"],"defaultApiVersion":"2018-09-01-preview","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-09-01-preview"}],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2019-11-01-preview","2018-09-01-preview"],"defaultApiVersion":"2018-09-01-preview","apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2018-09-01-preview"}],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DeviceUpdate","namespace":"Microsoft.DeviceUpdate","authorizations":[{"applicationId":"6ee392c4-d339-4083-b04d-6b7947c6cf78","roleDefinitionId":"a7c9caf5-ee6d-4cdd-94e0-917c34a027ec"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["East - US 2 EUAP","West US 2","West US","West Europe","Southeast Asia","East US","North - Europe","East Asia"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DigitalTwins","namespace":"Microsoft.DigitalTwins","authorizations":[{"applicationId":"0b07f429-9f4b-4714-9392-cc5e8e80c8b0"},{"applicationId":"c115998b-3d59-49b4-b55b-042a9ba1dbfe","roleDefinitionId":"07af60d1-cd6d-4ad4-9b56-ece6c78a3fe1"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-03-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"None"},{"resourceType":"locations/checkNameAvailability","locations":["West - Central US","West US 2","North Europe","Australia East","West Europe","East - US"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"digitalTwinsInstances","locations":["West - Central US","West US 2","North Europe","Australia East","West Europe","East - US"],"apiVersions":["2020-03-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"digitalTwinsInstances/operationResults","locations":["West - Central US","West US 2","North Europe","Australia East","West Europe","East - US"],"apiVersions":["2020-03-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"None"},{"resourceType":"digitalTwinsInstances/endpoints","locations":["West - Central US","West US 2","North Europe","Australia East","West Europe","East - US"],"apiVersions":["2020-03-01-preview"],"defaultApiVersion":"2020-03-01-preview","capabilities":"None"},{"resourceType":"operations","locations":["West - Central US"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.DomainRegistration","namespace":"Microsoft.DomainRegistration","authorization":{"applicationId":"ea2f600a-4980-45b7-89bf-d34da487bda1","roleDefinitionId":"54d7f2e3-5040-48a7-ae90-eebf629cfa0b"},"resourceTypes":[{"resourceType":"domains","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"domains/domainOwnershipIdentifiers","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"topLevelDomains","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"checkDomainAvailability","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"listDomainRecommendations","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"validateDomainRegistrationInformation","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"generateSsoRequest","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2020-06-01","2019-08-01","2018-02-01","2015-04-01","2015-02-01"],"apiProfiles":[{"profileVersion":"2017-03-09-profile","apiVersion":"2018-02-01"},{"profileVersion":"2018-03-01-hybrid","apiVersion":"2018-02-01"},{"profileVersion":"2018-06-01-profile","apiVersion":"2018-02-01"}],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.EnterpriseKnowledgeGraph","namespace":"Microsoft.EnterpriseKnowledgeGraph","resourceTypes":[{"resourceType":"services","locations":["East + US 2 EUAP","West US","West US 2","North Europe","Southeast Asia"],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-03-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Diagnostics","namespace":"Microsoft.Diagnostics","authorizations":[{"applicationId":"5b534afd-fdc0-4b38-a77f-af25442e3149","roleDefinitionId":"27d9fedd-5b4c-44b5-a9da-724fa33445c8"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-07-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.EnterpriseKnowledgeGraph","namespace":"Microsoft.EnterpriseKnowledgeGraph","resourceTypes":[{"resourceType":"services","locations":["East Asia","Southeast Asia","East US","East US 2","West US 2","West US","North Europe","West Europe"],"apiVersions":["2018-12-03"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["East @@ -6475,17 +7486,18 @@ interactions: Asia","Southeast Asia","East US","East US 2","West US 2","West US","North Europe","West Europe"],"apiVersions":["2018-12-03"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East Asia","Southeast Asia","East US","East US 2","West US 2","West US","North - Europe","West Europe"],"apiVersions":["2018-12-03"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Experimentation","namespace":"Microsoft.Experimentation","authorizations":[{"applicationId":"e00d2f8a-f6c8-46e4-b379-e66082e28ca8","roleDefinitionId":"d3a360d9-17f9-410e-9465-5c914c8cf570","managedByRoleDefinitionId":"fa096ccd-4e8f-49de-9594-64449b3ac6b3"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2019-11-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West + Europe","West Europe"],"apiVersions":["2018-12-03"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Experimentation","namespace":"Microsoft.Experimentation","authorizations":[{"applicationId":"e00d2f8a-f6c8-46e4-b379-e66082e28ca8","roleDefinitionId":"d3a360d9-17f9-410e-9465-5c914c8cf570","managedByRoleDefinitionId":"fa096ccd-4e8f-49de-9594-64449b3ac6b3"},{"applicationId":"b998f6f8-79d0-4b6a-8c25-5791dbe49ad0","roleDefinitionId":"69e94dda-0a4a-440b-b24e-21880bdd5174"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2019-11-01-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West + US 2"],"apiVersions":["2019-11-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West US 2"],"apiVersions":["2019-11-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ExtendedLocation","namespace":"Microsoft.ExtendedLocation","authorizations":[{"applicationId":"bc313c14-388c-4e7d-a58e-70017303ee3b","roleDefinitionId":"a775b938-2819-4dd0-8067-01f6e3b06392"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-07-15-privatepreview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-07-15-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Falcon","namespace":"Microsoft.Falcon","authorizations":[],"resourceTypes":[{"resourceType":"namespaces","locations":["West US"],"apiVersions":["2020-01-20-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features","namespace":"Microsoft.Features","resourceTypes":[{"resourceType":"features","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"},{"resourceType":"providers","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"},{"resourceType":"featureProviders","locations":[],"apiVersions":["2020-09-01","2020-01-01"],"capabilities":"None"},{"resourceType":"subscriptionFeatureRegistrations","locations":[],"apiVersions":["2020-09-01","2020-01-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HanaOnAzure","namespace":"Microsoft.HanaOnAzure","authorization":{"applicationId":"cc5476ec-3074-44d1-8461-711f5d9b0e39","roleDefinitionId":"4a10987e-dbcf-4c3d-8e3d-7ddcd9c771c2","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},"resourceTypes":[{"resourceType":"hanaInstances","locations":["West + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features","namespace":"Microsoft.Features","resourceTypes":[{"resourceType":"features","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"},{"resourceType":"providers","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"},{"resourceType":"featureProviders","locations":[],"apiVersions":["2020-09-01","2020-01-01"],"capabilities":"None"},{"resourceType":"subscriptionFeatureRegistrations","locations":[],"apiVersions":["2020-09-01","2020-01-01"],"capabilities":"None"},{"resourceType":"featureProviderNamespaces","locations":[],"apiVersions":["2020-09-01"],"capabilities":"None"},{"resourceType":"featureConfigurations","locations":[],"apiVersions":["2020-09-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2015-12-01","2014-08-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HanaOnAzure","namespace":"Microsoft.HanaOnAzure","authorization":{"applicationId":"cc5476ec-3074-44d1-8461-711f5d9b0e39","roleDefinitionId":"4a10987e-dbcf-4c3d-8e3d-7ddcd9c771c2","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"},"resourceTypes":[{"resourceType":"hanaInstances","locations":["West US","West US 2","East US","East US 2","West Europe","North Europe","Japan - East","Japan West","Australia East","Australia Southeast","South Central US"],"apiVersions":["2017-11-03-preview"],"capabilities":"SupportsTags, + East","Australia East","Australia Southeast","South Central US"],"apiVersions":["2017-11-03-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"sapMonitors","locations":["West US","West US 2","East US","East US 2","West Europe","North Europe","Japan East","Japan West","Australia East","Australia Southeast","Southeast Asia","South Central - US","UK South"],"apiVersions":["2017-11-03-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/operationsStatus","locations":["West + US","UK South"],"apiVersions":["2020-02-07-preview","2017-11-03-preview"],"defaultApiVersion":"2020-02-07-preview","capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/operationsStatus","locations":["West US","West US 2","East US","East US 2","West Europe","North Europe","Japan East","Japan West","Australia East","Australia Southeast","Southeast Asia","South Central US","UK South"],"apiVersions":["2017-11-03-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2017-11-03-preview"],"capabilities":"None"},{"resourceType":"locations/operations","locations":["West @@ -6498,79 +7510,49 @@ interactions: US","East US 2","South Central US","West US","East Asia","Southeast Asia","North Europe","West Europe","Canada Central","Canada East","UK South","UK West","Australia East","Australia Southeast","West US 2","South India","Central India","Japan - East","Japan West","Switzerland North","Switzerland West"],"apiVersions":["2018-10-31-preview","2018-10-31"],"defaultApiVersion":"2018-10-31","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridData","namespace":"Microsoft.HybridData","authorization":{"applicationId":"621269cf-1195-44a3-a835-c613d103dd15","roleDefinitionId":"00320cd4-8823-47f2-bbe4-5c9da031311d"},"resourceTypes":[{"resourceType":"dataManagers","locations":["West + East","Japan West","Switzerland North","Switzerland West"],"apiVersions":["2018-10-31-preview","2018-10-31"],"defaultApiVersion":"2018-10-31","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HealthBot","namespace":"Microsoft.HealthBot","authorizations":[{"applicationId":"6db4d6bb-6649-4dc2-84b7-0b5c6894031e","roleDefinitionId":"d42334cd-b979-4a22-accc-650d0d157676"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2020-12-08"],"capabilities":"None"},{"resourceType":"Locations","locations":[],"apiVersions":["2020-12-08"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US","West Europe"],"apiVersions":["2020-12-08"],"capabilities":"None"},{"resourceType":"healthBots","locations":["East + US","West Europe"],"apiVersions":["2020-12-08"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridData","namespace":"Microsoft.HybridData","authorization":{"applicationId":"621269cf-1195-44a3-a835-c613d103dd15","roleDefinitionId":"00320cd4-8823-47f2-bbe4-5c9da031311d"},"resourceTypes":[{"resourceType":"dataManagers","locations":["West US","North Europe","West Europe","East US","West US 2","West Central US","Southeast Asia"],"apiVersions":["2019-06-01","2016-06-01"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2019-06-01","2016-06-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridNetwork","namespace":"Microsoft.HybridNetwork","authorizations":[{"applicationId":"b8ed041c-aa91-418e-8f47-20c70abc2de1","roleDefinitionId":"b193432e-9b7e-4885-b2c0-052afdceace3"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["East - US 2 EUAP","West Central US"],"apiVersions":["2020-01-01-preview","2019-10-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IndustryDataLifecycle","namespace":"Microsoft.IndustryDataLifecycle","authorizations":[{"applicationId":"3072002f-3e97-4979-91f2-09fe40da755d"}],"resourceTypes":[{"resourceType":"custodianCollaboratives/termsOfUseDocuments","locations":["West + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2019-06-01","2016-06-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.HybridNetwork","namespace":"Microsoft.HybridNetwork","authorizations":[{"applicationId":"b8ed041c-aa91-418e-8f47-20c70abc2de1","roleDefinitionId":"b193432e-9b7e-4885-b2c0-052afdceace3"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"Locations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US 2 EUAP","West Central US","East US"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IndustryDataLifecycle","namespace":"Microsoft.IndustryDataLifecycle","authorizations":[{"applicationId":"3072002f-3e97-4979-91f2-09fe40da755d","roleDefinitionId":"23694dec-6164-410e-b12d-691a3c92ae59"}],"resourceTypes":[{"resourceType":"custodianCollaboratives/termsOfUseDocuments","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"defaultApiVersion":"2020-01-12-preview","capabilities":"None"},{"resourceType":"custodianCollaboratives/collaborativeImage","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"defaultApiVersion":"2020-01-12-preview","capabilities":"None"},{"resourceType":"custodianCollaboratives/invitations","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"custodianCollaboratives/invitations/termsOfUseDocuments","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"memberCollaboratives","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"defaultApiVersion":"2020-01-12-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"collaborativeInvitations","locations":["West + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"collaborativeInvitations","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"locations/rejectInvitation","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"locations/downloadInvitationFile","locations":["West - Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"dataproviders","locations":[],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"dataPackages","locations":[],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"memberCollaboratives/sharedDataPackages","locations":["West + Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"dataproviders","locations":[],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"locations/dataPackages","locations":["West + Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"memberCollaboratives/sharedDataPackages","locations":["West Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"custodianCollaboratives/receivedDataPackages","locations":["West - Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-01-12-preview"],"defaultApiVersion":"2020-01-12-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IoTCentral","namespace":"Microsoft.IoTCentral","authorizations":[{"applicationId":"9edfcdd9-0bc5-4bd4-b287-c3afc716aac7"}],"resourceTypes":[{"resourceType":"IoTApps","locations":["West - Europe","West US","East US 2","North Europe","East US","Central US","West - Central US","Australia","Asia Pacific","Europe","Japan","UK","United States"],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"checkSubdomainAvailability","locations":[],"apiVersions":["2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01","2017-07-01-privatepreview"],"defaultApiVersion":"2018-09-01","capabilities":"None"},{"resourceType":"appTemplates","locations":[],"apiVersions":["2018-09-01"],"defaultApiVersion":"2018-09-01","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IoTSpaces","namespace":"Microsoft.IoTSpaces","authorizations":[{"applicationId":"0b07f429-9f4b-4714-9392-cc5e8e80c8b0"}],"resourceTypes":[{"resourceType":"checkNameAvailability","locations":["North + Central US","East US 2"],"apiVersions":["2020-01-12-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-01-12-preview"],"defaultApiVersion":"2020-01-12-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IntelligentITDigitalTwin","namespace":"Microsoft.IntelligentITDigitalTwin","authorizations":[{"applicationId":"dfbed8b2-492a-414e-b2f0-482534e87bc5","roleDefinitionId":"0922588a-ac0c-4eb6-8d8f-afbeb8edf466"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2020-12-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IoTSecurity","namespace":"Microsoft.IoTSecurity","authorizations":[{"applicationId":"cfbd4387-1a16-4945-83c0-ec10e46cd4da","roleDefinitionId":"d5d6ff70-e29a-4cec-b30b-4bd7ebcdcbaa"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2021-02-01-preview"],"capabilities":"None"},{"resourceType":"defenderSettings","locations":[],"apiVersions":["2021-02-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.IoTSpaces","namespace":"Microsoft.IoTSpaces","authorizations":[{"applicationId":"0b07f429-9f4b-4714-9392-cc5e8e80c8b0"}],"resourceTypes":[{"resourceType":"checkNameAvailability","locations":["North Europe","West Europe","Australia East","West US 2","East US"],"apiVersions":["2017-10-01-preview"],"defaultApiVersion":"2017-10-01-preview","capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Graph","locations":["North Europe","West Europe","Australia East","West US 2","East US"],"apiVersions":["2017-10-01-preview"],"defaultApiVersion":"2017-10-01-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2017-10-01-preview"],"defaultApiVersion":"2017-10-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Kubernetes","namespace":"Microsoft.Kubernetes","authorizations":[{"applicationId":"64b12d6e-6549-484c-8cc6-6281839ba394","roleDefinitionId":"1d1d44cf-68a1-4def-a2b6-cd7efc3515af"},{"applicationId":"359431ad-ece5-496b-8768-be4bbfd82f36","roleDefinitionId":"1b5c71b7-9814-4b40-b62a-23018af874d8"}],"resourceTypes":[{"resourceType":"connectedClusters","locations":["East - US","West Europe"],"apiVersions":["2020-01-01-preview","2019-11-01-preview","2019-09-01-privatepreview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["East - US 2 EUAP","West Europe","East US"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-01-01-preview","2019-11-01-preview","2019-09-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.KubernetesConfiguration","namespace":"Microsoft.KubernetesConfiguration","authorizations":[{"applicationId":"c699bf69-fb1d-4eaf-999b-99e6b2ae4d85","roleDefinitionId":"90155430-a360-410f-af5d-89dc284d85c6"},{"applicationId":"03db181c-e9d3-4868-9097-f0b728327182","roleDefinitionId":"DE2ADB97-42D8-49C8-8FCF-DBB53EF936AC"},{"applicationId":"a0f92522-89de-4c5e-9a75-0044ccf66efd","roleDefinitionId":"b3429810-7d5c-420e-8605-cf280f3099f2"}],"resourceTypes":[{"resourceType":"sourceControlConfigurations","locations":["East - US","West Europe"],"apiVersions":["2019-11-01-preview"],"defaultApiVersion":"2019-11-01-preview","capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2020-07-01-preview","2019-11-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.LabServices","namespace":"Microsoft.LabServices","authorization":{"applicationId":"1a14be2a-e903-4cec-99cf-b2e209259a0f","roleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525","managedByRoleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525"},"resourceTypes":[{"resourceType":"labaccounts","locations":["West + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2017-10-01-preview"],"defaultApiVersion":"2017-10-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.KubernetesConfiguration","namespace":"Microsoft.KubernetesConfiguration","authorizations":[{"applicationId":"c699bf69-fb1d-4eaf-999b-99e6b2ae4d85","roleDefinitionId":"90155430-a360-410f-af5d-89dc284d85c6"},{"applicationId":"03db181c-e9d3-4868-9097-f0b728327182","roleDefinitionId":"DE2ADB97-42D8-49C8-8FCF-DBB53EF936AC"},{"applicationId":"a0f92522-89de-4c5e-9a75-0044ccf66efd","roleDefinitionId":"b3429810-7d5c-420e-8605-cf280f3099f2"}],"resourceTypes":[{"resourceType":"sourceControlConfigurations","locations":["East + US","West Europe","West Central US","West US 2","South Central US","East US + 2","North Europe","UK South","Southeast Asia","Australia East"],"apiVersions":["2021-03-01","2020-10-01-preview","2020-07-01-preview","2019-11-01-preview"],"defaultApiVersion":"2021-03-01","capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2021-03-01","2020-10-01-preview","2020-07-01-preview","2019-11-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.LabServices","namespace":"Microsoft.LabServices","authorization":{"applicationId":"1a14be2a-e903-4cec-99cf-b2e209259a0f","roleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525","managedByRoleDefinitionId":"8f2de81a-b9aa-49d8-b24c-11814d3ab525"},"resourceTypes":[{"resourceType":"labaccounts","locations":["West Central US","Japan East","West US","Australia Southeast","Australia Central","Canada Central","Central India","Central US","East Asia","Korea Central","North Europe","South Africa North","South Central US","Switzerland North","UK West","West India","Australia East","Australia Central 2","Brazil South","Canada East","East US","East US 2","France Central","France South","Japan West","Korea South","North Central US","South India","Southeast Asia","Switzerland West","UK South","West Europe","West - US 2"],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations/operations","locations":["West + US 2"],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"locations/operations","locations":["West Central US","Japan East","West US","Australia Southeast","Australia Central","Canada Central","Central India","Central US","East Asia","Korea Central","North Europe","South Africa North","South Central US","Switzerland North","UK West","West India","Australia East","Australia Central 2","Brazil South","Canada East","East US","East US 2","France Central","France South","Japan West","Korea South","North Central US","South India","Southeast Asia","Switzerland West","UK South","West Europe","West - US 2"],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"},{"resourceType":"users","locations":[],"apiVersions":["2019-01-01-preview","2019-01-01-beta","2019-01-01-alpha","2018-10-15","2017-12-01-preview","2017-12-01-beta","2017-12-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Maintenance","namespace":"Microsoft.Maintenance","authorization":{"applicationId":"f18474f2-a66a-4bb0-a3c9-9b8d892092fa","roleDefinitionId":"2f1ef7b0-d5c4-4d3c-98fa-6a9fa8e74aa5"},"resourceTypes":[{"resourceType":"maintenanceConfigurations","locations":["Central - US","East US","East US 2","West US","West US 2","West Central US","North Central - US","South Central US","North Europe","West Europe","East Asia","Southeast - Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia - Central","Australia Central 2","South Africa North","South Africa West","Brazil - South","South India","Central India","West India","Canada Central","Canada - East","UK South","UK West","Korea Central","Korea South","France Central","France - South"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"updates","locations":["Central - US","East US","East US 2","West US","West US 2","West Central US","North Central - US","South Central US","North Europe","West Europe","East Asia","Southeast - Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia - Central","Australia Central 2","South Africa North","South Africa West","Brazil - South","South India","Central India","West India","Canada Central","Canada - East","UK South","UK West","Korea Central","Korea South","France Central","France - South"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"configurationAssignments","locations":["Central - US","East US","East US 2","West US","West US 2","West Central US","North Central - US","South Central US","North Europe","West Europe","East Asia","Southeast - Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia - Central","Australia Central 2","South Africa North","South Africa West","Brazil - South","South India","Central India","West India","Canada Central","Canada - East","UK South","UK West","Korea Central","Korea South","France Central","France - South"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"applyUpdates","locations":["Central - US","East US","East US 2","West US","West US 2","West Central US","North Central - US","South Central US","North Europe","West Europe","East Asia","Southeast - Asia","Japan East","Japan West","Australia East","Australia Southeast","Australia - Central","Australia Central 2","South Africa North","South Africa West","Brazil - South","South India","Central India","West India","Canada Central","Canada - East","UK South","UK West","Korea Central","Korea South","France Central","France - South"],"apiVersions":["2020-07-01-preview","2020-04-01","2018-10-01","2018-06-01-preview","2017-04-26","2017-01-01","2016-01-01"],"capabilities":"SupportsExtension"},{"resourceType":"publicMaintenanceConfigurations","locations":[],"apiVersions":["2020-07-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Marketplace","namespace":"Microsoft.Marketplace","authorizations":[{"applicationId":"a0e1e353-1a3e-42cf-a8ea-3a9746eec58c"},{"applicationId":"a5ce81bb-67c7-4043-952a-22004782adb5"}],"resourceTypes":[{"resourceType":"register","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"},{"resourceType":"privategalleryitems","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"products","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"offers","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"macc","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/configs","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/configs/importImage","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/agreements","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"listAvailableOffers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"publishers","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"publishers/offers","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"publishers/offers/amendments","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"privateStoreClient","locations":[],"apiVersions":["2018-08-01-beta","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"privateStores","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"},{"resourceType":"privateStores/offers","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MarketplaceApps","namespace":"Microsoft.MarketplaceApps","resourceTypes":[{"resourceType":"classicDevServices","locations":["Northwest + US 2"],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"},{"resourceType":"users","locations":[],"apiVersions":["2019-01-01-preview","2019-01-01-beta","2019-01-01-alpha","2018-10-15","2017-12-01-preview","2017-12-01-beta","2017-12-01-alpha"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-01-01-preview","2018-10-15","2017-12-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Marketplace","namespace":"Microsoft.Marketplace","authorizations":[{"applicationId":"a0e1e353-1a3e-42cf-a8ea-3a9746eec58c"},{"applicationId":"87df0fbf-e22d-4d7c-bc30-f59ca7460837"},{"applicationId":"a5ce81bb-67c7-4043-952a-22004782adb5"}],"resourceTypes":[{"resourceType":"register","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"},{"resourceType":"privategalleryitems","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"products","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"offers","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"macc","locations":[],"apiVersions":["2018-08-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/configs","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/configs/importImage","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"offerTypes/publishers/offers/plans/agreements","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"listAvailableOffers","locations":[],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"publishers","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"publishers/offers","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"publishers/offers/amendments","locations":[],"apiVersions":["2019-06-30-preview"],"capabilities":"None"},{"resourceType":"privateStoreClient","locations":[],"apiVersions":["2018-08-01-beta","2018-03-01-beta"],"capabilities":"None"},{"resourceType":"privateStores","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"},{"resourceType":"privateStores/offers","locations":[],"apiVersions":["2020-01-01"],"capabilities":"None"},{"resourceType":"privateStores/requestApprovals/query","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"privateStores/requestApprovals/withdrawPlan","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"privateStores/RequestApprovals","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"privateStores/queryNotificationsState","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"privateStores/offers/acknowledgeNotification","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"},{"resourceType":"privateStores/AdminRequestApprovals","locations":[],"apiVersions":["2020-12-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.MarketplaceApps","namespace":"Microsoft.MarketplaceApps","resourceTypes":[{"resourceType":"classicDevServices","locations":["Northwest US","East Asia","Southeast Asia","East US","East US 2","West US","West US 2","North Central US","South Central US","West Central US","Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia @@ -6579,14 +7561,29 @@ interactions: Central US","West US"],"apiVersions":["2015-06-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2015-06-01"],"capabilities":"None"},{"resourceType":"offertypes","locations":["South Central US","West US"],"apiVersions":["2015-06-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ObjectStore","namespace":"Microsoft.ObjectStore","resourceTypes":[{"resourceType":"osNamespaces","locations":["West US"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Portal","namespace":"Microsoft.Portal","resourceTypes":[{"resourceType":"dashboards","locations":["Central + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.OpenLogisticsPlatform","namespace":"Microsoft.OpenLogisticsPlatform","authorizations":[{"applicationId":"3bc3fbf6-023a-4d86-bd09-bac559ccc9cc","roleDefinitionId":"38f09e57-663e-42b8-9db9-7d9e5138d5e4"}],"resourceTypes":[{"resourceType":"Locations","locations":["West + US"],"apiVersions":["2020-06-23-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US 2 EUAP","West Central US"],"apiVersions":["2020-06-23-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-06-23-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-06-23-preview"],"capabilities":"None"},{"resourceType":"shareInvites","locations":["East + US 2 EUAP","West Central US"],"apiVersions":["2020-06-23-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Portal","namespace":"Microsoft.Portal","resourceTypes":[{"resourceType":"dashboards","locations":["Central US","East Asia","Southeast Asia","East US","East US 2","West US","West US 2","North Central US","South Central US","West Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia Southeast","Australia East","West India","South India","Central India","Canada Central","Canada East","UK South","UK West","Korea Central","Korea South","France Central","South - Africa North"],"apiVersions":["2019-01-01-preview","2018-10-01-preview","2015-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["Central + Africa North","Switzerland West","Switzerland North"],"apiVersions":["2020-09-01-preview","2020-09-01-alpha","2019-01-01-preview","2018-10-01-preview","2015-08-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"tenantconfigurations","locations":["Central + US","East Asia","Southeast Asia","East US","East US 2","West US","West US + 2","North Central US","South Central US","West Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia Southeast","Australia + East","West India","South India","Central India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","Switzerland West","Switzerland North"],"apiVersions":["2020-09-01-preview","2019-01-01-preview"],"capabilities":"None"},{"resourceType":"listTenantConfigurationViolations","locations":["Central + US","East Asia","Southeast Asia","East US","East US 2","West US","West US + 2","North Central US","South Central US","West Central US","North Europe","West + Europe","Japan East","Japan West","Brazil South","Australia Southeast","Australia + East","West India","South India","Central India","Canada Central","Canada + East","UK South","UK West","Korea Central","Korea South","France Central","South + Africa North","Switzerland West","Switzerland North"],"apiVersions":["2020-09-01-preview","2019-01-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Central US","East Asia","Southeast Asia","East US","East US 2","West US","West US 2","North Central US","South Central US","West Central US","North Europe","West Europe","Japan East","Japan West","Brazil South","Australia Southeast","Australia @@ -6604,30 +7601,42 @@ interactions: Europe","Brazil South","Southeast Asia","Australia Southeast","Canada Central","Japan East","UK South","West India"],"apiVersions":["2016-01-29"],"defaultApiVersion":"2016-01-29","capabilities":"None"},{"resourceType":"privateLinkServicesForPowerBI","locations":["global"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"privateLinkServicesForPowerBI/operationResults","locations":["global"],"apiVersions":["2020-06-01"],"defaultApiVersion":"2020-06-01","capabilities":"None"},{"resourceType":"operations","locations":["East - US 2 EUAP"],"apiVersions":["2020-06-01","2016-01-29"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PowerPlatform","namespace":"Microsoft.PowerPlatform","authorization":{"applicationId":"e64bd61e-5424-451f-b666-e02ee2878437","roleDefinitionId":"51598b27-f396-476b-b212-90d7da526159"},"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ProjectBabylon","namespace":"Microsoft.ProjectBabylon","authorizations":[{"applicationId":"73c2949e-da2d-457a-9607-fcc665198967","roleDefinitionId":"1BC09725-0C9B-4F57-A3D0-FCCF4EB40120"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2019-10-01-preview"],"defaultApiVersion":"2019-10-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ProviderHub","namespace":"Microsoft.ProviderHub","resourceTypes":[{"resourceType":"providerRegistrations","locations":[],"apiVersions":["2019-02-01-preview"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2019-10-01"],"capabilities":"None"},{"resourceType":"providerRegistrations/resourceTypeRegistrations","locations":[],"apiVersions":["2020-06-01-preview","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"providerRegistrations/defaultRollouts","locations":[],"apiVersions":["2019-02-01-preview"],"capabilities":"None"},{"resourceType":"rollouts","locations":[],"apiVersions":["2019-02-01-preview"],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"availableAccounts","locations":[],"apiVersions":["2019-02-01-preview","2018-11-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Quantum","namespace":"Microsoft.Quantum","authorizations":[{"applicationId":"a77d91dc-971b-4cf7-90c8-f183194249bc","roleDefinitionId":"915bd376-2da8-411d-9906-895a54086a66"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"Locations","locations":["West - US"],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West - US","East US 2 EUAP"],"apiVersions":["2019-11-04-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.RedHatOpenShift","namespace":"Microsoft.RedHatOpenShift","authorizations":[{"applicationId":"f1dd0a37-89c6-4e07-bcd1-ffd3d43d8875","roleDefinitionId":"640c5ac9-6f32-4891-94f4-d20f7aa9a7e6","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"allowManagedByInheritance":true}}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-04-30","2019-12-31-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["Australia - East","Brazil South","Canada Central","Canada East","Central India","Central - US","East US","East US 2","France Central","Japan East","Japan West","Korea - Central","North Central US","North Europe","South Africa North","South Central - US","Southeast Asia","Switzerland North","UK South","UK West","West Europe","West + US 2 EUAP"],"apiVersions":["2020-06-01","2016-01-29"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.PowerPlatform","namespace":"Microsoft.PowerPlatform","authorization":{"applicationId":"e64bd61e-5424-451f-b666-e02ee2878437","roleDefinitionId":"51598b27-f396-476b-b212-90d7da526159"},"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ProjectBabylon","namespace":"Microsoft.ProjectBabylon","authorizations":[{"applicationId":"73c2949e-da2d-457a-9607-fcc665198967","roleDefinitionId":"1BC09725-0C9B-4F57-A3D0-FCCF4EB40120","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2019-10-01-preview"],"defaultApiVersion":"2019-10-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ProviderHub","namespace":"Microsoft.ProviderHub","resourceTypes":[{"resourceType":"providerRegistrations","locations":[],"apiVersions":["2020-11-20","2020-10-01-preview","2020-09-01-preview","2020-06-01-preview","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"operationStatuses","locations":[],"apiVersions":["2020-11-20","2020-06-01-preview","2019-10-01","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"providerRegistrations/resourceTypeRegistrations","locations":[],"apiVersions":["2020-11-20","2020-10-01-preview","2020-09-01-preview","2020-06-01-preview","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"providerRegistrations/defaultRollouts","locations":[],"apiVersions":["2020-11-20","2020-10-01-preview","2020-09-01-preview","2020-06-01-preview","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"providerRegistrations/customRollouts","locations":[],"apiVersions":["2020-11-20","2020-10-01-preview","2020-09-01-preview","2020-06-01-preview","2019-02-01-preview"],"capabilities":"None"},{"resourceType":"availableAccounts","locations":[],"apiVersions":["2020-06-01-preview","2019-02-01-preview","2018-11-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Purview","namespace":"Microsoft.Purview","authorizations":[{"applicationId":"73c2949e-da2d-457a-9607-fcc665198967","roleDefinitionId":"1BC09725-0C9B-4F57-A3D0-FCCF4EB40120","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635"}],"resourceTypes":[{"resourceType":"accounts","locations":["East + US","West Europe","Southeast Asia","Canada Central","South Central US","Brazil + South","East US 2"],"apiVersions":["2020-12-01-preview"],"defaultApiVersion":"2020-12-01-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"setDefaultAccount","locations":[],"apiVersions":["2020-12-01-preview"],"defaultApiVersion":"2020-12-01-preview","capabilities":"None"},{"resourceType":"removeDefaultAccount","locations":[],"apiVersions":["2020-12-01-preview"],"defaultApiVersion":"2020-12-01-preview","capabilities":"None"},{"resourceType":"getDefaultAccount","locations":[],"apiVersions":["2020-12-01-preview"],"defaultApiVersion":"2020-12-01-preview","capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-12-01-preview"],"defaultApiVersion":"2020-12-01-preview","capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["East + US","West Europe","Southeast Asia","Brazil South","Canada Central","South + Central US","East US 2"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Quantum","namespace":"Microsoft.Quantum","authorizations":[{"applicationId":"a77d91dc-971b-4cf7-90c8-f183194249bc","roleDefinitionId":"915bd376-2da8-411d-9906-895a54086a66"}],"resourceTypes":[{"resourceType":"Workspaces","locations":["West + US","East US","North Europe","West Europe","West US 2","West Central US"],"apiVersions":["2019-11-04-preview"],"defaultApiVersion":"2019-11-04-preview","capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, + SupportsLocation"},{"resourceType":"Operations","locations":[],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"Locations","locations":[],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West + US","East US","North Europe","West Europe","East US 2 EUAP","Central US EUAP","West + US 2","West Central US"],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"locations/offerings","locations":["West + US","East US","North Europe","West Europe","West US 2","West Central US"],"apiVersions":["2019-11-04-preview"],"capabilities":"None"},{"resourceType":"Locations/checkNameAvailability","locations":[],"apiVersions":["2019-11-04-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.RedHatOpenShift","namespace":"Microsoft.RedHatOpenShift","authorizations":[{"applicationId":"f1dd0a37-89c6-4e07-bcd1-ffd3d43d8875","roleDefinitionId":"640c5ac9-6f32-4891-94f4-d20f7aa9a7e6","managedByRoleDefinitionId":"9e3af657-a8ff-583c-a75c-2fe7c4bcb635","managedByAuthorization":{"allowManagedByInheritance":true}}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-04-30","2019-12-31-preview"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["Australia + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","France Central","Germany + West Central","Japan East","Japan West","Korea Central","North Central US","North + Europe","Norway East","South Africa North","South Central US","Southeast Asia","Switzerland + North","Switzerland West","UAE North","UK South","UK West","West Europe","West US 2","West US"],"apiVersions":["2020-04-30"],"capabilities":"None"},{"resourceType":"locations/operationsstatus","locations":["Australia - East","Brazil South","Canada Central","Canada East","Central India","Central - US","East US","East US 2","France Central","Japan East","Japan West","Korea - Central","North Central US","North Europe","South Africa North","South Central - US","Southeast Asia","Switzerland North","UK South","UK West","West Europe","West + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","France Central","Germany + West Central","Japan East","Japan West","Korea Central","North Central US","North + Europe","Norway East","South Africa North","South Central US","Southeast Asia","Switzerland + North","Switzerland West","UAE North","UK South","UK West","West Europe","West US 2","West US"],"apiVersions":["2020-04-30"],"capabilities":"None"},{"resourceType":"OpenShiftClusters","locations":["Australia - East","Brazil South","Canada Central","Canada East","Central India","Central - US","East US","East US 2","France Central","Japan East","Japan West","Korea - Central","North Central US","North Europe","South Africa North","South Central - US","Southeast Asia","Switzerland North","UK South","UK West","West Europe","West + East","Australia Southeast","Brazil South","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","France Central","Germany + West Central","Japan East","Japan West","Korea Central","North Central US","North + Europe","Norway East","South Africa North","South Central US","Southeast Asia","Switzerland + North","Switzerland West","UAE North","UK South","UK West","West Europe","West US 2","West US"],"apiVersions":["2020-04-30"],"defaultApiVersion":"2020-04-30","capabilities":"SystemAssignedResourceIdentity, - SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-04-30","2019-12-31-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ResourceGraph","namespace":"Microsoft.ResourceGraph","authorization":{"applicationId":"509e4652-da8d-478d-a730-e9d4a1996ca4"},"resourceTypes":[{"resourceType":"resources","locations":["East + SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-04-30","2019-12-31-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ResourceConnector","namespace":"Microsoft.ResourceConnector","authorizations":[{"applicationId":"585fc3c3-9a59-4720-8319-53cce041a605","roleDefinitionId":"008e7b93-7712-4d05-83ce-a9fcc80300e9"},{"applicationId":"d22ea4d1-2678-4a7b-aa5e-f340c2a7d993","roleDefinitionId":"7c812eee-67c9-4a05-a1b1-c0ac88fd1067"}],"resourceTypes":[{"resourceType":"locations","locations":[],"apiVersions":["2020-09-15-privatepreview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2021-02-01","2020-07-15-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ResourceGraph","namespace":"Microsoft.ResourceGraph","authorization":{"applicationId":"509e4652-da8d-478d-a730-e9d4a1996ca4"},"resourceTypes":[{"resourceType":"resources","locations":["East US"],"apiVersions":["2020-04-01-preview","2019-04-01","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"resourcesHistory","locations":["East - US"],"apiVersions":["2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"resourceChanges","locations":["East - US"],"apiVersions":["2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"resourceChangeDetails","locations":["East - US"],"apiVersions":["2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["East + US"],"apiVersions":["2020-09-01-preview","2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"resourceChanges","locations":["East + US"],"apiVersions":["2020-09-01-preview","2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"resourceChangeDetails","locations":["East + US"],"apiVersions":["2020-09-01-preview","2020-04-01-preview","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["East US"],"apiVersions":["2020-04-01-preview","2019-04-01","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"subscriptionsStatus","locations":["East US"],"apiVersions":["2019-04-01","2018-09-01-preview"],"capabilities":"None"},{"resourceType":"queries","locations":["global"],"apiVersions":["2018-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources","namespace":"Microsoft.Resources","authorization":{"applicationId":"3b990c8b-9607-4c2a-8b04-1d41985facca"},"resourceTypes":[{"resourceType":"tenants","locations":[],"apiVersions":["2020-01-01","2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"operationresults","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"notifyResourceJobs","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01"],"capabilities":"None"},{"resourceType":"tags","locations":[],"apiVersions":["2019-10-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01"],"capabilities":"SupportsExtension"},{"resourceType":"checkPolicyCompliance","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"capabilities":"None"},{"resourceType":"providers","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"checkresourcename","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"calculateTemplateHash","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"resources","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions","locations":[],"apiVersions":["2019-10-01","2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"subscriptions/resources","locations":[],"apiVersions":["2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/providers","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/operationresults","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"resourceGroups","locations":["Central @@ -6645,90 +7654,118 @@ interactions: East","UK South","UK West","Korea Central","Korea South","France Central","South Africa North","UAE North","Australia Central","Switzerland North","Germany West Central","Norway East"],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"SupportsTags, - SupportsLocation"},{"resourceType":"subscriptions/resourcegroups/resources","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/locations","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"subscriptions/tagnames","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/tagNames/tagValues","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"deployments","locations":[],"apiVersions":["2020-06-01","2019-09-01","2019-08-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"deployments/operations","locations":[],"apiVersions":["2020-06-01","2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"links","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2015-01-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-01-01"}],"capabilities":"None"},{"resourceType":"deploymentScripts","locations":["East + SupportsLocation"},{"resourceType":"subscriptions/resourcegroups/resources","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/locations","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2016-06-01"}],"capabilities":"None"},{"resourceType":"subscriptions/tagnames","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"subscriptions/tagNames/tagValues","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"deployments","locations":[],"apiVersions":["2020-10-01","2020-06-01","2019-09-01","2019-08-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"deployments/operations","locations":[],"apiVersions":["2020-10-01","2020-06-01","2019-09-01","2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"None"},{"resourceType":"links","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2016-06-01"},{"profileVersion":"2019-03-01-hybrid","apiVersion":"2018-05-01"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2015-01-01"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2015-01-01"}],"capabilities":"None"},{"resourceType":"bulkDelete","locations":[],"apiVersions":["2019-05-01","2019-04-01","2019-03-01","2018-11-01","2018-09-01","2018-08-01","2018-07-01","2018-05-01","2018-02-01","2018-01-01","2017-08-01","2017-06-01","2017-05-10","2017-05-01","2017-03-01","2016-09-01","2016-07-01","2016-06-01","2016-02-01","2015-11-01","2015-01-01","2014-04-01-preview"],"capabilities":"None"},{"resourceType":"deploymentScripts","locations":["East Asia","Southeast Asia","Australia East","Brazil South","Canada Central","East - US 2","East US","Central US","North Central US","UK South","Central India","South - India","Japan East","Korea Central","North Europe","West Central US","West - Europe","West US 2","West US","South Central US"],"apiVersions":["2019-10-01-preview"],"capabilities":"SupportsTags, + US 2","East US","Central US","North Central US","France Central","UK South","Central + India","South India","Japan East","Korea Central","North Europe","West Central + US","West Europe","West US 2","West US","South Central US"],"apiVersions":["2020-10-01","2019-10-01-preview"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"deploymentScripts/logs","locations":["East Asia","Southeast Asia","Australia East","Brazil South","Canada Central","East - US 2","East US","Central US","North Central US","UK South","Central India","South - India","Japan East","Korea Central","North Europe","West Central US","West - Europe","West US 2","West US","South Central US"],"apiVersions":["2019-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/deploymentScriptOperationResults","locations":["East + US 2","East US","Central US","North Central US","France Central","UK South","Central + India","South India","Japan East","Korea Central","North Europe","West Central + US","West Europe","West US 2","West US","South Central US"],"apiVersions":["2020-10-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"locations/deploymentScriptOperationResults","locations":["East Asia","Southeast Asia","Australia East","Brazil South","Canada Central","East - US 2","East US","Central US","North Central US","UK South","Central India","South - India","Japan East","Korea Central","North Europe","West Central US","West - Europe","West US 2","West US","South Central US"],"apiVersions":["2019-10-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SaaS","namespace":"Microsoft.SaaS","authorizations":[{"applicationId":"f738ef14-47dc-4564-b53b-45069484ccc7","roleDefinitionId":"b131dd2d-387a-4cae-bb9b-3d021f80d1e6"},{"applicationId":"20e940b3-4c77-4b0b-9a53-9e16a1b010a7"}],"resourceTypes":[{"resourceType":"applications","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"CrossResourceGroupResourceMove, - SupportsTags, SupportsLocation"},{"resourceType":"checknameavailability","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"checkModernEligibility","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"saasresources","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operationResults","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ScVmm","namespace":"Microsoft.ScVmm","authorizations":[],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-06-05-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East - US","West US 2","East US 2 EUAP"],"apiVersions":["2020-06-05-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-06-05-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SerialConsole","namespace":"Microsoft.SerialConsole","resourceTypes":[{"resourceType":"consoleServices","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"locations","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"locations/consoleServices","locations":["West - US 2","East US 2"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServiceFabricMesh","namespace":"Microsoft.ServiceFabricMesh","authorizations":[{"applicationId":"d10de03d-5ba3-497a-90e6-7ff8c9736059","roleDefinitionId":"BC13595A-E262-4621-929E-56FF90E6BF18"}],"resourceTypes":[{"resourceType":"applications","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + US 2","East US","Central US","North Central US","France Central","UK South","Central + India","South India","Japan East","Korea Central","North Europe","West Central + US","West Europe","West US 2","West US","South Central US"],"apiVersions":["2020-10-01","2019-10-01-preview"],"capabilities":"None"},{"resourceType":"templateSpecs","locations":["East + Asia","Southeast Asia","Australia East","Australia Central","Australia Central + 2","Australia Southeast","Brazil South","Canada Central","Canada East","Switzerland + North","Germany West Central","East US 2","East US","Central US","North Central + US","France Central","UK South","UK West","Central India","West India","South + India","Japan East","Japan West","Korea Central","Korea South","North Europe","Norway + East","UAE North","West Central US","West Europe","West US 2","West US","South + Central US","South Africa North"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"templateSpecs/versions","locations":["East + Asia","Southeast Asia","Australia East","Australia Central","Australia Central + 2","Australia Southeast","Brazil South","Canada Central","Canada East","Switzerland + North","Germany West Central","East US 2","East US","Central US","North Central + US","France Central","UK South","UK West","Central India","West India","South + India","Japan East","Japan West","Korea Central","Korea South","North Europe","Norway + East","UAE North","West Central US","West Europe","West US 2","West US","South + Central US","South Africa North"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SaaS","namespace":"Microsoft.SaaS","authorizations":[{"applicationId":"f738ef14-47dc-4564-b53b-45069484ccc7","roleDefinitionId":"b131dd2d-387a-4cae-bb9b-3d021f80d1e6"},{"applicationId":"20e940b3-4c77-4b0b-9a53-9e16a1b010a7"}],"resourceTypes":[{"resourceType":"applications","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"CrossResourceGroupResourceMove, + SupportsTags, SupportsLocation"},{"resourceType":"checknameavailability","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"checkModernEligibility","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"saasresources","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operationResults","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"operations","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"None"},{"resourceType":"resources","locations":["global"],"apiVersions":["2018-03-01-beta"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ScVmm","namespace":"Microsoft.ScVmm","authorizations":[{"applicationId":"319f651f-7ddb-4fc6-9857-7aef9250bd05","roleDefinitionId":"4fe6d683-8411-4247-8525-b6b5b8a80669"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-06-05-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US","West US 2","East US 2 EUAP","West Europe"],"apiVersions":["2020-06-05-preview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-06-05-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Search","namespace":"Microsoft.Search","authorization":{"applicationId":"408992c7-2af6-4ff1-92e3-65b73d2b5092","roleDefinitionId":"20FA3191-87CF-4C3D-9510-74CCB594A310"},"resourceTypes":[{"resourceType":"searchServices","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28","2014-07-31-Preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"networks","locations":["East US","East - US 2","West US","West US 2","South Central US","Central US","France Central","West - Europe","North Europe","UK South","UK West","Australia East","East Asia","Southeast - Asia","Korea Central","West India","Brazil South","Japan East","Norway East","South - Africa North","Switzerland North","Central India","UAE North","Germany West - Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"volumes","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"secrets","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"gateways","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/applicationOperations","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/networkOperations","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/volumeOperations","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/gatewayOperations","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"locations/secretOperations","locations":["East - US","East US 2","West US","West US 2","South Central US","Central US","France - Central","West Europe","North Europe","UK South","UK West","Australia East","East - Asia","Southeast Asia","Korea Central","West India","Brazil South","Japan - East","Norway East","South Africa North","Switzerland North","Central India","UAE - North","Germany West Central","North Central US"],"apiVersions":["2018-09-01-preview","2018-07-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-09-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServicesHub","namespace":"Microsoft.ServicesHub","authorizations":[{"applicationId":"9ed4cd8c-9a98-405f-966b-38ab1b0c24a3"}],"resourceTypes":[{"resourceType":"connectors","locations":["East - US"],"apiVersions":["2019-08-15-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"workspaces","locations":["East - US"],"apiVersions":["2019-08-15-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"supportOfferingEntitlement","locations":["East - US"],"apiVersions":["2019-08-15-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2019-08-15-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SoftwarePlan","namespace":"Microsoft.SoftwarePlan","resourceTypes":[{"resourceType":"hybridUseBenefits","locations":[],"apiVersions":["2019-06-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2019-06-01-preview"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2019-06-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorSimple","namespace":"Microsoft.StorSimple","resourceTypes":[{"resourceType":"managers","locations":["West + SupportsLocation"},{"resourceType":"checkServiceNameAvailability","locations":[],"apiVersions":["2015-02-28","2014-07-31-Preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"resourceHealthMetadata","locations":["Germany + West Central","Norway East","Switzerland West","Switzerland North","West US","West + US 2","East US","East US 2","North Europe","West Europe","Southeast Asia","East + Asia","North Central US","South Central US","Central US","Japan West","Japan + East","Korea Central","Australia East","Australia Southeast","Brazil South","Central + India","West Central US","Canada Central","UK South","France Central","South + Africa North","UAE North"],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2020-08-01-Preview","2020-08-01","2020-03-13","2019-10-01-Preview","2015-08-19","2015-02-28"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SecurityDetonation","namespace":"Microsoft.SecurityDetonation","authorizations":[{"applicationId":"29820072-374d-49b8-945a-3941d7e9b468","roleDefinitionId":"4ddf1807-30b0-464a-9d16-a8822daf866b"}],"resourceTypes":[{"resourceType":"operations","locations":["Australia + East","Australia Southeast","Australia Central 2","Central US","East US","East + US 2","West US","West US 2","North Central US","South Central US","West Central + US","East Asia","Southeast Asia","Brazil South","Japan East","Japan West","North + Europe","West Europe","Central India","South India","West India","Canada Central","Canada + East","UK West","UK South","Korea Central","Korea South","France Central","France + South","South Africa North","UAE North","Australia Central","Switzerland North","Germany + West Central","Norway East","South Africa West","UAE Central","Switzerland + West","Germany North","Norway West"],"apiVersions":["2020-07-01-preview","2019-08-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SerialConsole","namespace":"Microsoft.SerialConsole","resourceTypes":[{"resourceType":"consoleServices","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"serialPorts","locations":["Australia + Central","Australia East","Australia Southeast","Brazil South","Canada Central","Canada + East","Central India","Central US","East Asia","East US","East US 2","France + Central","Germany West Central","Japan East","Japan West","Korea Central","Korea + South","North Central US","North Europe","Norway East","South Africa North","South + Central US","Southeast Asia","South India","Switzerland North","UAE North","UK + South","UK West","West Central US","West Europe","West India","West US","West + US 2"],"apiVersions":["2018-05-01"],"capabilities":"SupportsExtension"},{"resourceType":"locations","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"locations/consoleServices","locations":["West + US 2","East US 2"],"apiVersions":["2018-05-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2018-05-01"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.ServicesHub","namespace":"Microsoft.ServicesHub","authorizations":[{"applicationId":"9ed4cd8c-9a98-405f-966b-38ab1b0c24a3"}],"resourceTypes":[{"resourceType":"connectors","locations":["Australia + East","Australia Southeast","Canada Central","Central India","Central US","East + Asia","East US","East US 2","France Central","Japan East","Korea Central","North + Europe","Southeast Asia","South Central US","UK South","West Central US","West + Europe","West US","West US 2"],"apiVersions":["2019-08-15-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"workspaces","locations":[],"apiVersions":["2019-08-15-preview"],"capabilities":"None"},{"resourceType":"supportOfferingEntitlement","locations":[],"apiVersions":["2019-08-15-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-08-15-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Singularity","namespace":"Microsoft.Singularity","authorizations":[{"applicationId":"349e15d0-1c96-4829-95e5-7fc8fb358ff3","roleDefinitionId":"da5c10f8-3b94-4076-bb95-1421b4518aee"}],"resourceTypes":[{"resourceType":"accounts","locations":["Central + US","South Central US","West Europe","West US 2","East US"],"apiVersions":["2020-12-01-preview"],"capabilities":"SupportsTags, + SupportsLocation"},{"resourceType":"accounts/storageContainers","locations":["Central + US","South Central US","West Europe","West US 2","East US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"accounts/accountQuotaPolicies","locations":["Central + US","South Central US","West Europe","West US 2","East US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"accounts/groupPolicies","locations":["Central + US","South Central US","West Europe","West US 2","East US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"accounts/jobs","locations":["Central + US","South Central US","West Europe","West US 2","East US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["Central + US","Australia Central","Australia East","Australia Southeast","Canada Central","Canada + East","Central India","East Asia","East US","East US 2","France Central","Germany + West Central","Japan East","Japan West","North Central US","North Europe","Norway + East","South Africa North","South Central US","South India","Southeast Asia","Switzerland + North","West Central US","West Europe","West India","West US","West US 2","UAE + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries","locations":["Central + US","South Central US","West Europe","Australia Central","Australia East","Australia + Southeast","Canada Central","Canada East","Central India","East Asia","East + US 2","France Central","Germany West Central","Japan East","Japan West","North + Central US","North Europe","Norway East","South Africa North","South India","Southeast + Asia","Switzerland North","West Central US","West India","West US","West US + 2","UAE North","UK West","UK South","Brazil South","Korea South","Korea Central","East + US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/instanceTypeSeries/instanceTypes","locations":["Central + US","South Central US","West Europe","Australia Central","Australia East","Australia + Southeast","Canada Central","Canada East","Central India","East Asia","East + US 2","France Central","Germany West Central","Japan East","Japan West","North + Central US","North Europe","Norway East","South Africa North","South India","Southeast + Asia","Switzerland North","West Central US","West India","West US","West US + 2","UAE North","UK West","UK South","Brazil South","Korea South","Korea Central","East + US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["Central + US","South Central US","West Europe","Australia Central","Australia East","Australia + Southeast","Canada Central","Canada East","Central India","East Asia","East + US 2","France Central","Germany West Central","Japan East","Japan West","North + Central US","North Europe","Norway East","South Africa North","South India","Southeast + Asia","Switzerland North","West Central US","West India","West US","West US + 2","UAE North","UK West","UK South","Brazil South","Korea South","Korea Central","East + US"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["Australia + Central","Australia East","Australia Southeast","Canada Central","Canada East","Central + India","Central US","East Asia","East US","East US 2","France Central","Germany + West Central","Japan East","Japan West","North Central US","North Europe","Norway + East","South Africa North","South Central US","South India","Southeast Asia","Switzerland + North","West Central US","West Europe","West India","West US","West US 2","UAE + North","UK West","UK South","Brazil South","Korea South","Korea Central"],"apiVersions":["2020-12-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.SoftwarePlan","namespace":"Microsoft.SoftwarePlan","resourceTypes":[{"resourceType":"hybridUseBenefits","locations":[],"apiVersions":["2019-06-01-preview"],"apiProfiles":[{"profileVersion":"2018-06-01-profile","apiVersion":"2019-06-01-preview"}],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":[],"apiVersions":["2019-06-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StoragePool","namespace":"Microsoft.StoragePool","authorizations":[{"applicationId":"5741a1ff-751d-4ad7-bcd1-dfe3c998fd11","roleDefinitionId":"3eef04c6-e880-42e9-aaef-6e04c508124c","managedByRoleDefinitionId":"7379b183-294f-4404-b062-f3b9a0f03f5a"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-03-15-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.StorSimple","namespace":"Microsoft.StorSimple","resourceTypes":[{"resourceType":"managers","locations":["West US","East US","North Europe","West Europe","Brazil South","East Asia","Southeast Asia","West Central US","Japan East","Japan West","Australia East","Australia - Southeast"],"apiVersions":["2017-06-01","2017-05-15","2017-01-01","2016-10-01","2016-06-01","2015-03-15","2014-09-01"],"capabilities":"SupportsTags, + Southeast"],"apiVersions":["2019-05-13","2017-06-01","2017-05-15","2017-01-01","2016-10-01","2016-06-01","2015-03-15","2014-09-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":["West Central - US","Southeast Asia"],"apiVersions":["2016-10-01","2016-06-01","2015-03-15","2014-09-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Subscription","namespace":"Microsoft.Subscription","authorizations":[{"applicationId":"e3335adb-5ca0-40dc-b8d3-bedc094e523b"},{"applicationId":"5da7367f-09c8-493e-8fd4-638089cddec3"}],"resourceTypes":[{"resourceType":"SubscriptionDefinitions","locations":["West + US","Southeast Asia"],"apiVersions":["2019-05-13","2016-10-01","2016-06-01","2015-03-15","2014-09-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Subscription","namespace":"Microsoft.Subscription","authorizations":[{"applicationId":"e3335adb-5ca0-40dc-b8d3-bedc094e523b"},{"applicationId":"5da7367f-09c8-493e-8fd4-638089cddec3"}],"resourceTypes":[{"resourceType":"SubscriptionDefinitions","locations":["West US"],"apiVersions":["2017-11-01-preview"],"capabilities":"None"},{"resourceType":"SubscriptionOperations","locations":["West US"],"apiVersions":["2019-10-01-preview","2018-11-01-preview","2018-03-01-preview","2017-11-01-preview"],"capabilities":"None"},{"resourceType":"CreateSubscription","locations":["Central US"],"apiVersions":["2019-10-01-preview","2018-11-01-preview","2018-03-01-preview"],"capabilities":"SupportsExtension"},{"resourceType":"operations","locations":["West @@ -6757,64 +7794,63 @@ interactions: Asia","East Asia","Australia East","Australia Southeast"],"apiVersions":["2020-04-01","2019-05-01-preview"],"capabilities":"None"}],"registrationState":"Registered","registrationPolicy":"RegistrationFree"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Synapse","namespace":"Microsoft.Synapse","authorizations":[{"applicationId":"9e09aefc-b2e5-4d19-9f74-3e3e8b11a57b","roleDefinitionId":"a53b114a-452b-4d20-bcd6-c51c3c8c5878","managedByRoleDefinitionId":"ede175bc-31e5-4074-ba98-e62b895797aa"},{"applicationId":"1ac05c7e-12d2-4605-bf9d-549d7041c6b3","roleDefinitionId":"48e77487-c9fa-4abe-8484-71ebdebdbbc2"},{"applicationId":"ec52d13d-2e85-410e-a89a-8c79fb6a32ac","roleDefinitionId":"c3a447c3-a63a-4905-a125-c6856f9d0e17"},{"applicationId":"5ebe1e69-13dd-4953-84fa-a74ed591db2e","roleDefinitionId":"e8ebe3e8-569b-4ad3-bea1-5b274fe0c49f"},{"applicationId":"2e458d69-0892-4655-b713-4f7b182315dd","roleDefinitionId":"45EA3B16-D4DD-48CA-BF0D-BBE644C0C0AF"}],"resourceTypes":[{"resourceType":"workspaces","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, SupportsLocation"},{"resourceType":"workspaces/bigDataPools","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"workspaces/sqlPools","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"workspaces/operationStatuses","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"workspaces/operationResults","locations":["West + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"workspaces/operationResults","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"checkNameAvailability","locations":[],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"privateLinkHubs","locations":["West + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"privateLinkHubs","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"locations","locations":[],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationResults","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["West + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationStatuses","locations":["West US 2","East US","North Europe","West Europe","Southeast Asia","Australia East","West Central US","South Central US","East US 2","UK South","West US","Australia - Southeast"],"apiVersions":["2019-06-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.TimeSeriesInsights","namespace":"Microsoft.TimeSeriesInsights","authorizations":[{"applicationId":"120d688d-1518-4cf7-bd38-182f158850b6","roleDefinitionId":"5a43abdf-bb87-42c4-9e56-1c24bf364150"}],"resourceTypes":[{"resourceType":"environments","locations":["France - Central","South Central Us","East US 2","West US","East US","North Europe","West - Europe","West US 2","Central US","Southeast Asia","Australia East","Australia - Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"environments/eventsources","locations":["France - Central","South Central Us","East US 2","West US","East US","North Europe","West - Europe","West US 2","Central US","Southeast Asia","Australia East","Australia - Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"environments/referenceDataSets","locations":["France - Central","South Central Us","East US 2","West US","East US","North Europe","West - Europe","West US 2","Central US","Southeast Asia","Australia East","Australia - Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"environments/accessPolicies","locations":["France - Central","South Central Us","East US 2","West US","East US","North Europe","West - Europe","West US 2","Central US","Southeast Asia","Australia East","Australia - Southeast","East Asia","UK West","UK South"],"apiVersions":["2020-05-15","2018-08-15-preview","2017-11-15","2017-02-28-preview"],"capabilities":"None"},{"resourceType":"operations","locations":["France - Central","South Central Us","East US 2","West US","East US","East US 2 EUAP","North - Europe","West Europe","Southeast Asia","Australia East","Australia Southeast","East - Asia","UK West","UK South","West US 2","Central US","West Central US","North - Central US"],"apiVersions":["2017-02-28-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Token","namespace":"Microsoft.Token","authorizations":[{"applicationId":"fe053c5f-3692-4f14-aef2-ee34fc081cae"}],"resourceTypes":[{"resourceType":"stores","locations":["Brazil - South","Central US","North Europe","Japan West","Australia Southeast","West - US","West Central US"],"apiVersions":["2018-08-01-preview"],"defaultApiVersion":"2018-08-01-preview","capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"stores/accessPolicies","locations":["Brazil - South","Central US","North Europe","Japan West","Australia Southeast","West - US","West Central US"],"apiVersions":["2018-08-01-preview"],"defaultApiVersion":"2018-08-01-preview","capabilities":"None"},{"resourceType":"stores/services","locations":["Brazil - South","Central US","North Europe","Japan West","Australia Southeast","West - US","West Central US"],"apiVersions":["2018-08-01-preview"],"defaultApiVersion":"2018-08-01-preview","capabilities":"None"},{"resourceType":"stores/services/tokens","locations":["Brazil - South","Central US","North Europe","Japan West","Australia Southeast","West - US","West Central US"],"apiVersions":["2018-08-01-preview"],"defaultApiVersion":"2018-08-01-preview","capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.visualstudio","namespace":"microsoft.visualstudio","authorization":{"applicationId":"499b84ac-1321-427f-aa17-267ca6975798","roleDefinitionId":"6a18f445-86f0-4e2e-b8a9-6b9b5677e3d8"},"resourceTypes":[{"resourceType":"account","locations":["North + Southeast","East Asia","Brazil South","Central US","Central India","Japan + East","North Central US","Canada Central","Canada East","Korea Central","South + Africa North","UK West","Japan West","France Central","Switzerland North","Germany + West Central"],"apiVersions":["2020-12-01","2019-06-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/microsoft.visualstudio","namespace":"microsoft.visualstudio","authorization":{"applicationId":"499b84ac-1321-427f-aa17-267ca6975798","roleDefinitionId":"6a18f445-86f0-4e2e-b8a9-6b9b5677e3d8"},"resourceTypes":[{"resourceType":"account","locations":["North Central US","South Central US","West Central US","East US","East US 2","West US","Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil South","Australia East","West India","Central India","South @@ -6837,8 +7873,9 @@ interactions: Central US","South Central US","West Central US","East US","East US 2","West US","Central US","North Europe","West Europe","East Asia","Southeast Asia","Japan East","Japan West","Brazil South","Australia East","West India","Central India","South - India","West US 2","Canada Central","UK South"],"apiVersions":["2014-04-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VMware","namespace":"Microsoft.VMware","authorizations":[{"applicationId":"ac9dc5fe-b644-4832-9d03-d9f1ab70c5f7","roleDefinitionId":"dd032bd9-65cc-4171-b688-c612566422ae"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2019-12-20-privatepreview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East - US","West US","East US 2 EUAP","West Europe"],"apiVersions":["2019-12-20-privatepreview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2019-12-20-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VMwareCloudSimple","namespace":"Microsoft.VMwareCloudSimple","authorizations":[{"applicationId":"d96199e7-4674-4bbf-a1c6-ddf93682f5ee","roleDefinitionId":"533012ca-a3e7-44e4-93b4-3143f8b9409d","allowedThirdPartyExtensions":[{"name":"CloudSimpleExtension"}]}],"resourceTypes":[{"resourceType":"virtualMachines","locations":["South + India","West US 2","Canada Central","UK South"],"apiVersions":["2014-04-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VMware","namespace":"Microsoft.VMware","authorizations":[{"applicationId":"ac9dc5fe-b644-4832-9d03-d9f1ab70c5f7","roleDefinitionId":"dd032bd9-65cc-4171-b688-c612566422ae"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-10-01-preview","2019-12-20-privatepreview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US","West US","East US 2 EUAP","West Europe"],"apiVersions":["2020-10-01-preview","2019-12-20-privatepreview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-10-01-preview","2019-12-20-privatepreview"],"capabilities":"None"},{"resourceType":"VCenters/InventoryItems","locations":["East + US","West US","West Europe"],"apiVersions":["2020-10-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VMwareCloudSimple","namespace":"Microsoft.VMwareCloudSimple","authorizations":[{"applicationId":"d96199e7-4674-4bbf-a1c6-ddf93682f5ee","roleDefinitionId":"533012ca-a3e7-44e4-93b4-3143f8b9409d","allowedThirdPartyExtensions":[{"name":"CloudSimpleExtension"}]}],"resourceTypes":[{"resourceType":"virtualMachines","locations":["South Central US","Switzerland North","Switzerland West","West Europe","East US","West US"],"apiVersions":["2019-04-01"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"dedicatedCloudNodes","locations":["South @@ -6861,37 +7898,60 @@ interactions: Central US","Switzerland North","Switzerland West","West Europe","East US","West US"],"apiVersions":["2019-04-01"],"capabilities":"None"},{"resourceType":"locations/operationresults","locations":["South Central US","Switzerland North","Switzerland West","West Europe","East US","West - US"],"apiVersions":["2019-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VnfManager","namespace":"Microsoft.VnfManager","authorizations":[{"applicationId":"b8ed041c-aa91-418e-8f47-20c70abc2de1","roleDefinitionId":"c8d69fc0-f0ed-43b3-bf1d-4dfdaacc6d2d"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations","locations":["East - US"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"},{"resourceType":"locations/operationstatuses","locations":["East - US","North Europe","East Asia","East US 2 EUAP"],"apiVersions":["2020-01-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VSOnline","namespace":"Microsoft.VSOnline","authorizations":[{"applicationId":"9bd5ab7f-4031-4045-ace9-6bebbad202f6","roleDefinitionId":"b879ac78-f1e6-448d-ab4c-5908cd5967c1"},{"applicationId":"48ef7923-268f-473d-bcf1-07f0997961f4","roleDefinitionId":"b879ac78-f1e6-448d-ab4c-5908cd5967c1"}],"resourceTypes":[{"resourceType":"accounts","locations":["West + US"],"apiVersions":["2019-04-01"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-04-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.VSOnline","namespace":"Microsoft.VSOnline","authorizations":[{"applicationId":"9bd5ab7f-4031-4045-ace9-6bebbad202f6","roleDefinitionId":"b879ac78-f1e6-448d-ab4c-5908cd5967c1"},{"applicationId":"48ef7923-268f-473d-bcf1-07f0997961f4","roleDefinitionId":"b879ac78-f1e6-448d-ab4c-5908cd5967c1"}],"resourceTypes":[{"resourceType":"accounts","locations":["West Europe","East US","West Us 2","Southeast Asia"],"apiVersions":["2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"CrossResourceGroupResourceMove, CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"plans","locations":["West - Europe","East US","West Us 2","Southeast Asia"],"apiVersions":["2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"CrossResourceGroupResourceMove, - CrossSubscriptionResourceMove, SystemAssignedResourceIdentity, SupportsTags, - SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-26-privatepreview","2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-privatepreview","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-05-26-privatepreview","2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-privatepreview","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WindowsESU","namespace":"Microsoft.WindowsESU","authorizations":[{"applicationId":"e6c69915-bcc7-4335-b655-c62f949d691b","roleDefinitionId":"9bccffcd-2d3d-4b7c-a2cb-bb26e77b4810"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2019-09-16-preview"],"capabilities":"None"},{"resourceType":"Locations","locations":[],"apiVersions":["2019-09-16-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East - US","West Europe"],"apiVersions":["2019-10-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WorkloadBuilder","namespace":"Microsoft.WorkloadBuilder","authorizations":[{"applicationId":"63c2c773-89fe-4164-a02f-b8c7fc1772ae","roleDefinitionId":"322358fa-ea51-4f6c-b9d6-3be64015f074"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2020-07-01-privatepreview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West - Central US","East US 2 EUAP"],"apiVersions":["2020-07-01-privatepreview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2020-07-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WorkloadMonitor","namespace":"Microsoft.WorkloadMonitor","authorizations":[{"applicationId":"ddc728e9-153d-4032-ab80-80e57af7a56f","roleDefinitionId":"553f60de-cc15-412f-9fdf-8f5152e7e0f5","managedByRoleDefinitionId":"553f60de-cc15-412f-9fdf-8f5152e7e0f5"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-01-13-preview","2018-08-31-preview"],"capabilities":"None"},{"resourceType":"componentsSummary","locations":[],"apiVersions":["2018-08-31-preview"],"capabilities":"None"},{"resourceType":"monitorInstancesSummary","locations":[],"apiVersions":["2018-08-31-preview"],"capabilities":"None"},{"resourceType":"monitorInstances","locations":[],"apiVersions":["2018-08-31-preview"],"capabilities":"SupportsExtension"},{"resourceType":"components","locations":[],"apiVersions":["2018-08-31-preview"],"capabilities":"SupportsExtension"},{"resourceType":"monitors","locations":[],"apiVersions":["2020-01-13-preview","2018-08-31-preview"],"capabilities":"SupportsExtension"},{"resourceType":"notificationSettings","locations":[],"apiVersions":["2018-08-31-preview"],"capabilities":"SupportsExtension"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Myget.PackageManagement","namespace":"Myget.PackageManagement","resourceTypes":[{"resourceType":"services","locations":["West + Europe","East US","West Us 2","Southeast Asia"],"apiVersions":["2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"SystemAssignedResourceIdentity, + SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2020-05-26-privatepreview","2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-privatepreview","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2020-05-26-privatepreview","2020-05-26-preview","2020-05-26-beta","2020-05-26-alpha","2019-07-01-privatepreview","2019-07-01-preview","2019-07-01-beta","2019-07-01-alpha"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WindowsESU","namespace":"Microsoft.WindowsESU","authorizations":[{"applicationId":"e6c69915-bcc7-4335-b655-c62f949d691b","roleDefinitionId":"9bccffcd-2d3d-4b7c-a2cb-bb26e77b4810"}],"resourceTypes":[{"resourceType":"Operations","locations":[],"apiVersions":["2019-09-16-preview"],"capabilities":"None"},{"resourceType":"Locations","locations":[],"apiVersions":["2019-09-16-preview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["East + US","West Europe"],"apiVersions":["2019-10-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WorkloadBuilder","namespace":"Microsoft.WorkloadBuilder","authorizations":[{"applicationId":"63c2c773-89fe-4164-a02f-b8c7fc1772ae","roleDefinitionId":"322358fa-ea51-4f6c-b9d6-3be64015f074"}],"resourceTypes":[{"resourceType":"Locations","locations":[],"apiVersions":["2021-03-01-privatepreview","2020-07-01-privatepreview"],"capabilities":"None"},{"resourceType":"Locations/OperationStatuses","locations":["West + Central US","East US 2 EUAP"],"apiVersions":["2020-07-01-privatepreview"],"capabilities":"None"},{"resourceType":"Operations","locations":[],"apiVersions":["2021-03-01-privatepreview","2020-07-01-privatepreview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.WorkloadMonitor","namespace":"Microsoft.WorkloadMonitor","authorizations":[{"applicationId":"ddc728e9-153d-4032-ab80-80e57af7a56f","roleDefinitionId":"553f60de-cc15-412f-9fdf-8f5152e7e0f5","managedByRoleDefinitionId":"553f60de-cc15-412f-9fdf-8f5152e7e0f5"}],"resourceTypes":[{"resourceType":"operations","locations":[],"apiVersions":["2020-01-13-preview"],"capabilities":"None"},{"resourceType":"monitors","locations":[],"apiVersions":["2020-01-13-preview"],"capabilities":"SupportsExtension"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Myget.PackageManagement","namespace":"Myget.PackageManagement","resourceTypes":[{"resourceType":"services","locations":["West Europe"],"apiVersions":["2015-01-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Paraleap.CloudMonix","namespace":"Paraleap.CloudMonix","resourceTypes":[{"resourceType":"services","locations":["West US"],"apiVersions":["2016-08-10"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-08-10"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-08-10"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-08-10"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Pokitdok.Platform","namespace":"Pokitdok.Platform","resourceTypes":[{"resourceType":"services","locations":["West US"],"apiVersions":["2016-05-17"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-05-17"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-05-17"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-05-17"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/RavenHq.Db","namespace":"RavenHq.Db","resourceTypes":[{"resourceType":"databases","locations":["East US","North Europe","West Europe"],"apiVersions":["2016-07-18"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-07-18"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-07-18"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-07-18"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Raygun.CrashReporting","namespace":"Raygun.CrashReporting","resourceTypes":[{"resourceType":"apps","locations":["East US"],"apiVersions":["2015-01-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2015-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Sparkpost.Basic","namespace":"Sparkpost.Basic","resourceTypes":[{"resourceType":"services","locations":["West - US"],"apiVersions":["2016-08-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/stackify.retrace","namespace":"stackify.retrace","resourceTypes":[{"resourceType":"services","locations":["West - US"],"apiVersions":["2016-01-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-01-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-01-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-01-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/U2uconsult.TheIdentityHub","namespace":"U2uconsult.TheIdentityHub","resourceTypes":[{"resourceType":"services","locations":["West - Europe"],"apiVersions":["2015-06-15"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Wandisco.Fusion","namespace":"Wandisco.Fusion","authorizations":[{"applicationId":"37b36496-3f4f-443a-a406-5e0a0535f6a3","roleDefinitionId":"b10cdc1f-fd21-4fe9-bae7-7e2e25a91a21"}],"resourceTypes":[{"resourceType":"Locations","locations":["East + US"],"apiVersions":["2016-08-01"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2016-08-01"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/U2uconsult.TheIdentityHub","namespace":"U2uconsult.TheIdentityHub","resourceTypes":[{"resourceType":"services","locations":["West + Europe"],"apiVersions":["2015-06-15"],"capabilities":"SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"},{"resourceType":"listCommunicationPreference","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"},{"resourceType":"updateCommunicationPreference","locations":[],"apiVersions":["2015-06-15"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Wandisco.Fusion","namespace":"Wandisco.Fusion","authorizations":[{"applicationId":"37b36496-3f4f-443a-a406-5e0a0535f6a3","roleDefinitionId":"b10cdc1f-fd21-4fe9-bae7-7e2e25a91a21"}],"resourceTypes":[{"resourceType":"fusionGroups","locations":["East + US","East Asia","North Europe","Southeast Asia","West Europe","West Central + US","West US","West US 2"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"fusionGroups/azureZones","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"fusionGroups/azureZones/plugins","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"fusionGroups/replicationRules","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"Locations","locations":["East US"],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"Locations/operationStatuses","locations":["East Asia","East US","East US 2 EUAP","North Europe","Southeast Asia","West Europe","West - Central US","West US","West US 2"],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"operations","locations":[],"apiVersions":["2019-09-01-preview"],"capabilities":"None"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"}]}' + Central US","West US","West US 2"],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"fusionGroups/replicationRules/migrations","locations":[],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"registeredSubscriptions","locations":[],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"fusionGroups/hiveReplicationRules","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"fusionGroups/managedOnPremZones","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"operations","locations":[],"apiVersions":["2019-09-01-preview"],"capabilities":"None"},{"resourceType":"migrators","locations":["East + US","East Asia","North Europe","Southeast Asia","West Europe","West Central + US","West US","West US 2"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"migrators/targets","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"},{"resourceType":"migrators/liveDataMigrations","locations":["East + US","West US","West US 2","West Central US","West Europe","North Europe","East + Asia","Southeast Asia"],"apiVersions":["2019-09-01-preview"],"capabilities":"CrossResourceGroupResourceMove, + CrossSubscriptionResourceMove, SupportsTags, SupportsLocation"}],"registrationState":"NotRegistered","registrationPolicy":"RegistrationRequired"}]}' headers: cache-control: - no-cache content-length: - - '970951' + - '1113110' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:40:52 GMT + - Fri, 26 Feb 2021 06:44:42 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resource_groups.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resource_groups.yaml index d49886848fd6..95b37be6bb7b 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resource_groups.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resource_groups.yaml @@ -13,9 +13,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -27,7 +27,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:05 GMT + - Fri, 26 Feb 2021 06:44:48 GMT expires: - '-1' pragma: @@ -51,9 +51,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -65,7 +65,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:05 GMT + - Fri, 26 Feb 2021 06:44:48 GMT expires: - '-1' pragma: @@ -89,9 +89,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '' @@ -101,7 +101,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:58:05 GMT + - Fri, 26 Feb 2021 06:44:48 GMT expires: - '-1' pragma: @@ -123,9 +123,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/unknowngroup?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/unknowngroup?api-version=2020-10-01 response: body: string: '' @@ -137,7 +137,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:05 GMT + - Fri, 26 Feb 2021 06:44:48 GMT expires: - '-1' pragma: @@ -161,23 +161,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/arm-python-RG","name":"arm-python-RG","type":"Microsoft.Resources/resourceGroups","location":"westeurope","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2-R-3","name":"sdk-test-qa2-R-3","type":"Microsoft.Resources/resourceGroups","location":"eastus2","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/VstsRG-lianwtestdevops-ffd5","name":"VstsRG-lianwtestdevops-ffd5","type":"Microsoft.Resources/resourceGroups","location":"centralus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qiaozhatest","name":"qiaozhatest","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sqlresourceGroupName","name":"sqlresourceGroupName","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2","name":"sdk-net-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2","name":"sdk-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/devops_pipeline_resourcename","name":"devops_pipeline_resourcename","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/devops_pipeline_resourcename2","name":"devops_pipeline_resourcename2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianw","name":"lianw","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/acctestRG-backup-200214153104593818-1","name":"acctestRG-backup-200214153104593818-1","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2-R","name":"sdk-test-qa2-R","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sample-group-virtual-machines","name":"azure-sample-group-virtual-machines","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/92F95D8F-3C67-4124-91C7-8CF07CDBF241/resourceGroups/DEFAULT-EVENTGRID","name":"DEFAULT-EVENTGRID","type":"Microsoft.Resources/resourceGroups","location":"westus2","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cloud-shell-storage-southeastasia","name":"cloud-shell-storage-southeastasia","type":"Microsoft.Resources/resourceGroups","location":"southeastasia","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/testresourceGroupName","name":"testresourceGroupName","type":"Microsoft.Resources/resourceGroups","location":"eastasia","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myDevopsResourceGroup2","name":"myDevopsResourceGroup2","type":"Microsoft.Resources/resourceGroups","location":"eastasia","tags":{"environment":"Terraform - Devops Test"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/resourceGroupYC","name":"resourceGroupYC","type":"Microsoft.Resources/resourceGroups","location":"westeurope","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cjf_resource_group_name2","name":"cjf_resource_group_name2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-changlong","name":"test-changlong","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/testgroupx","name":"testgroupx","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianwrs","name":"lianwrs","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/AzureBackupRG_eastus_1","name":"AzureBackupRG_eastus_1","type":"Microsoft.Resources/resourceGroups","location":"eastus","managedBy":"subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.RecoveryServices/","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","name":"iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-08-15T07:02:26.327834"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_compute_test_computef5f00e12","name":"test_cli_mgmt_compute_test_computef5f00e12","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-test","name":"azure-sdk-test","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/DefaultResourceGroup-EUS","name":"DefaultResourceGroup-EUS","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_wan_hub_test_network76dc116f","name":"test_cli_mgmt_network_wan_hub_test_network76dc116f","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-16T09:14:35"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/xqdh7wqbpok3jowpcsbkn5hxf6h56g24so7m2mq3vqmhg22rrldipp7rdxiweaneio324yjjag7","name":"xqdh7wqbpok3jowpcsbkn5hxf6h56g24so7m2mq3vqmhg22rrldipp7rdxiweaneio324yjjag7","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-17T02:52:26"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/uqyfn2w3rdkpalowspvhsoaodfg7253ejab37imk6a5rwo2fkuhztgxbkli72ireymqxzh4xeeh","name":"uqyfn2w3rdkpalowspvhsoaodfg7253ejab37imk6a5rwo2fkuhztgxbkli72ireymqxzh4xeeh","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-17T04:25:53"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/asdasasd_group","name":"asdasasd_group","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestqz44lhgyfadyuonzthxmzgrq4qtw5vctntbi2lyggv5neas6jklmdw2ot3qrglwn4xgw","name":"clitestqz44lhgyfadyuonzthxmzgrq4qtw5vctntbi2lyggv5neas6jklmdw2ot3qrglwn4xgw","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-07T03:31:29Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestt766m3arr3aw6mv4bamwqplradoeeyqcy2ivqpqsigthyiarurwanqjqzt6qaubnepb7","name":"clitestt766m3arr3aw6mv4bamwqplradoeeyqcy2ivqpqsigthyiarurwanqjqzt6qaubnepb7","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-07T06:12:37Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestleo4ph5sfx6z3zktznstrtxzj7llbya26xdg4qe477ebxol4xpl7zniwh3wkrh2m22uf","name":"clitestleo4ph5sfx6z3zktznstrtxzj7llbya26xdg4qe477ebxol4xpl7zniwh3wkrh2m22uf","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-14T05:19:35Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/xtz6sueevhsiau66hc5ccdmccqiru5l44rkejgbiujqrpvjfpmdn5mklbpyg34nyqpjlypwcdve","name":"xtz6sueevhsiau66hc5ccdmccqiru5l44rkejgbiujqrpvjfpmdn5mklbpyg34nyqpjlypwcdve","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-02T08:47:56.593193"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_managed_disks_test_grant_access609310b8","name":"test_mgmt_managed_disks_test_grant_access609310b8","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/ixatdrpmhso76rpni7zf4voepgpqxqfllzsuavybrhzwdd64eaeaq2ogq63i7numq3gfsetwvhx","name":"ixatdrpmhso76rpni7zf4voepgpqxqfllzsuavybrhzwdd64eaeaq2ogq63i7numq3gfsetwvhx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-18T07:29:38"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zwwhzeymmg3wfx4qtc3f5o2j5stk4ll6mtuzortcgsyg2dyqbfqb66eiikdphauomr5g3knxv6q","name":"zwwhzeymmg3wfx4qtc3f5o2j5stk4ll6mtuzortcgsyg2dyqbfqb66eiikdphauomr5g3knxv6q","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-18T07:37:32"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-for-js","name":"azure-sdk-for-js","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-for-node","name":"azure-sdk-for-node","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cleanupservice","name":"cleanupservice","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"What - Is Cleanup Service":"https://aka.ms/WhatIsCleanupService"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-box","name":"dev-box","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/git2gridtemplate","name":"git2gridtemplate","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/git2gridtesting","name":"git2gridtesting","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/ml-test","name":"ml-test","type":"Microsoft.Resources/resourceGroups","location":"southcentralus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/msi-test-functions","name":"msi-test-functions","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/vpn","name":"vpn","type":"Microsoft.Resources/resourceGroups","location":"ukwest","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/vpn-lon","name":"vpn-lon","type":"Microsoft.Resources/resourceGroups","location":"ukwest","properties":{"provisioningState":"Succeeded"}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qiaozhatest","name":"qiaozhatest","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2","name":"sdk-net-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/move_resource_name","name":"move_resource_name","type":"Microsoft.Resources/resourceGroups","location":"eastus2","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianwrs","name":"lianwrs","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","name":"iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-08-15T07:02:26.327834"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_compute_test_computef5f00e12","name":"test_cli_mgmt_compute_test_computef5f00e12","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitesttdfkwqitc4btv3oem44vsnymesndrcfl2dbdur5jlxge5crdkdwvzeolpxpq74ynnhqy","name":"clitesttdfkwqitc4btv3oem44vsnymesndrcfl2dbdur5jlxge5crdkdwvzeolpxpq74ynnhqy","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T02:39:18Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicjesitxk4azvy7m72uudmxgtnkbwzuaz7a6kmxspiphx5f632r3spfwhvdcdxc","name":"img_tmpl_basicjesitxk4azvy7m72uudmxgtnkbwzuaz7a6kmxspiphx5f632r3spfwhvdcdxc","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T03:16:03Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigoy2maw3coop2lzcctpp4tqmjpn4wqsqgtvjjk4ejxl4vi2bjb2no3idwsnnllch","name":"img_tmpl_sigoy2maw3coop2lzcctpp4tqmjpn4wqsqgtvjjk4ejxl4vi2bjb2no3idwsnnllch","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T03:16:04Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicuvanzcnk62oe34qobbbeqhjtxnkr7f5pr7lz6uq52elmo7axqcpcp5vsqpzgv","name":"img_tmpl_basicuvanzcnk62oe34qobbbeqhjtxnkr7f5pr7lz6uq52elmo7axqcpcp5vsqpzgv","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T05:13:46Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigwga535c5xjysq3klqyu66bk3nso6p3wngzf6ieoyqq53aierzbxt7fx4pstysjx","name":"img_tmpl_sigwga535c5xjysq3klqyu66bk3nso6p3wngzf6ieoyqq53aierzbxt7fx4pstysjx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T05:13:49Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicgfpypcfirw3o2qg47bz6mhjinfw7xd45kumxpr62dzeej77fo2evwjssar7a7","name":"img_tmpl_basicgfpypcfirw3o2qg47bz6mhjinfw7xd45kumxpr62dzeej77fo2evwjssar7a7","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:09:21Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig2f53rliiuddloj2dwn6swvtnddx5yqyxink7qrrsnkyza36qxk6aio5n4h2goof","name":"img_tmpl_sig2f53rliiuddloj2dwn6swvtnddx5yqyxink7qrrsnkyza36qxk6aio5n4h2goof","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:09:23Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigbl7gcnnu2xk4ofqgpr7s6uboohfxv6r3aoxmmgtjm33bnim4ed5l7u6ioji23aw","name":"img_tmpl_sigbl7gcnnu2xk4ofqgpr7s6uboohfxv6r3aoxmmgtjm33bnim4ed5l7u6ioji23aw","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:40:04Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicbkziktwszgrofclcldjgehemhfccg3vdh7hei5iqrccskczumbb3rsz6sxrgb","name":"img_tmpl_basicbkziktwszgrofclcldjgehemhfccg3vdh7hei5iqrccskczumbb3rsz6sxrgb","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:40:06Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig55k2al4qqcnlkshjrnncfqqnyj76pnyntzrl2epke3l7xj7kuabg5aztlqxhg3o","name":"img_tmpl_sig55k2al4qqcnlkshjrnncfqqnyj76pnyntzrl2epke3l7xj7kuabg5aztlqxhg3o","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T14:21:30Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigzozdskubnbphrhq6ujx4qoibivwpknb4i3qhx7gdy5ifr452qjwr7rnbr3n2vg5","name":"img_tmpl_sigzozdskubnbphrhq6ujx4qoibivwpknb4i3qhx7gdy5ifr452qjwr7rnbr3n2vg5","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T01:14:40Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basic7okgeofcfdh3pjtlcfpiyvhoo5n2ki3y76ykv5q4hj764p3wb7o5avesnv3nl","name":"img_tmpl_basic7okgeofcfdh3pjtlcfpiyvhoo5n2ki3y76ykv5q4hj764p3wb7o5avesnv3nl","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T01:14:40Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicci4bbhiv3amoqtxxwbkra27egbgn7iarnxxethyemm3mlx3v5rq2au2c3jkxa","name":"img_tmpl_basicci4bbhiv3amoqtxxwbkra27egbgn7iarnxxethyemm3mlx3v5rq2au2c3jkxa","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T02:08:51Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig2gyqqiddiy2bcpnfqzqhp6ptvyqwyyi6o3w7yxkmdn7wxqdwwzvm4sa7b6j2udn","name":"img_tmpl_sig2gyqqiddiy2bcpnfqzqhp6ptvyqwyyi6o3w7yxkmdn7wxqdwwzvm4sa7b6j2udn","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T02:08:51Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicvz674l3kimgrkmjf5bkiuzeuajlwacvpbnftxdd7wz5hehni5yoejvnowajae","name":"img_tmpl_basicvz674l3kimgrkmjf5bkiuzeuajlwacvpbnftxdd7wz5hehni5yoejvnowajae","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T03:46:32Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigoddhv4xs5ptliuitldhftm6x6b53x42jf7oshycnjalyqkp626dju6dgxz6rvbx","name":"img_tmpl_sigoddhv4xs5ptliuitldhftm6x6b53x42jf7oshycnjalyqkp626dju6dgxz6rvbx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T03:46:35Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicxl3pfy62bj7pkxsc7q5dryq6imaqdanqt67yrx5fkibnmiflwc7dw7xufyqb4","name":"img_tmpl_basicxl3pfy62bj7pkxsc7q5dryq6imaqdanqt67yrx5fkibnmiflwc7dw7xufyqb4","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T07:23:07Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig5r3k74ewp5brj6khls7unjwtbvnipz63mrlthznpny7hulqiyi367nh6fr44qym","name":"img_tmpl_sig5r3k74ewp5brj6khls7unjwtbvnipz63mrlthznpny7hulqiyi367nh6fr44qym","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T07:23:07Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bgbtwo5tm567agecnisclegwk2774l2iaedce5kn7trucndx6c2bdgvw45tyizcjhnbztbtts6n","name":"bgbtwo5tm567agecnisclegwk2774l2iaedce5kn7trucndx6c2bdgvw45tyizcjhnbztbtts6n","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2021-02-27T06:40:44"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/3fr3eokbnqtk7pi25ajuizojoniczfrf6256cwybeu6lrlhpe2dcb4fuyxvjutrxblj2jnsnjqe","name":"3fr3eokbnqtk7pi25ajuizojoniczfrf6256cwybeu6lrlhpe2dcb4fuyxvjutrxblj2jnsnjqe","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2021-02-27T06:43:04"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}]}' headers: cache-control: - no-cache content-length: - - '13653' + - '10445' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:05 GMT + - Fri, 26 Feb 2021 06:44:49 GMT expires: - '-1' pragma: @@ -205,9 +203,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"valueA","tag2":"valueB"},"properties":{"provisioningState":"Succeeded"}}' @@ -219,7 +217,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:06 GMT + - Fri, 26 Feb 2021 06:44:50 GMT expires: - '-1' pragma: @@ -247,9 +245,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-10-01 response: body: string: '{"value":[]}' @@ -261,7 +259,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:06 GMT + - Fri, 26 Feb 2021 06:44:50 GMT expires: - '-1' pragma: @@ -289,12 +287,12 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-10-01 response: body: - string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[]}}' + string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[]}}' headers: cache-control: - no-cache @@ -303,7 +301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:58:07 GMT + - Fri, 26 Feb 2021 06:44:51 GMT expires: - '-1' pragma: @@ -329,9 +327,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '' @@ -341,11 +339,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:58:10 GMT + - Fri, 26 Feb 2021 06:44:53 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -353,7 +351,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 202 message: Accepted @@ -367,9 +365,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -379,11 +377,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:58:25 GMT + - Fri, 26 Feb 2021 06:45:09 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -403,9 +401,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -415,11 +413,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:58:41 GMT + - Fri, 26 Feb 2021 06:45:24 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -439,9 +437,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -451,7 +449,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:58:57 GMT + - Fri, 26 Feb 2021 06:45:39 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resources.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resources.yaml index 527e37a4cef1..ef852ab5d454 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resources.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_resources.yaml @@ -9,7 +9,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4?api-version=2019-10-01 response: @@ -23,7 +23,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:00 GMT + - Fri, 26 Feb 2021 06:45:45 GMT expires: - '-1' pragma: @@ -47,7 +47,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4?api-version=2019-10-01 response: @@ -61,7 +61,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:00 GMT + - Fri, 26 Feb 2021 06:45:46 GMT expires: - '-1' pragma: @@ -89,7 +89,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4?api-version=2019-07-01 response: @@ -107,7 +107,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:07 GMT + - Fri, 26 Feb 2021 06:45:51 GMT expires: - '-1' pragma: @@ -124,9 +124,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1194 + - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1197 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 200 message: OK @@ -144,7 +144,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4?api-version=2019-07-01 response: @@ -162,7 +162,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:11 GMT + - Fri, 26 Feb 2021 06:45:55 GMT expires: - '-1' pragma: @@ -179,9 +179,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;237,Microsoft.Compute/PutVM30Min;1193 + - Microsoft.Compute/PutVM3Min;237,Microsoft.Compute/PutVM30Min;1196 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 200 message: OK @@ -195,7 +195,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4?api-version=2019-07-01 response: @@ -213,7 +213,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:11 GMT + - Fri, 26 Feb 2021 06:45:55 GMT expires: - '-1' pragma: @@ -230,7 +230,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3998,Microsoft.Compute/LowCostGet30Min;31996 + - Microsoft.Compute/LowCostGet3Min;3999,Microsoft.Compute/LowCostGet30Min;31999 status: code: 200 message: OK @@ -244,7 +244,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4?api-version=2019-07-01 response: @@ -262,7 +262,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:11 GMT + - Fri, 26 Feb 2021 06:45:56 GMT expires: - '-1' pragma: @@ -279,7 +279,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/LowCostGet3Min;3997,Microsoft.Compute/LowCostGet30Min;31995 + - Microsoft.Compute/LowCostGet3Min;3998,Microsoft.Compute/LowCostGet30Min;31998 status: code: 200 message: OK @@ -293,9 +293,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resources?$filter=name%20eq%20%27pytestavsetea520dc4%27&api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resources?$filter=name%20eq%20%27pytestavsetea520dc4%27&api-version=2020-10-01 response: body: string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4","name":"pytestavsetea520dc4","type":"Microsoft.Compute/availabilitySets","sku":{"name":"Classic"},"location":"westus"}]}' @@ -307,7 +307,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:11 GMT + - Fri, 26 Feb 2021 06:45:56 GMT expires: - '-1' pragma: @@ -335,9 +335,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/pynewgroupea520dc4?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/pynewgroupea520dc4?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4","name":"pynewgroupea520dc4","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}}' @@ -349,27 +349,23 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:41:13 GMT + - Fri, 26 Feb 2021 06:45:57 GMT expires: - '-1' pragma: - no-cache strict-transport-security: - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1197' status: - code: 200 - message: OK + code: 201 + message: Created - request: - body: 'b''b\''{"resources": ["/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4"], - "targetResourceGroup": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4"}\''''' + body: '{"resources": ["/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4"], + "targetResourceGroup": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4"}' headers: Accept: - application/json @@ -382,9 +378,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/validateMoveResources?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/validateMoveResources?api-version=2020-10-01 response: body: string: '' @@ -394,11 +390,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:41:16 GMT + - Fri, 26 Feb 2021 06:46:00 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -420,9 +416,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -432,11 +428,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:41:32 GMT + - Fri, 26 Feb 2021 06:46:16 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -456,9 +452,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -468,11 +464,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:41:47 GMT + - Fri, 26 Feb 2021 06:46:31 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -492,9 +488,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -504,11 +500,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:42:03 GMT + - Fri, 26 Feb 2021 06:46:46 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -528,9 +524,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -540,11 +536,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:42:19 GMT + - Fri, 26 Feb 2021 06:47:03 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -564,9 +560,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -576,11 +572,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:42:34 GMT + - Fri, 26 Feb 2021 06:47:18 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -600,9 +596,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLVZBTElEQVRFIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -610,7 +606,7 @@ interactions: cache-control: - no-cache date: - - Thu, 17 Sep 2020 07:42:49 GMT + - Fri, 26 Feb 2021 06:47:34 GMT expires: - '-1' pragma: @@ -623,8 +619,8 @@ interactions: code: 204 message: No Content - request: - body: 'b''b\''{"resources": ["/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4"], - "targetResourceGroup": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4"}\''''' + body: '{"resources": ["/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4"], + "targetResourceGroup": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4"}' headers: Accept: - application/json @@ -637,9 +633,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/moveResources?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/moveResources?api-version=2020-10-01 response: body: string: '' @@ -649,11 +645,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:42:55 GMT + - Fri, 26 Feb 2021 06:47:39 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -675,9 +671,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -687,11 +683,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:43:10 GMT + - Fri, 26 Feb 2021 06:47:54 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -711,9 +707,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -723,11 +719,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:43:25 GMT + - Fri, 26 Feb 2021 06:48:09 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -747,9 +743,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -759,11 +755,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:43:41 GMT + - Fri, 26 Feb 2021 06:48:25 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -783,9 +779,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -795,11 +791,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:43:56 GMT + - Fri, 26 Feb 2021 06:48:40 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -819,9 +815,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -831,11 +827,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:44:11 GMT + - Fri, 26 Feb 2021 06:48:55 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -855,9 +851,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -867,11 +863,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:44:28 GMT + - Fri, 26 Feb 2021 06:49:12 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -891,9 +887,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -903,11 +899,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:44:43 GMT + - Fri, 26 Feb 2021 06:49:27 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -927,9 +923,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -939,11 +935,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:44:59 GMT + - Fri, 26 Feb 2021 06:49:42 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -963,9 +959,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -975,11 +971,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:45:14 GMT + - Fri, 26 Feb 2021 06:49:58 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -999,9 +995,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -1011,11 +1007,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:45:29 GMT + - Fri, 26 Feb 2021 06:50:13 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1035,9 +1031,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -1047,11 +1043,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:45:45 GMT + - Fri, 26 Feb 2021 06:50:28 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1071,9 +1067,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -1083,11 +1079,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:46:00 GMT + - Fri, 26 Feb 2021 06:50:44 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1107,9 +1103,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -1119,11 +1115,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:46:16 GMT + - Fri, 26 Feb 2021 06:51:00 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1143,9 +1139,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLTVOS1JEQTdTVTNYRUlXRUdDSUZPTkdSSDZHSjJLQUpYS0JMWUU2S0FXQ08yQVg0fDREMkM1NEI2NkYwOTY1QzAtV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFQkFUQ0hNT1ZFSk9CLUMySUU2SEhUQjNLUzdRWE1YN0FGRFczWVM0WFdIRDUzNDdYWjRHSlJQSjU2SVZMfEUzNjU3NDk1QzY2MzAxNDktV0VTVFVTLU1PVkUiLCJqb2JMb2NhdGlvbiI6Indlc3R1cyJ9?api-version=2020-10-01 response: body: string: '' @@ -1153,7 +1149,7 @@ interactions: cache-control: - no-cache date: - - Thu, 17 Sep 2020 07:46:32 GMT + - Fri, 26 Feb 2021 06:51:15 GMT expires: - '-1' pragma: @@ -1179,7 +1175,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4?api-version=2019-07-01 response: @@ -1197,7 +1193,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:46:36 GMT + - Fri, 26 Feb 2021 06:51:19 GMT expires: - '-1' pragma: @@ -1214,9 +1210,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1192 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1195 x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1196' status: code: 200 message: OK @@ -1234,7 +1230,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4?api-version=2019-07-01 response: @@ -1252,7 +1248,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:46:39 GMT + - Fri, 26 Feb 2021 06:51:23 GMT expires: - '-1' pragma: @@ -1269,9 +1265,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1191 + - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1194 x-ms-ratelimit-remaining-subscription-writes: - - '1194' + - '1195' status: code: 200 message: OK @@ -1287,7 +1283,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavsetea520dc4?api-version=2019-07-01 response: @@ -1299,7 +1295,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:46:44 GMT + - Fri, 26 Feb 2021 06:51:27 GMT expires: - '-1' pragma: @@ -1312,7 +1308,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/DeleteVM3Min;239,Microsoft.Compute/DeleteVM30Min;1195 + - Microsoft.Compute/DeleteVM3Min;239,Microsoft.Compute/DeleteVM30Min;1199 x-ms-ratelimit-remaining-subscription-deletes: - '14999' status: @@ -1330,7 +1326,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/pynewgroupea520dc4/providers/Microsoft.Compute/availabilitySets/pytestavset123ea520dc4?api-version=2019-07-01 response: @@ -1342,7 +1338,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:46:48 GMT + - Fri, 26 Feb 2021 06:51:30 GMT expires: - '-1' pragma: @@ -1355,7 +1351,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/DeleteVM3Min;238,Microsoft.Compute/DeleteVM30Min;1194 + - Microsoft.Compute/DeleteVM3Min;238,Microsoft.Compute/DeleteVM30Min;1198 x-ms-ratelimit-remaining-subscription-deletes: - '14998' status: @@ -1373,9 +1369,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/pynewgroupea520dc4?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/pynewgroupea520dc4?api-version=2020-10-01 response: body: string: '' @@ -1385,11 +1381,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:46:50 GMT + - Fri, 26 Feb 2021 06:51:32 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1411,9 +1407,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -1423,11 +1419,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:05 GMT + - Fri, 26 Feb 2021 06:51:48 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1447,9 +1443,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -1459,11 +1455,11 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:21 GMT + - Fri, 26 Feb 2021 06:52:03 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: - no-cache strict-transport-security: @@ -1483,9 +1479,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1QWU5FV0dST1VQRUE1MjBEQzQtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' @@ -1495,7 +1491,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:36 GMT + - Fri, 26 Feb 2021 06:52:18 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_tag_operations.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_tag_operations.yaml index ae30f8faea10..aad31cc0e991 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_tag_operations.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource.test_tag_operations.yaml @@ -11,9 +11,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz","tagName":"tagxyz","count":{"type":"Total","value":0},"values":[]}' @@ -25,7 +25,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:47 GMT + - Fri, 26 Feb 2021 06:52:26 GMT expires: - '-1' pragma: @@ -35,7 +35,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1198' status: code: 201 message: Created @@ -51,9 +51,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":0}}' @@ -65,7 +65,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:50 GMT + - Fri, 26 Feb 2021 06:52:28 GMT expires: - '-1' pragma: @@ -75,7 +75,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1197' status: code: 201 message: Created @@ -89,28 +89,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/exampleTag","tagName":"exampleTag","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/exampleTag/tagValues/exampleValue","tagValue":"exampleValue","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/ms-resource-usage","tagName":"ms-resource-usage","count":{"type":"Total","value":2},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/ms-resource-usage/tagValues/azure-cloud-shell","tagValue":"azure-cloud-shell","count":{"type":"Total","value":2}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag1","tagName":"tag1","count":{"type":"Total","value":7},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag1/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":4}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag1/tagValues/Red","tagValue":"Red","count":{"type":"Total","value":3}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag2","tagName":"tag2","count":{"type":"Total","value":7},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag2/tagValues/value2","tagValue":"value2","count":{"type":"Total","value":4}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag2/tagValues/White","tagValue":"White","count":{"type":"Total","value":3}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/test","tagName":"test","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/test/tagValues/test1","tagValue":"test1","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/Migrate - Project","tagName":"Migrate Project","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/Migrate - Project/tagValues/testmigrate","tagValue":"testmigrate","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/Creator","tagName":"Creator","count":{"type":"Total","value":6},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/Creator/tagValues/Automatically - added by NRMS Azure Policy","tagValue":"Automatically added by NRMS Azure - Policy","count":{"type":"Total","value":6}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/NRMS-Info","tagName":"NRMS-Info","count":{"type":"Total","value":6},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/NRMS-Info/tagValues/http://aka.ms/nrms","tagValue":"http://aka.ms/nrms","count":{"type":"Total","value":6}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/NRMS-Version","tagName":"NRMS-Version","count":{"type":"Total","value":6},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/NRMS-Version/tagValues/2019-03-20","tagValue":"2019-03-20","count":{"type":"Total","value":6}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/key1","tagName":"key1","count":{"type":"Total","value":9},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/key1/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":9}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/key2","tagName":"key2","count":{"type":"Total","value":6},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/key2/tagValues/value2","tagValue":"value2","count":{"type":"Total","value":6}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagkey","tagName":"tagkey","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagkey/tagValues/lianwtesttags2","tagValue":"lianwtesttags2","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz","tagName":"tagxyz","count":{"type":"Total","value":0},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":0}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/environment","tagName":"environment","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/environment/tagValues/Terraform - Devops Test","tagValue":"Terraform Devops Test","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter","tagName":"DeleteAfter","count":{"type":"Total","value":8},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-08-15T07:02:26.327834","tagValue":"2020-08-15T07:02:26.327834","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-16T09:14:35","tagValue":"2020-09-16T09:14:35","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-17T02:52:26","tagValue":"2020-09-17T02:52:26","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-17T04:25:53","tagValue":"2020-09-17T04:25:53","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-02T08:47:56.593193","tagValue":"2020-09-02T08:47:56.593193","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-18T07:29:38","tagValue":"2020-09-18T07:29:38","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-18T07:37:32","tagValue":"2020-09-18T07:37:32","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-09-18T07:40:54","tagValue":"2020-09-18T07:40:54","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/product","tagName":"product","count":{"type":"Total","value":3},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/product/tagValues/azurecli","tagValue":"azurecli","count":{"type":"Total","value":3}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/cause","tagName":"cause","count":{"type":"Total","value":3},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/cause/tagValues/automation","tagValue":"automation","count":{"type":"Total","value":3}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date","tagName":"date","count":{"type":"Total","value":3},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2020-08-07T03:31:29Z","tagValue":"2020-08-07T03:31:29Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2020-08-07T06:12:37Z","tagValue":"2020-08-07T06:12:37Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2020-08-14T05:19:35Z","tagValue":"2020-08-14T05:19:35Z","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/What - Is Cleanup Service","tagName":"What Is Cleanup Service","count":{"type":"Total","value":1},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/What - Is Cleanup Service/tagValues/https://aka.ms/WhatIsCleanupService","tagValue":"https://aka.ms/WhatIsCleanupService","count":{"type":"Total","value":1}}]}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag1","tagName":"tag1","count":{"type":"Total","value":2},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag1/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":2}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag2","tagName":"tag2","count":{"type":"Total","value":2},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tag2/tagValues/value2","tagValue":"value2","count":{"type":"Total","value":2}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz","tagName":"tagxyz","count":{"type":"Total","value":0},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1","tagValue":"value1","count":{"type":"Total","value":0}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter","tagName":"DeleteAfter","count":{"type":"Total","value":4},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2020-08-15T07:02:26.327834","tagValue":"2020-08-15T07:02:26.327834","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2021-02-27T06:40:44","tagValue":"2021-02-27T06:40:44","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2021-02-27T06:43:04","tagValue":"2021-02-27T06:43:04","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/DeleteAfter/tagValues/2021-02-27T06:45:40","tagValue":"2021-02-27T06:45:40","count":{"type":"Total","value":1}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/product","tagName":"product","count":{"type":"Total","value":18},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/product/tagValues/azurecli","tagValue":"azurecli","count":{"type":"Total","value":18}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/cause","tagName":"cause","count":{"type":"Total","value":18},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/cause/tagValues/automation","tagValue":"automation","count":{"type":"Total","value":18}}]},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date","tagName":"date","count":{"type":"Total","value":18},"values":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T02:39:18Z","tagValue":"2021-02-23T02:39:18Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T03:16:03Z","tagValue":"2021-02-23T03:16:03Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T03:16:04Z","tagValue":"2021-02-23T03:16:04Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T05:13:46Z","tagValue":"2021-02-23T05:13:46Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T05:13:49Z","tagValue":"2021-02-23T05:13:49Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T07:09:21Z","tagValue":"2021-02-23T07:09:21Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T07:09:23Z","tagValue":"2021-02-23T07:09:23Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T07:40:04Z","tagValue":"2021-02-23T07:40:04Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T07:40:06Z","tagValue":"2021-02-23T07:40:06Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-23T14:21:30Z","tagValue":"2021-02-23T14:21:30Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-24T01:14:40Z","tagValue":"2021-02-24T01:14:40Z","count":{"type":"Total","value":2}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-24T02:08:51Z","tagValue":"2021-02-24T02:08:51Z","count":{"type":"Total","value":2}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-24T03:46:32Z","tagValue":"2021-02-24T03:46:32Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-24T03:46:35Z","tagValue":"2021-02-24T03:46:35Z","count":{"type":"Total","value":1}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/date/tagValues/2021-02-24T07:23:07Z","tagValue":"2021-02-24T07:23:07Z","count":{"type":"Total","value":2}}]}]}' headers: cache-control: - no-cache content-length: - - '7923' + - '5120' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:51 GMT + - Fri, 26 Feb 2021 06:52:28 GMT expires: - '-1' pragma: @@ -136,9 +129,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz/tagValues/value1?api-version=2020-10-01 response: body: string: '' @@ -148,7 +141,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:53 GMT + - Fri, 26 Feb 2021 06:52:30 GMT expires: - '-1' pragma: @@ -174,9 +167,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/tagNames/tagxyz?api-version=2020-10-01 response: body: string: '' @@ -186,7 +179,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:55 GMT + - Fri, 26 Feb 2021 06:52:32 GMT expires: - '-1' pragma: @@ -214,9 +207,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default","name":"default","type":"Microsoft.Resources/tags","properties":{"tags":{"tagKey1":"tagValue1","tagKey2":"tagValue2"}}}' @@ -228,7 +221,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:57 GMT + - Fri, 26 Feb 2021 06:52:34 GMT expires: - '-1' pragma: @@ -242,7 +235,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1196' status: code: 200 message: OK @@ -256,9 +249,9 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default","name":"default","type":"Microsoft.Resources/tags","properties":{"tags":{"tagKey1":"tagValue1","tagKey2":"tagValue2"}}}' @@ -270,7 +263,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:58 GMT + - Fri, 26 Feb 2021 06:52:34 GMT expires: - '-1' pragma: @@ -298,9 +291,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default","name":"default","type":"Microsoft.Resources/tags","properties":{"tags":{"tagKey2":"tagValue2"}}}' @@ -312,7 +305,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 07:47:58 GMT + - Fri, 26 Feb 2021 06:52:35 GMT expires: - '-1' pragma: @@ -326,7 +319,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1195' status: code: 200 message: OK @@ -342,9 +335,9 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/tags/default?api-version=2020-10-01 response: body: string: '' @@ -354,7 +347,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 07:47:59 GMT + - Fri, 26 Feb 2021 06:52:36 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_async.test_resource_groups.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_async.test_resource_groups.yaml index ba821e3890f8..6317a280c0d8 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_async.test_resource_groups.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_async.test_resource_groups.yaml @@ -9,9 +9,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -19,25 +19,25 @@ interactions: cache-control: no-cache content-length: '316' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:15 GMT + date: Fri, 26 Feb 2021 06:52:40 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-ratelimit-remaining-subscription-writes: '1199' + x-ms-ratelimit-remaining-subscription-writes: '1197' status: code: 201 message: Created - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -46,7 +46,7 @@ interactions: content-encoding: gzip content-length: '319' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:15 GMT + date: Fri, 26 Feb 2021 06:52:40 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -55,23 +55,23 @@ interactions: status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '' headers: cache-control: no-cache content-length: '0' - date: Thu, 17 Sep 2020 08:11:15 GMT + date: Fri, 26 Feb 2021 06:52:40 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -79,16 +79,16 @@ interactions: status: code: 204 message: No Content - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: HEAD - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/unknowngroup?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/unknowngroup?api-version=2020-10-01 response: body: string: '' @@ -96,7 +96,7 @@ interactions: cache-control: no-cache content-length: '104' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:15 GMT + date: Fri, 26 Feb 2021 06:52:40 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -105,27 +105,25 @@ interactions: status: code: 404 message: Not Found - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/unknowngroup?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/unknowngroup?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups?api-version=2020-10-01 response: body: - string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/arm-python-RG","name":"arm-python-RG","type":"Microsoft.Resources/resourceGroups","location":"westeurope","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2-R-3","name":"sdk-test-qa2-R-3","type":"Microsoft.Resources/resourceGroups","location":"eastus2","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/VstsRG-lianwtestdevops-ffd5","name":"VstsRG-lianwtestdevops-ffd5","type":"Microsoft.Resources/resourceGroups","location":"centralus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qiaozhatest","name":"qiaozhatest","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sqlresourceGroupName","name":"sqlresourceGroupName","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2","name":"sdk-net-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2","name":"sdk-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/devops_pipeline_resourcename","name":"devops_pipeline_resourcename","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/devops_pipeline_resourcename2","name":"devops_pipeline_resourcename2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianw","name":"lianw","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/acctestRG-backup-200214153104593818-1","name":"acctestRG-backup-200214153104593818-1","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-test-qa2-R","name":"sdk-test-qa2-R","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sample-group-virtual-machines","name":"azure-sample-group-virtual-machines","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/92F95D8F-3C67-4124-91C7-8CF07CDBF241/resourceGroups/DEFAULT-EVENTGRID","name":"DEFAULT-EVENTGRID","type":"Microsoft.Resources/resourceGroups","location":"westus2","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cloud-shell-storage-southeastasia","name":"cloud-shell-storage-southeastasia","type":"Microsoft.Resources/resourceGroups","location":"southeastasia","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/testresourceGroupName","name":"testresourceGroupName","type":"Microsoft.Resources/resourceGroups","location":"eastasia","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myDevopsResourceGroup2","name":"myDevopsResourceGroup2","type":"Microsoft.Resources/resourceGroups","location":"eastasia","tags":{"environment":"Terraform - Devops Test"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/resourceGroupYC","name":"resourceGroupYC","type":"Microsoft.Resources/resourceGroups","location":"westeurope","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cjf_resource_group_name2","name":"cjf_resource_group_name2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test-changlong","name":"test-changlong","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/testgroupx","name":"testgroupx","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianwrs","name":"lianwrs","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/AzureBackupRG_eastus_1","name":"AzureBackupRG_eastus_1","type":"Microsoft.Resources/resourceGroups","location":"eastus","managedBy":"subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.RecoveryServices/","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","name":"iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-08-15T07:02:26.327834"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_compute_test_computef5f00e12","name":"test_cli_mgmt_compute_test_computef5f00e12","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-test","name":"azure-sdk-test","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/DefaultResourceGroup-EUS","name":"DefaultResourceGroup-EUS","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_network_wan_hub_test_network76dc116f","name":"test_cli_mgmt_network_wan_hub_test_network76dc116f","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-16T09:14:35"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/xqdh7wqbpok3jowpcsbkn5hxf6h56g24so7m2mq3vqmhg22rrldipp7rdxiweaneio324yjjag7","name":"xqdh7wqbpok3jowpcsbkn5hxf6h56g24so7m2mq3vqmhg22rrldipp7rdxiweaneio324yjjag7","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-17T02:52:26"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/uqyfn2w3rdkpalowspvhsoaodfg7253ejab37imk6a5rwo2fkuhztgxbkli72ireymqxzh4xeeh","name":"uqyfn2w3rdkpalowspvhsoaodfg7253ejab37imk6a5rwo2fkuhztgxbkli72ireymqxzh4xeeh","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-09-17T04:25:53"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/asdasasd_group","name":"asdasasd_group","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestqz44lhgyfadyuonzthxmzgrq4qtw5vctntbi2lyggv5neas6jklmdw2ot3qrglwn4xgw","name":"clitestqz44lhgyfadyuonzthxmzgrq4qtw5vctntbi2lyggv5neas6jklmdw2ot3qrglwn4xgw","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-07T03:31:29Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestt766m3arr3aw6mv4bamwqplradoeeyqcy2ivqpqsigthyiarurwanqjqzt6qaubnepb7","name":"clitestt766m3arr3aw6mv4bamwqplradoeeyqcy2ivqpqsigthyiarurwanqjqzt6qaubnepb7","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-07T06:12:37Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitestleo4ph5sfx6z3zktznstrtxzj7llbya26xdg4qe477ebxol4xpl7zniwh3wkrh2m22uf","name":"clitestleo4ph5sfx6z3zktznstrtxzj7llbya26xdg4qe477ebxol4xpl7zniwh3wkrh2m22uf","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2020-08-14T05:19:35Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/xtz6sueevhsiau66hc5ccdmccqiru5l44rkejgbiujqrpvjfpmdn5mklbpyg34nyqpjlypwcdve","name":"xtz6sueevhsiau66hc5ccdmccqiru5l44rkejgbiujqrpvjfpmdn5mklbpyg34nyqpjlypwcdve","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-02T08:47:56.593193"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_managed_disks_test_grant_access609310b8","name":"test_mgmt_managed_disks_test_grant_access609310b8","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/ixatdrpmhso76rpni7zf4voepgpqxqfllzsuavybrhzwdd64eaeaq2ogq63i7numq3gfsetwvhx","name":"ixatdrpmhso76rpni7zf4voepgpqxqfllzsuavybrhzwdd64eaeaq2ogq63i7numq3gfsetwvhx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-18T07:29:38"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/zwwhzeymmg3wfx4qtc3f5o2j5stk4ll6mtuzortcgsyg2dyqbfqb66eiikdphauomr5g3knxv6q","name":"zwwhzeymmg3wfx4qtc3f5o2j5stk4ll6mtuzortcgsyg2dyqbfqb66eiikdphauomr5g3knxv6q","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2020-09-18T07:37:32"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-for-js","name":"azure-sdk-for-js","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/azure-sdk-for-node","name":"azure-sdk-for-node","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/cleanupservice","name":"cleanupservice","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"What - Is Cleanup Service":"https://aka.ms/WhatIsCleanupService"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/dev-box","name":"dev-box","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/git2gridtemplate","name":"git2gridtemplate","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/git2gridtesting","name":"git2gridtesting","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/ml-test","name":"ml-test","type":"Microsoft.Resources/resourceGroups","location":"southcentralus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/msi-test-functions","name":"msi-test-functions","type":"Microsoft.Resources/resourceGroups","location":"westus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/vpn","name":"vpn","type":"Microsoft.Resources/resourceGroups","location":"ukwest","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/vpn-lon","name":"vpn-lon","type":"Microsoft.Resources/resourceGroups","location":"ukwest","properties":{"provisioningState":"Succeeded"}}]}' + string: '{"value":[{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/qiaozhatest","name":"qiaozhatest","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/sdk-net-test-qa2","name":"sdk-net-test-qa2","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/move_resource_name","name":"move_resource_name","type":"Microsoft.Resources/resourceGroups","location":"eastus2","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/lianwrs","name":"lianwrs","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","name":"iyljd2wtoqh43dern43sawzmqxkeari3bcqiadgfste4outj7cdmmslvr4yfw2vmrsqeiogmitj","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"DeleteAfter":"2020-08-15T07:02:26.327834"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_cli_mgmt_compute_test_computef5f00e12","name":"test_cli_mgmt_compute_test_computef5f00e12","type":"Microsoft.Resources/resourceGroups","location":"eastus","properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/clitesttdfkwqitc4btv3oem44vsnymesndrcfl2dbdur5jlxge5crdkdwvzeolpxpq74ynnhqy","name":"clitesttdfkwqitc4btv3oem44vsnymesndrcfl2dbdur5jlxge5crdkdwvzeolpxpq74ynnhqy","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T02:39:18Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicjesitxk4azvy7m72uudmxgtnkbwzuaz7a6kmxspiphx5f632r3spfwhvdcdxc","name":"img_tmpl_basicjesitxk4azvy7m72uudmxgtnkbwzuaz7a6kmxspiphx5f632r3spfwhvdcdxc","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T03:16:03Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigoy2maw3coop2lzcctpp4tqmjpn4wqsqgtvjjk4ejxl4vi2bjb2no3idwsnnllch","name":"img_tmpl_sigoy2maw3coop2lzcctpp4tqmjpn4wqsqgtvjjk4ejxl4vi2bjb2no3idwsnnllch","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T03:16:04Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicuvanzcnk62oe34qobbbeqhjtxnkr7f5pr7lz6uq52elmo7axqcpcp5vsqpzgv","name":"img_tmpl_basicuvanzcnk62oe34qobbbeqhjtxnkr7f5pr7lz6uq52elmo7axqcpcp5vsqpzgv","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T05:13:46Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigwga535c5xjysq3klqyu66bk3nso6p3wngzf6ieoyqq53aierzbxt7fx4pstysjx","name":"img_tmpl_sigwga535c5xjysq3klqyu66bk3nso6p3wngzf6ieoyqq53aierzbxt7fx4pstysjx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T05:13:49Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicgfpypcfirw3o2qg47bz6mhjinfw7xd45kumxpr62dzeej77fo2evwjssar7a7","name":"img_tmpl_basicgfpypcfirw3o2qg47bz6mhjinfw7xd45kumxpr62dzeej77fo2evwjssar7a7","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:09:21Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig2f53rliiuddloj2dwn6swvtnddx5yqyxink7qrrsnkyza36qxk6aio5n4h2goof","name":"img_tmpl_sig2f53rliiuddloj2dwn6swvtnddx5yqyxink7qrrsnkyza36qxk6aio5n4h2goof","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:09:23Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigbl7gcnnu2xk4ofqgpr7s6uboohfxv6r3aoxmmgtjm33bnim4ed5l7u6ioji23aw","name":"img_tmpl_sigbl7gcnnu2xk4ofqgpr7s6uboohfxv6r3aoxmmgtjm33bnim4ed5l7u6ioji23aw","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:40:04Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicbkziktwszgrofclcldjgehemhfccg3vdh7hei5iqrccskczumbb3rsz6sxrgb","name":"img_tmpl_basicbkziktwszgrofclcldjgehemhfccg3vdh7hei5iqrccskczumbb3rsz6sxrgb","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T07:40:06Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig55k2al4qqcnlkshjrnncfqqnyj76pnyntzrl2epke3l7xj7kuabg5aztlqxhg3o","name":"img_tmpl_sig55k2al4qqcnlkshjrnncfqqnyj76pnyntzrl2epke3l7xj7kuabg5aztlqxhg3o","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-23T14:21:30Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigzozdskubnbphrhq6ujx4qoibivwpknb4i3qhx7gdy5ifr452qjwr7rnbr3n2vg5","name":"img_tmpl_sigzozdskubnbphrhq6ujx4qoibivwpknb4i3qhx7gdy5ifr452qjwr7rnbr3n2vg5","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T01:14:40Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basic7okgeofcfdh3pjtlcfpiyvhoo5n2ki3y76ykv5q4hj764p3wb7o5avesnv3nl","name":"img_tmpl_basic7okgeofcfdh3pjtlcfpiyvhoo5n2ki3y76ykv5q4hj764p3wb7o5avesnv3nl","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T01:14:40Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicci4bbhiv3amoqtxxwbkra27egbgn7iarnxxethyemm3mlx3v5rq2au2c3jkxa","name":"img_tmpl_basicci4bbhiv3amoqtxxwbkra27egbgn7iarnxxethyemm3mlx3v5rq2au2c3jkxa","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T02:08:51Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig2gyqqiddiy2bcpnfqzqhp6ptvyqwyyi6o3w7yxkmdn7wxqdwwzvm4sa7b6j2udn","name":"img_tmpl_sig2gyqqiddiy2bcpnfqzqhp6ptvyqwyyi6o3w7yxkmdn7wxqdwwzvm4sa7b6j2udn","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T02:08:51Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicvz674l3kimgrkmjf5bkiuzeuajlwacvpbnftxdd7wz5hehni5yoejvnowajae","name":"img_tmpl_basicvz674l3kimgrkmjf5bkiuzeuajlwacvpbnftxdd7wz5hehni5yoejvnowajae","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T03:46:32Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sigoddhv4xs5ptliuitldhftm6x6b53x42jf7oshycnjalyqkp626dju6dgxz6rvbx","name":"img_tmpl_sigoddhv4xs5ptliuitldhftm6x6b53x42jf7oshycnjalyqkp626dju6dgxz6rvbx","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T03:46:35Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_basicxl3pfy62bj7pkxsc7q5dryq6imaqdanqt67yrx5fkibnmiflwc7dw7xufyqb4","name":"img_tmpl_basicxl3pfy62bj7pkxsc7q5dryq6imaqdanqt67yrx5fkibnmiflwc7dw7xufyqb4","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T07:23:07Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/img_tmpl_sig5r3k74ewp5brj6khls7unjwtbvnipz63mrlthznpny7hulqiyi367nh6fr44qym","name":"img_tmpl_sig5r3k74ewp5brj6khls7unjwtbvnipz63mrlthznpny7hulqiyi367nh6fr44qym","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"product":"azurecli","cause":"automation","date":"2021-02-24T07:23:07Z"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/bgbtwo5tm567agecnisclegwk2774l2iaedce5kn7trucndx6c2bdgvw45tyizcjhnbztbtts6n","name":"bgbtwo5tm567agecnisclegwk2774l2iaedce5kn7trucndx6c2bdgvw45tyizcjhnbztbtts6n","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2021-02-27T06:40:44"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/3fr3eokbnqtk7pi25ajuizojoniczfrf6256cwybeu6lrlhpe2dcb4fuyxvjutrxblj2jnsnjqe","name":"3fr3eokbnqtk7pi25ajuizojoniczfrf6256cwybeu6lrlhpe2dcb4fuyxvjutrxblj2jnsnjqe","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2021-02-27T06:43:04"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/c2ie6hhtb3ks7qxmx7afdw3ys4xwhd5347xz4gjrpj56ivl5krcwipvpc3jo22wo4ahuoans5jl","name":"c2ie6hhtb3ks7qxmx7afdw3ys4xwhd5347xz4gjrpj56ivl5krcwipvpc3jo22wo4ahuoans5jl","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"DeleteAfter":"2021-02-27T06:45:40"},"properties":{"provisioningState":"Succeeded"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}]}' headers: cache-control: no-cache content-encoding: gzip - content-length: '2375' + content-length: '2390' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:16 GMT + date: Fri, 26 Feb 2021 06:52:41 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -134,7 +132,7 @@ interactions: status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups?api-version=2020-10-01 - request: body: '{"tags": {"tag1": "valueA", "tag2": "valueB"}}' headers: @@ -145,9 +143,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050","name":"test_mgmt_resource_test_resource_groups457f1050","type":"Microsoft.Resources/resourceGroups","location":"westus","tags":{"tag1":"valueA","tag2":"valueB"},"properties":{"provisioningState":"Succeeded"}}' @@ -155,27 +153,27 @@ interactions: cache-control: no-cache content-encoding: gzip content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:18 GMT + date: Fri, 26 Feb 2021 06:52:43 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains transfer-encoding: chunked vary: Accept-Encoding x-content-type-options: nosniff - x-ms-ratelimit-remaining-subscription-writes: '1194' + x-ms-ratelimit-remaining-subscription-writes: '1199' status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-10-01 response: body: string: '{"value":[]}' @@ -184,7 +182,7 @@ interactions: content-encoding: gzip content-length: '133' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:18 GMT + date: Fri, 26 Feb 2021 06:52:43 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -193,7 +191,7 @@ interactions: status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourceGroups/test_mgmt_resource_test_resource_groups457f1050/resources?api-version=2020-10-01 - request: body: '{"resources": ["*"]}' headers: @@ -204,18 +202,18 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: POST - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-10-01 response: body: - string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[]}}' + string: '{"template":{"$schema":"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[]}}' headers: cache-control: no-cache content-encoding: gzip - content-length: '257' + content-length: '258' content-type: application/json; charset=utf-8 - date: Thu, 17 Sep 2020 08:11:19 GMT + date: Fri, 26 Feb 2021 06:52:44 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -224,93 +222,93 @@ interactions: status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050/exportTemplate?api-version=2020-10-01 - request: body: null headers: Accept: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 response: body: string: '' headers: cache-control: no-cache content-length: '0' - date: Thu, 17 Sep 2020 08:11:22 GMT + date: Fri, 26 Feb 2021 06:52:47 GMT expires: '-1' - location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff - x-ms-ratelimit-remaining-subscription-deletes: '14995' + x-ms-ratelimit-remaining-subscription-deletes: '14999' status: code: 202 message: Accepted - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/resourcegroups/test_mgmt_resource_test_resource_groups457f1050?api-version=2020-10-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' headers: cache-control: no-cache content-length: '0' - date: Thu, 17 Sep 2020 08:11:38 GMT + date: Fri, 26 Feb 2021 06:53:02 GMT expires: '-1' - location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff status: code: 202 message: Accepted - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' headers: cache-control: no-cache content-length: '0' - date: Thu, 17 Sep 2020 08:11:54 GMT + date: Fri, 26 Feb 2021 06:53:19 GMT expires: '-1' - location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + location: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains x-content-type-options: nosniff status: code: 202 message: Accepted - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 - request: body: null headers: User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 response: body: string: '' headers: cache-control: no-cache content-length: '0' - date: Thu, 17 Sep 2020 08:12:11 GMT + date: Fri, 26 Feb 2021 06:53:35 GMT expires: '-1' pragma: no-cache strict-transport-security: max-age=31536000; includeSubDomains @@ -318,5 +316,5 @@ interactions: status: code: 200 message: OK - url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-06-01 + url: https://management.azure.com/subscriptions/92f95d8f-3c67-4124-91c7-8cf07cdbf241/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGTUdNVDo1RlJFU09VUkNFOjVGVEVTVDo1RlJFU09VUkNFOjVGR1JPVVBTNDU3RjEwNTAtV0VTVFVTIiwiam9iTG9jYXRpb24iOiJ3ZXN0dXMifQ?api-version=2020-10-01 version: 1 diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_deployment_scripts.test_deployment_scripts.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_deployment_scripts.test_deployment_scripts.yaml index a7d6b3563297..91494705bcc5 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_deployment_scripts.test_deployment_scripts.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_deployment_scripts.test_deployment_scripts.yaml @@ -21,7 +21,7 @@ interactions: uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai?api-version=2015-08-31-preview response: body: - string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai","name":"uai","type":"Microsoft.ManagedIdentity/userAssignedIdentities","location":"westus","tags":{"key1":"value1"},"properties":{"tenantId":"00000000-0000-0000-0000-000000000000","principalId":"6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3","clientId":"87125114-8c82-4af1-a9a4-638511e2b898","clientSecretUrl":"https://control-westus.identity.azure.net/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai/credentials?tid=00000000-0000-0000-0000-000000000000&oid=6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3&aid=87125114-8c82-4af1-a9a4-638511e2b898"}}' + string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai","name":"uai","type":"Microsoft.ManagedIdentity/userAssignedIdentities","location":"westus","tags":{"key1":"value1"},"properties":{"tenantId":"00000000-0000-0000-0000-000000000000","principalId":"4125ce1c-3362-492c-9ac9-f857ffb84bbf","clientId":"1885b2ed-06f1-4d82-b6f7-0c386ba21c16","clientSecretUrl":"https://control-westus.identity.azure.net/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai/credentials?tid=00000000-0000-0000-0000-000000000000&oid=4125ce1c-3362-492c-9ac9-f857ffb84bbf&aid=1885b2ed-06f1-4d82-b6f7-0c386ba21c16"}}' headers: cache-control: - no-cache @@ -30,32 +30,29 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:26:09 GMT + - Fri, 26 Feb 2021 07:37:54 GMT expires: - '-1' location: - /subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai pragma: - no-cache - server: - - Microsoft-HTTPAPI/2.0 strict-transport-security: - max-age=31536000; includeSubDomains x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1195' status: code: 201 message: Created - request: - body: 'b''b\''{"identity": {"type": "UserAssigned", "userAssignedIdentities": - {"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai": + body: '{"identity": {"type": "UserAssigned", "userAssignedIdentities": {"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai": {}}}, "location": "westus", "kind": "AzurePowerShell", "properties": {"cleanupPreference": - "Always", "scriptContent": "Param([string]$Location,[string]$Name) $deploymentScriptOutputs[\\\''test\\\''] - = \\\''value\\\'' Get-AzResourceGroup -Location $Location -Name $Name", "arguments": - "-Location \\\''westus\\\'' -Name \\\\"*rg2\\\\"", "retentionInterval": "P7D", - "timeout": "PT1H", "azPowerShellVersion": "3.0"}}\''''' + "Always", "scriptContent": "Param([string]$Location,[string]$Name) $deploymentScriptOutputs[''test''] + = ''value'' Get-AzResourceGroup -Location $Location -Name $Name", "arguments": + "-Location ''westus'' -Name \"*rg2\"", "retentionInterval": "P1DT2H", "timeout": + "PT30M", "azPowerShellVersion": "3.0"}}' headers: Accept: - application/json @@ -64,11 +61,11 @@ interactions: Connection: - keep-alive Content-Length: - - '656' + - '660' Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest?api-version=2019-10-01-preview response: @@ -76,34 +73,34 @@ interactions: string: "{\r\n \"kind\": \"AzurePowerShell\",\r\n \"identity\": {\r\n \"\ type\": \"userAssigned\",\r\n \"tenantId\": \"00000000-0000-0000-0000-000000000000\"\ ,\r\n \"userAssignedIdentities\": {\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai\"\ - : {\r\n \"principalId\": \"6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3\",\r\ - \n \"clientId\": \"87125114-8c82-4af1-a9a4-638511e2b898\"\r\n \ + : {\r\n \"principalId\": \"4125ce1c-3362-492c-9ac9-f857ffb84bbf\",\r\ + \n \"clientId\": \"1885b2ed-06f1-4d82-b6f7-0c386ba21c16\"\r\n \ \ }\r\n }\r\n },\r\n \"location\": \"westus\",\r\n \"systemData\": {\r\ \n \"createdBy\": \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n \"createdByType\"\ - : \"Application\",\r\n \"createdAt\": \"2020-09-17T08:26:14.7627267Z\"\ + : \"Application\",\r\n \"createdAt\": \"2021-02-26T07:38:00.0375613Z\"\ ,\r\n \"lastModifiedBy\": \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n\ \ \"lastModifiedByType\": \"Application\",\r\n \"lastModifiedAt\": \"\ - 2020-09-17T08:26:14.7627267Z\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\"\ + 2021-02-26T07:38:00.0375613Z\"\r\n },\r\n \"properties\": {\r\n \"provisioningState\"\ : \"Creating\",\r\n \"azPowerShellVersion\": \"3.0\",\r\n \"scriptContent\"\ : \"Param([string]$Location,[string]$Name) $deploymentScriptOutputs['test']\ \ = 'value' Get-AzResourceGroup -Location $Location -Name $Name\",\r\n \ \ \"arguments\": \"-Location 'westus' -Name \\\"*rg2\\\"\",\r\n \"retentionInterval\"\ - : \"P7D\",\r\n \"timeout\": \"PT1H\",\r\n \"containerSettings\": {},\r\ - \n \"status\": {},\r\n \"cleanupPreference\": \"Always\"\r\n },\r\n\ - \ \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest\"\ + : \"P1DT2H\",\r\n \"timeout\": \"PT30M\",\r\n \"containerSettings\"\ + : {},\r\n \"status\": {},\r\n \"cleanupPreference\": \"Always\"\r\n\ + \ },\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest\"\ ,\r\n \"type\": \"Microsoft.Resources/deploymentScripts\",\r\n \"name\"\ : \"scripttest\"\r\n}" headers: azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48?api-version=2019-10-01-preview + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8?api-version=2019-10-01-preview cache-control: - no-cache content-length: - - '1631' + - '1635' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:26:21 GMT + - Fri, 26 Feb 2021 07:38:07 GMT expires: - '-1' pragma: @@ -115,7 +112,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1196' status: code: 201 message: Created @@ -129,16 +126,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48?api-version=2019-10-01-preview + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8?api-version=2019-10-01-preview response: body: - string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48\"\ - ,\r\n \"name\": \"c67b8de0-7811-4119-b140-f0abed3bbf48\",\r\n \"status\"\ + string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8\"\ + ,\r\n \"name\": \"8d79f879-1515-41ed-9be8-28707d9542b8\",\r\n \"status\"\ : \"provisioningResources\",\r\n \"error\": {\r\n \"code\": \"DeploymentScriptOperationFailed\"\ - ,\r\n \"message\": \"The client '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3'\ - \ with object id '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3' does not have authorization\ + ,\r\n \"message\": \"The client '4125ce1c-3362-492c-9ac9-f857ffb84bbf'\ + \ with object id '4125ce1c-3362-492c-9ac9-f857ffb84bbf' does not have authorization\ \ to perform action 'Microsoft.Resources/subscriptions/providers/read' over\ \ scope '/subscriptions/00000000-0000-0000-0000-000000000000' or the scope\ \ is invalid. If access was recently granted, please refresh your credentials.\"\ @@ -151,7 +148,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:26:38 GMT + - Fri, 26 Feb 2021 07:38:24 GMT expires: - '-1' pragma: @@ -179,16 +176,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48?api-version=2019-10-01-preview + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8?api-version=2019-10-01-preview response: body: - string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48\"\ - ,\r\n \"name\": \"c67b8de0-7811-4119-b140-f0abed3bbf48\",\r\n \"status\"\ + string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8\"\ + ,\r\n \"name\": \"8d79f879-1515-41ed-9be8-28707d9542b8\",\r\n \"status\"\ : \"provisioningResources\",\r\n \"error\": {\r\n \"code\": \"DeploymentScriptOperationFailed\"\ - ,\r\n \"message\": \"The client '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3'\ - \ with object id '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3' does not have authorization\ + ,\r\n \"message\": \"The client '4125ce1c-3362-492c-9ac9-f857ffb84bbf'\ + \ with object id '4125ce1c-3362-492c-9ac9-f857ffb84bbf' does not have authorization\ \ to perform action 'Microsoft.Resources/subscriptions/providers/read' over\ \ scope '/subscriptions/00000000-0000-0000-0000-000000000000' or the scope\ \ is invalid. If access was recently granted, please refresh your credentials.\"\ @@ -201,7 +198,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:08 GMT + - Fri, 26 Feb 2021 07:38:54 GMT expires: - '-1' pragma: @@ -229,16 +226,16 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48?api-version=2019-10-01-preview + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8?api-version=2019-10-01-preview response: body: - string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/c67b8de0-7811-4119-b140-f0abed3bbf48\"\ - ,\r\n \"name\": \"c67b8de0-7811-4119-b140-f0abed3bbf48\",\r\n \"status\"\ + string: "{\r\n \"id\": \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/locations/westus/deploymentScriptOperationResults/8d79f879-1515-41ed-9be8-28707d9542b8\"\ + ,\r\n \"name\": \"8d79f879-1515-41ed-9be8-28707d9542b8\",\r\n \"status\"\ : \"failed\",\r\n \"error\": {\r\n \"code\": \"DeploymentScriptOperationFailed\"\ - ,\r\n \"message\": \"The client '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3'\ - \ with object id '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3' does not have authorization\ + ,\r\n \"message\": \"The client '4125ce1c-3362-492c-9ac9-f857ffb84bbf'\ + \ with object id '4125ce1c-3362-492c-9ac9-f857ffb84bbf' does not have authorization\ \ to perform action 'Microsoft.Resources/subscriptions/providers/read' over\ \ scope '/subscriptions/00000000-0000-0000-0000-000000000000' or the scope\ \ is invalid. If access was recently granted, please refresh your credentials.\"\ @@ -251,7 +248,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:38 GMT + - Fri, 26 Feb 2021 07:39:25 GMT expires: - '-1' pragma: @@ -283,7 +280,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PATCH uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest?api-version=2019-10-01-preview response: @@ -291,25 +288,25 @@ interactions: string: "{\r\n \"kind\": \"AzurePowerShell\",\r\n \"identity\": {\r\n \"\ type\": \"userAssigned\",\r\n \"tenantId\": \"00000000-0000-0000-0000-000000000000\"\ ,\r\n \"userAssignedIdentities\": {\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai\"\ - : {\r\n \"principalId\": \"6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3\",\r\ - \n \"clientId\": \"87125114-8c82-4af1-a9a4-638511e2b898\"\r\n \ + : {\r\n \"principalId\": \"4125ce1c-3362-492c-9ac9-f857ffb84bbf\",\r\ + \n \"clientId\": \"1885b2ed-06f1-4d82-b6f7-0c386ba21c16\"\r\n \ \ }\r\n }\r\n },\r\n \"location\": \"westus\",\r\n \"tags\": {\r\n \ \ \"key1\": \"value1\"\r\n },\r\n \"systemData\": {\r\n \"createdBy\"\ : \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n \"createdByType\": \"Application\"\ - ,\r\n \"createdAt\": \"2020-09-17T08:26:14.7627267Z\",\r\n \"lastModifiedBy\"\ + ,\r\n \"createdAt\": \"2021-02-26T07:38:00.0375613Z\",\r\n \"lastModifiedBy\"\ : \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n \"lastModifiedByType\"\ - : \"Application\",\r\n \"lastModifiedAt\": \"2020-09-17T08:27:40.4931881Z\"\ + : \"Application\",\r\n \"lastModifiedAt\": \"2021-02-26T07:39:26.3541299Z\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\",\r\ \n \"azPowerShellVersion\": \"3.0\",\r\n \"scriptContent\": \"Param([string]$Location,[string]$Name)\ \ $deploymentScriptOutputs['test'] = 'value' Get-AzResourceGroup -Location\ \ $Location -Name $Name\",\r\n \"arguments\": \"-Location 'westus' -Name\ - \ \\\"*rg2\\\"\",\r\n \"retentionInterval\": \"P7D\",\r\n \"timeout\"\ - : \"PT1H\",\r\n \"containerSettings\": {},\r\n \"status\": {\r\n \ - \ \"startTime\": \"2020-09-17T08:27:34.7475113Z\",\r\n \"endTime\"\ - : \"2020-09-17T08:27:35.2319117Z\",\r\n \"expirationTime\": \"2020-09-24T08:27:35.2319117Z\"\ + \ \\\"*rg2\\\"\",\r\n \"retentionInterval\": \"P1DT2H\",\r\n \"timeout\"\ + : \"PT30M\",\r\n \"containerSettings\": {},\r\n \"status\": {\r\n \ + \ \"startTime\": \"2021-02-26T07:39:20.4466136Z\",\r\n \"endTime\"\ + : \"2021-02-26T07:39:21.1559554Z\",\r\n \"expirationTime\": \"2021-02-27T09:39:21.1559554Z\"\ ,\r\n \"error\": {\r\n \"code\": \"DeploymentScriptOperationFailed\"\ - ,\r\n \"message\": \"The client '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3'\ - \ with object id '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3' does not have authorization\ + ,\r\n \"message\": \"The client '4125ce1c-3362-492c-9ac9-f857ffb84bbf'\ + \ with object id '4125ce1c-3362-492c-9ac9-f857ffb84bbf' does not have authorization\ \ to perform action 'Microsoft.Resources/subscriptions/providers/read' over\ \ scope '/subscriptions/00000000-0000-0000-0000-000000000000' or the scope\ \ is invalid. If access was recently granted, please refresh your credentials.\"\ @@ -321,11 +318,11 @@ interactions: cache-control: - no-cache content-length: - - '2292' + - '2296' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:42 GMT + - Fri, 26 Feb 2021 07:39:28 GMT expires: - '-1' pragma: @@ -341,7 +338,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1195' status: code: 200 message: OK @@ -355,7 +352,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest?api-version=2019-10-01-preview response: @@ -363,25 +360,25 @@ interactions: string: "{\r\n \"kind\": \"AzurePowerShell\",\r\n \"identity\": {\r\n \"\ type\": \"userAssigned\",\r\n \"tenantId\": \"00000000-0000-0000-0000-000000000000\"\ ,\r\n \"userAssignedIdentities\": {\r\n \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.ManagedIdentity/userAssignedIdentities/uai\"\ - : {\r\n \"principalId\": \"6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3\",\r\ - \n \"clientId\": \"87125114-8c82-4af1-a9a4-638511e2b898\"\r\n \ + : {\r\n \"principalId\": \"4125ce1c-3362-492c-9ac9-f857ffb84bbf\",\r\ + \n \"clientId\": \"1885b2ed-06f1-4d82-b6f7-0c386ba21c16\"\r\n \ \ }\r\n }\r\n },\r\n \"location\": \"westus\",\r\n \"tags\": {\r\n \ \ \"key1\": \"value1\"\r\n },\r\n \"systemData\": {\r\n \"createdBy\"\ : \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n \"createdByType\": \"Application\"\ - ,\r\n \"createdAt\": \"2020-09-17T08:26:14.7627267Z\",\r\n \"lastModifiedBy\"\ + ,\r\n \"createdAt\": \"2021-02-26T07:38:00.0375613Z\",\r\n \"lastModifiedBy\"\ : \"8a95323f-4a83-4a69-903f-7d2c69349c3c\",\r\n \"lastModifiedByType\"\ - : \"Application\",\r\n \"lastModifiedAt\": \"2020-09-17T08:27:40.4931881Z\"\ + : \"Application\",\r\n \"lastModifiedAt\": \"2021-02-26T07:39:26.3541299Z\"\ \r\n },\r\n \"properties\": {\r\n \"provisioningState\": \"Failed\",\r\ \n \"azPowerShellVersion\": \"3.0\",\r\n \"scriptContent\": \"Param([string]$Location,[string]$Name)\ \ $deploymentScriptOutputs['test'] = 'value' Get-AzResourceGroup -Location\ \ $Location -Name $Name\",\r\n \"arguments\": \"-Location 'westus' -Name\ - \ \\\"*rg2\\\"\",\r\n \"retentionInterval\": \"P7D\",\r\n \"timeout\"\ - : \"PT1H\",\r\n \"containerSettings\": {},\r\n \"status\": {\r\n \ - \ \"startTime\": \"2020-09-17T08:27:34.7475113Z\",\r\n \"endTime\"\ - : \"2020-09-17T08:27:35.2319117Z\",\r\n \"expirationTime\": \"2020-09-24T08:27:35.2319117Z\"\ + \ \\\"*rg2\\\"\",\r\n \"retentionInterval\": \"P1DT2H\",\r\n \"timeout\"\ + : \"PT30M\",\r\n \"containerSettings\": {},\r\n \"status\": {\r\n \ + \ \"startTime\": \"2021-02-26T07:39:20.4466136Z\",\r\n \"endTime\"\ + : \"2021-02-26T07:39:21.1559554Z\",\r\n \"expirationTime\": \"2021-02-27T09:39:21.1559554Z\"\ ,\r\n \"error\": {\r\n \"code\": \"DeploymentScriptOperationFailed\"\ - ,\r\n \"message\": \"The client '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3'\ - \ with object id '6b4c193f-bb7a-4546-83ef-9b0c1b72d5d3' does not have authorization\ + ,\r\n \"message\": \"The client '4125ce1c-3362-492c-9ac9-f857ffb84bbf'\ + \ with object id '4125ce1c-3362-492c-9ac9-f857ffb84bbf' does not have authorization\ \ to perform action 'Microsoft.Resources/subscriptions/providers/read' over\ \ scope '/subscriptions/00000000-0000-0000-0000-000000000000' or the scope\ \ is invalid. If access was recently granted, please refresh your credentials.\"\ @@ -393,11 +390,11 @@ interactions: cache-control: - no-cache content-length: - - '2292' + - '2296' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:42 GMT + - Fri, 26 Feb 2021 07:39:28 GMT expires: - '-1' pragma: @@ -425,7 +422,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest/logs/default?api-version=2019-10-01-preview response: @@ -441,7 +438,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:43 GMT + - Fri, 26 Feb 2021 07:39:29 GMT expires: - '-1' pragma: @@ -469,7 +466,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest/logs?api-version=2019-10-01-preview response: @@ -486,7 +483,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:27:43 GMT + - Fri, 26 Feb 2021 07:39:29 GMT expires: - '-1' pragma: @@ -516,7 +513,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Resources/deploymentScripts/scripttest?api-version=2019-10-01-preview response: @@ -528,7 +525,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:27:46 GMT + - Fri, 26 Feb 2021 07:39:32 GMT expires: - '-1' pragma: @@ -540,7 +537,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14997' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_features.test_features.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_features.test_features.yaml index bed2aed84519..c37f5b20f977 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_features.test_features.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_features.test_features.yaml @@ -9,21 +9,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/features?api-version=2015-12-01 response: body: - string: '{"value":[{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/preview","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIaaS/features/cloudSimpleRp1","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIaaS/cloudSimpleRp1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp10","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp10"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp11","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp12","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp13","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp13"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp14","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp14"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp15","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp15"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp16","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp17","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp18","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp19","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp2","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp20","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp20"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp21","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp21"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp22","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp22"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp23","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp23"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp24","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp24"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp25","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp25"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp6","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp7","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp7"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp8","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp8"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp9","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp9"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/stagingRP","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/stagingRP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/previewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/previewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/tipAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/tipAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.aadiam/features/betalogconnector","type":"Microsoft.Features/providers/features","name":"microsoft.aadiam/betalogconnector"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.aadiam/features/testinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.aadiam/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Advisor/features/dev","type":"Microsoft.Features/providers/features","name":"Microsoft.Advisor/dev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.alertsmanagement/features/enableSmartDiagnostics","type":"Microsoft.Features/providers/features","name":"microsoft.alertsmanagement/enableSmartDiagnostics"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/testinproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/testinproductionmdm","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/testinproductionmdm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Archive/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Archive/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/aseAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/aseAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ccAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ccAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ciAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ciAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/dsc","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/dsc"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/eapAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/eapAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ncusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ncusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/neAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/neAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/scusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/scusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/wcusuksAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/wcusuksAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/B2CV2Resource","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/B2CV2Resource"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/CPIMCSP","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/CPIMCSP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/eosEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/eosEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/tinaEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/tinaEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureStack/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureStack/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureStack/features/Marketplace","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureStack/Marketplace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/BatchAccountWhitelistSAN","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/BatchAccountWhitelistSAN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/portaltest","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/portaltest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/portaltest2","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/portaltest2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/SwiftProd","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/SwiftProd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BatchAI/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.BatchAI/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BatchAI/features/workspace","type":"Microsoft.Features/providers/features","name":"Microsoft.BatchAI/workspace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BigAnalytics/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.BigAnalytics/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Blockchain/features/privatePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Blockchain/privatePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cache/features/betaAccess2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cache/betaAccess2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cache/features/betaAccess3","type":"Microsoft.Features/providers/features","name":"Microsoft.Cache/betaAccess3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cache/features/CanaryCheckNameAvailability","type":"Microsoft.Features/providers/features","name":"microsoft.cache/CanaryCheckNameAvailability"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicIaaSMigrate/features/ClassicIaaSMigrate","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicIaaSMigrate/ClassicIaaSMigrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicInfrastructureMigrate/features/ClassicInfrastructureMigrate","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicInfrastructureMigrate/ClassicInfrastructureMigrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicSubscription/features/InternalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicSubscription/InternalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/internalmsft","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/internalmsft"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/internalonly","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/internalonly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/testinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/AutoApproveFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/AutoApproveFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/formUnderstandingPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/formUnderstandingPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/TokenAuthPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/TokenAuthPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalAdvancedSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalAdvancedSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CAPSImagePublishing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CAPSImagePublishing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalStandardSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalStandardSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CorPersistence","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CorPersistence"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DedicatedNodeGroup","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DedicatedNodeGroup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/disableDisksAndSnapshotsPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/disableDisksAndSnapshotsPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableSerialConsole"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EnableCrossSubscriptionWithKeyVaultResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EnableCrossSubscriptionWithKeyVaultResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtensionsFastpath","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtensionsFastpath"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtraLargeVMScaleSetPerfEvaluation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtraLargeVMScaleSetPerfEvaluation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableDeadMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableDeadMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateDiskCopyForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateDiskCopyForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.StopMigrateSkipDiskCopyForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.StopMigrateSkipDiskCopyForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.VMPreprovisioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.VMPreprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/Fabric.UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/Fabric.UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/FastPollingOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/FastPollingOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Foobar","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Foobar"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageBigBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageBigBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryApplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryApplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageHighScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageHighScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryRemoveUserSourceDependency","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryRemoveUserSourceDependency"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ImpedeFastPolling","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ImpedeFastPolling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/IncrementalSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/IncrementalSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestVMUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestVMUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LocalDiffDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LocalDiffDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/lowprioritysinglevm","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/lowprioritysinglevm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedDisksPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedDisksPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedResourcesMove","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedResourcesMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MRProfile","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MRProfile"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/MultipleAvailabilityZones","type":"Microsoft.Features/providers/features","name":"microsoft.compute/MultipleAvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NetworkPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NetworkPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NewAllocator","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NewAllocator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NodeFlight","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NodeFlight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OptOutScaleSetPipelinePreemption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OptOutScaleSetPipelinePreemption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OSUpgradeForServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OSUpgradeForServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/OverProvision","type":"Microsoft.Features/providers/features","name":"microsoft.compute/OverProvision"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverprovisionedExtensionDelay","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverprovisionedExtensionDelay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalance","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalance"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithFDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithFDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PerfTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PerfTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PremiumDiskLatencyOptimized","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PremiumDiskLatencyOptimized"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ProximityPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ProximityPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RegionalUltraSSDVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RegionalUltraSSDVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RepairVMScaleSetInstancesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RepairVMScaleSetInstancesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/Reprovisioning","type":"Microsoft.Features/providers/features","name":"microsoft.compute/Reprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePolicyOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePolicyOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RunScripts","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RunScripts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEnablePremiumLRSReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEnablePremiumLRSReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/SpotMeterValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/SpotMeterValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/StandardSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/StandardSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TenantReserveActivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TenantReserveActivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TipNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TipNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraSSDWithVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraSSDWithVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionForVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionForVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionWithOSUpgrades","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionWithOSUpgrades"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UsePreprovisionedVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UsePreprovisionedVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UserImageSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UserImageSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VirtualMachineRuntimeServiceDisablePackageValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VirtualMachineRuntimeServiceDisablePackageValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMPipelineBatchingPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMPipelineBatchingPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewV2Access","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewV2Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ZRSImagesAndSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ZRSImagesAndSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ConnectedEnvironment/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.ConnectedEnvironment/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/aciOnAtlas","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/aciOnAtlas"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/extension","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/extension"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/privatepreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/privatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/previewSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/previewSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegisry/features/BlockRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegisry/BlockRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/privilegedSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/privilegedSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/BlockRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/BlockRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/BetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/BetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AAD","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AAD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ACS-EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ACS-EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ACSVNext","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ACSVNext"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AddContainerInsightsSolution","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AddContainerInsightsSolution"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-AzurePolicyAutoApprove","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-AzurePolicyAutoApprove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CanadaCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CanadaCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CanadaEast","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CanadaEast"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CentralUS","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CentralUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-EastUS","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-EastUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-EnableAzureDataPlanePolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-EnableAzureDataPlanePolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-INT","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-INT"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-RegionEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-RegionEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-UKWest","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-UKWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSAuditLog","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSAuditLog"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-WestUS2","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-WestUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AksBypassRegionWritesDisabled","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AksBypassRegionWritesDisabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSAzureStandardLoadBalancer","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSAzureStandardLoadBalancer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSHTTPCustomFeatures","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSHTTPCustomFeatures"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AksBypassServiceGate","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AksBypassServiceGate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSLockingDownEgressPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSLockingDownEgressPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSPrivateLinkPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSPrivateLinkPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowSwarmWindowsAgent","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowSwarmWindowsAgent"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/APIServerSecurityPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/APIServerSecurityPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AROGA","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AROGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ARORemoteGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ARORemoteGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AvailabilityZonePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AvailabilityZonePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ControlPlaneUnderlay","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ControlPlaneUnderlay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/DockerEngineImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/DockerEngineImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableCCPMutatingWebhook","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableCCPMutatingWebhook"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableNetworkPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableNetworkPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableSingleIPPerCCP","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableSingleIPPerCCP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/HTTP-Application-Routing","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/HTTP-Application-Routing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableXTablesLock","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableXTablesLock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ManagedCluster","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ManagedCluster"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/LowPriorityPoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/LowPriorityPoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MSIPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MSIPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MobyImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MobyImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MultiAgentpoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MultiAgentpoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/NodePublicIPPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/NodePublicIPPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenVPN","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenVPN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenshiftManagedCluster","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenshiftManagedCluster"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSABypassMarketplace","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSABypassMarketplace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSAInProgressFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSAInProgressFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/PodSecurityPolicyPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/PodSecurityPolicyPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/RBAC","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/RBAC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/V20180331API","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/V20180331API"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/SaveOSATestConfig","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/SaveOSATestConfig"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/WindowsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/WindowsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/VMSSPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/VMSSPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Contoso/features/RPaaSSampleApp","type":"Microsoft.Features/providers/features","name":"Microsoft.Contoso/RPaaSSampleApp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CostManagementBeta/features/TenantRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.CostManagementBeta/TenantRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomerInsights/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomerInsights/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/customrp","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/customrp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/associations","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/associations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/UpcomingRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/UpcomingRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/HeavyCreateAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/HeavyCreateAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/DBEIntAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/DBEIntAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/EdgeSignUp","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/EdgeSignUp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/PassiveStampAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/PassiveStampAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksEUAPAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksEUAPAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksControlPlane","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksControlPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/TowboatAllowedSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/TowboatAllowedSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksTestEnv","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksTestEnv"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PPEAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PPEAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PRODAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PRODAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PRODAccessNew","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PRODAccessNew"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/DFAccessInBuildout","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/DFAccessInBuildout"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataExchange/features/workspacePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataExchange/workspacePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/GatewayHAPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/GatewayHAPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/GatewayHAPublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/GatewayHAPublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/requestedBetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/requestedBetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeStore/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeStore/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeStore/features/requestedBetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeStore/requestedBetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/BuddyA","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/BuddyA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/demo","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/demo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/int","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/staging","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/staging"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataShare/features/ReactSqlUxPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataShare/ReactSqlUxPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/privatePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/privatePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/threatdetection","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/threatdetection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DbforMySQL/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DbforMySQL/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbformysql/features/webappnewbizmodel","type":"Microsoft.Features/providers/features","name":"microsoft.dbformysql/webappnewbizmodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/citus64vCores","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/citus64vCores"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/cituspreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/cituspreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/citusRoles","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/citusRoles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/indexAdvisor","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/indexAdvisor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossazureactivedirectoryadmin","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossazureactivedirectoryadmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbforpostgresql/features/pgversionten","type":"Microsoft.Features/providers/features","name":"microsoft.dbforpostgresql/pgversionten"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbforpostgresql/features/webappnewbizmodel","type":"Microsoft.Features/providers/features","name":"microsoft.dbforpostgresql/webappnewbizmodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/admdev","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/admdev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/ignite2018PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/ignite2018PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.devices/features/AzureIoTElasticPools","type":"Microsoft.Features/providers/features","name":"microsoft.devices/AzureIoTElasticPools"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.devices/features/AzureIoTProvisioningService","type":"Microsoft.Features/providers/features","name":"microsoft.devices/AzureIoTProvisioningService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Devices/features/PublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Devices/PublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Integration","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Integration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test2","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test3","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test4","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dns/features/privatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.dns/privatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/autopilot-flight-3","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/autopilot-flight-3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/storageanalytics-public-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/storageanalytics-public-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DomainRegistration/features/betaGD","type":"Microsoft.Features/providers/features","name":"Microsoft.DomainRegistration/betaGD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventGrid/features/storageEventSubscriptions","type":"Microsoft.Features/providers/features","name":"Microsoft.EventGrid/storageEventSubscriptions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Experimentation/features/POC","type":"Microsoft.Features/providers/features","name":"Microsoft.Experimentation/POC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DataBoxCanaryTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DataBoxCanaryTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DataIngestionService","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DataIngestionService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DeviceImportAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DeviceImportAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/diskimportaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/diskimportaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/ExpressPodCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/ExpressPodCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/IgniteSignup","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/IgniteSignup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/MockGdcoAndUps","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/MockGdcoAndUps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/MockXtService","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/MockXtService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExternalShim/features/ExternalShimAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ExternalShim/ExternalShimAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Genomics/features/DevelopmentEnvironmentAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Genomics/DevelopmentEnvironmentAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/CanaryParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/CanaryParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GA20181120","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GA20181120"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HanaOnAzure/features/noAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.HanaOnAzure/noAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/AzureDedicatedHsm","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/AzureDedicatedHsm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/DedicatedHsmEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/DedicatedHsmEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/deploymentVerification","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/deploymentVerification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/drillVerification","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/drillVerification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/UseDogfoodHSM","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/UseDogfoodHSM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/UseDogfoodHsmAdminPlane","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/UseDogfoodHsmAdminPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/HybridComputePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/HybridComputePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridcompute/features/HybridComputeExtensionPreview","type":"Microsoft.Features/providers/features","name":"microsoft.hybridcompute/HybridComputeExtensionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/HybridRPCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/HybridRPCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridData/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridData/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/AIMONEnvironment","type":"Microsoft.Features/providers/features","name":"microsoft.insights/AIMONEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/actiongrouptestinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.insights/actiongrouptestinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/azurehealthlimitedpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/azurehealthlimitedpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/azurehealthpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/azurehealthpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/baseline-preview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/baseline-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/baseline-dogfood","type":"Microsoft.Features/providers/features","name":"microsoft.insights/baseline-dogfood"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/billingv3","type":"Microsoft.Features/providers/features","name":"microsoft.insights/billingv3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/diagnosticsettingpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/diagnosticsettingpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/customMetric","type":"Microsoft.Features/providers/features","name":"microsoft.insights/customMetric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableCCAN","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableCCAN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableCHNRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableCHNRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableCID","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableCID"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableNOERegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableNOERegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableNOWRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableNOWRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableSEA","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableSEA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableSEAURegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableSEAURegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableSUK","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableSUK"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableWestUS2","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableWestUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/metricalertprivatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/metricalertprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/metricalertmultidimprivatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/metricalertmultidimprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NotificationRulePreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NotificationRulePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NotificationGroupPreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NotificationGroupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/ScheduledQueryRulesPROD","type":"Microsoft.Features/providers/features","name":"microsoft.insights/ScheduledQueryRulesPROD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/ScheduledQueryRulesAIMON","type":"Microsoft.Features/providers/features","name":"microsoft.insights/ScheduledQueryRulesAIMON"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/testinproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/testinproductionmdm","type":"Microsoft.Features/providers/features","name":"microsoft.insights/testinproductionmdm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/testinproductionnms","type":"Microsoft.Features/providers/features","name":"microsoft.insights/testinproductionnms"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTCentral/features/metering","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTCentral/metering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/CanaryCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/CanaryCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/MVP","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/MVP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IotSpaces/features/PPECustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IotSpaces/PPECustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IotSpaces/features/PreviewCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IotSpaces/PreviewCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/ScaleTestCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/ScaleTestCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/EventGridPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/EventGridPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/HSMPoolEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/HSMPoolEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kona/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kona/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kona/features/betaAccess2","type":"Microsoft.Features/providers/features","name":"Microsoft.Kona/betaAccess2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kubernetes/features/previewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kubernetes/previewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/sourceControlConfiguration","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/sourceControlConfiguration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowSwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowSwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseSharedIdentities","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseSharedIdentities"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.LabServices/features/DevInProdIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.LabServices/DevInProdIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AllowCrossSubscriptionGatewayAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AllowCrossSubscriptionGatewayAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AmeProjectionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AmeProjectionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AllowUnlimitedLogicApps","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AllowUnlimitedLogicApps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/FairfaxDemo","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/FairfaxDemo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/HostingEnvironmentsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/HostingEnvironmentsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPrivateRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPrivateRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPreviewDisable","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPreviewDisable"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningCompute/features/ViennaPublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningCompute/ViennaPublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningExperimentation/features/CanaryFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningExperimentation/CanaryFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Maintenance/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Maintenance/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ManagedIdentity/features/EnableSecurityGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.ManagedIdentity/EnableSecurityGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ManagedNetwork/features/mncbetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ManagedNetwork/mncbetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Microsoft/features/AllowNetworkWatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Microsoft/AllowNetworkWatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Mindaro/features/tip2","type":"Microsoft.Features/providers/features","name":"Microsoft.Mindaro/tip2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Mindaro/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.Mindaro/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/AllowSMB","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/AllowSMB"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFGATenant","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFGATenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFNFSv4Preview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFNFSv4Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFReplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFReplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSnapRestorePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSnapRestorePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/managementNicAdmin","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/managementNicAdmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/testing","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/testing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAcceleratedNetworkingFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAcceleratedNetworkingFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAccessRuleExtendedProperties","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAccessRuleExtendedProperties"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAcceleratedNetworkingForLinux","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAcceleratedNetworkingForLinux"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateOptimizations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateOptimizations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateAsyncValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateAsyncValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwWafBotManagerRuleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwWafBotManagerRuleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwPerSiteFirewallPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwPerSiteFirewallPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayClientAuthentication","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayClientAuthentication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwWafCustomRuleGeoMatch","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwWafCustomRuleGeoMatch"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayLoadDistributionPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayLoadDistributionPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV2WildcardListener","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV2WildcardListener"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationSecurityGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationSecurityGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayZonePinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayZonePinning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAzureFirewall","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAzureFirewall"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAsgsOnVmScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAsgsOnVmScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBaremetalServers","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBaremetalServers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBastionHostPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBastionHostPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBastionHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBastionHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowClassicCrossSubscriptionPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowClassicCrossSubscriptionPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBringYourOwnPublicIpAddress","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBringYourOwnPublicIpAddress"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCoExistenceAnyOrder","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCoExistenceAnyOrder"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexExpressRouteGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexExpressRouteGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexGlobalVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexGlobalVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexSecurity","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexSecurity"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDdosProtectionPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDdosProtectionPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDisableBgpRouteProgagation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDisableBgpRouteProgagation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDestinationServiceEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDestinationServiceEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDSeriesForBrooklyn","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDSeriesForBrooklyn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.network/features/allowERArmProviderPortal","type":"Microsoft.Features/providers/features","name":"microsoft.network/allowERArmProviderPortal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDynamicRedirectToTestGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDynamicRedirectToTestGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowExRCrossRegionResourceValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowExRCrossRegionResourceValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFpgaEnabledClustersFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFpgaEnabledClustersFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFrontdoor","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFrontdoor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalCrpHttpClient","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalCrpHttpClient"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalTagsForSql","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalTagsForSql"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalPeeringTransit","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalPeeringTransit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalTagsForStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalTagsForStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowHidingCrossSubscriptionResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowHidingCrossSubscriptionResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGRPeerConnection","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGRPeerConnection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowILBAllPortsRule","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowILBAllPortsRule"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIntendedPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIntendedPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIntentedPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIntentedPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowInterfaceEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowInterfaceEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowInternalDelegations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowInternalDelegations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIPv6CAOnStandardLB","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIPv6CAOnStandardLB"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpv6GlobalReach","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpv6GlobalReach"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIPv6VirtualNetwork","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIPv6VirtualNetwork"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreviewWave2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreviewWave2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreviewWave3","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreviewWave3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBSNATallocationPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBSNATallocationPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLoadBalancingOnSecondaryIpConfigs","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLoadBalancingOnSecondaryIpConfigs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMacPreservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMacPreservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMaxPrivateLinkServicesPerLoadBalancerOptimization","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMaxPrivateLinkServicesPerLoadBalancerOptimization"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultiNicOnVMScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultiNicOnVMScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultipleAddressPrefixesOnSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultipleAddressPrefixesOnSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultipleIpConfigurationsPerNic","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultipleIpConfigurationsPerNic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMutipleAddressPrefixesOnSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMutipleAddressPrefixesOnSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNatGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNatGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetwatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetwatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkIntentPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkIntentPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkProfiles","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkProfiles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcher","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcher"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcherConnectivityCheck","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcherConnectivityCheck"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicyPrivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicyPrivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicySlice","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicySlice"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicyValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicyValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpResourcePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpResourcePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpVirtualRouterSlice","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpVirtualRouterSlice"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowOutboundNatRule","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowOutboundNatRule"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowP2SCortexAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowP2SCortexAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPaaSEndpointAcl","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPaaSEndpointAcl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPingMesh","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPingMesh"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreflightValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreflightValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrepareNetworkPoliciesAction","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrepareNetworkPoliciesAction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateLinkServices","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateLinkServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPseudoClientAppId","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPseudoClientAppId"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpMobility","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpMobility"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIPOnVMScaleSetVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIPOnVMScaleSetVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpPrefix","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpPrefix"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpsAndLoadBalancingOnSecondaryIpConfigsInVMScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpsAndLoadBalancingOnSecondaryIpConfigsInVMScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToApplicationGatewayBvt1Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToApplicationGatewayBvt1Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteBvt2Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteBvt2Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteBvt3Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteBvt3Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteCPGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteCPGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteDPGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteDPGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteMXGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteMXGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteRSGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteRSGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectMaps","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectMaps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRegionalGatewayManagerForSecureGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRegionalGatewayManagerForSecureGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRegionalVMSSVirtualNetworkGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRegionalVMSSVirtualNetworkGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRouteServiceAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRouteServiceAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRouteTables","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRouteTables"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingPreferenceFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingPreferenceFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRPGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRPGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSecureVnets","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSecureVnets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowServiceEndpointPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowServiceEndpointPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSingleNicAndMultiNicInSameAvailabilitySet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSingleNicAndMultiNicInSameAvailabilitySet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowStandardLBOutboundRulesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowStandardLBOutboundRulesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowStaticPublicIpAsInstanceIp","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowStaticPublicIpAsInstanceIp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubnetDelegation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubnetDelegation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubscriptionMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubscriptionMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowThrottleCrpOperations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowThrottleCrpOperations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVMsFromDifferentVnetsOnAvailabilitySet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVMsFromDifferentVnetsOnAvailabilitySet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVMSSVirtualNetworkGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVMSSVirtualNetworkGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVmssHealthProbe","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVmssHealthProbe"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVnetGatewayOpenVpnProtocol","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVnetGatewayOpenVpnProtocol"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.network/features/AllowVpnclientIpsecPoliciesSet","type":"Microsoft.Features/providers/features","name":"microsoft.network/AllowVpnclientIpsecPoliciesSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/armApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/azurednspreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/azurednspreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/bastionShareableLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/bastionShareableLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsAliasPortalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsAliasPortalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsBdmProd","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsBdmProd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsBdmPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsBdmPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsReleaseCandidate","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsReleaseCandidate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableDdosProtectionPlanBilling","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableDdosProtectionPlanBilling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableOperationBatching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableOperationBatching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableTenantNoSyncLock","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableTenantNoSyncLock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableTenantOperationBatching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableTenantOperationBatching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableValidationInBackgroundTask","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableValidationInBackgroundTask"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/HybridRegionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/HybridRegionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ExrGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ExrGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/InternetAnalyzerPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/InternetAnalyzerPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/isVMSSVirtualNetworkGatewayAllowed","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/isVMSSVirtualNetworkGatewayAllowed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/PrivateDnsGcpPPE","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/PrivateDnsGcpPPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/PrivateDnsGcpDaily","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/PrivateDnsGcpDaily"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/SkipPseudoVipGeneration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/SkipPseudoVipGeneration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/SecureGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/SecureGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ThrottleArmOperationsRnm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ThrottleArmOperationsRnm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/TestFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/TestFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/TrafficManagerHeatMap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/TrafficManagerHeatMap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Netwotk/features/AllowGlobalPeeringTransit","type":"Microsoft.Features/providers/features","name":"Microsoft.Netwotk/AllowGlobalPeeringTransit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/VpnGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/VpnGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NotificationHubs/features/NHubMetrics","type":"Microsoft.Features/providers/features","name":"Microsoft.NotificationHubs/NHubMetrics"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.OperationalInsights/features/LAClusterApiEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.OperationalInsights/LAClusterApiEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.OperationalInsights/features/SwitzerlandRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.OperationalInsights/SwitzerlandRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowCarrierInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowCarrierInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowDirectInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowDirectInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowCDNInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowCDNInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowDirectPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowDirectPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowExchangeInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowExchangeInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowPeeringService","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowPeeringService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowExchangePeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowExchangePeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/AKS-DataPlaneAutoApprove","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/AKS-DataPlaneAutoApprove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/Insights","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/Insights"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/Events","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/Events"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/States","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/States"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Project/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.Project/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/32DiskBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/32DiskBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/AzureFileShareBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/AzureFileShareBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/BackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/BackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/BlockedFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/BlockedFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/CrossRegionRestore","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/CrossRegionRestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/HanaBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/HanaBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/InstantBackupandRecovery","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/InstantBackupandRecovery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/ItemLevelRecovery","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/ItemLevelRecovery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/LargeDiskVMBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/LargeDiskVMBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MABAlertingFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MABAlertingFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MercuryAutoProtection","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MercuryAutoProtection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/PPEAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/PPEAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/PremiumStorageBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/PremiumStorageBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesCanada","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesCanada"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesBeta","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesBeta"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesResourceMove","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesResourceMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesUK","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesUK"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesWUS2","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesWUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/ResourceGraphSyncEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/ResourceGraphSyncEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/WorkloadBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/WorkloadBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/CspTest","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/CspTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/PrivacyEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/PrivacyEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/ple","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/ple"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resouces/features/EUAPParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resouces/EUAPParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AllowInternalDelegations","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AllowInternalDelegations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ARMDisableResourcesPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ARMDisableResourcesPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ARMLimitx2","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ARMLimitx2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AvailabilityZones","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AzureBuildout","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AzureBuildout"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/DataControlAgreement","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/DataControlAgreement"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/EUAPParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/EUAPParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/FairfaxDemo","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/FairfaxDemo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyWestCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyWestCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/mandatoryRetentionPeriodEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/mandatoryRetentionPeriodEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayEast","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayEast"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayWest","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/SouthAfricaRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/SouthAfricaRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.resources/features/SwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"microsoft.resources/SwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/SwitzerlandRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/SwitzerlandRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.resources/features/SwitzerlandWest","type":"Microsoft.Features/providers/features","name":"microsoft.resources/SwitzerlandWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/TestFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/TestFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ThrottledSubscriptions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ThrottledSubscriptions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/UAERegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/UAERegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Saas/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Saas/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/AdvancedThreatProtection","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/AdvancedThreatProtection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ApplicationWhitelisting","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ApplicationWhitelisting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ApplicationWhiteliting","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ApplicationWhiteliting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/appwhitelistingaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/appwhitelistingaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.security/features/Assessments","type":"Microsoft.Features/providers/features","name":"microsoft.security/Assessments"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/CoreDev1","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/CoreDev1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev1","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev2","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev3","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/discoveredSecuritySolutions","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/discoveredSecuritySolutions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/externalSecuritySolutions","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/externalSecuritySolutions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Integration","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Integration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-dev2","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-dev2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-dev3","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-dev3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-int","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-rome3int","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-rome3int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitvmaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitvmaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/NacJIT","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/NacJIT"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.security/features/NetworkData","type":"Microsoft.Features/providers/features","name":"microsoft.security/NetworkData"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/networkMap","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/networkMap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/northSouth","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/northSouth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/PricingBundles","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/PricingBundles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ShzadaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ShzadaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/VaGrayLabel","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/VaGrayLabel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/WindowsDefenderAtp","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/WindowsDefenderAtp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SerialConsole/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SerialConsole/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/seabreezePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/seabreezePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/seabreezePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/seabreezePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/serviceFabricEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/serviceFabricEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/serviceFabricStageAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/serviceFabricStageAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabricMesh/features/seabreezePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabricMesh/seabreezePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabricMesh/features/serviceFabricEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabricMesh/serviceFabricEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Services/features/RPSaaSPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Services/RPSaaSPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SignalR/features/betaaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SignalR/betaaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SignalRService/features/betaaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SignalRService/betaaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplianceEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplianceEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplianceMultiRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplianceMultiRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/AppliancePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/AppliancePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplicationGA","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplicationGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/4tbpool","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/4tbpool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/4TBOption","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/4TBOption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/dataSync","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/dataSync"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/dataeditor-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/dataeditor-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/dw-asa","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/dw-asa"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/ExternalTdeCertificate","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/ExternalTdeCertificate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/firewall-enforce-azure-policy","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/firewall-enforce-azure-policy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/hyperscale-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/hyperscale-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisor","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisorPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisorPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisorPublic","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisorPublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/LongTermRetention","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/LongTermRetention"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/LongTermRetentionV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/LongTermRetentionV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/ManagedInstancePublic","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/ManagedInstancePublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-test","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/pesto","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/pesto"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/pesto-lite","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/pesto-lite"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor-webqueryendpoint","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor-webqueryendpoint"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/QueryPerformanceInsightPublic","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/QueryPerformanceInsightPublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/serverless-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/serverless-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/SQL-DW","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/SQL-DW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-4tb-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-4tb-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-ActiveDirectoryAdmin","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-ActiveDirectoryAdmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/sqldb-addonstorage","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/sqldb-addonstorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-ElasticJobs","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-ElasticJobs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-elasticpool","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-elasticpool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-fsv2","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-fsv2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-higherStandardPerDbDtu","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-higherStandardPerDbDtu"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-JobAccounts","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-JobAccounts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-mseries","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-mseries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-premiumrs","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-premiumrs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-vcoremodel","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-vcoremodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldbsterling","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldbsterling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldbtde","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldbtde"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/tdeAkvIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/tdeAkvIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/ADLSGen1Shim","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/ADLSGen1Shim"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/adlsgen2BlobInterop","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/adlsgen2BlobInterop"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowADFS","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowADFS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowArchive","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowArchive"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowHNS","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowHNS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowLinuxOptimizedShares","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowLinuxOptimizedShares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/AllowNFSV3","type":"Microsoft.Features/providers/features","name":"microsoft.storage/AllowNFSV3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowStorageV1Accounts","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowStorageV1Accounts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowTargetStampSpecification","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowTargetStampSpecification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/armApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/BlobIndex","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/BlobIndex"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/BlobQuery","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/BlobQuery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Changefeed","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Changefeed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/ContainerSoftDelete","type":"Microsoft.Features/providers/features","name":"microsoft.storage/ContainerSoftDelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/CustomerControlledFailover","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/CustomerControlledFailover"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/EncryptionAtRest","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/EncryptionAtRest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/jurobins","type":"Microsoft.Features/providers/features","name":"microsoft.storage/jurobins"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/LivesiteThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/LivesiteThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/ObjectReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/ObjectReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/premiumblob","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/premiumblob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.storage/features/PremiumHns","type":"Microsoft.Features/providers/features","name":"Microsoft.storage/PremiumHns"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/RestoreBlobRanges","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/RestoreBlobRanges"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Tags","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Tags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/version","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/version"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Versioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Versioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/XArchive","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/XArchive"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorageCache/features/generalAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorageCache/generalAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storagereplication/features/SOS","type":"Microsoft.Features/providers/features","name":"microsoft.storagereplication/SOS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/betaAcess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/betaAcess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/EnableUnsupportedGeo","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/EnableUnsupportedGeo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/StorSimpleGardaIbizaInGA","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/StorSimpleGardaIbizaInGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/StorSimpleGardaIbizaMigrated","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/StorSimpleGardaIbizaMigrated"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StreamAnalytics/features/ASA_NewRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.StreamAnalytics/ASA_NewRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StreamAnalytics/features/ProdWestUSX","type":"Microsoft.Features/providers/features","name":"Microsoft.StreamAnalytics/ProdWestUSX"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/extendedCapacityAndRetention","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/extendedCapacityAndRetention"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/previewV2","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/previewV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Token/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Token/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Uic/features/uxdevelopment","type":"Microsoft.Features/providers/features","name":"Microsoft.Uic/uxdevelopment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/CanaryAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/CanaryAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VisualStudio/features/ExtensionResource","type":"Microsoft.Features/providers/features","name":"Microsoft.VisualStudio/ExtensionResource"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/CloudSimpleRP1","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/CloudSimpleRP1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp11","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp12","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/CloudSimpleRP16","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/CloudSimpleRP16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp17","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp18","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp2","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp3","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.vmwarecloudsimple/features/eastus-devtest-bl31","type":"Microsoft.Features/providers/features","name":"microsoft.vmwarecloudsimple/eastus-devtest-bl31"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-03","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-03"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-04","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-04"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-05","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-05"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-06","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-06"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-07","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-07"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-08","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-08"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-devtest-virt-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-devtest-virt-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-devtest-virt-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-devtest-virt-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-03","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-03"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-04","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-04"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-05","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-05"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-06","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-06"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-07","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-07"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-08","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-08"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-09","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-09"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-10","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-10"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-11","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-12","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-13","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-13"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-14","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-14"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-15","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-15"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-16","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-17","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-18","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-19","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-20","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-20"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-23","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-23"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-24","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-24"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-25","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-25"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-26","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-26"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-27","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-27"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-28","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-28"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-30","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-30"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-31","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-31"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-32","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-32"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-33","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-33"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-34","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-34"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-37","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-37"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-38","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-38"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-39","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-39"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-40","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-40"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-41","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-41"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-42","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-42"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-43","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-43"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-44","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-44"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-45","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-45"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-46","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-46"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-47","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-47"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-48","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-48"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-49","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-49"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-50","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-50"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-51","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-51"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-52","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-52"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-53","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-53"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-54","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-54"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-57","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-57"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-59","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-59"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-61","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-61"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-62","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-62"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-63","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-63"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-64","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-64"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-65","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-65"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-66","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-66"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-67","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-67"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-68","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-68"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-69","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-69"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-70","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-70"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-71","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-71"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-72","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-72"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-73","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-73"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-74","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-74"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-77","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-77"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-78","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-78"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-79","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-79"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-80","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-80"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-81","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-81"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-82","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-82"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-83","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-83"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-84","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-84"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/expire-on-7-25-19","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/expire-on-7-25-19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/itops-he","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/itops-he"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/kiev-test-demo","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/kiev-test-demo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-1","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-2","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-3","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-4","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitFractions","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitFractions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitNone","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitNone"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitOnes","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitOnes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitZeros","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitZeros"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/stg-csos","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/stg-csos"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/subscriptionsWhiteList","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/subscriptionsWhiteList"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/westeurope-test","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/westeurope-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/westus-he-test","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/westus-he-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/westus-maas","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/westus-maas"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/ASEInEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/ASEInEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaCentral2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaCentral2RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaSouthEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaSouthEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/BrazilSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/BrazilSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CanadaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CanadaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CanadaEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CanadaEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralUSEUAPRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralUSEUAPRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastAsiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastAsiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastAsiaStageRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastAsiaStageRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUS2EUAPRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUS2EUAPRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUS2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUS2RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EventGridIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EventGridIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/FranceCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/FranceCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/FranceSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/FranceSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JapanEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JapanEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JapanWestRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JapanWestRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/KoreaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/KoreaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/KoreaSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/KoreaSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorthCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorthCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorthEuropeRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorthEuropeRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/PinnedToGlobalEndpoint","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/PinnedToGlobalEndpoint"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthEastAsiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthEastAsiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/TestFeatureRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/TestFeatureRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UAECentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UAECentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UKSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UKSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UKWestRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UKWestRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/Undelete","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/Undelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UseTipForTopLevelProxyOnlyApis","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UseTipForTopLevelProxyOnlyApis"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestEuropeRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestEuropeRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.WindowsIoT/features/DevelopmentEnvironmentAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.WindowsIoT/DevelopmentEnvironmentAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.WindowsIoT/features/WcusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.WindowsIoT/WcusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Xrm/features/uxdevelopment","type":"Microsoft.Features/providers/features","name":"Microsoft.Xrm/uxdevelopment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowObjectReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowObjectReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ESXiDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ESXiDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowNfsFileShares","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowNfsFileShares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/WorkloadBackupSoftDelete","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/WorkloadBackupSoftDelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/PrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/PrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/PrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/PrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AROPrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AROPrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MSvDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MSvDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Capacity/features/QuotaAPI","type":"Microsoft.Features/providers/features","name":"Microsoft.Capacity/QuotaAPI"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Capacity/features/QuotaBetaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Capacity/QuotaBetaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/GermanyNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/GermanyNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/IsHybridServicesTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/IsHybridServicesTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/BlockCustomerManagedKey","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/BlockCustomerManagedKey"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AllowLinkedNotificationsToHiddenRP","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AllowLinkedNotificationsToHiddenRP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAccountEncryptionKeyForQueues","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAccountEncryptionKeyForQueues"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAccountEncryptionKeyForTables","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAccountEncryptionKeyForTables"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorwayWest","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorwayWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventGrid/features/PartnerOperations","type":"Microsoft.Features/providers/features","name":"Microsoft.EventGrid/PartnerOperations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Blockchain/features/WCUSParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Blockchain/WCUSParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableComputeOnlyUpdates","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableComputeOnlyUpdates"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/StaticSitesEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/StaticSitesEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kubernetes/features/ppeAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kubernetes/ppeAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AAD-V2","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AAD-V2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/managedClustersTestRegionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/managedClustersTestRegionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SyncBookmark","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SyncBookmark"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DCSizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DCSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/XLargeDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/XLargeDisk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DV3Sizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DV3Sizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG3","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG4","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDW","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGZ","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGZ"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLACC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLACC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DDAGen5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DDAGen5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ASeriesInternal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ASeriesInternal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Nested","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Nested"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Internal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Internal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.VnfManager/features/allowmecvendor","type":"Microsoft.Features/providers/features","name":"microsoft.VnfManager/allowmecvendor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.VnfManager/features/allowmecvnf","type":"Microsoft.Features/providers/features","name":"microsoft.VnfManager/allowmecvnf"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/Staging","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/Staging"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSNetworkModePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSNetworkModePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BlockchainTokens/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.BlockchainTokens/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossazureactivedirectoryadmin","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossazureactivedirectoryadmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNVAInVHub","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNVAInVHub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/Helm3Preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/Helm3Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/INT-APROVED","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/INT-APROVED"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/SpotPoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/SpotPoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenshift/features/INT-APPROVED","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenshift/INT-APPROVED"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/azurearcprivatepreview","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/azurearcprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-NewAPIVersion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-NewAPIVersion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV2UrlRewrite","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV2UrlRewrite"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/HongKongBoxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/HongKongBoxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/IndiaBoxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/IndiaBoxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.vmwarecloudsimple/features/new-region-test-client","type":"Microsoft.Features/providers/features","name":"microsoft.vmwarecloudsimple/new-region-test-client"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnablePrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnablePrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowGenevaObtainer","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowGenevaObtainer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/MPAWorm","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/MPAWorm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowMoveDatabase","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowMoveDatabase"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.network/features/EnableRnmCallback","type":"Microsoft.Features/providers/features","name":"Microsoft.network/EnableRnmCallback"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/PartitionedDns","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/PartitionedDns"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Containerservice/features/AKS-AzurePolicyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Containerservice/AKS-AzurePolicyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-gp-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-gp-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFBackupOperator","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFBackupOperator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFTierChange","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFTierChange"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFFlexPool","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFFlexPool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSnapshotPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSnapshotPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NotificationHubs/features/germanyWestCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.NotificationHubs/germanyWestCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/MetricAPI","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/MetricAPI"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/vnetLocationCheckBypass","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/vnetLocationCheckBypass"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ARM.AFEC/features/multiaz-gp-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.ARM.AFEC/multiaz-gp-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/AIWorkspacePreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/AIWorkspacePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/TasksPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/TasksPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UseCustomizedUbuntuPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UseCustomizedUbuntuPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DevFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DevFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/StagingFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/StagingFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/ProdFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/ProdFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.vnfmanager/features/allowRegisteredSubscriptions","type":"Microsoft.Features/providers/features","name":"microsoft.vnfmanager/allowRegisteredSubscriptions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Providerhub/features/FeaturePutApi","type":"Microsoft.Features/providers/features","name":"Microsoft.Providerhub/FeaturePutApi"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Mv2SmallSizeSeries","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Mv2SmallSizeSeries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TerraformOSS/features/EnableTerraformWithWhitelistedTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.TerraformOSS/EnableTerraformWithWhitelistedTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AnmPRFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AnmPRFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/DBEBvtAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/DBEBvtAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/internalOnly","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/internalOnly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/BestPracticePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/BestPracticePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSANewUnderlayTesting","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSANewUnderlayTesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV1AndV2InSameSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV1AndV2InSameSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayPrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayPrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsSnapshot","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsSnapshot"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/ShowBannerForDeviceUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/ShowBannerForDeviceUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SharedIdentityEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SharedIdentityEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ResourceHealth/features/EnableKustoClustersRhc","type":"Microsoft.Features/providers/features","name":"Microsoft.ResourceHealth/EnableKustoClustersRhc"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/Endpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/Endpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PPE","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Datadog/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Datadog/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/preproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/preproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwPublicAndPrivateIpOnSamePort","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwPublicAndPrivateIpOnSamePort"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateVMValidationOptimizations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateVMValidationOptimizations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance1","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance3","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance4","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/DataBoxExportAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/DataBoxExportAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionO365","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionO365"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/InProgress","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/InProgress"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoReserveActivateInColocation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoReserveActivateInColocation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServicesHub/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServicesHub/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/NodeImageUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/NodeImageUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/MHSM_HighCapacitySKU","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/MHSM_HighCapacitySKU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ListOfPinnedFabricClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ListOfPinnedFabricClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/NPSSizes","type":"Microsoft.Features/providers/features","name":"microsoft.compute/NPSSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AISupercomputer/features/internalEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.AISupercomputer/internalEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/SaveAROTestConfig","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/SaveAROTestConfig"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/USSTAGESCParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/USSTAGESCParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionDM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionDM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionEngine","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionEngine"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionCM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionCM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionDM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionDM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionCM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionCM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionEngine","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionEngine"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/TestDFInProduction","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/TestDFInProduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Service","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Service"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/aropreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/aropreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNsgAndRouteTableOnBMDelegatedSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNsgAndRouteTableOnBMDelegatedSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFirewallPremium","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFirewallPremium"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ChangeAnalysis/features/NotificationsPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ChangeAnalysis/NotificationsPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowRequireInfrastructureEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowRequireInfrastructureEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/armApiInternalAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/armApiInternalAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-IngressApplicationGatewayAddon","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-IngressApplicationGatewayAddon"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EncryptionAtHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EncryptionAtHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/Gen2VMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/Gen2VMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/DisableDeploymentGrooming","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/DisableDeploymentGrooming"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/BastionFeaturesEnableKerberos","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/BastionFeaturesEnableKerberos"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Synapse/features/SparkCatalogInSAS","type":"Microsoft.Features/providers/features","name":"Microsoft.Synapse/SparkCatalogInSAS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowSMBMultichannel","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowSMBMultichannel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/RbacAuthorizationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/RbacAuthorizationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataMigrator","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataMigrator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataPlane","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataPlatform","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataPlatform"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventHub/features/AllowPrivateEndpointProxies","type":"Microsoft.Features/providers/features","name":"Microsoft.EventHub/AllowPrivateEndpointProxies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/AllowRequireInfrastructureEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/AllowRequireInfrastructureEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ChangeAnalysis/features/ResourceChangesPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ChangeAnalysis/ResourceChangesPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TrustedVMBackfillEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TrustedVMBackfillEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/EnableApiConnectionKeys","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/EnableApiConnectionKeys"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MaxSurgePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MaxSurgePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_germanywestcentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_germanywestcentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/testAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/testAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenShiftSupportGate","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenShiftSupportGate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBringYourOwnIpAddressForThirdParties","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBringYourOwnIpAddressForThirdParties"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVipswap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVipswap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableAzureRBACPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableAzureRBACPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Confluent/features/confluentOrgAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Confluent/confluentOrgAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.securitygraph/features/IsgAccess","type":"Microsoft.Features/providers/features","name":"microsoft.securitygraph/IsgAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ProximityPlacementGroupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ProximityPlacementGroupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubscriptionLoadBalancerCaching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubscriptionLoadBalancerCaching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/devEnvironment","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/devEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridnetwork/features/allowVnfVendor","type":"Microsoft.Features/providers/features","name":"microsoft.hybridnetwork/allowVnfVendor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridnetwork/features/allowVnfCustomer","type":"Microsoft.Features/providers/features","name":"microsoft.hybridnetwork/allowVnfCustomer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.HybridNetwork/features/HybridNetworkRPaaSRegistration","type":"Microsoft.Features/providers/features","name":"microsoft.HybridNetwork/HybridNetworkRPaaSRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Notebooks/features/AzureNBDevTestTraffic","type":"Microsoft.Features/providers/features","name":"Microsoft.Notebooks/AzureNBDevTestTraffic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchSubscriptionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchSubscriptionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableEncryptionAtHostPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableEncryptionAtHostPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableAzureDiskFileCSIDriver","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableAzureDiskFileCSIDriver"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PPE-NEU","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PPE-NEU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/JediBetaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/JediBetaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/SQLInVMPresenceVisibility","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/SQLInVMPresenceVisibility"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/useContainerd","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/useContainerd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ContainerRuntime","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ContainerRuntime"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JediBetaTestAntares","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JediBetaTestAntares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/GPUDedicatedVHDPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/GPUDedicatedVHDPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/MicrosoftRRDCLab1","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/MicrosoftRRDCLab1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/westus2mockedge","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/westus2mockedge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Notebooks/features/AzureNBCanaryTraffic","type":"Microsoft.Features/providers/features","name":"Microsoft.Notebooks/AzureNBCanaryTraffic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-OMSAppMonitoring","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-OMSAppMonitoring"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/LogSearchAlertsV2","type":"Microsoft.Features/providers/features","name":"microsoft.insights/LogSearchAlertsV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PowerBI/features/DailyPrivateLinkServicesForPowerBI","type":"Microsoft.Features/providers/features","name":"Microsoft.PowerBI/DailyPrivateLinkServicesForPowerBI"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/ResourceMoveAllowed","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/ResourceMoveAllowed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CopyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CopyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MabAfecTestEv2","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MabAfecTestEv2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Authorization/features/PolicyExemptionPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Authorization/PolicyExemptionPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/dummyfeature","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/dummyfeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSTOnBMDelegatedSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSTOnBMDelegatedSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UserAssignedIdentityPreviewInternalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UserAssignedIdentityPreviewInternalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/AKS-GitOps-FeatureFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/AKS-GitOps-FeatureFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/attestations","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/attestations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableUltraSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableUltraSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMoreASPerLBfWithoutVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMoreASPerLBfWithoutVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithConfigurableRepairActions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithConfigurableRepairActions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/EV2TestAFECFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/EV2TestAFECFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UseCustomizedContainerRuntime","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UseCustomizedContainerRuntime"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AzureEdgeZones","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AzureEdgeZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ImportExport/features/SouthAfricaNorthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ImportExport/SouthAfricaNorthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowWorkloadTypeOnBM","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowWorkloadTypeOnBM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.cdn/features/EnablePrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.cdn/EnablePrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_brazilsouth","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_brazilsouth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SystemPriorityCopy","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SystemPriorityCopy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Swiftlet/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Swiftlet/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UserAssignedIdentityPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UserAssignedIdentityPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Codespaces/features/CanaryUSEC","type":"Microsoft.Features/providers/features","name":"Microsoft.Codespaces/CanaryUSEC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraDisk512E","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraDisk512E"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resiliency/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Resiliency/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IntelligentITDigitalTwin/features/AccessControl","type":"Microsoft.Features/providers/features","name":"Microsoft.IntelligentITDigitalTwin/AccessControl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetappInfraOnBM","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetappInfraOnBM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.migrate/features/TestFeatureEV2","type":"Microsoft.Features/providers/features","name":"microsoft.migrate/TestFeatureEV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFDoubleEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFDoubleEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticExtensionUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticExtensionUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGPhaseScaleOutCopies","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGPhaseScaleOutCopies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-GitOps","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-GitOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NewRegions","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NewRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/FastPathEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/FastPathEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.migrate/features/TestFeatureEV2Migrate","type":"Microsoft.Features/providers/features","name":"microsoft.migrate/TestFeatureEV2Migrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Relay/features/AllowPrivateEndpointProxies","type":"Microsoft.Features/providers/features","name":"Microsoft.Relay/AllowPrivateEndpointProxies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ForwardAzGatewayTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ForwardAzGatewayTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/DataBoxExportHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/DataBoxExportHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.policyinsights/features/checkPolicyRestrictions","type":"Microsoft.Features/providers/features","name":"microsoft.policyinsights/checkPolicyRestrictions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GCEV2TestFeature001","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GCEV2TestFeature001"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/ManagedClustersPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/ManagedClustersPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/EastUS2EUAPMockEdge","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/EastUS2EUAPMockEdge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/QueryPacks","type":"Microsoft.Features/providers/features","name":"microsoft.insights/QueryPacks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/Extensions","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/Extensions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableEphemeralOSDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableEphemeralOSDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableDscpConfiguration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableDscpConfiguration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/pitr-public-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/pitr-public-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/USSTAGEEParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/USSTAGEEParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.FootprintMonitoring/features/FirstPartyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.FootprintMonitoring/FirstPartyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateInt","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateInt"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdatePPE","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdatePPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsAppendBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsAppendBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/FixedMaintenanceWindow","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/FixedMaintenanceWindow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateEndpointNSG","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateEndpointNSG"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExtendedLocation/features/CustomLocations-pp","type":"Microsoft.Features/providers/features","name":"Microsoft.ExtendedLocation/CustomLocations-pp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExtendedLocation/features/CustomLocations-ppauto","type":"Microsoft.Features/providers/features","name":"Microsoft.ExtendedLocation/CustomLocations-ppauto"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/spotPriorityServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/spotPriorityServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSMBEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSMBEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSMBCAShare","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSMBCAShare"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyAccessGA","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyAccessGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Capacity/features/CentrallyManagedLicenses","type":"Microsoft.Features/providers/features","name":"Microsoft.Capacity/CentrallyManagedLicenses"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GCEV2TestFeature002","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GCEV2TestFeature002"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossrdbmsinfrastructureencryption","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossrdbmsinfrastructureencryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossrdbmsinfrastructureencryption","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossrdbmsinfrastructureencryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossrdbmsbyokga","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossrdbmsbyokga"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossrdbmsbyokga","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossrdbmsbyokga"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridNetwork/features/Routing-CanaryCentralEUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridNetwork/Routing-CanaryCentralEUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Services.NonWcusUs","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Services.NonWcusUs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/SwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/SwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Services.WcusOnly","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Services.WcusOnly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Services.NonWcus","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Services.NonWcus"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/orcasconfignopdl","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/orcasconfignopdl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningServices/features/MFE","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningServices/MFE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFMultiOU","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFMultiOU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFLdapoverTls","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFLdapoverTls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFLdapExtendedGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFLdapExtendedGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableJapanWest","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableJapanWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableAustraliaCentral","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableAustraliaCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/PublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/PublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Contoso/features/RPaaSBridge","type":"Microsoft.Features/providers/features","name":"Microsoft.Contoso/RPaaSBridge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/EUAPRunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/EUAPRunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AutonomousDevelopmentPlatform/features/EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.AutonomousDevelopmentPlatform/EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowStorageServiceEncryptionIdentity","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowStorageServiceEncryptionIdentity"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SqlVirtualMachine/features/BulkRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.SqlVirtualMachine/BulkRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomerLockbox/features/CustomerLockboxFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomerLockbox/CustomerLockboxFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ReserveMacOnCreateNic","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ReserveMacOnCreateNic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAttributeBasedAccessControl","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAttributeBasedAccessControl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSharedAD","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSharedAD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/UpdateCenter","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/UpdateCenter"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionKOps","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionKOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionKOps","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionKOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionSE","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionSE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionSE","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionSE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Chaos/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Chaos/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Chaos/features/SquallTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Chaos/SquallTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Baremetal/features/ClusterStorPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Baremetal/ClusterStorPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreviewRebootless","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreviewRebootless"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableMsftAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableMsftAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableTip1Access","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableTip1Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerHA","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerHA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerCMW","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerCMW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerVnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerVnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/PilotRunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/PilotRunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/RunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/RunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/RunnerRPV1","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/RunnerRPV1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/RegionsInTesting","type":"Microsoft.Features/providers/features","name":"microsoft.insights/RegionsInTesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/citusComputeScaling","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/citusComputeScaling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreProvisionedVmReuseWithSingleNicAndAccelNet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreProvisionedVmReuseWithSingleNicAndAccelNet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyVerify","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyVerify"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SecurityInsights/features/IncidentsThrottlingTestFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.SecurityInsights/IncidentsThrottlingTestFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/EnableSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/EnableSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForpostgresql/features/citusStorageScaling","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForpostgresql/citusStorageScaling"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralUSRegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestUS2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestUS2RegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestUSRegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AppConfiguration/features/InternalGA","type":"Microsoft.Features/providers/features","name":"Microsoft.AppConfiguration/InternalGA"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AHUB","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AHUB"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowManagedDisksReplaceOSDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowManagedDisksReplaceOSDisk"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowPreReleaseRegions"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowValidationRegions"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/armApiPreviewAccess"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticOSUpgradeWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticOSUpgradeWithGalleryImage"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AvailabilitySetPinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AvailabilitySetPinning"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZAPInternalVMSKU","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZAPInternalVMSKU"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzAP"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFGA","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFGA"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzureVirtualMachineSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzureVirtualMachineSerialConsole"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/DisableNetworkWatcherAutocreation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/DisableNetworkWatcherAutocreation"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/RelAPI","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/RelAPI"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/VirtualMachineTemplatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/VirtualMachineTemplatePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZBalancing"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/BatchGetTenantInformantionRequests","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/BatchGetTenantInformantionRequests"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVirtualNetworkTap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVirtualNetworkTap"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TerraformOSS/features/EnableTerraform","type":"Microsoft.Features/providers/features","name":"Microsoft.TerraformOSS/EnableTerraform"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAzureNetworkManager","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAzureNetworkManager"}]}' + string: '{"value":[{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/preview","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIaaS/features/cloudSimpleRp1","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIaaS/cloudSimpleRp1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp10","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp10"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp11","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp12","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp13","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp13"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp14","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp14"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp15","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp15"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp16","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp17","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp18","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp19","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp2","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp20","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp20"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp21","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp21"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp22","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp22"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp23","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp23"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp24","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp24"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp25","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp25"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp6","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp7","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp7"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp8","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp8"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/cloudSimpleRp9","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/cloudSimpleRp9"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/CloudSimple.PrivateCloudIAAS/features/stagingRP","type":"Microsoft.Features/providers/features","name":"CloudSimple.PrivateCloudIAAS/stagingRP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/previewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/previewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/tipAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/tipAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.aadiam/features/betalogconnector","type":"Microsoft.Features/providers/features","name":"microsoft.aadiam/betalogconnector"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.aadiam/features/testinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.aadiam/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Advisor/features/dev","type":"Microsoft.Features/providers/features","name":"Microsoft.Advisor/dev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.alertsmanagement/features/enableSmartDiagnostics","type":"Microsoft.Features/providers/features","name":"microsoft.alertsmanagement/enableSmartDiagnostics"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/testinproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/testinproductionmdm","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/testinproductionmdm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Archive/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Archive/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/aseAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/aseAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ccAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ccAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ciAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ciAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/dsc","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/dsc"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/eapAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/eapAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/ncusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/ncusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/neAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/neAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/scusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/scusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/wcusuksAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/wcusuksAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/B2CV2Resource","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/B2CV2Resource"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureActiveDirectory/features/CPIMCSP","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureActiveDirectory/CPIMCSP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/eosEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/eosEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/tinaEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/tinaEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureStack/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureStack/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureStack/features/Marketplace","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureStack/Marketplace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/BatchAccountWhitelistSAN","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/BatchAccountWhitelistSAN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/portaltest","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/portaltest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/portaltest2","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/portaltest2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Batch/features/SwiftProd","type":"Microsoft.Features/providers/features","name":"Microsoft.Batch/SwiftProd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BatchAI/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.BatchAI/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BatchAI/features/workspace","type":"Microsoft.Features/providers/features","name":"Microsoft.BatchAI/workspace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BigAnalytics/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.BigAnalytics/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Blockchain/features/privatePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Blockchain/privatePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cache/features/betaAccess2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cache/betaAccess2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cache/features/betaAccess3","type":"Microsoft.Features/providers/features","name":"Microsoft.Cache/betaAccess3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cache/features/CanaryCheckNameAvailability","type":"Microsoft.Features/providers/features","name":"microsoft.cache/CanaryCheckNameAvailability"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicIaaSMigrate/features/ClassicIaaSMigrate","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicIaaSMigrate/ClassicIaaSMigrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicInfrastructureMigrate/features/ClassicInfrastructureMigrate","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicInfrastructureMigrate/ClassicInfrastructureMigrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ClassicSubscription/features/InternalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ClassicSubscription/InternalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/internalmsft","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/internalmsft"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/internalonly","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/internalonly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.cloudes/features/testinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.cloudes/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/AutoApproveFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/AutoApproveFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/formUnderstandingPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/formUnderstandingPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CognitiveServices/features/TokenAuthPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CognitiveServices/TokenAuthPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalAdvancedSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalAdvancedSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CAPSImagePublishing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CAPSImagePublishing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalStandardSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalStandardSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CorPersistence","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CorPersistence"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DedicatedNodeGroup","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DedicatedNodeGroup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/disableDisksAndSnapshotsPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/disableDisksAndSnapshotsPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableSerialConsole"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EnableCrossSubscriptionWithKeyVaultResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EnableCrossSubscriptionWithKeyVaultResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtensionsFastpath","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtensionsFastpath"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableDeadMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableDeadMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateDiskCopyForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateDiskCopyForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.StopMigrateSkipDiskCopyForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.StopMigrateSkipDiskCopyForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.VMPreprovisioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.VMPreprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/Fabric.UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/Fabric.UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/FastPollingOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/FastPollingOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Foobar","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Foobar"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageBigBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageBigBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryApplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryApplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageHighScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageHighScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryRemoveUserSourceDependency","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryRemoveUserSourceDependency"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ImpedeFastPolling","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ImpedeFastPolling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/IncrementalSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/IncrementalSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestVMUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestVMUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LocalDiffDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LocalDiffDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/lowprioritysinglevm","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/lowprioritysinglevm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedDisksPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedDisksPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedResourcesMove","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedResourcesMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MRProfile","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MRProfile"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/MultipleAvailabilityZones","type":"Microsoft.Features/providers/features","name":"microsoft.compute/MultipleAvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NetworkPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NetworkPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NewAllocator","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NewAllocator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NodeFlight","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NodeFlight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OptOutScaleSetPipelinePreemption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OptOutScaleSetPipelinePreemption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OSUpgradeForServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OSUpgradeForServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/OverProvision","type":"Microsoft.Features/providers/features","name":"microsoft.compute/OverProvision"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverprovisionedExtensionDelay","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverprovisionedExtensionDelay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalance","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalance"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithFDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithFDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PerfTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PerfTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PremiumDiskLatencyOptimized","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PremiumDiskLatencyOptimized"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ProximityPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ProximityPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RegionalUltraSSDVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RegionalUltraSSDVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RepairVMScaleSetInstancesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RepairVMScaleSetInstancesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/Reprovisioning","type":"Microsoft.Features/providers/features","name":"microsoft.compute/Reprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePolicyOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePolicyOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RunScripts","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RunScripts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEnablePremiumLRSReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEnablePremiumLRSReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/SpotMeterValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/SpotMeterValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/StandardSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/StandardSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TenantReserveActivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TenantReserveActivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TipNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TipNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraSSDWithVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraSSDWithVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionForVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionForVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionWithOSUpgrades","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionWithOSUpgrades"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UsePreprovisionedVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UsePreprovisionedVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UserImageSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UserImageSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VirtualMachineRuntimeServiceDisablePackageValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VirtualMachineRuntimeServiceDisablePackageValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMPipelineBatchingPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMPipelineBatchingPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewV2Access","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewV2Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ZRSImagesAndSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ZRSImagesAndSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ConnectedEnvironment/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.ConnectedEnvironment/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/aciOnAtlas","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/aciOnAtlas"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/extension","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/extension"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/privatepreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/privatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/previewSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/previewSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegisry/features/BlockRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegisry/BlockRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/privilegedSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/privilegedSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/BlockRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/BlockRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/BetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/BetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ACS-EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ACS-EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ACSVNext","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ACSVNext"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AddContainerInsightsSolution","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AddContainerInsightsSolution"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-AzurePolicyAutoApprove","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-AzurePolicyAutoApprove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CanadaCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CanadaCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CanadaEast","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CanadaEast"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-CentralUS","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-CentralUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-EastUS","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-EastUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-EnableAzureDataPlanePolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-EnableAzureDataPlanePolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-INT","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-INT"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-RegionEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-RegionEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-UKWest","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-UKWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSAuditLog","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSAuditLog"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-WestUS2","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-WestUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AksBypassRegionWritesDisabled","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AksBypassRegionWritesDisabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSAzureStandardLoadBalancer","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSAzureStandardLoadBalancer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSHTTPCustomFeatures","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSHTTPCustomFeatures"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AksBypassServiceGate","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AksBypassServiceGate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSLockingDownEgressPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSLockingDownEgressPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSPrivateLinkPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSPrivateLinkPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowSwarmWindowsAgent","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowSwarmWindowsAgent"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/APIServerSecurityPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/APIServerSecurityPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AROGA","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AROGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ARORemoteGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ARORemoteGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AvailabilityZonePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AvailabilityZonePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ControlPlaneUnderlay","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ControlPlaneUnderlay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/DockerEngineImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/DockerEngineImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableCCPMutatingWebhook","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableCCPMutatingWebhook"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableNetworkPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableNetworkPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableSingleIPPerCCP","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableSingleIPPerCCP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/HTTP-Application-Routing","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/HTTP-Application-Routing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableXTablesLock","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableXTablesLock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ManagedCluster","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ManagedCluster"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/LowPriorityPoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/LowPriorityPoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MSIPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MSIPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MobyImage","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MobyImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MultiAgentpoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MultiAgentpoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/NodePublicIPPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/NodePublicIPPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenVPN","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenVPN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenshiftManagedCluster","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenshiftManagedCluster"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSABypassMarketplace","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSABypassMarketplace"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSAInProgressFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSAInProgressFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/PodSecurityPolicyPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/PodSecurityPolicyPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/RBAC","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/RBAC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/V20180331API","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/V20180331API"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/SaveOSATestConfig","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/SaveOSATestConfig"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/WindowsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/WindowsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/VMSSPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/VMSSPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Contoso/features/RPaaSSampleApp","type":"Microsoft.Features/providers/features","name":"Microsoft.Contoso/RPaaSSampleApp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CostManagementBeta/features/TenantRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.CostManagementBeta/TenantRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomerInsights/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomerInsights/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/customrp","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/customrp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/associations","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/associations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomProviders/features/UpcomingRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomProviders/UpcomingRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/HeavyCreateAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/HeavyCreateAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/DBEIntAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/DBEIntAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/EdgeSignUp","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/EdgeSignUp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/PassiveStampAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/PassiveStampAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksEUAPAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksEUAPAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksControlPlane","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksControlPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/TowboatAllowedSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/TowboatAllowedSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DatabricksTestEnv","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DatabricksTestEnv"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PPEAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PPEAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PRODAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PRODAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCatalog/features/PRODAccessNew","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCatalog/PRODAccessNew"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/DFAccessInBuildout","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/DFAccessInBuildout"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataExchange/features/workspacePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataExchange/workspacePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/GatewayHAPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/GatewayHAPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataFactory/features/GatewayHAPublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataFactory/GatewayHAPublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/internalAccessWestCentralUS","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/internalAccessWestCentralUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/internalAccessWestUS2","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/internalAccessWestUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/requestedBetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/requestedBetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeAnalytics/features/Scope","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeAnalytics/Scope"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeStore/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeStore/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataLakeStore/features/requestedBetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataLakeStore/requestedBetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/BuddyA","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/BuddyA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/demo","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/demo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/int","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataMigration/features/staging","type":"Microsoft.Features/providers/features","name":"Microsoft.DataMigration/staging"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataShare/features/ReactSqlUxPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataShare/ReactSqlUxPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/privatePreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/privatePreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/threatdetection","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/threatdetection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DbforMySQL/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DbforMySQL/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbformysql/features/webappnewbizmodel","type":"Microsoft.Features/providers/features","name":"microsoft.dbformysql/webappnewbizmodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/citus64vCores","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/citus64vCores"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/citusHA","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/citusHA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/cituspreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/cituspreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/citusRoles","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/citusRoles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/firewallRuleAllowAzureServices","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/firewallRuleAllowAzureServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/georeplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/georeplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/georestore","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/georestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/indexAdvisor","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/indexAdvisor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/newStorageLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/newStorageLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossazureactivedirectoryadmin","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossazureactivedirectoryadmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbforpostgresql/features/pgversionten","type":"Microsoft.Features/providers/features","name":"microsoft.dbforpostgresql/pgversionten"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/replica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/replica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/resourceHealth","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/resourceHealth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/storageautogrow","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/storageautogrow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/vnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/vnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbforpostgresql/features/webappnewbizmodel","type":"Microsoft.Features/providers/features","name":"microsoft.dbforpostgresql/webappnewbizmodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/workloadInsight","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/workloadInsight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/admdev","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/admdev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/ignite2018PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/ignite2018PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeploymentManager/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.DeploymentManager/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.devices/features/AzureIoTElasticPools","type":"Microsoft.Features/providers/features","name":"microsoft.devices/AzureIoTElasticPools"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.devices/features/AzureIoTProvisioningService","type":"Microsoft.Features/providers/features","name":"microsoft.devices/AzureIoTProvisioningService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Devices/features/PublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Devices/PublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/DevInProdIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/DevInProdIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Integration","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Integration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test2","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test3","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/Test4","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/Test4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dns/features/privatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.dns/privatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/autopilot-flight-3","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/autopilot-flight-3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/storageanalytics-public-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/storageanalytics-public-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DomainRegistration/features/betaGD","type":"Microsoft.Features/providers/features","name":"Microsoft.DomainRegistration/betaGD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventGrid/features/storageEventSubscriptions","type":"Microsoft.Features/providers/features","name":"Microsoft.EventGrid/storageEventSubscriptions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Experimentation/features/POC","type":"Microsoft.Features/providers/features","name":"Microsoft.Experimentation/POC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DataBoxCanaryTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DataBoxCanaryTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DataIngestionService","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DataIngestionService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/DeviceImportAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/DeviceImportAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/diskimportaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/diskimportaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/ExpressPodCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/ExpressPodCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/IgniteSignup","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/IgniteSignup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExpressPod/features/MockGdcoAndUps","type":"Microsoft.Features/providers/features","name":"Microsoft.ExpressPod/MockGdcoAndUps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Expresspod/features/MockXtService","type":"Microsoft.Features/providers/features","name":"Microsoft.Expresspod/MockXtService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExternalShim/features/ExternalShimAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ExternalShim/ExternalShimAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Genomics/features/DevelopmentEnvironmentAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Genomics/DevelopmentEnvironmentAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/CanaryParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/CanaryParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GA20181120","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GA20181120"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HanaOnAzure/features/noAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.HanaOnAzure/noAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/AzureDedicatedHsm","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/AzureDedicatedHsm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/DedicatedHsmEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/DedicatedHsmEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/deploymentVerification","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/deploymentVerification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/drillVerification","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/drillVerification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/UseDogfoodHSM","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/UseDogfoodHSM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HardwareSecurityModules/features/UseDogfoodHsmAdminPlane","type":"Microsoft.Features/providers/features","name":"Microsoft.HardwareSecurityModules/UseDogfoodHsmAdminPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/HybridComputePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/HybridComputePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridcompute/features/HybridComputeExtensionPreview","type":"Microsoft.Features/providers/features","name":"microsoft.hybridcompute/HybridComputeExtensionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/HybridRPCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/HybridRPCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridData/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridData/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/AIMONEnvironment","type":"Microsoft.Features/providers/features","name":"microsoft.insights/AIMONEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/actiongrouptestinproduction","type":"Microsoft.Features/providers/features","name":"microsoft.insights/actiongrouptestinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/azurehealthlimitedpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/azurehealthlimitedpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/azurehealthpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/azurehealthpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/baseline-preview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/baseline-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/baseline-dogfood","type":"Microsoft.Features/providers/features","name":"microsoft.insights/baseline-dogfood"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/billingv3","type":"Microsoft.Features/providers/features","name":"microsoft.insights/billingv3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/diagnosticsettingpreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/diagnosticsettingpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/customMetric","type":"Microsoft.Features/providers/features","name":"microsoft.insights/customMetric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableCCAN","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableCCAN"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableCHNRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableCHNRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableCID","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableCID"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableNOERegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableNOERegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableNOWRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableNOWRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableSEA","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableSEA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EnableSEAURegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EnableSEAURegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableSUK","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableSUK"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableWestUS2","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableWestUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/metricalertprivatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/metricalertprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/metricalertmultidimprivatepreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/metricalertmultidimprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NotificationRulePreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NotificationRulePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NotificationGroupPreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NotificationGroupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/ScheduledQueryRulesPROD","type":"Microsoft.Features/providers/features","name":"microsoft.insights/ScheduledQueryRulesPROD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/ScheduledQueryRulesAIMON","type":"Microsoft.Features/providers/features","name":"microsoft.insights/ScheduledQueryRulesAIMON"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/testinproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/testinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/testinproductionmdm","type":"Microsoft.Features/providers/features","name":"microsoft.insights/testinproductionmdm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/testinproductionnms","type":"Microsoft.Features/providers/features","name":"microsoft.insights/testinproductionnms"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTCentral/features/metering","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTCentral/metering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/CanaryCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/CanaryCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/MVP","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/MVP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IotSpaces/features/PPECustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IotSpaces/PPECustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IotSpaces/features/PreviewCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IotSpaces/PreviewCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTSpaces/features/ScaleTestCustomers","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTSpaces/ScaleTestCustomers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/EventGridPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/EventGridPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/HSMPoolEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/HSMPoolEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kona/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kona/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kona/features/betaAccess2","type":"Microsoft.Features/providers/features","name":"Microsoft.Kona/betaAccess2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kubernetes/features/previewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kubernetes/previewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/sourceControlConfiguration","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/sourceControlConfiguration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowSwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowSwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseSharedIdentities","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseSharedIdentities"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.LabServices/features/DevInProdIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.LabServices/DevInProdIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AllowCrossSubscriptionGatewayAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AllowCrossSubscriptionGatewayAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AmeProjectionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AmeProjectionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/AllowUnlimitedLogicApps","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/AllowUnlimitedLogicApps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/FairfaxDemo","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/FairfaxDemo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/HostingEnvironmentsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/HostingEnvironmentsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPrivateRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPrivateRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/IsolatedEnvironmentsPreviewDisable","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/IsolatedEnvironmentsPreviewDisable"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningCompute/features/ViennaPublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningCompute/ViennaPublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningExperimentation/features/CanaryFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningExperimentation/CanaryFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Maintenance/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Maintenance/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ManagedIdentity/features/EnableSecurityGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.ManagedIdentity/EnableSecurityGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ManagedNetwork/features/mncbetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ManagedNetwork/mncbetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Microsoft/features/AllowNetworkWatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Microsoft/AllowNetworkWatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Mindaro/features/tip2","type":"Microsoft.Features/providers/features","name":"Microsoft.Mindaro/tip2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Mindaro/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.Mindaro/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/AllowSMB","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/AllowSMB"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFGATenant","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFGATenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFNFSv4Preview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFNFSv4Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFReplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFReplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSnapRestorePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSnapRestorePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/managementNicAdmin","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/managementNicAdmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/testing","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/testing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAcceleratedNetworkingFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAcceleratedNetworkingFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAccessRuleExtendedProperties","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAccessRuleExtendedProperties"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAcceleratedNetworkingForLinux","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAcceleratedNetworkingForLinux"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateOptimizations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateOptimizations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateAsyncValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateAsyncValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwWafBotManagerRuleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwWafBotManagerRuleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwPerSiteFirewallPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwPerSiteFirewallPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayClientAuthentication","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayClientAuthentication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwWafCustomRuleGeoMatch","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwWafCustomRuleGeoMatch"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayLoadDistributionPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayLoadDistributionPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV2WildcardListener","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV2WildcardListener"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationSecurityGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationSecurityGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayZonePinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayZonePinning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAzureFirewall","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAzureFirewall"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAsgsOnVmScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAsgsOnVmScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBaremetalServers","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBaremetalServers"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBastionHostPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBastionHostPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBastionHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBastionHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowClassicCrossSubscriptionPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowClassicCrossSubscriptionPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBringYourOwnPublicIpAddress","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBringYourOwnPublicIpAddress"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCoExistenceAnyOrder","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCoExistenceAnyOrder"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexExpressRouteGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexExpressRouteGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexGlobalVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexGlobalVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowCortexSecurity","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowCortexSecurity"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDdosProtectionPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDdosProtectionPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDisableBgpRouteProgagation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDisableBgpRouteProgagation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDestinationServiceEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDestinationServiceEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDSeriesForBrooklyn","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDSeriesForBrooklyn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.network/features/allowERArmProviderPortal","type":"Microsoft.Features/providers/features","name":"microsoft.network/allowERArmProviderPortal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowDynamicRedirectToTestGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowDynamicRedirectToTestGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowExRCrossRegionResourceValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowExRCrossRegionResourceValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFpgaEnabledClustersFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFpgaEnabledClustersFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFrontdoor","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFrontdoor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalCrpHttpClient","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalCrpHttpClient"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalTagsForSql","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalTagsForSql"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalPeeringTransit","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalPeeringTransit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGlobalTagsForStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGlobalTagsForStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowHidingCrossSubscriptionResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowHidingCrossSubscriptionResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGRPeerConnection","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGRPeerConnection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowILBAllPortsRule","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowILBAllPortsRule"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIntendedPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIntendedPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIntentedPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIntentedPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowInterfaceEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowInterfaceEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowInternalDelegations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowInternalDelegations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIPv6CAOnStandardLB","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIPv6CAOnStandardLB"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpv6GlobalReach","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpv6GlobalReach"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpv6PrivatePeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpv6PrivatePeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIPv6VirtualNetwork","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIPv6VirtualNetwork"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreviewWave2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreviewWave2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBPreviewWave3","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBPreviewWave3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLBSNATallocationPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLBSNATallocationPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowLoadBalancingOnSecondaryIpConfigs","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowLoadBalancingOnSecondaryIpConfigs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMacPreservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMacPreservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMaxPrivateLinkServicesPerLoadBalancerOptimization","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMaxPrivateLinkServicesPerLoadBalancerOptimization"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultiNicOnVMScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultiNicOnVMScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultipleAddressPrefixesOnSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultipleAddressPrefixesOnSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMultipleIpConfigurationsPerNic","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMultipleIpConfigurationsPerNic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMutipleAddressPrefixesOnSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMutipleAddressPrefixesOnSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNatGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNatGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetwatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetwatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkIntentPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkIntentPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkProfiles","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkProfiles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcher","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcher"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcherAzureReachabilityReport","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcherAzureReachabilityReport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetworkWatcherConnectivityCheck","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetworkWatcherConnectivityCheck"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicyPrivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicyPrivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicySlice","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicySlice"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpFirewallPolicyValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpFirewallPolicyValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpResourcePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpResourcePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNfvrpVirtualRouterSlice","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNfvrpVirtualRouterSlice"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowOutboundNatRule","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowOutboundNatRule"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowP2SCortexAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowP2SCortexAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPaaSEndpointAcl","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPaaSEndpointAcl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPingMesh","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPingMesh"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreflightValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreflightValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrepareNetworkPoliciesAction","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrepareNetworkPoliciesAction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateEndpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateEndpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateLinkServices","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateLinkServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPseudoClientAppId","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPseudoClientAppId"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpMobility","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpMobility"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIPOnVMScaleSetVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIPOnVMScaleSetVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpPrefix","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpPrefix"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPublicIpsAndLoadBalancingOnSecondaryIpConfigsInVMScaleSet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPublicIpsAndLoadBalancingOnSecondaryIpConfigsInVMScaleSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToApplicationGatewayBvt1Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToApplicationGatewayBvt1Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteBvt2Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteBvt2Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteBvt3Gwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteBvt3Gwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteCPGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteCPGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteDPGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteDPGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteMXGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteMXGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectGwmCallsToExpressRouteRSGwm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectGwmCallsToExpressRouteRSGwm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRedirectMaps","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRedirectMaps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRegionalGatewayManagerForSecureGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRegionalGatewayManagerForSecureGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRegionalVMSSVirtualNetworkGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRegionalVMSSVirtualNetworkGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRouteServiceAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRouteServiceAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRouteTables","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRouteTables"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingPreferenceFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingPreferenceFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRPGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRPGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSecureVnets","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSecureVnets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowServiceEndpointPolicies","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowServiceEndpointPolicies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSingleNicAndMultiNicInSameAvailabilitySet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSingleNicAndMultiNicInSameAvailabilitySet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowStandardLBOutboundRulesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowStandardLBOutboundRulesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowStaticPublicIpAsInstanceIp","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowStaticPublicIpAsInstanceIp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubnetDelegation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubnetDelegation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubscriptionMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubscriptionMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowThrottleCrpOperations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowThrottleCrpOperations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVMsFromDifferentVnetsOnAvailabilitySet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVMsFromDifferentVnetsOnAvailabilitySet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVMSSVirtualNetworkGateway","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVMSSVirtualNetworkGateway"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVmssHealthProbe","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVmssHealthProbe"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVnetPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVnetPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVnetGatewayOpenVpnProtocol","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVnetGatewayOpenVpnProtocol"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.network/features/AllowVpnclientIpsecPoliciesSet","type":"Microsoft.Features/providers/features","name":"microsoft.network/AllowVpnclientIpsecPoliciesSet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/armApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/azurednspreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/azurednspreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/bastionShareableLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/bastionShareableLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsAliasPortalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsAliasPortalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsBdmProd","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsBdmProd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsBdmPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsBdmPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsReleaseCandidate","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsReleaseCandidate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/CloudDnsThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/CloudDnsThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableDdosProtectionPlanBilling","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableDdosProtectionPlanBilling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableOperationBatching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableOperationBatching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableTenantNoSyncLock","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableTenantNoSyncLock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableTenantOperationBatching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableTenantOperationBatching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableValidationInBackgroundTask","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableValidationInBackgroundTask"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/HybridRegionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/HybridRegionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ExrGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ExrGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/InternetAnalyzerPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/InternetAnalyzerPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/isVMSSVirtualNetworkGatewayAllowed","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/isVMSSVirtualNetworkGatewayAllowed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/PrivateDnsGcpPPE","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/PrivateDnsGcpPPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/PrivateDnsGcpDaily","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/PrivateDnsGcpDaily"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/SkipPseudoVipGeneration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/SkipPseudoVipGeneration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/SecureGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/SecureGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ThrottleArmOperationsRnm","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ThrottleArmOperationsRnm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/TestFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/TestFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/TrafficManagerHeatMap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/TrafficManagerHeatMap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Netwotk/features/AllowGlobalPeeringTransit","type":"Microsoft.Features/providers/features","name":"Microsoft.Netwotk/AllowGlobalPeeringTransit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/VpnGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/VpnGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NotificationHubs/features/NHubMetrics","type":"Microsoft.Features/providers/features","name":"Microsoft.NotificationHubs/NHubMetrics"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.OperationalInsights/features/LAClusterApiEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.OperationalInsights/LAClusterApiEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.OperationalInsights/features/SwitzerlandRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.OperationalInsights/SwitzerlandRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowCarrierInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowCarrierInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowDirectInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowDirectInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowCDNInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowCDNInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowDirectPeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowDirectPeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowExchangeInterconnect","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowExchangeInterconnect"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowPeeringService","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowPeeringService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Peering/features/AllowExchangePeering","type":"Microsoft.Features/providers/features","name":"Microsoft.Peering/AllowExchangePeering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/AKS-DataPlaneAutoApprove","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/AKS-DataPlaneAutoApprove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/Insights","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/Insights"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/Events","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/Events"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/States","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/States"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Project/features/tip","type":"Microsoft.Features/providers/features","name":"Microsoft.Project/tip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/32DiskBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/32DiskBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/AzureFileShareBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/AzureFileShareBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/BackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/BackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/BlockedFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/BlockedFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/CrossRegionRestore","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/CrossRegionRestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/HanaBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/HanaBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/InstantBackupandRecovery","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/InstantBackupandRecovery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/ItemLevelRecovery","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/ItemLevelRecovery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/LargeDiskVMBackupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/LargeDiskVMBackupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MABAlertingFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MABAlertingFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MercuryAutoProtection","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MercuryAutoProtection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/PPEAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/PPEAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/PremiumStorageBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/PremiumStorageBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesCanada","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesCanada"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesBeta","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesBeta"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesResourceMove","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesResourceMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesUK","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesUK"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/RecoveryServicesWUS2","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/RecoveryServicesWUS2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/ResourceGraphSyncEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/ResourceGraphSyncEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/WorkloadBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/WorkloadBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/CspTest","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/CspTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/PrivacyEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/PrivacyEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/ple","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/ple"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resouces/features/EUAPParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resouces/EUAPParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RemoteApp/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RemoteApp/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AllowInternalDelegations","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AllowInternalDelegations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ARMDisableResourcesPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ARMDisableResourcesPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ARMLimitx2","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ARMLimitx2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AvailabilityZones","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AzureBuildout","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AzureBuildout"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/DataControlAgreement","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/DataControlAgreement"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/EUAPParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/EUAPParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/FairfaxDemo","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/FairfaxDemo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/GermanyWestCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/GermanyWestCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/mandatoryRetentionPeriodEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/mandatoryRetentionPeriodEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayEast","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayEast"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/NorwayWest","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/NorwayWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/SouthAfricaRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/SouthAfricaRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.resources/features/SwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"microsoft.resources/SwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/SwitzerlandRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/SwitzerlandRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.resources/features/SwitzerlandWest","type":"Microsoft.Features/providers/features","name":"microsoft.resources/SwitzerlandWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/TestFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/TestFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/ThrottledSubscriptions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/ThrottledSubscriptions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/UAERegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/UAERegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Saas/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Saas/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/AdvancedThreatProtection","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/AdvancedThreatProtection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ApplicationWhitelisting","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ApplicationWhitelisting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ApplicationWhiteliting","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ApplicationWhiteliting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/appwhitelistingaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/appwhitelistingaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.security/features/Assessments","type":"Microsoft.Features/providers/features","name":"microsoft.security/Assessments"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/CoreDev1","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/CoreDev1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev1","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev2","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Dev3","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Dev3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/discoveredSecuritySolutions","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/discoveredSecuritySolutions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/externalSecuritySolutions","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/externalSecuritySolutions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/Integration","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/Integration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-dev2","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-dev2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-dev3","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-dev3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-int","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitnac-rome3int","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitnac-rome3int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/jitvmaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/jitvmaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/NacJIT","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/NacJIT"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.security/features/NetworkData","type":"Microsoft.Features/providers/features","name":"microsoft.security/NetworkData"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/networkMap","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/networkMap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/northSouth","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/northSouth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/PricingBundles","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/PricingBundles"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/ShzadaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/ShzadaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/VaGrayLabel","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/VaGrayLabel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/WindowsDefenderAtp","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/WindowsDefenderAtp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SerialConsole/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SerialConsole/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/seabreezePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/seabreezePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/seabreezePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/seabreezePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/serviceFabricEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/serviceFabricEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/serviceFabricStageAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/serviceFabricStageAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabricMesh/features/seabreezePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabricMesh/seabreezePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabricMesh/features/serviceFabricEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabricMesh/serviceFabricEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Services/features/RPSaaSPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Services/RPSaaSPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SignalR/features/betaaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SignalR/betaaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SignalRService/features/betaaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.SignalRService/betaaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplianceEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplianceEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplianceMultiRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplianceMultiRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/AppliancePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/AppliancePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Solutions/features/ApplicationGA","type":"Microsoft.Features/providers/features","name":"Microsoft.Solutions/ApplicationGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/4tbpool","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/4tbpool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/4TBOption","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/4TBOption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/dataSync","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/dataSync"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/dataeditor-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/dataeditor-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/dw-asa","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/dw-asa"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/ExternalTdeCertificate","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/ExternalTdeCertificate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/firewall-enforce-azure-policy","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/firewall-enforce-azure-policy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/hyperscale-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/hyperscale-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisor","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisorPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisorPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/IndexAdvisorPublic","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/IndexAdvisorPublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/LongTermRetention","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/LongTermRetention"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/LongTermRetentionV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/LongTermRetentionV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/ManagedInstancePublic","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/ManagedInstancePublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-test","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/pesto","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/pesto"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/pesto-lite","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/pesto-lite"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/queryeditor-webqueryendpoint","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/queryeditor-webqueryendpoint"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/QueryPerformanceInsightPublic","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/QueryPerformanceInsightPublic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/serverless-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/serverless-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/SQL-DW","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/SQL-DW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-4tb-publicpreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-4tb-publicpreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-ActiveDirectoryAdmin","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-ActiveDirectoryAdmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/sqldb-addonstorage","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/sqldb-addonstorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-ElasticJobs","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-ElasticJobs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-elasticpool","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-elasticpool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-fsv2","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-fsv2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-higherStandardPerDbDtu","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-higherStandardPerDbDtu"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-JobAccounts","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-JobAccounts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-mseries","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-mseries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-premiumrs","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-premiumrs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldb-vcoremodel","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldb-vcoremodel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldbsterling","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldbsterling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/sqldbtde","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/sqldbtde"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/tdeAkvIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/tdeAkvIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/ADLSGen1Shim","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/ADLSGen1Shim"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/adlsgen2BlobInterop","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/adlsgen2BlobInterop"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowADFS","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowADFS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowArchive","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowArchive"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowHNS","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowHNS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowLinuxOptimizedShares","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowLinuxOptimizedShares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/AllowNFSV3","type":"Microsoft.Features/providers/features","name":"microsoft.storage/AllowNFSV3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowPreReleaseRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowSharedIdentities","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowSharedIdentities"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowStorageV1Accounts","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowStorageV1Accounts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowTargetStampSpecification","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowTargetStampSpecification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/armApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/BlobIndex","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/BlobIndex"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/BlobQuery","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/BlobQuery"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Changefeed","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Changefeed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/ContainerSoftDelete","type":"Microsoft.Features/providers/features","name":"microsoft.storage/ContainerSoftDelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/CustomerControlledFailover","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/CustomerControlledFailover"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/EncryptionAtRest","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/EncryptionAtRest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storage/features/jurobins","type":"Microsoft.Features/providers/features","name":"microsoft.storage/jurobins"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/LivesiteThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/LivesiteThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/ObjectReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/ObjectReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/premiumblob","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/premiumblob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.storage/features/PremiumHns","type":"Microsoft.Features/providers/features","name":"Microsoft.storage/PremiumHns"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/RestoreBlobRanges","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/RestoreBlobRanges"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Tags","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Tags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/version","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/version"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/Versioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/Versioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/XArchive","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/XArchive"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorageCache/features/generalAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorageCache/generalAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.storagereplication/features/SOS","type":"Microsoft.Features/providers/features","name":"microsoft.storagereplication/SOS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/betaAcess","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/betaAcess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/EnableUnsupportedGeo","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/EnableUnsupportedGeo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/StorSimpleGardaIbizaInGA","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/StorSimpleGardaIbizaInGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/StorSimpleGardaIbizaMigrated","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/StorSimpleGardaIbizaMigrated"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StreamAnalytics/features/ASA_NewRegion","type":"Microsoft.Features/providers/features","name":"Microsoft.StreamAnalytics/ASA_NewRegion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StreamAnalytics/features/ProdWestUSX","type":"Microsoft.Features/providers/features","name":"Microsoft.StreamAnalytics/ProdWestUSX"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/extendedCapacityAndRetention","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/extendedCapacityAndRetention"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/previewV2","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/previewV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Token/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Token/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Uic/features/uxdevelopment","type":"Microsoft.Features/providers/features","name":"Microsoft.Uic/uxdevelopment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/CanaryAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/CanaryAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VisualStudio/features/ExtensionResource","type":"Microsoft.Features/providers/features","name":"Microsoft.VisualStudio/ExtensionResource"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/CloudSimpleRP1","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/CloudSimpleRP1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp11","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp12","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/CloudSimpleRP16","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/CloudSimpleRP16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp17","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp18","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp2","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/cloudSimpleRp3","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/cloudSimpleRp3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.vmwarecloudsimple/features/eastus-devtest-bl31","type":"Microsoft.Features/providers/features","name":"microsoft.vmwarecloudsimple/eastus-devtest-bl31"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-03","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-03"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-04","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-04"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-05","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-05"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-06","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-06"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-07","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-07"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-azure-eastus-devtest-08","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-azure-eastus-devtest-08"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-devtest-virt-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-devtest-virt-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-devtest-virt-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-devtest-virt-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-01","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-01"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-02","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-02"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-03","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-03"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-04","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-04"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-05","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-05"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-06","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-06"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-07","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-07"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-08","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-08"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-09","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-09"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-10","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-10"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-11","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-11"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-12","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-12"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-13","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-13"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-14","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-14"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-15","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-15"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-16","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-16"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-17","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-17"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-18","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-18"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-19","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-20","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-20"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-23","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-23"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-24","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-24"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-25","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-25"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-26","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-26"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-27","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-27"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-28","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-28"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-30","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-30"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-31","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-31"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-32","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-32"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-33","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-33"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-34","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-34"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-37","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-37"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-38","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-38"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-39","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-39"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-40","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-40"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-41","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-41"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-42","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-42"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-43","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-43"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-44","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-44"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-45","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-45"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-46","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-46"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-47","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-47"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-48","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-48"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-49","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-49"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-50","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-50"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-51","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-51"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-52","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-52"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-53","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-53"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-54","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-54"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-57","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-57"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-59","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-59"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-61","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-61"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-62","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-62"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-63","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-63"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-64","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-64"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-65","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-65"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-66","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-66"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-67","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-67"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-68","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-68"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-69","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-69"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-70","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-70"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-71","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-71"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-72","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-72"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-73","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-73"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-74","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-74"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-77","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-77"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-78","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-78"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/env-cs-westus-devtest-79","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/env-cs-westus-devtest-79"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-80","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-80"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-81","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-81"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-82","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-82"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-83","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-83"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/env-cs-westus-devtest-84","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/env-cs-westus-devtest-84"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/expire-on-7-25-19","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/expire-on-7-25-19"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/itops-he","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/itops-he"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/kiev-test-demo","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/kiev-test-demo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-1","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-2","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-3","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/multi-region-4","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/multi-region-4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitFractions","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitFractions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitNone","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitNone"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitOnes","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitOnes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/mustEmitZeros","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/mustEmitZeros"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/stg-csos","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/stg-csos"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/subscriptionsWhiteList","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/subscriptionsWhiteList"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMWareCloudSimple/features/westeurope-test","type":"Microsoft.Features/providers/features","name":"Microsoft.VMWareCloudSimple/westeurope-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/westus-he-test","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/westus-he-test"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VMwareCloudSimple/features/westus-maas","type":"Microsoft.Features/providers/features","name":"Microsoft.VMwareCloudSimple/westus-maas"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/ASEInEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/ASEInEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaCentral2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaCentral2RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/AustraliaSouthEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/AustraliaSouthEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/BrazilSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/BrazilSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CanadaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CanadaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CanadaEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CanadaEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralUSEUAPRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralUSEUAPRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastAsiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastAsiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastAsiaStageRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastAsiaStageRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUS2EUAPRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUS2EUAPRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUS2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUS2RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EastUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EastUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/EventGridIntegration","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/EventGridIntegration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/FranceCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/FranceCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/FranceSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/FranceSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JapanEastRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JapanEastRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JapanWestRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JapanWestRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/KoreaCentralRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/KoreaCentralRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/KoreaSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/KoreaSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorthCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorthCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorthEuropeRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorthEuropeRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/PinnedToGlobalEndpoint","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/PinnedToGlobalEndpoint"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/RegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthEastAsiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthEastAsiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/SouthIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/SouthIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/TestFeatureRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/TestFeatureRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UAECentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UAECentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UKSouthRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UKSouthRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UKWestRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UKWestRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/Undelete","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/Undelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/UseTipForTopLevelProxyOnlyApis","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/UseTipForTopLevelProxyOnlyApis"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestCentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestCentralUSRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestEuropeRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestEuropeRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestIndiaRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestIndiaRegionEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.WindowsIoT/features/DevelopmentEnvironmentAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.WindowsIoT/DevelopmentEnvironmentAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.WindowsIoT/features/WcusAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.WindowsIoT/WcusAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Xrm/features/uxdevelopment","type":"Microsoft.Features/providers/features","name":"Microsoft.Xrm/uxdevelopment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowObjectReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowObjectReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ESXiDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ESXiDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowNfsFileShares","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowNfsFileShares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/WorkloadBackupSoftDelete","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/WorkloadBackupSoftDelete"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/PrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/PrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/PrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/PrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AROPrivateClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AROPrivateClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MSvDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MSvDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/GermanyNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/GermanyNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/IsHybridServicesTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/IsHybridServicesTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/BlockCustomerManagedKey","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/BlockCustomerManagedKey"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AllowLinkedNotificationsToHiddenRP","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AllowLinkedNotificationsToHiddenRP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAccountEncryptionKeyForQueues","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAccountEncryptionKeyForQueues"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAccountEncryptionKeyForTables","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAccountEncryptionKeyForTables"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/NorwayWest","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/NorwayWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventGrid/features/PartnerOperations","type":"Microsoft.Features/providers/features","name":"Microsoft.EventGrid/PartnerOperations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Blockchain/features/WCUSParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Blockchain/WCUSParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableComputeOnlyUpdates","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableComputeOnlyUpdates"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/StaticSitesEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/StaticSitesEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kubernetes/features/ppeAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Kubernetes/ppeAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AAD-V2","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AAD-V2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/privateip","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/privateip"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/managedClustersTestRegionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/managedClustersTestRegionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SyncBookmark","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SyncBookmark"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DCSizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DCSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/XLargeDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/XLargeDisk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DV3Sizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DV3Sizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG3","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG4","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDW","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGZ","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGZ"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLACC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLACC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DDAGen5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DDAGen5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ASeriesInternal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ASeriesInternal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Nested","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Nested"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Internal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Internal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TimeSeriesInsights/features/Staging","type":"Microsoft.Features/providers/features","name":"Microsoft.TimeSeriesInsights/Staging"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKSNetworkModePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKSNetworkModePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.BlockchainTokens/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.BlockchainTokens/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossazureactivedirectoryadmin","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossazureactivedirectoryadmin"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNVAInVHub","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNVAInVHub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/Helm3Preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/Helm3Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/INT-APROVED","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/INT-APROVED"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/SpotPoolPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/SpotPoolPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenshift/features/INT-APPROVED","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenshift/INT-APPROVED"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/azurearcprivatepreview","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/azurearcprivatepreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-NewAPIVersion","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-NewAPIVersion"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV2UrlRewrite","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV2UrlRewrite"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/HongKongBoxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/HongKongBoxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/IndiaBoxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/IndiaBoxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.vmwarecloudsimple/features/new-region-test-client","type":"Microsoft.Features/providers/features","name":"microsoft.vmwarecloudsimple/new-region-test-client"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnablePrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnablePrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowGenevaObtainer","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowGenevaObtainer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/MPAWorm","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/MPAWorm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowMoveDatabase","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowMoveDatabase"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.network/features/EnableRnmCallback","type":"Microsoft.Features/providers/features","name":"Microsoft.network/EnableRnmCallback"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/PartitionedDns","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/PartitionedDns"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Containerservice/features/AKS-AzurePolicyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Containerservice/AKS-AzurePolicyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SQL/features/multiaz-gp-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.SQL/multiaz-gp-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFBackupOperator","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFBackupOperator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFTierChange","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFTierChange"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFFlexPool","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFFlexPool"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSnapshotPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSnapshotPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NotificationHubs/features/germanyWestCentral","type":"Microsoft.Features/providers/features","name":"Microsoft.NotificationHubs/germanyWestCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/MetricAPI","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/MetricAPI"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerInstance/features/vnetLocationCheckBypass","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerInstance/vnetLocationCheckBypass"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ARM.AFEC/features/multiaz-gp-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.ARM.AFEC/multiaz-gp-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/AIWorkspacePreview","type":"Microsoft.Features/providers/features","name":"microsoft.insights/AIWorkspacePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerRegistry/features/TasksPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerRegistry/TasksPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UseCustomizedUbuntuPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UseCustomizedUbuntuPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/DevFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/DevFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/StagingFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/StagingFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/ProdFedRAMP","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/ProdFedRAMP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Providerhub/features/FeaturePutApi","type":"Microsoft.Features/providers/features","name":"Microsoft.Providerhub/FeaturePutApi"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Mv2SmallSizeSeries","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Mv2SmallSizeSeries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TerraformOSS/features/EnableTerraformWithWhitelistedTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.TerraformOSS/EnableTerraformWithWhitelistedTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AnmPRFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AnmPRFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMOrchestratorMultiFD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMOrchestratorMultiFD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMOrchestratorSingleFD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMOrchestratorSingleFD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/DBEBvtAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/DBEBvtAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevSpaces/features/internalOnly","type":"Microsoft.Features/providers/features","name":"Microsoft.DevSpaces/internalOnly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/BestPracticePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/BestPracticePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OSANewUnderlayTesting","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OSANewUnderlayTesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayV1AndV2InSameSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayV1AndV2InSameSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayPrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayPrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsSnapshot","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsSnapshot"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.StorSimple/features/ShowBannerForDeviceUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.StorSimple/ShowBannerForDeviceUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SharedIdentityEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SharedIdentityEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ResourceHealth/features/EnableKustoClustersRhc","type":"Microsoft.Features/providers/features","name":"Microsoft.ResourceHealth/EnableKustoClustersRhc"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/Endpoints","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/Endpoints"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PPE","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Datadog/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Datadog/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/preproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/preproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwPublicAndPrivateIpOnSamePort","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwPublicAndPrivateIpOnSamePort"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAllocateVMValidationOptimizations","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAllocateVMValidationOptimizations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance1","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance3","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowRoutingToTestNfvrpInstance4","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowRoutingToTestNfvrpInstance4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBox/features/DataBoxExportAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBox/DataBoxExportAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionO365","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionO365"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/InProgress","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/InProgress"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoReserveActivateInColocation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoReserveActivateInColocation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServicesHub/features/betaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServicesHub/betaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/NodeImageUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/NodeImageUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/MHSM_HighCapacitySKU","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/MHSM_HighCapacitySKU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/ossdenypublicendpointaccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/ossdenypublicendpointaccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ListOfPinnedFabricClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ListOfPinnedFabricClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/NPSSizes","type":"Microsoft.Features/providers/features","name":"microsoft.compute/NPSSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AISupercomputer/features/internalEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.AISupercomputer/internalEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/SaveAROTestConfig","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/SaveAROTestConfig"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/USSTAGESCParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/USSTAGESCParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionDM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionDM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionEngine","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionEngine"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionCM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionCM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionDM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionDM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionCM","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionCM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionEngine","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionEngine"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/TestDFInProduction","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/TestDFInProduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Service","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Service"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/aropreview","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/aropreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNsgAndRouteTableOnBMDelegatedSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNsgAndRouteTableOnBMDelegatedSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowFirewallPremium","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowFirewallPremium"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ChangeAnalysis/features/NotificationsPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ChangeAnalysis/NotificationsPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowRequireInfrastructureEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowRequireInfrastructureEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/armApiInternalAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/armApiInternalAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-IngressApplicationGatewayAddon","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-IngressApplicationGatewayAddon"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EncryptionAtHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EncryptionAtHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/Gen2VMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/Gen2VMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/DisableDeploymentGrooming","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/DisableDeploymentGrooming"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/BastionFeaturesEnableKerberos","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/BastionFeaturesEnableKerberos"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Synapse/features/SparkCatalogInSAS","type":"Microsoft.Features/providers/features","name":"Microsoft.Synapse/SparkCatalogInSAS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowSMBMultichannel","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowSMBMultichannel"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KeyVault/features/RbacAuthorizationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.KeyVault/RbacAuthorizationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataMigrator","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataMigrator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataPlane","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataPlane"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Wandisco.Fusion/features/LiveDataPlatform","type":"Microsoft.Features/providers/features","name":"Wandisco.Fusion/LiveDataPlatform"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Sql/features/AllowRequireInfrastructureEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Sql/AllowRequireInfrastructureEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ChangeAnalysis/features/ResourceChangesPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ChangeAnalysis/ResourceChangesPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TrustedVMBackfillEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TrustedVMBackfillEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Logic/features/EnableApiConnectionKeys","type":"Microsoft.Features/providers/features","name":"Microsoft.Logic/EnableApiConnectionKeys"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/MaxSurgePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/MaxSurgePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_germanywestcentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_germanywestcentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AAD/features/testAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.AAD/testAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/OpenShiftSupportGate","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/OpenShiftSupportGate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowBringYourOwnIpAddressForThirdParties","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowBringYourOwnIpAddressForThirdParties"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVipswap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVipswap"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableAzureRBACPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableAzureRBACPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Confluent/features/confluentOrgAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Confluent/confluentOrgAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.securitygraph/features/IsgAccess","type":"Microsoft.Features/providers/features","name":"microsoft.securitygraph/IsgAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ProximityPlacementGroupPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ProximityPlacementGroupPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSubscriptionLoadBalancerCaching","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSubscriptionLoadBalancerCaching"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/devEnvironment","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/devEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridnetwork/features/allowVnfVendor","type":"Microsoft.Features/providers/features","name":"microsoft.hybridnetwork/allowVnfVendor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.hybridnetwork/features/allowVnfCustomer","type":"Microsoft.Features/providers/features","name":"microsoft.hybridnetwork/allowVnfCustomer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.HybridNetwork/features/HybridNetworkRPaaSRegistration","type":"Microsoft.Features/providers/features","name":"microsoft.HybridNetwork/HybridNetworkRPaaSRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Notebooks/features/AzureNBDevTestTraffic","type":"Microsoft.Features/providers/features","name":"Microsoft.Notebooks/AzureNBDevTestTraffic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchSubscriptionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchSubscriptionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgreSQL/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgreSQL/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/orcastls","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/orcastls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableEncryptionAtHostPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableEncryptionAtHostPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableAzureDiskFileCSIDriver","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableAzureDiskFileCSIDriver"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/PPE-NEU","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/PPE-NEU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/JediBetaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/JediBetaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMariaDB/features/largeStorage","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMariaDB/largeStorage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/SQLInVMPresenceVisibility","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/SQLInVMPresenceVisibility"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/useContainerd","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/useContainerd"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/ContainerRuntime","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/ContainerRuntime"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/JediBetaTestAntares","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/JediBetaTestAntares"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/GPUDedicatedVHDPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/GPUDedicatedVHDPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/MicrosoftRRDCLab1","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/MicrosoftRRDCLab1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/westus2mockedge","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/westus2mockedge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Notebooks/features/AzureNBCanaryTraffic","type":"Microsoft.Features/providers/features","name":"Microsoft.Notebooks/AzureNBCanaryTraffic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-OMSAppMonitoring","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-OMSAppMonitoring"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/LogSearchAlertsV2","type":"Microsoft.Features/providers/features","name":"microsoft.insights/LogSearchAlertsV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PowerBI/features/DailyPrivateLinkServicesForPowerBI","type":"Microsoft.Features/providers/features","name":"Microsoft.PowerBI/DailyPrivateLinkServicesForPowerBI"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/ResourceMoveAllowed","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/ResourceMoveAllowed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CopyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CopyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/MabAfecTestEv2","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/MabAfecTestEv2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Authorization/features/PolicyExemptionPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Authorization/PolicyExemptionPrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ApiManagement/features/dummyfeature","type":"Microsoft.Features/providers/features","name":"Microsoft.ApiManagement/dummyfeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowSTOnBMDelegatedSubnet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowSTOnBMDelegatedSubnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UserAssignedIdentityPreviewInternalTest","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UserAssignedIdentityPreviewInternalTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/AKS-GitOps-FeatureFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/AKS-GitOps-FeatureFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CloudServices","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CloudServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/attestations","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/attestations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableUltraSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableUltraSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowMoreASPerLBfWithoutVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowMoreASPerLBfWithoutVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithConfigurableRepairActions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithConfigurableRepairActions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/EV2TestAFECFlag","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/EV2TestAFECFlag"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UseCustomizedContainerRuntime","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UseCustomizedContainerRuntime"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AzureEdgeZones","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AzureEdgeZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ImportExport/features/SouthAfricaNorthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ImportExport/SouthAfricaNorthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowWorkloadTypeOnBM","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowWorkloadTypeOnBM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.cdn/features/EnablePrivateLink","type":"Microsoft.Features/providers/features","name":"Microsoft.cdn/EnablePrivateLink"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_brazilsouth","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_brazilsouth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SystemPriorityCopy","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SystemPriorityCopy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Swiftlet/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Swiftlet/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/UserAssignedIdentityPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/UserAssignedIdentityPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Codespaces/features/CanaryUSEC","type":"Microsoft.Features/providers/features","name":"Microsoft.Codespaces/CanaryUSEC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraDisk512E","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraDisk512E"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resiliency/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Resiliency/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IntelligentITDigitalTwin/features/AccessControl","type":"Microsoft.Features/providers/features","name":"Microsoft.IntelligentITDigitalTwin/AccessControl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowNetappInfraOnBM","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowNetappInfraOnBM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.migrate/features/TestFeatureEV2","type":"Microsoft.Features/providers/features","name":"microsoft.migrate/TestFeatureEV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFDoubleEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFDoubleEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGPhaseScaleOutCopies","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGPhaseScaleOutCopies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-GitOps","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-GitOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/NewRegions","type":"Microsoft.Features/providers/features","name":"microsoft.insights/NewRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/FastPathEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/FastPathEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.migrate/features/TestFeatureEV2Migrate","type":"Microsoft.Features/providers/features","name":"microsoft.migrate/TestFeatureEV2Migrate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Automation/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Automation/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Relay/features/AllowPrivateEndpointProxies","type":"Microsoft.Features/providers/features","name":"Microsoft.Relay/AllowPrivateEndpointProxies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ForwardAzGatewayTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ForwardAzGatewayTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/DataBoxExportHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/DataBoxExportHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.policyinsights/features/checkPolicyRestrictions","type":"Microsoft.Features/providers/features","name":"microsoft.policyinsights/checkPolicyRestrictions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GCEV2TestFeature001","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GCEV2TestFeature001"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/ManagedClustersPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/ManagedClustersPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/EastUS2EUAPMockEdge","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/EastUS2EUAPMockEdge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/QueryPacks","type":"Microsoft.Features/providers/features","name":"microsoft.insights/QueryPacks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/Extensions","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/Extensions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/EnableEphemeralOSDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/EnableEphemeralOSDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableDscpConfiguration","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableDscpConfiguration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DocumentDB/features/pitr-public-preview","type":"Microsoft.Features/providers/features","name":"Microsoft.DocumentDB/pitr-public-preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/USSTAGEEParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/USSTAGEEParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.FootprintMonitoring/features/FirstPartyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.FootprintMonitoring/FirstPartyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateInt","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateInt"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdatePPE","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdatePPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsAppendBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsAppendBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/FixedMaintenanceWindow","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/FixedMaintenanceWindow"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPrivateEndpointNSG","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPrivateEndpointNSG"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExtendedLocation/features/CustomLocations-pp","type":"Microsoft.Features/providers/features","name":"Microsoft.ExtendedLocation/CustomLocations-pp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExtendedLocation/features/CustomLocations-ppauto","type":"Microsoft.Features/providers/features","name":"Microsoft.ExtendedLocation/CustomLocations-ppauto"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceFabric/features/spotPriorityServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceFabric/spotPriorityServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSMBEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSMBEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSMBCAShare","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSMBCAShare"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyAccessGA","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyAccessGA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Capacity/features/CentrallyManagedLicenses","type":"Microsoft.Features/providers/features","name":"Microsoft.Capacity/CentrallyManagedLicenses"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.GuestConfiguration/features/GCEV2TestFeature002","type":"Microsoft.Features/providers/features","name":"Microsoft.GuestConfiguration/GCEV2TestFeature002"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossrdbmsinfrastructureencryption","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossrdbmsinfrastructureencryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossrdbmsinfrastructureencryption","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossrdbmsinfrastructureencryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMySQL/features/ossrdbmsbyokga","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMySQL/ossrdbmsbyokga"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforPostgreSQL/features/ossrdbmsbyokga","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforPostgreSQL/ossrdbmsbyokga"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridNetwork/features/Routing-CanaryCentralEUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridNetwork/Routing-CanaryCentralEUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databricks/features/SwitzerlandNorth","type":"Microsoft.Features/providers/features","name":"Microsoft.Databricks/SwitzerlandNorth"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/privatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/privatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Services.WcusOnly","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Services.WcusOnly"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/Microsoft.AIDLS.Services.NonWcus","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/Microsoft.AIDLS.Services.NonWcus"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMariaDB/features/orcasconfignopdl","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMariaDB/orcasconfignopdl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MachineLearningServices/features/MFE","type":"Microsoft.Features/providers/features","name":"Microsoft.MachineLearningServices/MFE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFMultiOU","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFMultiOU"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFLdapoverTls","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFLdapoverTls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFLdapExtendedGroups","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFLdapExtendedGroups"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableJapanWest","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableJapanWest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/EnableAustraliaCentral","type":"Microsoft.Features/providers/features","name":"microsoft.insights/EnableAustraliaCentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/PublicPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/PublicPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Contoso/features/RPaaSBridge","type":"Microsoft.Features/providers/features","name":"Microsoft.Contoso/RPaaSBridge"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/EUAPRunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/EUAPRunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AutonomousDevelopmentPlatform/features/EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.AutonomousDevelopmentPlatform/EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowStorageServiceEncryptionIdentity","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowStorageServiceEncryptionIdentity"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SqlVirtualMachine/features/BulkRegistration","type":"Microsoft.Features/providers/features","name":"Microsoft.SqlVirtualMachine/BulkRegistration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.CustomerLockbox/features/CustomerLockboxFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.CustomerLockbox/CustomerLockboxFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ReserveMacOnCreateNic","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ReserveMacOnCreateNic"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowAttributeBasedAccessControl","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowAttributeBasedAccessControl"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSharedAD","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSharedAD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/UpdateCenter","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/UpdateCenter"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionKOps","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionKOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionKOps","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionKOps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseStorageSubscriptionSE","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseStorageSubscriptionSE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/UseComputeSubscriptionSE","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/UseComputeSubscriptionSE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Chaos/features/PreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Chaos/PreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Chaos/features/SquallTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Chaos/SquallTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Baremetal/features/ClusterStorPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Baremetal/ClusterStorPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreviewRebootless","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreviewRebootless"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableMsftAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableMsftAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.D365CustomerInsights/features/enableTip1Access","type":"Microsoft.Features/providers/features","name":"Microsoft.D365CustomerInsights/enableTip1Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerHA","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerHA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerCMW","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerCMW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/singleServerVnet","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/singleServerVnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/PilotRunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/PilotRunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/RunnerRPV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/RunnerRPV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Cdn/features/RunnerRPV1","type":"Microsoft.Features/providers/features","name":"Microsoft.Cdn/RunnerRPV1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/RegionsInTesting","type":"Microsoft.Features/providers/features","name":"microsoft.insights/RegionsInTesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/citusComputeScaling","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/citusComputeScaling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPreProvisionedVmReuseWithSingleNicAndAccelNet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPreProvisionedVmReuseWithSingleNicAndAccelNet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/EarlyVerify","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/EarlyVerify"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SecurityInsights/features/IncidentsThrottlingTestFeature","type":"Microsoft.Features/providers/features","name":"Microsoft.SecurityInsights/IncidentsThrottlingTestFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/EnableSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/EnableSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForpostgresql/features/citusStorageScaling","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForpostgresql/citusStorageScaling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/nsxSimplifiedExperience","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/nsxSimplifiedExperience"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AppAssessment/features/migratePrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.AppAssessment/migratePrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFAesEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFAesEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFLdapSigning","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFLdapSigning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdatePerf","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdatePerf"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UACDataboxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UACDataboxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.dbformysql/features/singleServerCMW","type":"Microsoft.Features/providers/features","name":"Microsoft.dbformysql/singleServerCMW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.dbformysql/features/singleServerVnet","type":"Microsoft.Features/providers/features","name":"Microsoft.dbformysql/singleServerVnet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/BrazilSouthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/BrazilSouthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/BRSDataboxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/BRSDataboxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/BRSDiskAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/BRSDiskAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/BRSHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/BRSHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UACHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UACHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UACDiskAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UACDiskAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UAECentralAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UAECentralAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UKSouthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UKSouthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UKSDataboxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UKSDataboxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UKSDiskAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UKSDiskAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/UKSHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/UKSHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/SZNHeavyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/SZNHeavyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/SZNDiskAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/SZNDiskAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/SZNDataboxAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/SZNDataboxAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Databox/features/SwitzerlandNorthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Databox/SwitzerlandNorthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFVolumeGroup","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFVolumeGroup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforpostgresql/features/singleServerHelpRequest","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforpostgresql/singleServerHelpRequest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBforMysql/features/singleServerHelpRequest","type":"Microsoft.Features/providers/features","name":"Microsoft.DBforMysql/singleServerHelpRequest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/LogicApps-2020-09-RegionsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/LogicApps-2020-09-RegionsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AutonomousDevelopmentPlatform/features/PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.AutonomousDevelopmentPlatform/PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/MigrateToMSIClusterPreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/MigrateToMSIClusterPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGTrustedVM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGTrustedVM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/portalSiteToSiteVpn","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/portalSiteToSiteVpn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithVMScaleSetsAtScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithVMScaleSetsAtScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/MSIPrivateLinkEarlyAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/MSIPrivateLinkEarlyAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/IsCloudManagementEnabledForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/IsCloudManagementEnabledForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DigitalTwins/features/DenyList","type":"Microsoft.Features/providers/features","name":"Microsoft.DigitalTwins/DenyList"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.resources/features/InternalAzureEdgeZones","type":"Microsoft.Features/providers/features","name":"microsoft.resources/InternalAzureEdgeZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Bing/features/InternalTesting","type":"Microsoft.Features/providers/features","name":"Microsoft.Bing/InternalTesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/portalSRMAddon","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/portalSRMAddon"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/DisableVirtualMachineQuota","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/DisableVirtualMachineQuota"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DevTestLab/features/DisableLabVirtualMachineQuota","type":"Microsoft.Features/providers/features","name":"Microsoft.DevTestLab/DisableLabVirtualMachineQuota"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Communication/features/PhoneNumberInboundCallingAllowed","type":"Microsoft.Features/providers/features","name":"Microsoft.Communication/PhoneNumberInboundCallingAllowed"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Insights/features/EUAPParticipation","type":"Microsoft.Features/providers/features","name":"Microsoft.Insights/EUAPParticipation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/ciEnvironment","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/ciEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/canaryEnvironment","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/canaryEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataCollaboration/features/intEnvironment","type":"Microsoft.Features/providers/features","name":"Microsoft.DataCollaboration/intEnvironment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.OpenLogisticsPlatform/features/WorkspacesOperations","type":"Microsoft.Features/providers/features","name":"Microsoft.OpenLogisticsPlatform/WorkspacesOperations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFAzureKeyVaultEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFAzureKeyVaultEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsOnMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsOnMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradeSDPWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradeSDPWithGalleryImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/singleServerHA","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/singleServerHA"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.Spanning.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.Spanning.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SignalRService/features/AllowCustomDomainCertificate","type":"Microsoft.Features/providers/features","name":"Microsoft.SignalRService/AllowCustomDomainCertificate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.securityinsights/features/SatelliteClusterAustralia","type":"Microsoft.Features/providers/features","name":"microsoft.securityinsights/SatelliteClusterAustralia"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAppGwWafPolicyHigherLimits","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAppGwWafPolicyHigherLimits"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.operationalinsights/features/QueryPacks","type":"Microsoft.Features/providers/features","name":"microsoft.operationalinsights/QueryPacks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Kusto/features/AllowDdv4Sku","type":"Microsoft.Features/providers/features","name":"Microsoft.Kusto/AllowDdv4Sku"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoRollingUpgradeForSFAutoOSUpgrade","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoRollingUpgradeForSFAutoOSUpgrade"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UseElasticPipelineOptimization","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UseElasticPipelineOptimization"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureData/features/ArcDataRPaas","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureData/ArcDataRPaas"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/AutoUpgradePreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/AutoUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.AzPE.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.AzPE.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/SQLFixedMaintenanceWindowCanary","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/SQLFixedMaintenanceWindowCanary"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableResourceLevelLocking","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableResourceLevelLocking"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/isVwanDeploy","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/isVwanDeploy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridNetwork/features/AllowVendorTestingRedirection","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridNetwork/AllowVendorTestingRedirection"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AzureArcData/features/ArcDataRpaasDev","type":"Microsoft.Features/providers/features","name":"Microsoft.AzureArcData/ArcDataRpaasDev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/PodSubnetPreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/PodSubnetPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AlertsManagement/features/rhartestinproduction","type":"Microsoft.Features/providers/features","name":"Microsoft.AlertsManagement/rhartestinproduction"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnablePodIdentityPreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnablePodIdentityPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.Spanning.OptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.Spanning.OptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.operationalinsights/features/EnableQueryPacks","type":"Microsoft.Features/providers/features","name":"microsoft.operationalinsights/EnableQueryPacks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RestorePointsRetrieveSAS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RestorePointsRetrieveSAS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/flexibleServerReplica","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/flexibleServerReplica"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnableACRTeleport","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnableACRTeleport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IndustryDataLifecycle/features/CanaryAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.IndustryDataLifecycle/CanaryAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/CustomNodeConfigPreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/CustomNodeConfigPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.insights/features/basicstandardtest","type":"Microsoft.Features/providers/features","name":"microsoft.insights/basicstandardtest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/EnableRecoveryServicesVaultAmpAlerts","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/EnableRecoveryServicesVaultAmpAlerts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataProtection/features/BlobOperationalBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.DataProtection/BlobOperationalBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AFDEUAPRunnerV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AFDEUAPRunnerV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AFDPilotRunnerV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AFDPilotRunnerV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AFDPrivateProductionV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AFDPrivateProductionV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AFDProdRunnerV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AFDProdRunnerV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CapacityReservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CapacityReservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.CapacityReservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.CapacityReservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowServiceChain","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowServiceChain"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowUpdateAddressSpaceInPeeredVnets","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowUpdateAddressSpaceInPeeredVnets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/DisableMachinesPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/DisableMachinesPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridCompute/features/PreviewRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridCompute/PreviewRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.CapacityReservationOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.CapacityReservationOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ExtendedLocation/features/CustomLocations-int","type":"Microsoft.Features/providers/features","name":"Microsoft.ExtendedLocation/CustomLocations-int"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/UseCustomizedWindowsPreview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/UseCustomizedWindowsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/UseAKSWindows2004Preview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/UseAKSWindows2004Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DelegatedNetwork/features/ControllerAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.DelegatedNetwork/ControllerAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RedHatOpenShift/features/RedHatEngineering","type":"Microsoft.Features/providers/features","name":"Microsoft.RedHatOpenShift/RedHatEngineering"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SecurityInsights/features/noIncidentThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.SecurityInsights/noIncidentThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SecurityInsights/features/CancelIncidentThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.SecurityInsights/CancelIncidentThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.LoadTestService/features/loadTestBetaAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.LoadTestService/loadTestBetaAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridNetwork/features/Allow-WestCentralUS","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridNetwork/Allow-WestCentralUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataBoxEdge/features/SkipDeviceVersionCheckForResourceMove","type":"Microsoft.Features/providers/features","name":"Microsoft.DataBoxEdge/SkipDeviceVersionCheckForResourceMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SecurityInsights/features/applyIncidentThrottling","type":"Microsoft.Features/providers/features","name":"Microsoft.SecurityInsights/applyIncidentThrottling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ContainerService/features/AKS-ConfidentialComputingAddon","type":"Microsoft.Features/providers/features","name":"Microsoft.ContainerService/AKS-ConfidentialComputingAddon"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnablePrivateClusterFQDNSubdomain","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnablePrivateClusterFQDNSubdomain"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.IoTCentral/features/scootaloo","type":"Microsoft.Features/providers/features","name":"Microsoft.IoTCentral/scootaloo"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/HostReplaceCustomerNotification","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/HostReplaceCustomerNotification"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowPremiumSkuLb","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowPremiumSkuLb"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMCustomImagePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMCustomImagePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPatchModeOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPatchModeOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsSoftDeleteFilesFolder","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsSoftDeleteFilesFolder"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ResourceConnector/features/Appliances-pp","type":"Microsoft.Features/providers/features","name":"Microsoft.ResourceConnector/Appliances-pp"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ResourceConnector/features/Appliances-ppauto","type":"Microsoft.Features/providers/features","name":"Microsoft.ResourceConnector/Appliances-ppauto"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutorotationForDiskEncryptionAtRest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutorotationForDiskEncryptionAtRest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.PolicyInsights/features/policyStateChangeNotifications","type":"Microsoft.Features/providers/features","name":"Microsoft.PolicyInsights/policyStateChangeNotifications"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AnyBuild/features/TestResourceProvider","type":"Microsoft.Features/providers/features","name":"Microsoft.AnyBuild/TestResourceProvider"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForPostgresql/features/flexibleServerDeleteFeedback","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForPostgresql/flexibleServerDeleteFeedback"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySql/features/flexibleServerDeleteFeedback","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySql/flexibleServerDeleteFeedback"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/OptimizeCreateDnsCalls","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/OptimizeCreateDnsCalls"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ConnectedVehicle/features/stagingAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ConnectedVehicle/stagingAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HealthcareApis/features/Gen2PrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.HealthcareApis/Gen2PrivatePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableMaxPrivateEndpointsVia64kPath","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableMaxPrivateEndpointsVia64kPath"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableHighAvailabilityMode","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableHighAvailabilityMode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.EventGrid/features/EventGridPreviewFeatures2021H1","type":"Microsoft.Features/providers/features","name":"Microsoft.EventGrid/EventGridPreviewFeatures2021H1"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SqlVirtualMachine/features/TestAFECForTPID","type":"Microsoft.Features/providers/features","name":"Microsoft.SqlVirtualMachine/TestAFECForTPID"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DbForPostgreSQL/features/MarlinSubscriptionSwitch","type":"Microsoft.Features/providers/features","name":"Microsoft.DbForPostgreSQL/MarlinSubscriptionSwitch"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.HybridNetwork/features/Routing-CanaryEastUS2EUAP","type":"Microsoft.Features/providers/features","name":"Microsoft.HybridNetwork/Routing-CanaryEastUS2EUAP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowFileVerlaine","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowFileVerlaine"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFSDNAppliance","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFSDNAppliance"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForpostgresql/features/perfDataReset","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForpostgresql/perfDataReset"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.security/features/iotsolutionmigration","type":"Microsoft.Features/providers/features","name":"microsoft.security/iotsolutionmigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AlertsManagement/features/PreviewSmartDetectionsMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.AlertsManagement/PreviewSmartDetectionsMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AlertsManagement/features/SmartAlertsTeamExperimentalDetectors","type":"Microsoft.Features/providers/features","name":"Microsoft.AlertsManagement/SmartAlertsTeamExperimentalDetectors"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ImportExport/features/KoreaSouthAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.ImportExport/KoreaSouthAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.operationalinsights/features/IsTroubleShootEnabled","type":"Microsoft.Features/providers/features","name":"microsoft.operationalinsights/IsTroubleShootEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/GitHub.Enterprise/features/EnableAccess","type":"Microsoft.Features/providers/features","name":"GitHub.Enterprise/EnableAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMApps","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMApps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/EnableRSVaultSecurityAlertsToAzureMonitor","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/EnableRSVaultSecurityAlertsToAzureMonitor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/EnableAzureBackupJobFailureAlertsToAzureMonitor","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/EnableAzureBackupJobFailureAlertsToAzureMonitor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DataProtection/features/EnableAzureBackupJobFailureAlertsToAzureMonitor","type":"Microsoft.Features/providers/features","name":"Microsoft.DataProtection/EnableAzureBackupJobFailureAlertsToAzureMonitor"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ManagedResolverPPE","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ManagedResolverPPE"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Maps/features/betaAccessTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Maps/betaAccessTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SpotTryRestore","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SpotTryRestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.KubernetesConfiguration/features/ClusterConfigurationAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.KubernetesConfiguration/ClusterConfigurationAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/QAtesting","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/QAtesting"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.SerialConsole.PPE/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.SerialConsole.PPE/AllowValidationRegions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/BastionGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/BastionGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/HnsSoftDeleteFilesFolders","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/HnsSoftDeleteFilesFolders"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceLinker/features/canaryEnable","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceLinker/canaryEnable"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ServiceLinker/features/EastUS2EUAPEnable","type":"Microsoft.Features/providers/features","name":"Microsoft.ServiceLinker/EastUS2EUAPEnable"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/MatchNatRulePortOffsetToScaleSetVMIndex","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/MatchNatRulePortOffsetToScaleSetVMIndex"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Providers.Test/features/autoApproveTestFeature","type":"Microsoft.Features/providers/features","name":"Providers.Test/autoApproveTestFeature"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableBillingOnMseev2","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableBillingOnMseev2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/EnableBillingOnBM","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/EnableBillingOnBM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateProdWUS","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateProdWUS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Communication/features/ResourceGeoAwareness","type":"Microsoft.Features/providers/features","name":"Microsoft.Communication/ResourceGeoAwareness"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Communication/features/StagingGeoAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Communication/StagingGeoAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RestorePointExcludeDisks","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RestorePointExcludeDisks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFFileRestore","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFFileRestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFUserQuota","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFUserQuota"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnableAKSWindowsDSR","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnableAKSWindowsDSR"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/UseAKSWindows2019Preview","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/UseAKSWindows2019Preview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/KubeletDisk","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/KubeletDisk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnableAKSWindowsCalico","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnableAKSWindowsCalico"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/BackupCreateVaultWithCmk","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/BackupCreateVaultWithCmk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnableCloudControllerManager","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnableCloudControllerManager"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Synapse/features/TSQLStreaming","type":"Microsoft.Features/providers/features","name":"Microsoft.Synapse/TSQLStreaming"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowApplicationGatewayDenyOutboundInternet","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowApplicationGatewayDenyOutboundInternet"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_uswest3","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_uswest3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SsdZrsManagedDisks","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SsdZrsManagedDisks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/LogicApps-Yakima","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/LogicApps-Yakima"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/ServiceEndpointPoliciesAliasesOnboarding","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/ServiceEndpointPoliciesAliasesOnboarding"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_indiacentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_indiacentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Resources/features/AZ_koreacentral","type":"Microsoft.Features/providers/features","name":"Microsoft.Resources/AZ_koreacentral"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowIpv6CloudService","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowIpv6CloudService"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MobileNetwork/features/AllowMobileNetworkCustomer","type":"Microsoft.Features/providers/features","name":"Microsoft.MobileNetwork/AllowMobileNetworkCustomer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateDev","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateDev"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DeviceUpdate/features/AzureDeviceUpdateTest","type":"Microsoft.Features/providers/features","name":"Microsoft.DeviceUpdate/AzureDeviceUpdateTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/MICROSOFT.DATABOXEDGE/features/ASE-CLOUD-MGMT-K8S-PREVIEW","type":"Microsoft.Features/providers/features","name":"MICROSOFT.DATABOXEDGE/ASE-CLOUD-MGMT-K8S-PREVIEW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.RecoveryServices/features/HANASnapshotBackup","type":"Microsoft.Features/providers/features","name":"Microsoft.RecoveryServices/HANASnapshotBackup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.dbforpostgresql/features/locationCapability","type":"Microsoft.Features/providers/features","name":"microsoft.dbforpostgresql/locationCapability"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowGatewayLoadBalancer","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowGatewayLoadBalancer"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/customIops","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/customIops"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CrossScaleSetSFCoordination","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CrossScaleSetSFCoordination"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMNetworkInterfaceConfigurations","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMNetworkInterfaceConfigurations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/EnableAzureKeyvaultSecretsProvider","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/EnableAzureKeyvaultSecretsProvider"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/AKS-ExtensionManager","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/AKS-ExtensionManager"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.DBForMySQL/features/locationCapability","type":"Microsoft.Features/providers/features","name":"Microsoft.DBForMySQL/locationCapability"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.ConnectedVMwarevSphere/features/ConnectedVMwarePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.ConnectedVMwarevSphere/ConnectedVMwarePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/CloudSanExperience","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/CloudSanExperience"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Communication/features/AllowResourceMove","type":"Microsoft.Features/providers/features","name":"Microsoft.Communication/AllowResourceMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/BastionGwGatewaySubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/BastionGwGatewaySubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Security/features/IngestionSettings","type":"Microsoft.Features/providers/features","name":"Microsoft.Security/IngestionSettings"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SpotBlock","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SpotBlock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.testbase/features/EastUS2EUAPEnable","type":"Microsoft.Features/providers/features","name":"microsoft.testbase/EastUS2EUAPEnable"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.ContainerService/features/AKS-AzureKeyVaultSecretsProvider","type":"Microsoft.Features/providers/features","name":"microsoft.ContainerService/AKS-AzureKeyVaultSecretsProvider"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LiveTierChange","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LiveTierChange"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/VariableResiliency","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/VariableResiliency"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Storage/features/AllowVRS","type":"Microsoft.Features/providers/features","name":"Microsoft.Storage/AllowVRS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.operationalinsights/features/storageinsigtenabled","type":"Microsoft.Features/providers/features","name":"microsoft.operationalinsights/storageinsigtenabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AVS/features/drsPlacementPolicy","type":"Microsoft.Features/providers/features","name":"Microsoft.AVS/drsPlacementPolicy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Devices/features/CosmosDBRoutingEndpointPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Devices/CosmosDBRoutingEndpointPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EarlyStartVMSSRoleInstances","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EarlyStartVMSSRoleInstances"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/CentralUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/CentralUSRegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestUS2RegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestUS2RegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Web/features/WestUSRegionEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Web/WestUSRegionEnabled"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.AppConfiguration/features/InternalGA","type":"Microsoft.Features/providers/features","name":"Microsoft.AppConfiguration/InternalGA"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AHUB","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AHUB"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowManagedDisksReplaceOSDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowManagedDisksReplaceOSDisk"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowPreReleaseRegions"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowValidationRegions"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/armApiPreviewAccess"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticOSUpgradeWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticOSUpgradeWithGalleryImage"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AvailabilitySetPinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AvailabilitySetPinning"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZAPInternalVMSKU","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZAPInternalVMSKU"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzAP"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.NetApp/features/ANFGA","type":"Microsoft.Features/providers/features","name":"Microsoft.NetApp/ANFGA"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzureVirtualMachineSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzureVirtualMachineSerialConsole"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/DisableNetworkWatcherAutocreation","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/DisableNetworkWatcherAutocreation"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/RelAPI","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/RelAPI"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.VirtualMachineImages/features/VirtualMachineTemplatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.VirtualMachineImages/VirtualMachineTemplatePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZBalancing"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/BatchGetTenantInformantionRequests","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/BatchGetTenantInformantionRequests"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowVirtualNetworkTap","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowVirtualNetworkTap"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.TerraformOSS/features/EnableTerraform","type":"Microsoft.Features/providers/features","name":"Microsoft.TerraformOSS/EnableTerraform"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Network/features/AllowAzureNetworkManager","type":"Microsoft.Features/providers/features","name":"Microsoft.Network/AllowAzureNetworkManager"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PlatformSettingsOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PlatformSettingsOverride"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MixedReality/features/ObjectUnderstandingPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.MixedReality/ObjectUnderstandingPrivatePreview"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.MixedReality/features/ObjectAnchorsPrivatePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.MixedReality/ObjectAnchorsPrivatePreview"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticExtensionUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticExtensionUpgradePreview"}]}' headers: cache-control: - no-cache content-length: - - '349631' + - '409517' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:36:48 GMT + - Fri, 26 Feb 2021 06:54:03 GMT expires: - '-1' pragma: @@ -49,21 +49,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features?api-version=2015-12-01 response: body: - string: '{"value":[{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalAdvancedSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalAdvancedSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CAPSImagePublishing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CAPSImagePublishing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalStandardSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalStandardSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CorPersistence","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CorPersistence"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DedicatedNodeGroup","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DedicatedNodeGroup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/disableDisksAndSnapshotsPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/disableDisksAndSnapshotsPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableSerialConsole"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EnableCrossSubscriptionWithKeyVaultResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EnableCrossSubscriptionWithKeyVaultResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtensionsFastpath","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtensionsFastpath"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtraLargeVMScaleSetPerfEvaluation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtraLargeVMScaleSetPerfEvaluation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableDeadMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableDeadMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateDiskCopyForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateDiskCopyForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.StopMigrateSkipDiskCopyForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.StopMigrateSkipDiskCopyForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.VMPreprovisioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.VMPreprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/Fabric.UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/Fabric.UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/FastPollingOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/FastPollingOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Foobar","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Foobar"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageBigBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageBigBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryApplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryApplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageHighScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageHighScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryRemoveUserSourceDependency","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryRemoveUserSourceDependency"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ImpedeFastPolling","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ImpedeFastPolling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/IncrementalSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/IncrementalSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestVMUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestVMUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LocalDiffDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LocalDiffDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/lowprioritysinglevm","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/lowprioritysinglevm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedDisksPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedDisksPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedResourcesMove","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedResourcesMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MRProfile","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MRProfile"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/MultipleAvailabilityZones","type":"Microsoft.Features/providers/features","name":"microsoft.compute/MultipleAvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NetworkPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NetworkPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NewAllocator","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NewAllocator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NodeFlight","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NodeFlight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OptOutScaleSetPipelinePreemption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OptOutScaleSetPipelinePreemption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OSUpgradeForServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OSUpgradeForServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/OverProvision","type":"Microsoft.Features/providers/features","name":"microsoft.compute/OverProvision"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverprovisionedExtensionDelay","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverprovisionedExtensionDelay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalance","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalance"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithFDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithFDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PerfTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PerfTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PremiumDiskLatencyOptimized","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PremiumDiskLatencyOptimized"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ProximityPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ProximityPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RegionalUltraSSDVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RegionalUltraSSDVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RepairVMScaleSetInstancesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RepairVMScaleSetInstancesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/Reprovisioning","type":"Microsoft.Features/providers/features","name":"microsoft.compute/Reprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePolicyOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePolicyOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RunScripts","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RunScripts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEnablePremiumLRSReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEnablePremiumLRSReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/SpotMeterValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/SpotMeterValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/StandardSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/StandardSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TenantReserveActivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TenantReserveActivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TipNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TipNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraSSDWithVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraSSDWithVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionForVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionForVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionWithOSUpgrades","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionWithOSUpgrades"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UsePreprovisionedVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UsePreprovisionedVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UserImageSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UserImageSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VirtualMachineRuntimeServiceDisablePackageValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VirtualMachineRuntimeServiceDisablePackageValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMPipelineBatchingPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMPipelineBatchingPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewV2Access","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewV2Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ZRSImagesAndSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ZRSImagesAndSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ESXiDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ESXiDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MSvDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MSvDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SyncBookmark","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SyncBookmark"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DCSizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DCSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/XLargeDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/XLargeDisk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DV3Sizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DV3Sizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG3","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG4","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDW","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGZ","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGZ"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLACC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLACC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DDAGen5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DDAGen5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ASeriesInternal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ASeriesInternal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Nested","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Nested"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Internal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Internal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Mv2SmallSizeSeries","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Mv2SmallSizeSeries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SharedIdentityEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SharedIdentityEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoReserveActivateInColocation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoReserveActivateInColocation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ListOfPinnedFabricClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ListOfPinnedFabricClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/NPSSizes","type":"Microsoft.Features/providers/features","name":"microsoft.compute/NPSSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EncryptionAtHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EncryptionAtHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TrustedVMBackfillEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TrustedVMBackfillEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchSubscriptionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchSubscriptionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/JediBetaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/JediBetaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CopyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CopyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithConfigurableRepairActions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithConfigurableRepairActions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SystemPriorityCopy","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SystemPriorityCopy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraDisk512E","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraDisk512E"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticExtensionUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticExtensionUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGPhaseScaleOutCopies","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGPhaseScaleOutCopies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ForwardAzGatewayTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ForwardAzGatewayTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreviewRebootless","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreviewRebootless"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AHUB","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AHUB"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowManagedDisksReplaceOSDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowManagedDisksReplaceOSDisk"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowPreReleaseRegions"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowValidationRegions"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/armApiPreviewAccess"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticOSUpgradeWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticOSUpgradeWithGalleryImage"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AvailabilitySetPinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AvailabilitySetPinning"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZAPInternalVMSKU","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZAPInternalVMSKU"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzAP"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzureVirtualMachineSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzureVirtualMachineSerialConsole"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZBalancing"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/BatchGetTenantInformantionRequests","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/BatchGetTenantInformantionRequests"}]}' + string: '{"value":[{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsPlan","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsPlan"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalAdvancedSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalAdvancedSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalEssentialsSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CAPSImagePublishing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CAPSImagePublishing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalStandardSupport","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CanonicalStandardSupport"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CorPersistence","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CorPersistence"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DedicatedNodeGroup","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DedicatedNodeGroup"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/disableDisksAndSnapshotsPerRGLimit","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/disableDisksAndSnapshotsPerRGLimit"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableSerialConsole"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DsmsSecrets","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DsmsSecrets"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EnableCrossSubscriptionWithKeyVaultResources","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EnableCrossSubscriptionWithKeyVaultResources"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ExtensionsFastpath","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ExtensionsFastpath"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.DisableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.DisableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableDeadMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableDeadMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigrationGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigrationGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateDiskCopyForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateDiskCopyForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableTenantLeaseOperationsOnNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableTenantLeaseOperationsOnNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableStopMigrateGen","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableStopMigrateGen"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.StopMigrateSkipDiskCopyForSub","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.StopMigrateSkipDiskCopyForSub"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.EnableVMFaultInjectorForTenant","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.EnableVMFaultInjectorForTenant"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.VMPreprovisioning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.VMPreprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/Fabric.UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/Fabric.UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/FastPollingOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/FastPollingOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.AllowUnhealthyNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.AllowUnhealthyNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.EnableCustomizedTenantLiveMigration","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.EnableCustomizedTenantLiveMigration"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Feature.DisableServiceHealing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Feature.DisableServiceHealing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Foobar","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Foobar"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageBigBlob","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageBigBlob"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryApplicationPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryApplicationPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryImageHighScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryImageHighScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/GalleryRemoveUserSourceDependency","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/GalleryRemoveUserSourceDependency"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ImpedeFastPolling","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ImpedeFastPolling"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/IncrementalSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/IncrementalSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestVMUpdate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestVMUpdate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LocalDiffDiskPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LocalDiffDiskPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/lowprioritysinglevm","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/lowprioritysinglevm"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedDisksPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedDisksPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ManagedResourcesMove","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ManagedResourcesMove"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MRProfile","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MRProfile"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/MultipleAvailabilityZones","type":"Microsoft.Features/providers/features","name":"microsoft.compute/MultipleAvailabilityZones"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NetworkPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NetworkPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NewAllocator","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NewAllocator"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NodeFlight","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NodeFlight"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OptOutScaleSetPipelinePreemption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OptOutScaleSetPipelinePreemption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OSUpgradeForServiceFabric","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OSUpgradeForServiceFabric"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/OverProvision","type":"Microsoft.Features/providers/features","name":"microsoft.compute/OverProvision"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverprovisionedExtensionDelay","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverprovisionedExtensionDelay"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalance","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalance"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithFDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithFDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/OverProvisionWithUDBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/OverProvisionWithUDBalancing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PerfTestSubscription","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PerfTestSubscription"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PremiumDiskLatencyOptimized","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PremiumDiskLatencyOptimized"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ProximityPlacementGroupsPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ProximityPlacementGroupsPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RegionalUltraSSDVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RegionalUltraSSDVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RepairVMScaleSetInstancesPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RepairVMScaleSetInstancesPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/Reprovisioning","type":"Microsoft.Features/providers/features","name":"microsoft.compute/Reprovisioning"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RollingUpgradePolicyOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RollingUpgradePolicyOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RunScripts","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RunScripts"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEnablePremiumLRSReplication","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEnablePremiumLRSReplication"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.compute/features/SpotMeterValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.compute/SpotMeterValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6NP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6NP"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/StandardSSD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/StandardSSD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TenantReserveActivate","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TenantReserveActivate"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TipNode","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TipNode"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UDWithinFDAlignment","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UDWithinFDAlignment"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraSSDWithVMSS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraSSDWithVMSS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionForVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionForVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UnifiedDiskEncryptionWithOSUpgrades","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UnifiedDiskEncryptionWithOSUpgrades"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UsePreprovisionedVMs","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UsePreprovisionedVMs"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UserImageSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UserImageSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VirtualMachineRuntimeServiceDisablePackageValidation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VirtualMachineRuntimeServiceDisablePackageValidation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMPipelineBatchingPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMPipelineBatchingPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewAccess"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/vmssApiPreviewV2Access","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/vmssApiPreviewV2Access"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ZRSImagesAndSnapshots","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ZRSImagesAndSnapshots"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ESXiDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ESXiDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/MSvDedicatedHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/MSvDedicatedHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SyncBookmark","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SyncBookmark"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DCSizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DCSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/XLargeDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/XLargeDisk"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DV3Sizes","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DV3Sizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG3","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG3"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG4","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG4"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLG6","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLG6"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLDW","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLDW"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGZ","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGZ"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLGM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLGM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQLACC","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQLACC"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SQL","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SQL"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/DDAGen5","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/DDAGen5"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ASeriesInternal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ASeriesInternal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Nested","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Nested"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Dv2Internal","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Dv2Internal"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TEST2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TEST2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGEncryption","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGEncryption"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Mv2SmallSizeSeries","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Mv2SmallSizeSeries"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMOrchestratorMultiFD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMOrchestratorMultiFD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMOrchestratorSingleFD","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMOrchestratorSingleFD"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SharedIdentityEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SharedIdentityEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoReserveActivateInColocation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoReserveActivateInColocation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ListOfPinnedFabricClusters","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ListOfPinnedFabricClusters"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/microsoft.compute/features/NPSSizes","type":"Microsoft.Features/providers/features","name":"microsoft.compute/NPSSizes"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EncryptionAtHost","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EncryptionAtHost"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/TrustedVMBackfillEnabled","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/TrustedVMBackfillEnabled"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchSubscriptionPreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchSubscriptionPreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/JediBetaTest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/JediBetaTest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CopyV2","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CopyV2"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CloudServices","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CloudServices"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithConfigurableRepairActions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithConfigurableRepairActions"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SystemPriorityCopy","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SystemPriorityCopy"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UltraDisk512E","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UltraDisk512E"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGPhaseScaleOutCopies","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGPhaseScaleOutCopies"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGSharing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGSharing"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/ForwardAzGatewayTags","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/ForwardAzGatewayTags"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestHotPatchVMPreviewRebootless","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestHotPatchVMPreviewRebootless"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SIGTrustedVM","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SIGTrustedVM"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticRepairsWithVMScaleSetsAtScale","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticRepairsWithVMScaleSetsAtScale"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradeSDPWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradeSDPWithGalleryImage"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.Spanning.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.Spanning.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/NoRollingUpgradeForSFAutoOSUpgrade","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/NoRollingUpgradeForSFAutoOSUpgrade"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/UseElasticPipelineOptimization","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/UseElasticPipelineOptimization"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.AzPE.OptOut","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.AzPE.OptOut"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.AzSM.NewDeployment.Spanning.OptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.AzSM.NewDeployment.Spanning.OptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RestorePointsRetrieveSAS","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RestorePointsRetrieveSAS"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CapacityReservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CapacityReservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.CapacityReservation","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.CapacityReservation"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/Fabric.CapacityReservationOptIn","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/Fabric.CapacityReservationOptIn"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMCustomImagePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMCustomImagePreview"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/InGuestAutoPatchVMPatchModeOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/InGuestAutoPatchVMPatchModeOverride"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutorotationForDiskEncryptionAtRest","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutorotationForDiskEncryptionAtRest"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMApps","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMApps"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SpotTryRestore","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SpotTryRestore"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/RestorePointExcludeDisks","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/RestorePointExcludeDisks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SsdZrsManagedDisks","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SsdZrsManagedDisks"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CrossScaleSetSFCoordination","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/CrossScaleSetSFCoordination"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/VMNetworkInterfaceConfigurations","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/VMNetworkInterfaceConfigurations"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/SpotBlock","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/SpotBlock"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/LiveTierChange","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/LiveTierChange"},{"properties":{"state":"NotRegistered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/EarlyStartVMSSRoleInstances","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/EarlyStartVMSSRoleInstances"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AHUB","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AHUB"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowManagedDisksReplaceOSDisk","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowManagedDisksReplaceOSDisk"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowPreReleaseRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowPreReleaseRegions"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AllowValidationRegions","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AllowValidationRegions"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/armApiPreviewAccess","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/armApiPreviewAccess"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticOSUpgradeWithGalleryImage","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticOSUpgradeWithGalleryImage"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutoOSUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutoOSUpgradePreview"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AvailabilitySetPinning","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AvailabilitySetPinning"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZAPInternalVMSKU","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZAPInternalVMSKU"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzAP","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzAP"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AzureVirtualMachineSerialConsole","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AzureVirtualMachineSerialConsole"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AZBalancing","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AZBalancing"},{"properties":{"state":"Pending"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/BatchGetTenantInformantionRequests","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/BatchGetTenantInformantionRequests"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/PlatformSettingsOverride","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/PlatformSettingsOverride"},{"properties":{"state":"Registered"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/AutomaticExtensionUpgradePreview","type":"Microsoft.Features/providers/features","name":"Microsoft.Compute/AutomaticExtensionUpgradePreview"}]}' headers: cache-control: - no-cache content-length: - - '41924' + - '49826' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:36:49 GMT + - Fri, 26 Feb 2021 06:54:03 GMT expires: - '-1' pragma: @@ -89,7 +89,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Features/providers/Microsoft.Compute/features/CanonicalEssentialsPlan?api-version=2015-12-01 response: @@ -103,7 +103,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:36:49 GMT + - Fri, 26 Feb 2021 06:54:04 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_links.test_links.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_links.test_links.yaml index 8c12fc119c76..15a7eb3867d6 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_links.test_links.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_links.test_links.yaml @@ -13,7 +13,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a?api-version=2019-07-01 response: @@ -31,7 +31,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:10 GMT + - Fri, 26 Feb 2021 06:54:17 GMT expires: - '-1' pragma: @@ -48,9 +48,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1199 + - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1193 x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 200 message: OK @@ -68,7 +68,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a2?api-version=2019-07-01 response: @@ -86,7 +86,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:13 GMT + - Fri, 26 Feb 2021 06:54:21 GMT expires: - '-1' pragma: @@ -103,15 +103,15 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1198 + - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1192 x-ms-ratelimit-remaining-subscription-writes: - - '1197' + - '1198' status: code: 200 message: OK - request: - body: 'b''b\''{"properties": {"targetId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a2", - "notes": "Testing links"}}\''''' + body: '{"properties": {"targetId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a2", + "notes": "Testing links"}}' headers: Accept: - application/json @@ -124,7 +124,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a/providers/Microsoft.Resources/links/myLink?api-version=2016-09-01 response: @@ -139,7 +139,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:15 GMT + - Fri, 26 Feb 2021 06:54:23 GMT expires: - '-1' pragma: @@ -149,7 +149,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1198' status: code: 201 message: Created @@ -163,7 +163,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a/providers/Microsoft.Resources/links/myLink?api-version=2016-09-01 response: @@ -178,7 +178,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:25 GMT + - Fri, 26 Feb 2021 06:54:33 GMT expires: - '-1' pragma: @@ -204,7 +204,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Resources/links?api-version=2016-09-01 response: @@ -219,7 +219,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:25 GMT + - Fri, 26 Feb 2021 06:54:34 GMT expires: - '-1' pragma: @@ -245,7 +245,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a/providers/Microsoft.Resources/links?$filter=atScope%28%29&api-version=2016-09-01 response: @@ -260,7 +260,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:26 GMT + - Fri, 26 Feb 2021 06:54:34 GMT expires: - '-1' pragma: @@ -286,7 +286,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a/providers/Microsoft.Resources/links?$filter=atScope%28%29&api-version=2016-09-01 response: @@ -301,7 +301,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:37:26 GMT + - Fri, 26 Feb 2021 06:54:34 GMT expires: - '-1' pragma: @@ -329,7 +329,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset7650e8a/providers/Microsoft.Resources/links/myLink?api-version=2016-09-01 response: @@ -341,7 +341,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:37:26 GMT + - Fri, 26 Feb 2021 06:54:34 GMT expires: - '-1' pragma: @@ -351,7 +351,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14998' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_group_level.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_group_level.yaml index 01c9b03e1d82..83bd1c101dbd 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_group_level.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_group_level.yaml @@ -13,7 +13,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -27,7 +27,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:19 GMT + - Fri, 26 Feb 2021 06:54:40 GMT expires: - '-1' pragma: @@ -51,7 +51,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -65,7 +65,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:19 GMT + - Fri, 26 Feb 2021 06:54:41 GMT expires: - '-1' pragma: @@ -91,7 +91,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/locks?api-version=2016-09-01 response: @@ -105,7 +105,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:20 GMT + - Fri, 26 Feb 2021 06:54:41 GMT expires: - '-1' pragma: @@ -133,7 +133,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -145,7 +145,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:45:20 GMT + - Fri, 26 Feb 2021 06:54:41 GMT expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_level.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_level.yaml index bdb3e7a3a795..5b3886799871 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_level.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_resource_level.yaml @@ -13,7 +13,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2?api-version=2019-07-01 response: @@ -31,7 +31,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:34 GMT + - Fri, 26 Feb 2021 06:54:51 GMT expires: - '-1' pragma: @@ -48,9 +48,9 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;239,Microsoft.Compute/PutVM30Min;1197 + - Microsoft.Compute/PutVM3Min;237,Microsoft.Compute/PutVM30Min;1191 x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1197' status: code: 200 message: OK @@ -68,7 +68,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -82,7 +82,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:35 GMT + - Fri, 26 Feb 2021 06:54:53 GMT expires: - '-1' pragma: @@ -92,7 +92,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1199' status: code: 201 message: Created @@ -106,7 +106,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -120,7 +120,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:36 GMT + - Fri, 26 Feb 2021 06:54:53 GMT expires: - '-1' pragma: @@ -146,7 +146,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2/providers/Microsoft.Authorization/locks?api-version=2016-09-01 response: @@ -160,7 +160,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:36 GMT + - Fri, 26 Feb 2021 06:54:54 GMT expires: - '-1' pragma: @@ -188,7 +188,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -200,7 +200,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:45:36 GMT + - Fri, 26 Feb 2021 06:54:54 GMT expires: - '-1' pragma: @@ -210,7 +210,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14998' + - '14999' status: code: 200 message: OK @@ -226,7 +226,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset529215f2?api-version=2019-07-01 response: @@ -238,7 +238,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:45:41 GMT + - Fri, 26 Feb 2021 06:54:58 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_subscription_level.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_subscription_level.yaml index 8ef7907b061b..4836cb71d09e 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_subscription_level.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_at_subscription_level.yaml @@ -13,7 +13,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -27,7 +27,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:46 GMT + - Fri, 26 Feb 2021 06:55:01 GMT expires: - '-1' pragma: @@ -37,7 +37,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1198' status: code: 201 message: Created @@ -51,7 +51,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -65,7 +65,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:46 GMT + - Fri, 26 Feb 2021 06:55:01 GMT expires: - '-1' pragma: @@ -91,7 +91,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/locks?api-version=2016-09-01 response: @@ -105,7 +105,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:46 GMT + - Fri, 26 Feb 2021 06:55:01 GMT expires: - '-1' pragma: @@ -133,7 +133,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -145,7 +145,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:45:46 GMT + - Fri, 26 Feb 2021 06:55:01 GMT expires: - '-1' pragma: @@ -155,7 +155,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14999' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_by_scope.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_by_scope.yaml index bf66f4ab69d9..41533293c323 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_by_scope.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_locks.test_locks_by_scope.yaml @@ -13,7 +13,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset9be91233?api-version=2019-07-01 response: @@ -31,7 +31,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:58 GMT + - Fri, 26 Feb 2021 06:55:14 GMT expires: - '-1' pragma: @@ -48,7 +48,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-resource: - - Microsoft.Compute/PutVM3Min;238,Microsoft.Compute/PutVM30Min;1196 + - Microsoft.Compute/PutVM3Min;236,Microsoft.Compute/PutVM30Min;1190 x-ms-ratelimit-remaining-subscription-writes: - '1198' status: @@ -68,7 +68,7 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT uri: https://management.azure.com/%2Fsubscriptions%2F00000000-0000-0000-0000-000000000000%2FresourceGroups%2Frgname%2Fproviders%2FMicrosoft.Compute%2FavailabilitySets%2Fpytestavset9be91233/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -82,7 +82,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:59 GMT + - Fri, 26 Feb 2021 06:55:17 GMT expires: - '-1' pragma: @@ -92,7 +92,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1196' + - '1193' status: code: 201 message: Created @@ -106,7 +106,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/%2Fsubscriptions%2F00000000-0000-0000-0000-000000000000%2FresourceGroups%2Frgname%2Fproviders%2FMicrosoft.Compute%2FavailabilitySets%2Fpytestavset9be91233/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -120,7 +120,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:45:59 GMT + - Fri, 26 Feb 2021 06:55:17 GMT expires: - '-1' pragma: @@ -148,7 +148,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/%2Fsubscriptions%2F00000000-0000-0000-0000-000000000000%2FresourceGroups%2Frgname%2Fproviders%2FMicrosoft.Compute%2FavailabilitySets%2Fpytestavset9be91233/providers/Microsoft.Authorization/locks/pylockrg?api-version=2016-09-01 response: @@ -160,7 +160,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:46:00 GMT + - Fri, 26 Feb 2021 06:55:17 GMT expires: - '-1' pragma: @@ -186,7 +186,7 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Compute/availabilitySets/pytestavset9be91233?api-version=2019-07-01 response: @@ -198,7 +198,7 @@ interactions: content-length: - '0' date: - - Thu, 17 Sep 2020 08:46:04 GMT + - Fri, 26 Feb 2021 06:55:21 GMT expires: - '-1' pragma: @@ -213,7 +213,7 @@ interactions: x-ms-ratelimit-remaining-resource: - Microsoft.Compute/DeleteVM3Min;238,Microsoft.Compute/DeleteVM30Min;1196 x-ms-ratelimit-remaining-subscription-deletes: - - '14999' + - '14998' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application.yaml index fdb92047da77..ce6f082dd309 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application.yaml @@ -13,9 +13,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_group_name_xyz","name":"test_group_name_xyz","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -27,7 +27,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:56:27 GMT + - Fri, 26 Feb 2021 07:47:33 GMT expires: - '-1' pragma: @@ -41,7 +41,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1195' + - '1193' status: code: 200 message: OK @@ -67,17 +67,17 @@ interactions: response: body: string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_AA72A3C7E3B9E76E4AE1321D434F01B35432A061/fec1d14da02d4e98aa0f0d9a83797457/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East + description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_F1B90E93BCFE331383DFAD1DB89A7CB6BA19C79DDA5163C026E9FED2CF76CC52/88ec6983df6d456d99526c93b1dae83c/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East US"}' headers: cache-control: - no-cache content-length: - - '1527' + - '1551' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:56:35 GMT + - Fri, 26 Feb 2021 07:47:42 GMT expires: - '-1' pragma: @@ -87,7 +87,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1199' + - '1196' status: code: 201 message: Created @@ -107,17 +107,17 @@ interactions: response: body: string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_AA72A3C7E3B9E76E4AE1321D434F01B35432A061/fec1d14da02d4e98aa0f0d9a83797457/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East + description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_F1B90E93BCFE331383DFAD1DB89A7CB6BA19C79DDA5163C026E9FED2CF76CC52/88ec6983df6d456d99526c93b1dae83c/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East US"}' headers: cache-control: - no-cache content-length: - - '1527' + - '1551' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:57:06 GMT + - Fri, 26 Feb 2021 07:48:13 GMT expires: - '-1' pragma: @@ -149,17 +149,17 @@ interactions: response: body: string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_AA72A3C7E3B9E76E4AE1321D434F01B35432A061/fec1d14da02d4e98aa0f0d9a83797457/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East + description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_F1B90E93BCFE331383DFAD1DB89A7CB6BA19C79DDA5163C026E9FED2CF76CC52/88ec6983df6d456d99526c93b1dae83c/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East US"}' headers: cache-control: - no-cache content-length: - - '1527' + - '1551' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:57:06 GMT + - Fri, 26 Feb 2021 07:48:13 GMT expires: - '-1' pragma: @@ -176,9 +176,9 @@ interactions: code: 200 message: OK - request: - body: 'b''b\''{"location": "East US", "kind": "ServiceCatalog", "properties": - {"managedResourceGroupId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz", - "applicationDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition"}}\''''' + body: '{"location": "East US", "kind": "ServiceCatalog", "properties": {"managedResourceGroupId": + "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz", + "applicationDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition"}}' headers: Accept: - application/json @@ -201,7 +201,7 @@ interactions: headers: azure-asyncoperation: - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East - US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRPU1FRS1E3NVlWNUs2UEZNNFFGTUI3SDVRVFhOSERFVllKWFhDU1VWQlVZVzNRUDo3QzIxQUI3NTJBRDVCNzYwNUI6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 + US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3pqZXpta3lic25zM2t2dGh5ZHRkcWxoeGdtbG1ienBpc2NudzNraHU1aHUyeHl5Z2hkY3Z3a3BwemVtdjNoaGliM2duNHNzanE1ai9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaSkVaTUtZQlNOUzNLVlRIWURURFFMSFhHTUxNQlpQSVNDTlczS0hVNUhVMlhZWTo3Q0RCRDIyNkM4REQ2NDg1Q0Q6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 cache-control: - no-cache content-length: @@ -209,11 +209,11 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:57:09 GMT + - Fri, 26 Feb 2021 07:48:17 GMT expires: - '-1' location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRPU1FRS1E3NVlWNUs2UEZNNFFGTUI3SDVRVFhOSERFVllKWFhDU1VWQlVZVzNRUDo3QzIxQUI3NTJBRDVCNzYwNUI6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 + - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3pqZXpta3lic25zM2t2dGh5ZHRkcWxoeGdtbG1ienBpc2NudzNraHU1aHUyeHl5Z2hkY3Z3a3BwemVtdjNoaGliM2duNHNzanE1ai9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaSkVaTUtZQlNOUzNLVlRIWURURFFMSFhHTUxNQlpQSVNDTlczS0hVNUhVMlhZWTo3Q0RCRDIyNkM4REQ2NDg1Q0Q6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 pragma: - no-cache strict-transport-security: @@ -221,212 +221,10 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1198' + - '1195' status: code: 201 message: Created -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '{"properties":{"managedResourceGroupId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz","applicationDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","publisherPackageId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","provisioningState":"Accepted","authorizations":[],"createdBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"},"updatedBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest","name":"applicationtest","type":"Microsoft.Solutions/applications","kind":"ServiceCatalog","location":"East - US"}' - headers: - cache-control: - - no-cache - content-length: - - '1228' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:57:10 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: 'b''{"kind": "ServiceCatalog", "properties": {"managedResourceGroupId": - "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz"}}''' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '169' - Content-Type: - - application/json - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:57:11 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWNhdGlvblJlc291cmNlUGF0Y2hKb2I6MkRSR0E6MkRPU1FRS1E3NVlWNUs2UEZNNFFGTUI3SDVRVFhOSERFVllKWFhDU1VWQlVZVzNRUDo3QzIxQUI3NTJBRDVCNzYwNUI6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-writes: - - '1197' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:57:11 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRE9TUVFLUTc1WVY1SzZQRk00UUZNQjdINVFUWE5IREVWWUpYWENTVVZCVVlXM1FQOjdDMjFBQjc1MkFENUI3NjA1QjoyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14999' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRPU1FRS1E3NVlWNUs2UEZNNFFGTUI3SDVRVFhOSERFVllKWFhDU1VWQlVZVzNRUDo3QzIxQUI3NTJBRDVCNzYwNUI6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - response: - body: - string: '{"status":"Failed","error":{"code":"InvalidApplianceState","message":"The - provisioning failed for resource type ''Microsoft.Solutions/applications'' - with name ''applicationtest'' since the appliance is in an invalid state ''Deleting''."}}' - headers: - cache-control: - - no-cache - content-length: - - '232' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:57:26 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRE9TUVFLUTc1WVY1SzZQRk00UUZNQjdINVFUWE5IREVWWUpYWENTVVZCVVlXM1FQOjdDMjFBQjc1MkFENUI3NjA1QjoyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 - response: - body: - string: '{"status":"Accepted"}' - headers: - cache-control: - - no-cache - content-length: - - '21' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:57:28 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted - request: body: null headers: @@ -439,19 +237,24 @@ interactions: User-Agent: - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL29zcXFrcTc1eXY1azZwZm00cWZtYjdoNXF0eG5oZGV2eWp4eGNzdXZidXl3M3FwYmU3d3h1dHFlNXFuaWpvd2pjbzJkYnIzanNtdS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRE9TUVFLUTc1WVY1SzZQRk00UUZNQjdINVFUWE5IREVWWUpYWENTVVZCVVlXM1FQOjdDMjFBQjc1MkFENUI3NjA1QjoyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3pqZXpta3lic25zM2t2dGh5ZHRkcWxoeGdtbG1ienBpc2NudzNraHU1aHUyeHl5Z2hkY3Z3a3BwemVtdjNoaGliM2duNHNzanE1ai9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaSkVaTUtZQlNOUzNLVlRIWURURFFMSFhHTUxNQlpQSVNDTlczS0hVNUhVMlhZWTo3Q0RCRDIyNkM4REQ2NDg1Q0Q6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 response: body: - string: '{"status":"Succeeded"}' + string: '{"status":"Failed","error":{"code":"ApplianceProvisioningFailed","message":"The + resource group ''/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz'' + already exists with a managed by property ''/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/c3him2kacb2tvfbfnryspaawzwhmlrg5jyyp37do7hfdda7beeryuaekxuwcp7xbpd3gptovx23/providers/Microsoft.Solutions/applications/applicationtest'' + which does not match the applicationId ''/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest''. + Please specify a new non-existent resource group as the managed by resource + group."}}' headers: cache-control: - no-cache content-length: - - '22' + - '770' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:57:58 GMT + - Fri, 26 Feb 2021 07:48:33 GMT expires: - '-1' pragma: @@ -467,188 +270,4 @@ interactions: status: code: 200 message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:58:00 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14998' - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:58:04 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14999' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:58:20 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:58:36 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:58:51 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 200 - message: OK version: 1 diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application_by_id.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application_by_id.yaml index 7cf29b5f7e7f..119e20e93e33 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application_by_id.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_managed_application.test_application_by_id.yaml @@ -13,9 +13,9 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-06-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-10-01 response: body: string: '{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/test_group_name_xyz","name":"test_group_name_xyz","type":"Microsoft.Resources/resourceGroups","location":"eastus","tags":{"tag1":"value1"},"properties":{"provisioningState":"Succeeded"}}' @@ -27,93 +27,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 08:59:02 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-writes: - - '1198' - status: - code: 201 - message: Created -- request: - body: '{"location": "East US", "properties": {"lockLevel": "None", "displayName": - "myManagedApplicationDef", "authorizations": [], "description": "myManagedApplicationDef - description", "packageFileUri": "https://raw.githubusercontent.com/Azure/azure-quickstart-templates/master/101-managed-application-with-linked-templates/artifacts/ManagedAppZip/pkg.zip"}}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '351' - Content-Type: - - application/json - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition?api-version=2018-06-01 - response: - body: - string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_76783B9EEC87F1CFE3DFCE457A514FE992F22723/725dec848bc84342ab46b35e8b614848/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East - US"}' - headers: - cache-control: - - no-cache - content-length: - - '1527' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:59:11 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-writes: - - '1196' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition?api-version=2018-06-01 - response: - body: - string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_76783B9EEC87F1CFE3DFCE457A514FE992F22723/725dec848bc84342ab46b35e8b614848/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East - US"}' - headers: - cache-control: - - no-cache - content-length: - - '1527' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:59:42 GMT + - Fri, 26 Feb 2021 07:42:20 GMT expires: - '-1' pragma: @@ -123,527 +37,11 @@ interactions: transfer-encoding: - chunked vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition?api-version=2018-06-01 - response: - body: - string: '{"properties":{"authorizations":[],"isEnabled":true,"lockLevel":"None","displayName":"myManagedApplicationDef","description":"myManagedApplicationDef - description","artifacts":[{"name":"ApplicationResourceTemplate","type":"Template","uri":"https://prdsapplianceprodbl01.blob.core.windows.net/applicationdefinitions/E3823_92F95D8F3C67412491C78CF07CDBF241_76783B9EEC87F1CFE3DFCE457A514FE992F22723/725dec848bc84342ab46b35e8b614848/applicationResourceTemplate.json"},{"name":"CreateUiDefinition","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/CreateUiDefinition?api-version=2017-09-01"},{"name":"MainTemplateParameters","type":"Custom","uri":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition/applicationArtifacts/MainTemplateParameters?api-version=2017-09-01"}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","name":"applicationdefinition","type":"Microsoft.Solutions/applicationDefinitions","location":"East - US"}' - headers: - cache-control: - - no-cache - content-length: - - '1527' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:59:42 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: 'b''b\''{"location": "East US", "kind": "ServiceCatalog", "properties": - {"managedResourceGroupId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz", - "applicationDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition"}}\''''' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '440' - Content-Type: - - application/json - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '{"properties":{"managedResourceGroupId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz","applicationDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","publisherPackageId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","provisioningState":"Accepted","authorizations":[],"createdBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"},"updatedBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest","name":"applicationtest","type":"Microsoft.Solutions/applications","kind":"ServiceCatalog","location":"East - US"}' - headers: - azure-asyncoperation: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East - US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaVzJHQVBOTkNYSEVMNks2VklETzVNUFo3VURaNlBFM01QUkJDUkhKSVJNVFdaQTo3Q0VCMjkxRUREN0JDMUM5NTU6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - cache-control: - - no-cache - content-length: - - '1228' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:59:46 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaVzJHQVBOTkNYSEVMNks2VklETzVNUFo3VURaNlBFM01QUkJDUkhKSVJNVFdaQTo3Q0VCMjkxRUREN0JDMUM5NTU6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-writes: - - '1195' - status: - code: 201 - message: Created -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '{"properties":{"managedResourceGroupId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz","applicationDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","publisherPackageId":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition","provisioningState":"Accepted","authorizations":[],"createdBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"},"updatedBy":{"oid":"123743cc-88ef-49ee-920e-13958fe5697d","applicationId":"8a95323f-4a83-4a69-903f-7d2c69349c3c"}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest","name":"applicationtest","type":"Microsoft.Solutions/applications","kind":"ServiceCatalog","location":"East - US"}' - headers: - cache-control: - - no-cache - content-length: - - '1228' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 08:59:46 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: 'b''{"kind": "ServiceCatalog", "properties": {"managedResourceGroupId": - "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myManagedRGtest_group_name_xyz"}}''' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '169' - Content-Type: - - application/json - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: PATCH - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:59:47 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWNhdGlvblJlc291cmNlUGF0Y2hKb2I6MkRSR0E6MkRaVzJHQVBOTkNYSEVMNks2VklETzVNUFo3VURaNlBFM01QUkJDUkhKSVJNVFdaQTo3Q0VCMjkxRUREN0JDMUM5NTU6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains + - Accept-Encoding x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - '1194' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applications/applicationtest?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 08:59:48 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRFpXMkdBUE5OQ1hIRUw2SzZWSURPNU1QWjdVRFo2UEUzTVBSQkNSSEpJUk1UV1pBOjdDRUIyOTFFREQ3QkMxQzk1NToyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14996' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VQcm92aXNpb25pbmdKb2I6MkRSR0E6MkRaVzJHQVBOTkNYSEVMNks2VklETzVNUFo3VURaNlBFM01QUkJDUkhKSVJNVFdaQTo3Q0VCMjkxRUREN0JDMUM5NTU6MkRBUFBMSUNBVElPTlRFU1QifQ?api-version=2018-06-01 - response: - body: - string: '{"status":"Failed","error":{"code":"InvalidApplianceState","message":"The - provisioning failed for resource type ''Microsoft.Solutions/applications'' - with name ''applicationtest'' since the appliance is in an invalid state ''Deleting''."}}' - headers: - cache-control: - - no-cache - content-length: - - '232' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 09:00:01 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRFpXMkdBUE5OQ1hIRUw2SzZWSURPNU1QWjdVRFo2UEUzTVBSQkNSSEpJUk1UV1pBOjdDRUIyOTFFREQ3QkMxQzk1NToyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 - response: - body: - string: '{"status":"Accepted"}' - headers: - cache-control: - - no-cache - content-length: - - '21' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 09:00:03 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/locations/East%20US/operationStatuses/eyJmdWxseVF1YWxpZmllZEFwcGxpYW5jZUlkIjoiL3N1YnNjcmlwdGlvbnMvOTJmOTVkOGYtM2M2Ny00MTI0LTkxYzctOGNmMDdjZGJmMjQxL3Jlc291cmNlR3JvdXBzL3p3MmdhcG5uY3hoZWw2azZ2aWRvNW1wejd1ZHo2cGUzbXByYmNyaGppcm10d3phNWVramZ6cmZvbm82MzZvYXp3eG83ZndsaGx1dS9wcm92aWRlcnMvTWljcm9zb2Z0LlNvbHV0aW9ucy9hcHBsaWNhdGlvbnMvYXBwbGljYXRpb250ZXN0Iiwiam9iSWQiOiJBcHBsaWFuY2VEZXByb3Zpc2lvbmluZ0pvYjoyRFJHQToyRFpXMkdBUE5OQ1hIRUw2SzZWSURPNU1QWjdVRFo2UEUzTVBSQkNSSEpJUk1UV1pBOjdDRUIyOTFFREQ3QkMxQzk1NToyREFQUExJQ0FUSU9OVEVTVCJ9?api-version=2018-06-01 - response: - body: - string: '{"status":"Succeeded"}' - headers: - cache-control: - - no-cache - content-length: - - '22' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 09:00:34 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - transfer-encoding: - - chunked - vary: - - Accept-Encoding,Accept-Encoding - x-content-type-options: - - nosniff - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-mgmt-resource/unknown Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Solutions/applicationDefinitions/applicationdefinition?api-version=2018-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 09:00:39 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14995' - status: - code: 200 - message: OK -- request: - body: null - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - Content-Length: - - '0' - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/test_group_name_xyz?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 09:00:43 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - x-ms-ratelimit-remaining-subscription-deletes: - - '14998' - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 09:00:58 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 09:01:14 GMT - expires: - - '-1' - location: - - https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff - status: - code: 202 - message: Accepted -- request: - body: null - headers: - Accept: - - '*/*' - Accept-Encoding: - - gzip, deflate - Connection: - - keep-alive - User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) - method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/operationresults/eyJqb2JJZCI6IlJFU09VUkNFR1JPVVBERUxFVElPTkpPQi1URVNUOjVGR1JPVVA6NUZOQU1FOjVGWFlaLUVBU1RVUyIsImpvYkxvY2F0aW9uIjoiZWFzdHVzIn0?api-version=2020-06-01 - response: - body: - string: '' - headers: - cache-control: - - no-cache - content-length: - - '0' - date: - - Thu, 17 Sep 2020 09:01:30 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - x-content-type-options: - - nosniff status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition.yaml index cc97e3e62a8a..67d75fc00e77 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition.yaml @@ -16,13 +16,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"policyType":"Custom","mode":"Indexed","description":"Don''t - create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:55.7481401Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' + create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:15.3292265Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -31,7 +31,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:55 GMT + - Fri, 26 Feb 2021 07:40:14 GMT expires: - '-1' pragma: @@ -41,7 +41,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1193' + - '1198' status: code: 201 message: Created @@ -55,13 +55,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"policyType":"Custom","mode":"Indexed","description":"Don''t - create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:55.7481401Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' + create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:15.3292265Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -70,7 +70,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:55 GMT + - Fri, 26 Feb 2021 07:40:15 GMT expires: - '-1' pragma: @@ -96,691 +96,8484 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01 + response: + body: + string: '{"value":[{"properties":{"displayName":"Disk encryption should be enabled + on Azure Data Explorer","policyType":"BuiltIn","mode":"Indexed","description":"Enabling + disk encryption helps protect and safeguard your data to meet your organizational + security and compliance commitments.","metadata":{"version":"2.0.0","category":"Azure + Data Explorer"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Kusto/Clusters"},{"anyOf":[{"field":"Microsoft.Kusto/clusters/enableDiskEncryption","exists":false},{"field":"Microsoft.Kusto/clusters/enableDiskEncryption","equals":false}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f4b53539-8df9-40e4-86c6-6b607703bd4e","type":"Microsoft.Authorization/policyDefinitions","name":"f4b53539-8df9-40e4-86c6-6b607703bd4e"},{"properties":{"displayName":"Azure + Data Explorer encryption at rest should use a customer-managed key","policyType":"BuiltIn","mode":"Indexed","description":"Enabling + encryption at rest using a customer-managed key on your Azure Data Explorer + cluster provides additional control over the key being used by the encryption + at rest. This feature is oftentimes applicable to customers with special compliance + requirements and requires a Key Vault to managing the keys.","metadata":{"version":"1.0.0","category":"Azure + Data Explorer"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Kusto/Clusters"},{"anyOf":[{"field":"Microsoft.Kusto/clusters/keyVaultProperties","exists":false},{"field":"Microsoft.Kusto/clusters/keyVaultProperties.keyName","exists":false},{"field":"Microsoft.Kusto/clusters/keyVaultProperties.keyVersion","exists":false},{"field":"Microsoft.Kusto/clusters/keyVaultProperties.keyVaultUri","exists":false}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/81e74cea-30fd-40d5-802f-d72103c2aaaa","type":"Microsoft.Authorization/policyDefinitions","name":"81e74cea-30fd-40d5-802f-d72103c2aaaa"},{"properties":{"displayName":"App + Configuration should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network. By mapping private endpoints to your app configuration instances + instead of the entire service, you''ll also be protected against data leakage + risks. Learn more at: https://aka.ms/appconfig/private-endpoint.","metadata":{"version":"1.0.2","category":"App + Configuration"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.AppConfiguration/configurationStores"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.AppConfiguration/configurationStores/privateEndpointConnections","existenceCondition":{"field":"Microsoft.AppConfiguration/configurationStores/privateEndpointConnections/privateLinkServiceConnectionState.status","equals":"Approved"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ca610c1d-041c-4332-9d88-7ed3094967c7","type":"Microsoft.Authorization/policyDefinitions","name":"ca610c1d-041c-4332-9d88-7ed3094967c7"},{"properties":{"displayName":"Double + encryption should be enabled on Azure Data Explorer","policyType":"BuiltIn","mode":"Indexed","description":"Enabling + double encryption helps protect and safeguard your data to meet your organizational + security and compliance commitments. When double encryption has been enabled, + data in the storage account is encrypted twice, once at the service level + and once at the infrastructure level, using two different encryption algorithms + and two different keys.","metadata":{"version":"2.0.0","category":"Azure Data + Explorer"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Kusto/Clusters"},{"anyOf":[{"field":"Microsoft.Kusto/clusters/enableDoubleEncryption","exists":false},{"field":"Microsoft.Kusto/clusters/enableDoubleEncryption","equals":false}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ec068d99-e9c7-401f-8cef-5bdde4e6ccf1","type":"Microsoft.Authorization/policyDefinitions","name":"ec068d99-e9c7-401f-8cef-5bdde4e6ccf1"},{"properties":{"displayName":"App + Configuration should use a customer-managed key","policyType":"BuiltIn","mode":"Indexed","description":"Customer-managed + keys provide enhanced data protection by allowing you to manage your encryption + keys. This is often required to meet compliance requirements.","metadata":{"version":"1.1.0","category":"App + Configuration"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.AppConfiguration/configurationStores"},{"field":"Microsoft.AppConfiguration/configurationStores/encryption.keyVaultProperties.keyIdentifier","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/967a4b4b-2da9-43c1-b7d0-f98d0d74d0b1","type":"Microsoft.Authorization/policyDefinitions","name":"967a4b4b-2da9-43c1-b7d0-f98d0d74d0b1"},{"properties":{"displayName":"Deploy + Log Analytics agent for Linux virtual machine scale sets","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Log Analytics agent for Linux virtual machine scale sets if the VM Image (OS) + is in the list defined and the agent is not installed. Note: if your scale + set upgradePolicy is set to Manual, you need to apply the extension to the + all VMs in the set by calling upgrade on them. In CLI this would be az vmss + update-instances.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"15*"}]}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"sles-12-sp*"},{"field":"Microsoft.Compute/imageOffer","like":"sles-15-sp*"}]},{"field":"Microsoft.Compute/imageSKU","in":["gen1","gen2"]}]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16_04*lts-gen2"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18_04*lts-gen2"},{"field":"Microsoft.Compute/imageSKU","like":"20_04*lts"},{"field":"Microsoft.Compute/imageSKU","like":"20_04*lts-gen2"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"8*"},{"field":"Microsoft.Compute/imageSKU","like":"9*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293","/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"OmsAgentForLinux"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"}},"variables":{"vmExtensionName":"OMSAgentForLinux","vmExtensionPublisher":"Microsoft.EnterpriseCloud.Monitoring","vmExtensionType":"OmsAgentForLinux","vmExtensionTypeHandlerVersion":"1.13"},"resources":[{"name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","type":"Microsoft.Compute/virtualMachineScaleSets/extensions","location":"[parameters(''location'')]","apiVersion":"2018-06-01","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true,"settings":{"workspaceId":"[reference(parameters(''logAnalytics''), + ''2015-03-20'').customerId]","stopOnMultipleConnections":"true"},"protectedSettings":{"workspaceKey":"[listKeys(parameters(''logAnalytics''), + ''2015-03-20'').primarySharedKey]"}}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for: '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5ee9e9ed-0b42-41b7-8c9c-3cfb2fbe2069","type":"Microsoft.Authorization/policyDefinitions","name":"5ee9e9ed-0b42-41b7-8c9c-3cfb2fbe2069"},{"properties":{"displayName":"Deploy + Log Analytics agent for Linux VMs","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Log Analytics agent for Linux VMs if the VM Image (OS) is in the list defined + and the agent is not installed.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"15*"}]}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"sles-12-sp*"},{"field":"Microsoft.Compute/imageOffer","like":"sles-15-sp*"}]},{"field":"Microsoft.Compute/imageSKU","in":["gen1","gen2"]}]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16_04*lts-gen2"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18_04*lts-gen2"},{"field":"Microsoft.Compute/imageSKU","like":"20_04*lts"},{"field":"Microsoft.Compute/imageSKU","like":"20_04*lts-gen2"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"8*"},{"field":"Microsoft.Compute/imageSKU","like":"9*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"OmsAgentForLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"}},"variables":{"vmExtensionName":"OMSAgentForLinux","vmExtensionPublisher":"Microsoft.EnterpriseCloud.Monitoring","vmExtensionType":"OmsAgentForLinux","vmExtensionTypeHandlerVersion":"1.13"},"resources":[{"name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","apiVersion":"2018-06-01","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true,"settings":{"workspaceId":"[reference(parameters(''logAnalytics''), + ''2015-03-20'').customerId]","stopOnMultipleConnections":"true"},"protectedSettings":{"workspaceKey":"[listKeys(parameters(''logAnalytics''), + ''2015-03-20'').primarySharedKey]"}}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for VM'', '': '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/053d3325-282c-4e5c-b944-24faffd30d77","type":"Microsoft.Authorization/policyDefinitions","name":"053d3325-282c-4e5c-b944-24faffd30d77"},{"properties":{"displayName":"Azure + Stream Analytics jobs should use customer-managed keys to encrypt data","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys when you want to securely store any metadata and private + data assets of your Stream Analytics jobs in your storage account. This gives + you total control over how your Stream Analytics data is encrypted.","metadata":{"version":"1.0.0","category":"Stream + Analytics"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + desired effect of the policy."},"allowedValues":["audit","deny","disabled"],"defaultValue":"audit"}},"policyRule":{"if":{"allOf":[{"field":"Microsoft.StreamAnalytics/streamingJobs/contentStoragePolicy","equals":"SystemAccount"},{"field":"type","equals":"Microsoft.StreamAnalytics/streamingJobs"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/87ba29ef-1ab3-4d82-b763-87fcd4f531f7","type":"Microsoft.Authorization/policyDefinitions","name":"87ba29ef-1ab3-4d82-b763-87fcd4f531f7"},{"properties":{"displayName":"Virtual + network injection should be enabled for Azure Data Explorer","policyType":"BuiltIn","mode":"Indexed","description":"Secure + your network perimeter with virtual network injection which allows you to + enforce network security group rules, connect on-premises and secure your + data connection sources with service endpoints.","metadata":{"version":"1.0.0","category":"Azure + Data Explorer"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Kusto/Clusters"},{"anyOf":[{"field":"Microsoft.Kusto/clusters/virtualNetworkConfiguration","exists":false},{"field":"Microsoft.Kusto/clusters/virtualNetworkConfiguration.subnetId","exists":false},{"field":"Microsoft.Kusto/clusters/virtualNetworkConfiguration.enginePublicIpId","exists":false},{"field":"Microsoft.Kusto/clusters/virtualNetworkConfiguration.dataManagementPublicIpId","exists":false}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9ad2fd1f-b25f-47a2-aa01-1a5a779e6413","type":"Microsoft.Authorization/policyDefinitions","name":"9ad2fd1f-b25f-47a2-aa01-1a5a779e6413"},{"properties":{"displayName":"Shared + dashboards should not have markdown tiles with inline content","policyType":"BuiltIn","mode":"Indexed","description":"Disallow + creating a shared dashboard that has inline content in markdown tiles and + enforce that the content should be stored as a markdown file that''s hosted + online. If you use inline content in the markdown tile, you cannot manage + encryption of the content. By configuring your own storage, you can encrypt, + double encrypt and even bring your own keys. Enabling this policy restricts + users to use 2020-09-01-preview or above version of shared dashboards REST + API.","metadata":{"version":"1.0.0","category":"Portal"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Portal/dashboards"},{"anyof":[{"not":{"value":"[requestContext().apiVersion]","greaterOrEquals":"2020-09-01-alpha"}},{"count":{"field":"Microsoft.Portal/dashboards/lenses[*].parts[*]","where":{"allOf":[{"field":"Microsoft.Portal/dashboards/lenses[*].parts[*].metadata.type","equals":"Extension/HubsExtension/PartType/MarkdownPart"},{"anyOf":[{"field":"Microsoft.Portal/dashboards/lenses[*].parts[*].metadata.Extension-HubsExtension-PartType-MarkdownPart.settings.content.settings.markdownUri","exists":"false"},{"field":"Microsoft.Portal/dashboards/lenses[*].parts[*].metadata.Extension-HubsExtension-PartType-MarkdownPart.settings.content.settings.markdownSource","exists":"false"},{"field":"Microsoft.Portal/dashboards/lenses[*].parts[*].metadata.Extension-HubsExtension-PartType-MarkdownPart.settings.content.settings.markdownSource","equals":"1"}]}]}},"greater":0}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/04c655fe-0ac7-48ae-9a32-3a2e208c7624","type":"Microsoft.Authorization/policyDefinitions","name":"04c655fe-0ac7-48ae-9a32-3a2e208c7624"},{"properties":{"displayName":"[Preview]: + Configure backup on VMs without a given tag to a new recovery services vault + with a default policy","policyType":"BuiltIn","mode":"Indexed","description":"Enforce + backup for all virtual machines by deploying a recovery services vault in + the same location and resource group as the virtual machine. Doing this is + useful when different application teams in your organization are allocated + separate resource groups and need to manage their own backups and restores. + You can optionally exclude virtual machines containing a specified tag to + control the scope of assignment. See https://aka.ms/AzureVMAppCentricBackupExcludeTag","metadata":{"version":"1.0.0-preview","preview":true,"category":"Backup"},"parameters":{"exclusionTagName":{"type":"String","metadata":{"displayName":"[Preview]: + Exclusion Tag Name","description":"Name of the tag to use for excluding VMs + from the scope of this policy. This should be used along with the Exclusion + Tag Value parameter. Learn more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":""},"exclusionTagValue":{"type":"Array","metadata":{"displayName":"[Preview]: + Exclusion Tag Values","description":"Value of the tag to use for excluding + VMs from the scope of this policy (in case of multiple values, use a comma-separated + list). This should be used along with the Exclusion Tag Name parameter. Learn + more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"not":{"field":"[concat(''tags['', + parameters(''exclusionTagName''), '']'')]","in":"[parameters(''exclusionTagValue'')]"}},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2019"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.RecoveryServices/backupprotecteditems","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c","/providers/Microsoft.Authorization/roleDefinitions/5e467623-bb1f-42f4-a55d-6e525e11384b"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string","metadata":{"description":"Name + of Azure Virtual Machines"}},"vmRgName":{"type":"string","metadata":{"description":"Resource + group containing the virtual machines."}},"location":{"type":"string","metadata":{"description":"Location + for VM and Backup vault"}}},"variables":{"backupFabric":"Azure","backupPolicy":"DefaultPolicy","v2VmType":"Microsoft.Compute/virtualMachines","v2VmContainer":"iaasvmcontainer;iaasvmcontainerv2;","v2Vm":"vm;iaasvmcontainerv2;","vaultName":"[take(concat(''RSVault-'', + parameters(''location''), ''-'', guid(resourceGroup().id)),50)]"},"resources":[{"name":"[variables(''vaultName'')]","type":"Microsoft.RecoveryServices/vaults","apiVersion":"2016-06-01","location":"[parameters(''location'')]","properties":{},"sku":{"name":"Standard"}},{"name":"[concat(variables(''vaultName''), + ''/'', variables(''backupFabric''), ''/'', variables(''v2VmContainer''), concat(parameters(''vmRgName''),'';'',parameters(''vmName'')), + ''/'', variables(''v2Vm''), concat(parameters(''vmRgName''),'';'',parameters(''vmName'')))]","apiVersion":"2016-12-01","location":"[parameters(''location'')]","type":"Microsoft.RecoveryServices/vaults/backupFabrics/protectionContainers/protectedItems","dependsOn":["[resourceId(''Microsoft.RecoveryServices/vaults/'', + variables(''vaultName''))]"],"properties":{"protectedItemType":"[variables(''v2VmType'')]","policyId":"[resourceId(''Microsoft.RecoveryServices/vaults/backupPolicies'', + variables(''vaultName''),variables(''backupPolicy''))]","sourceResourceId":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/'', parameters(''vmRgName''), + ''/providers/Microsoft.Compute/virtualMachines/'', parameters(''vmName''))]"}}],"outputs":{"status":{"type":"string","value":"[concat(''Backup + enabled successfully for VM:'', '' '', parameters(''vmName''), ''Backup Vault: + '', variables(''vaultName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"vmRgName":{"value":"[resourceGroup().name]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/98d0b9f8-fd90-49c9-88e2-d3baf3b0dd86","type":"Microsoft.Authorization/policyDefinitions","name":"98d0b9f8-fd90-49c9-88e2-d3baf3b0dd86"},{"properties":{"displayName":"Vulnerabilities + on your SQL databases should be remediated","policyType":"BuiltIn","mode":"Indexed","description":"Monitor + Vulnerability Assessment scan results and recommendations for how to remediate + database vulnerabilities.","metadata":{"version":"4.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Sql/servers","Microsoft.Sql/managedinstances"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"82e20e14-edc5-4373-bfc4-f13121257c37","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/feedbf84-6b99-488c-acc2-71c829aa5ffc","type":"Microsoft.Authorization/policyDefinitions","name":"feedbf84-6b99-488c-acc2-71c829aa5ffc"},{"properties":{"displayName":"[Preview]: + Configure backup on VMs with a given tag to an existing recovery services + vault in the same location","policyType":"BuiltIn","mode":"Indexed","description":"Enforce + backup for all virtual machines by backing them up to an existing central + recovery services vault in the same location and subscription as the virtual + machine. Doing this is useful when there is a central team in your organization + managing backups for all resources in a subscription. You can optionally include + virtual machines containing a specified tag to control the scope of assignment. + See https://aka.ms/AzureVMCentralBackupIncludeTag","metadata":{"version":"1.0.0-preview","preview":true,"category":"Backup"},"parameters":{"vaultLocation":{"type":"String","metadata":{"displayName":"[Preview]: + Location (Specify the location of the VMs that you want to protect)","description":"Specify + the location of the VMs that you want to protect. VMs should be backed up + to a vault in the same location. For example - CanadaCentral","strongType":"location"}},"inclusionTagName":{"type":"String","metadata":{"displayName":"[Preview]: + Inclusion Tag Name","description":"Name of the tag to use for including VMs + in the scope of this policy. This should be used along with the Inclusion + Tag Value parameter. Learn more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":""},"inclusionTagValue":{"type":"Array","metadata":{"displayName":"[Preview]: + Inclusion Tag Values","description":"Value of the tag to use for including + VMs in the scope of this policy (in case of multiple values, use a comma-separated + list). This should be used along with the Inclusion Tag Name parameter. Learn + more at https://aka.ms/AppCentricVMBackupPolicy."}},"backupPolicyId":{"type":"String","metadata":{"displayName":"[Preview]: + Backup Policy (of type Azure VM from a vault in the location chosen above)","description":"Specify + the ID of the Azure Backup policy to configure backup of the virtual machines. + The selected Azure Backup policy should be of type Azure Virtual Machine. + This policy needs to be in a vault that is present in the location chosen + above. For example - /subscriptions//resourceGroups//providers/Microsoft.RecoveryServices/vaults//backupPolicies/","strongType":"Microsoft.RecoveryServices/vaults/backupPolicies"}},"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["deployIfNotExists","auditIfNotExists","disabled"],"defaultValue":"deployIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","equals":"[parameters(''vaultLocation'')]"},{"field":"[concat(''tags['', + parameters(''inclusionTagName''), '']'')]","in":"[parameters(''inclusionTagValue'')]"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2019"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c","/providers/microsoft.authorization/roleDefinitions/5e467623-bb1f-42f4-a55d-6e525e11384b"],"type":"Microsoft.RecoveryServices/backupprotecteditems","deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"backupPolicyId":{"type":"String"},"fabricName":{"type":"String"},"protectionContainers":{"type":"String"},"protectedItems":{"type":"String"},"sourceResourceId":{"type":"String"}},"resources":[{"apiVersion":"2017-05-10","name":"[concat(''DeployProtection-'',uniqueString(parameters(''protectedItems'')))]","type":"Microsoft.Resources/deployments","resourceGroup":"[first(skip(split(parameters(''backupPolicyId''), + ''/''), 4))]","subscriptionId":"[first(skip(split(parameters(''backupPolicyId''), + ''/''), 2))]","properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"backupPolicyId":{"type":"String"},"fabricName":{"type":"String"},"protectionContainers":{"type":"String"},"protectedItems":{"type":"String"},"sourceResourceId":{"type":"String"}},"resources":[{"type":"Microsoft.RecoveryServices/vaults/backupFabrics/protectionContainers/protectedItems","name":"[concat(first(skip(split(parameters(''backupPolicyId''), + ''/''), 8)), ''/'', parameters(''fabricName''), ''/'',parameters(''protectionContainers''), + ''/'', parameters(''protectedItems''))]","apiVersion":"2016-06-01","properties":{"protectedItemType":"Microsoft.Compute/virtualMachines","policyId":"[parameters(''backupPolicyId'')]","sourceResourceId":"[parameters(''sourceResourceId'')]"}}]},"parameters":{"backupPolicyId":{"value":"[parameters(''backupPolicyId'')]"},"fabricName":{"value":"[parameters(''fabricName'')]"},"protectionContainers":{"value":"[parameters(''protectionContainers'')]"},"protectedItems":{"value":"[parameters(''protectedItems'')]"},"sourceResourceId":{"value":"[parameters(''sourceResourceId'')]"}}}}]},"parameters":{"backupPolicyId":{"value":"[parameters(''backupPolicyId'')]"},"fabricName":{"value":"Azure"},"protectionContainers":{"value":"[concat(''iaasvmcontainer;iaasvmcontainerv2;'', + resourceGroup().name, '';'' ,field(''name''))]"},"protectedItems":{"value":"[concat(''vm;iaasvmcontainerv2;'', + resourceGroup().name, '';'' ,field(''name''))]"},"sourceResourceId":{"value":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/'', resourceGroup().name, + ''/providers/Microsoft.Compute/virtualMachines/'',field(''name''))]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/345fa903-145c-4fe1-8bcd-93ec2adccde8","type":"Microsoft.Authorization/policyDefinitions","name":"345fa903-145c-4fe1-8bcd-93ec2adccde8"},{"properties":{"displayName":"Configure + backup on VMs without a given tag to an existing recovery services vault in + the same location","policyType":"BuiltIn","mode":"Indexed","description":"Enforce + backup for all virtual machines by backing them up to an existing central + recovery services vault in the same location and subscription as the virtual + machine. Doing this is useful when there is a central team in your organization + managing backups for all resources in a subscription. You can optionally exclude + virtual machines containing a specified tag to control the scope of assignment. + See https://aka.ms/AzureVMCentralBackupExcludeTag","metadata":{"version":"1.1.0","category":"Backup"},"parameters":{"vaultLocation":{"type":"String","metadata":{"displayName":"Location + (Specify the location of the VMs that you want to protect)","description":"Specify + the location of the VMs that you want to protect. VMs should be backed up + to a vault in the same location. For example - southeastasia","strongType":"location"}},"backupPolicyId":{"type":"String","metadata":{"displayName":"Backup + Policy (of type Azure VM from a vault in the location chosen above)","description":"Specify + the id of the Azure backup policy to configure backup of the virtual machines. + The selected Azure backup policy should be of type Azure virtual machine. + This policy needs to be in a vault that is present in the location chosen + above. For example - /subscriptions//resourceGroups//providers/Microsoft.RecoveryServices/vaults//backupPolicies/","strongType":"Microsoft.RecoveryServices/vaults/backupPolicies"}},"exclusionTagName":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Name of the tag to use for excluding VMs from the + scope of this policy. This should be used along with the Exclusion Tag Value + parameter. Learn more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":""},"exclusionTagValue":{"type":"Array","metadata":{"displayName":"Exclusion + Tag Values","description":"Value of the tag to use for excluding VMs from + the scope of this policy (in case of multiple values, use a comma-separated + list). This should be used along with the Exclusion Tag Name parameter. Learn + more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":[]},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["deployIfNotExists","auditIfNotExists","disabled"],"defaultValue":"deployIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","equals":"[parameters(''vaultLocation'')]"},{"anyOf":[{"not":{"field":"[concat(''tags['', + parameters(''exclusionTagName''), '']'')]","in":"[parameters(''exclusionTagValue'')]"}},{"value":"[empty(parameters(''exclusionTagValue''))]","equals":"true"},{"value":"[empty(parameters(''exclusionTagName''))]","equals":"true"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2019"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c","/providers/microsoft.authorization/roleDefinitions/5e467623-bb1f-42f4-a55d-6e525e11384b"],"type":"Microsoft.RecoveryServices/backupprotecteditems","deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"backupPolicyId":{"type":"String"},"fabricName":{"type":"String"},"protectionContainers":{"type":"String"},"protectedItems":{"type":"String"},"sourceResourceId":{"type":"String"}},"resources":[{"apiVersion":"2017-05-10","name":"[concat(''DeployProtection-'',uniqueString(parameters(''protectedItems'')))]","type":"Microsoft.Resources/deployments","resourceGroup":"[first(skip(split(parameters(''backupPolicyId''), + ''/''), 4))]","subscriptionId":"[first(skip(split(parameters(''backupPolicyId''), + ''/''), 2))]","properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"backupPolicyId":{"type":"String"},"fabricName":{"type":"String"},"protectionContainers":{"type":"String"},"protectedItems":{"type":"String"},"sourceResourceId":{"type":"String"}},"resources":[{"type":"Microsoft.RecoveryServices/vaults/backupFabrics/protectionContainers/protectedItems","name":"[concat(first(skip(split(parameters(''backupPolicyId''), + ''/''), 8)), ''/'', parameters(''fabricName''), ''/'',parameters(''protectionContainers''), + ''/'', parameters(''protectedItems''))]","apiVersion":"2016-06-01","properties":{"protectedItemType":"Microsoft.Compute/virtualMachines","policyId":"[parameters(''backupPolicyId'')]","sourceResourceId":"[parameters(''sourceResourceId'')]"}}]},"parameters":{"backupPolicyId":{"value":"[parameters(''backupPolicyId'')]"},"fabricName":{"value":"[parameters(''fabricName'')]"},"protectionContainers":{"value":"[parameters(''protectionContainers'')]"},"protectedItems":{"value":"[parameters(''protectedItems'')]"},"sourceResourceId":{"value":"[parameters(''sourceResourceId'')]"}}}}]},"parameters":{"backupPolicyId":{"value":"[parameters(''backupPolicyId'')]"},"fabricName":{"value":"Azure"},"protectionContainers":{"value":"[concat(''iaasvmcontainer;iaasvmcontainerv2;'', + resourceGroup().name, '';'' ,field(''name''))]"},"protectedItems":{"value":"[concat(''vm;iaasvmcontainerv2;'', + resourceGroup().name, '';'' ,field(''name''))]"},"sourceResourceId":{"value":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/'', resourceGroup().name, + ''/providers/Microsoft.Compute/virtualMachines/'',field(''name''))]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/09ce66bc-1220-4153-8104-e3f51c936913","type":"Microsoft.Authorization/policyDefinitions","name":"09ce66bc-1220-4153-8104-e3f51c936913"},{"properties":{"displayName":"[Preview]: + Storage account public access should be disallowed","policyType":"BuiltIn","mode":"Indexed","description":"Anonymous + public read access to containers and blobs in Azure Storage is a convenient + way to share data but might present security risks. To prevent data breaches + caused by undesired anonymous access, Microsoft recommends preventing public + access to a storage account unless your scenario requires it.","metadata":{"version":"2.0.1-preview","category":"Storage","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"The effect determines what happens when the policy + rule is evaluated to match"},"allowedValues":["audit","deny","disabled"],"defaultValue":"audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"field":"id","notContains":"/resourceGroups/databricks-rg-"},{"not":{"field":"Microsoft.Storage/storageAccounts/allowBlobPublicAccess","equals":"false"}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4fa4b6c0-31ca-4c0d-b10d-24b96f62a751","type":"Microsoft.Authorization/policyDefinitions","name":"4fa4b6c0-31ca-4c0d-b10d-24b96f62a751"},{"properties":{"displayName":"Synapse + managed private endpoints should only connect to resources in approved Azure + Active Directory tenants","policyType":"BuiltIn","mode":"Indexed","description":"Protect + your Synapse workspace by only allowing connections to resources in approved + Azure Active Directory (Azure AD) tenants. The approved Azure AD tenants can + be defined during policy assignment.","metadata":{"version":"1.0.0","category":"Synapse"},"parameters":{"allowedTenantIds":{"type":"Array","metadata":{"displayName":"List + of Allowed Tenant Ids for private endpoint creation","description":"This parameter + defines the list of Allowed Tenant Ids that are allowed to create managed + private endpoints in the workspaces"},"defaultValue":[]},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled","Deny"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Synapse/workspaces"},{"count":{"field":"Microsoft.Synapse/workspaces/managedVirtualNetworkSettings.allowedAadTenantIdsForLinking[*]","where":{"field":"Microsoft.Synapse/workspaces/managedVirtualNetworkSettings.allowedAadTenantIdsForLinking[*]","notIn":"[parameters(''allowedTenantIds'')]"}},"greater":0}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3a003702-13d2-4679-941b-937e58c443f0","type":"Microsoft.Authorization/policyDefinitions","name":"3a003702-13d2-4679-941b-937e58c443f0"},{"properties":{"displayName":"[Preview]: + Configure backup on VMs with a given tag to a new recovery services vault + with a default policy","policyType":"BuiltIn","mode":"Indexed","description":"Enforce + backup for all virtual machines by deploying a recovery services vault in + the same location and resource group as the virtual machine. Doing this is + useful when different application teams in your organization are allocated + separate resource groups and need to manage their own backups and restores. + You can optionally include virtual machines containing a specified tag to + control the scope of assignment. See https://aka.ms/AzureVMAppCentricBackupIncludeTag","metadata":{"version":"1.0.0-preview","preview":true,"category":"Backup"},"parameters":{"inclusionTagName":{"type":"String","metadata":{"displayName":"[Preview]: + Inclusion Tag Name","description":"Name of the tag to use for including VMs + in the scope of this policy. This should be used along with the Inclusion + Tag Value parameter. Learn more at https://aka.ms/AppCentricVMBackupPolicy"},"defaultValue":""},"inclusionTagValue":{"type":"Array","metadata":{"displayName":"[Preview]: + Inclusion Tag Values","description":"Value of the tag to use for including + VMs in the scope of this policy (in case of multiple values, use a comma-separated + list). This should be used along with the Inclusion Tag Name parameter. Learn + more at https://aka.ms/AppCentricVMBackupPolicy."},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"[concat(''tags['', + parameters(''inclusionTagName''), '']'')]","in":"[parameters(''inclusionTagValue'')]"},{"value":"[empty(parameters(''inclusionTagValue''))]","equals":"true"},{"value":"[empty(parameters(''inclusionTagName''))]","equals":"true"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2019"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.RecoveryServices/backupprotecteditems","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c","/providers/Microsoft.Authorization/roleDefinitions/5e467623-bb1f-42f4-a55d-6e525e11384b"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string","metadata":{"description":"Name + of Azure Virtual Machines"}},"vmRgName":{"type":"string","metadata":{"description":"Resource + group containing the virtual machines."}},"location":{"type":"string","metadata":{"description":"Location + for VM and Backup vault"}}},"variables":{"backupFabric":"Azure","backupPolicy":"DefaultPolicy","v2VmType":"Microsoft.Compute/virtualMachines","v2VmContainer":"iaasvmcontainer;iaasvmcontainerv2;","v2Vm":"vm;iaasvmcontainerv2;","vaultName":"[take(concat(''RSVault-'', + parameters(''location''), ''-'', guid(resourceGroup().id)),50)]"},"resources":[{"name":"[variables(''vaultName'')]","type":"Microsoft.RecoveryServices/vaults","apiVersion":"2016-06-01","location":"[parameters(''location'')]","properties":{},"sku":{"name":"Standard"}},{"name":"[concat(variables(''vaultName''), + ''/'', variables(''backupFabric''), ''/'', variables(''v2VmContainer''), concat(parameters(''vmRgName''),'';'',parameters(''vmName'')), + ''/'', variables(''v2Vm''), concat(parameters(''vmRgName''),'';'',parameters(''vmName'')))]","apiVersion":"2016-12-01","location":"[parameters(''location'')]","type":"Microsoft.RecoveryServices/vaults/backupFabrics/protectionContainers/protectedItems","dependsOn":["[resourceId(''Microsoft.RecoveryServices/vaults/'', + variables(''vaultName''))]"],"properties":{"protectedItemType":"[variables(''v2VmType'')]","policyId":"[resourceId(''Microsoft.RecoveryServices/vaults/backupPolicies'', + variables(''vaultName''),variables(''backupPolicy''))]","sourceResourceId":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/'', parameters(''vmRgName''), + ''/providers/Microsoft.Compute/virtualMachines/'', parameters(''vmName''))]"}}],"outputs":{"status":{"type":"string","value":"[concat(''Backup + enabled successfully for VM:'', '' '', parameters(''vmName''), ''Backup Vault: + '', variables(''vaultName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"vmRgName":{"value":"[resourceGroup().name]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/83644c87-93dd-49fe-bf9f-6aff8fd0834e","type":"Microsoft.Authorization/policyDefinitions","name":"83644c87-93dd-49fe-bf9f-6aff8fd0834e"},{"properties":{"displayName":"Deploy + - Configure suppression rules for Azure Security Center alerts","policyType":"BuiltIn","mode":"All","description":"Suppress + Azure Security Center alerts to reduce alerts fatigue by deploying suppression + rules on your management group or subscription.","metadata":{"category":"Security + Center","version":"1.0.0"},"parameters":{"alertType":{"type":"String","metadata":{"displayName":"Alert + Type","description":"Enter the alert type field of the alert you would like + to suppress. Alert type could be queried via alerts api or PowerShell, learn + more at https://aka.ms/asc-alertsPwoershell"}},"suppressionRuleName":{"type":"String","metadata":{"displayName":"Rule + name","description":"Rule names must begin with a letter or a number, be between + 2 and 50 characters, and contain no symbols other than dashes ( - ) or underscores + ( _ )"}},"state":{"type":"String","metadata":{"displayName":"State"},"allowedValues":["Enabled","Disabled"],"defaultValue":"Enabled"},"reason":{"type":"String","metadata":{"displayName":"Reason"},"allowedValues":["The + severity of the alert should be lower","The alert detecting too many normal + activities","The alert is too noisy - hitting on the same resources too many + times","The resource isn''t relevant for me to monitor","The alert detecting + normal activity on specific entity","The alert isn''t actionable - not clear + how to investigate the threat","Other"]},"comment":{"type":"String","metadata":{"displayName":"Comment"},"defaultValue":""},"expirationDate":{"type":"DateTime","metadata":{"displayName":"Expiration + date"}},"entityOneType":{"type":"String","metadata":{"displayName":"First + entity type","description":"To refine the suppression rules to suppress alerts + only for specific entities, enter the type of the entity you would like to + suppress. Only alerts containing all of the entities defined in the rule will + be suppressed (alerts without entities will be suppressed entirely)."},"allowedValues":["User + account - name","User account - AAD user ID","User account - UPN suffix","Azure + resource ID","File - name","File - directory","File hash","Host - name","Host + - Azure ID","Host - DNS Domain","Host - OMS agent ID","IP address","Malware + - name","Malware - category","Process - command line",""],"defaultValue":""},"entityOneOp":{"type":"String","metadata":{"displayName":"First + entity operation"},"allowedValues":["Equals","Contains",""],"defaultValue":""},"entityOneValue":{"type":"String","metadata":{"displayName":"First + entity value","description":"The value of the entity. Only alerts containing + all of the entities defined in the rule will be suppressed (alerts without + entities will be suppressed entirely)."},"defaultValue":""},"entitySecondType":{"type":"String","metadata":{"displayName":"Second + entity type","description":"To refine the suppression rules to suppress alerts + only for specific entities, enter the type of the entity you would like to + suppress. Only alerts containing all of the entities defined in the rule will + be suppressed (alerts without entities will be suppressed entirely)."},"allowedValues":["User + account - name","User account - AAD user ID","User account - UPN suffix","Azure + resource ID","File - name","File - directory","File hash","Host - name","Host + - Azure ID","Host - DNS Domain","Host - OMS agent ID","IP address","Malware + - name","Malware - category","Process - command line",""],"defaultValue":""},"entitySecondOp":{"type":"String","metadata":{"displayName":"Second + entity operation"},"allowedValues":["Equals","Contains",""],"defaultValue":""},"entitySecondValue":{"type":"String","metadata":{"displayName":"Second + entity value","description":"The value of the entity. Only alerts containing + all of the entities defined in the rule will be suppressed (alerts without + entities will be suppressed entirely)."},"defaultValue":""}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/alertsSuppressionRules","name":"[parameters(''suppressionRuleName'')]","existenceScope":"subscription","deploymentScope":"subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd"],"deployment":{"location":"centralus","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"alertType":{"type":"String"},"suppressionRuleName":{"type":"String"},"state":{"type":"String"},"reason":{"type":"String"},"comment":{"type":"String"},"expirationDate":{"type":"String"},"entityOneType":{"type":"String"},"entityOneOp":{"type":"String"},"entityOneValue":{"type":"String"},"entitySecondType":{"type":"String"},"entitySecondOp":{"type":"String"},"entitySecondValue":{"type":"String"}},"variables":{"reasonToEnum":{"The + severity of the alert should be lower":"AlertSeverityTooHigh","The alert detecting + too many normal activities":"FalsePositive","The alert is too noisy - hitting + on the same resources too many times":"Noise","The resource isn''t relevant + for me to monitor":"NotRelevant","The alert detecting normal activity on specific + entity":"SpecificEntityFalsePositive","The alert isn''t actionable - not clear + how to investigate the threat":"Unclear","Other":"Other"},"entityNameToType":{"User + account - name":"entities.account.name","User account - AAD user ID":"entities.account.aaduserid","User + account - UPN suffix":"entities.account.upnsuffix","Azure resource ID":"entities.azureresource.resourceid","File + - name":"entities.file.name","File - directory":"entities.file.directory","File + hash":"entities.filehash.value","Host - name":"entities.host.hostname","Host + - Azure ID":"entities.host.azureid","Host - DNS Domain":"entities.host.dnsdomain","Host + - OMS agent ID":"entities.host.omsagentid","IP address":"entities.ip.address","Malware + - name":"entities.malware.name","Malware - category":"entities.malware.category","Process + - command line: ":"entities.process.commandline"},"entityOperationNameToOperation":{"Equals":"in","Contains":"contains"}},"resources":[{"type":"Microsoft.Security/alertsSuppressionRules","apiVersion":"2019-01-01-preview","name":"[parameters(''suppressionRuleName'')]","location":"centralus","properties":{"alertType":"[parameters(''alertType'')]","state":"[parameters(''state'')]","reason":"[variables(''reasonToEnum'')[parameters(''reason'')]]","comment":"[parameters(''comment'')]","expirationDateUtc":"[parameters(''expirationDate'')]","suppressionAlertsScope":"[if(and(or(empty(parameters(''entityOneType'')), + empty(parameters(''entityOneOp'')), empty(parameters(''entityOneValue''))), + or(empty(parameters(''entitySecondType'')), empty(parameters(''entitySecondOp'')), + empty(parameters(''entitySecondValue'')))), null(), json(concat(''{ \"allOf\": + ['', if(or(empty(parameters(''entityOneType'')), empty(parameters(''entityOneOp'')), + empty(parameters(''entityOneValue''))), '''', concat('' { \"field\": \"'', + variables(''entityNameToType'')[parameters(''entityOneType'')], ''\", \"'', + variables(''entityOperationNameToOperation'')[parameters(''entityOneOp'')], + ''\":'', if(equals(parameters(''entityOneOp''), ''Equals''), ''['', ''''), + '' \"'', parameters(''entityOneValue''), ''\"'', if(equals(parameters(''entityOneOp''), + ''Equals''), '']'', ''''), '' }'', if(or(empty(parameters(''entitySecondType'')), + empty(parameters(''entitySecondOp'')), empty(parameters(''entitySecondValue''))), + '''', '', ''))), if(or(empty(parameters(''entitySecondType'')), empty(parameters(''entitySecondOp'')), + empty(parameters(''entitySecondValue''))), '''', concat('' { \"field\": \"'', + variables(''entityNameToType'')[parameters(''entitySecondType'')], ''\", \"'', + variables(''entityOperationNameToOperation'')[parameters(''entitySecondOp'')], + ''\":'', if(equals(parameters(''entitySecondOp''), ''Equals''), ''['', ''''), + '' \"'', parameters(''entitySecondValue''), ''\"'', if(equals(parameters(''entitySecondOp''), + ''Equals''), '']'', ''''), '' } '')), ''] }'')))]"}}]},"parameters":{"alertType":{"value":"[parameters(''alertType'')]"},"suppressionRuleName":{"value":"[parameters(''suppressionRuleName'')]"},"state":{"value":"[parameters(''state'')]"},"reason":{"value":"[parameters(''reason'')]"},"comment":{"value":"[parameters(''comment'')]"},"expirationDate":{"value":"[parameters(''expirationDate'')]"},"entityOneType":{"value":"[parameters(''entityOneType'')]"},"entityOneOp":{"value":"[parameters(''entityOneOp'')]"},"entityOneValue":{"value":"[parameters(''entityOneValue'')]"},"entitySecondType":{"value":"[parameters(''entitySecondType'')]"},"entitySecondOp":{"value":"[parameters(''entitySecondOp'')]"},"entitySecondValue":{"value":"[parameters(''entitySecondValue'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/80e94a21-c6cd-4c95-a2c7-beb5704e61c0","type":"Microsoft.Authorization/policyDefinitions","name":"80e94a21-c6cd-4c95-a2c7-beb5704e61c0"},{"properties":{"displayName":"Azure + API for FHIR should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + API for FHIR should have at least one approved private endpoint connection. + Clients in a virtual network can securely access resources that have private + endpoint connections through private links. For more information, visit: https://aka.ms/fhir-privatelink.","metadata":{"version":"1.0.0","category":"API + for FHIR"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.HealthcareApis/services"},{"count":{"field":"Microsoft.HealthcareApis/services/privateEndpointConnections[*]","where":{"field":"Microsoft.HealthcareApis/services/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1ee56206-5dd1-42ab-b02d-8aae8b1634ce","type":"Microsoft.Authorization/policyDefinitions","name":"1ee56206-5dd1-42ab-b02d-8aae8b1634ce"},{"properties":{"displayName":"Adaptive + network hardening recommendations should be applied on internet facing virtual + machines","policyType":"BuiltIn","mode":"Indexed","description":"Azure Security + Center analyzes the traffic patterns of Internet facing virtual machines and + provides Network Security Group rule recommendations that reduce the potential + attack surface","metadata":{"version":"3.0.0","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachines"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"f9f0eed0-f143-47bf-b856-671ea2eeed62","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/08e6af2d-db70-460a-bfe9-d5bd474ba9d6","type":"Microsoft.Authorization/policyDefinitions","name":"08e6af2d-db70-460a-bfe9-d5bd474ba9d6"},{"properties":{"displayName":"IP + firewall rules on Azure Synapse workspaces should be removed","policyType":"BuiltIn","mode":"All","description":"Removing + all IP firewall rules improves security by ensuring your Azure Synapse workspace + can only be accessed from a private endpoint. This configuration audits creation + of firewall rules that allow public network access on the workspace.","metadata":{"version":"1.0.0","category":"Synapse"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Synapse/workspaces/firewallrules"},{"field":"name","exists":"true"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/56fd377d-098c-4f02-8406-81eb055902b8","type":"Microsoft.Authorization/policyDefinitions","name":"56fd377d-098c-4f02-8406-81eb055902b8"},{"properties":{"displayName":"Private + endpoint connections on Azure Synapse workspaces should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Private + endpoints can be configured to connect privately to an Azure Synapse workspace. + This is used to enforce a secure communication channel to Azure Synapse workspace.","metadata":{"version":"1.0.0","category":"Synapse"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Synapse/workspaces"},{"count":{"field":"Microsoft.Synapse/workspaces/privateEndpointConnections[*]","where":{"field":"Microsoft.Synapse/workspaces/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/72d11df1-dd8a-41f7-8925-b05b960ebafc","type":"Microsoft.Authorization/policyDefinitions","name":"72d11df1-dd8a-41f7-8925-b05b960ebafc"},{"properties":{"displayName":"Add + or replace a tag on subscriptions","policyType":"BuiltIn","mode":"All","description":"Adds + or replaces the specified tag and value on subscriptions via a remediation + task. Existing resource groups can be remediated by triggering a remediation + task. See https://aka.ms/azurepolicyremediation for more information on policy + remediation.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[parameters(''tagValue'')]"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/4a9ae827-6dc8-4573-8ac7-8239d42aa03f"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/61a4d60b-7326-440e-8051-9f94394d4dd1","type":"Microsoft.Authorization/policyDefinitions","name":"61a4d60b-7326-440e-8051-9f94394d4dd1"},{"properties":{"displayName":"Add + a tag to subscriptions","policyType":"BuiltIn","mode":"All","description":"Adds + the specified tag and value to subscriptions via a remediation task. If the + tag exists with a different value it will not be changed. See https://aka.ms/azurepolicyremediation + for more information on policy remediation.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/4a9ae827-6dc8-4573-8ac7-8239d42aa03f"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/96d9a89c-0d67-41fc-899d-2b9599f76a24","type":"Microsoft.Authorization/policyDefinitions","name":"96d9a89c-0d67-41fc-899d-2b9599f76a24"},{"properties":{"displayName":"Azure + Synapse workspaces should use customer-managed keys to encrypt data at rest","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys to control the encryption at rest of the data stored + in Azure Synapse workspaces. Customer-managed keys deliver double encryption + by adding a second layer of encryption on top of the default encryption with + service-managed keys.","metadata":{"version":"1.0.0","category":"Synapse"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Synapse/workspaces"},{"field":"Microsoft.Synapse/workspaces/encryption.cmk.key.name","exists":false}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f7d52b2d-e161-4dfa-a82b-55e564167385","type":"Microsoft.Authorization/policyDefinitions","name":"f7d52b2d-e161-4dfa-a82b-55e564167385"},{"properties":{"displayName":"Managed + workspace virtual network on Azure Synapse workspaces should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Enabling + a managed workspace virtual network ensures that your workspace is network + isolated from other workspaces. Data integration and Spark resources deployed + in this virtual network also provides user level isolation for Spark activities.","metadata":{"version":"1.0.0","category":"Synapse"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Synapse/workspaces"},{"field":"Microsoft.Synapse/workspaces/managedVirtualNetwork","notEquals":"default"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2d9dbfa3-927b-4cf0-9d0f-08747f971650","type":"Microsoft.Authorization/policyDefinitions","name":"2d9dbfa3-927b-4cf0-9d0f-08747f971650"},{"properties":{"displayName":"Container + registries should not allow unrestricted network access","policyType":"BuiltIn","mode":"Indexed","description":"Azure + container registries by default accept connections over the internet from + hosts on any network. To protect your registries from potential threats, allow + access from only specific public IP addresses or address ranges. If your registry + doesn''t have an IP/firewall rule or a configured virtual network, it will + appear in the unhealthy resources. Learn more about Container Registry network + rules here: https://aka.ms/acr/portal/public-network and here https://aka.ms/acr/vnet.","metadata":{"version":"1.0.1","category":"Container + Registry"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerRegistry/registries"},{"anyof":[{"field":"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction","exists":"false"},{"field":"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction","equals":"Allow"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d0793b48-0edc-4296-a390-4c75d1bdfd71","type":"Microsoft.Authorization/policyDefinitions","name":"d0793b48-0edc-4296-a390-4c75d1bdfd71"},{"properties":{"displayName":"Cognitive + Services accounts should enable data encryption with a customer-managed key + (CMK)","policyType":"BuiltIn","mode":"Indexed","description":"Customer-managed + keys (CMK) are commonly required to meet regulatory compliance standards. + CMKs enable the data stored in Cognitive Services to be encrypted with an + Azure Key Vault key created and owned by you. You have full control and responsibility + for the key lifecycle, including rotation and management. Learn more about + CMK encryption at https://aka.ms/cosmosdb-cmk.","metadata":{"version":"1.0.3","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"field":"Microsoft.CognitiveServices/accounts/encryption.keySource","notEquals":"Microsoft.KeyVault"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/67121cc7-ff39-4ab8-b7e3-95b84dab487d","type":"Microsoft.Authorization/policyDefinitions","name":"67121cc7-ff39-4ab8-b7e3-95b84dab487d"},{"properties":{"displayName":"Both + operating systems and data disks in Azure Kubernetes Service clusters should + be encrypted by customer-managed keys","policyType":"BuiltIn","mode":"Indexed","description":"Encrypting + OS and data disks using customer-managed keys provides more control and greater + flexibility in key management. This is a common requirement in many regulatory + and industry compliance standards.","metadata":{"version":"1.0.0","category":"Kubernetes"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"''Audit'' + allows a non-compliant resource to be created or updated, but flags it as + non-compliant. ''Deny'' blocks the non-compliant resource creation or update. + ''Disabled'' turns off the policy."},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/diskEncryptionSetID","exists":"False"},{"field":"Microsoft.ContainerService/managedClusters/diskEncryptionSetID","equals":""}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7d7be79c-23ba-4033-84dd-45e2a5ccdd67","type":"Microsoft.Authorization/policyDefinitions","name":"7d7be79c-23ba-4033-84dd-45e2a5ccdd67"},{"properties":{"displayName":"Container + registries should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network.By mapping private endpoints to your container registries + instead of the entire service, you''ll also be protected against data leakage + risks. Learn more at: https://aka.ms/acr/private-link.","metadata":{"version":"1.0.1","category":"Container + Registry"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerRegistry/registries"},{"count":{"field":"Microsoft.ContainerRegistry/registries/privateEndpointConnections[*]","where":{"field":"Microsoft.ContainerRegistry/registries/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e8eef0a8-67cf-4eb4-9386-14b0e78733d4","type":"Microsoft.Authorization/policyDefinitions","name":"e8eef0a8-67cf-4eb4-9386-14b0e78733d4"},{"properties":{"displayName":"Function + apps should have ''Client Certificates (Incoming client certificates)'' enabled","policyType":"BuiltIn","mode":"Indexed","description":"Client + certificates allow for the app to request a certificate for incoming requests. + Only clients with valid certificates will be able to reach the app.","metadata":{"version":"1.0.1","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"},{"field":"Microsoft.Web/sites/clientCertEnabled","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eaebaea7-8013-4ceb-9d14-7eb32271373c","type":"Microsoft.Authorization/policyDefinitions","name":"eaebaea7-8013-4ceb-9d14-7eb32271373c"},{"properties":{"displayName":"Azure + Data Box jobs should enable double encryption for data at rest on the device","policyType":"BuiltIn","mode":"Indexed","description":"Enable + a second layer of software-based encryption for data at rest on the device. + The device is already protected via Advanced Encryption Standard 256-bit encryption + for data at rest. This option adds a second layer of data encryption.","metadata":{"version":"1.0.0","category":"Data + Box"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + desired effect of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"supportedSKUs":{"type":"Array","metadata":{"displayName":"Supported + SKUs","description":"The list of SKUs that support software-based double encryption"},"allowedValues":["DataBox","DataBoxHeavy"],"defaultValue":["DataBox","DataBoxHeavy"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DataBox/jobs"},{"field":"Microsoft.Databox/jobs/sku.name","in":"[parameters(''supportedSKUs'')]"},{"field":"Microsoft.DataBox/jobs/details.preferences.encryptionPreferences.doubleEncryption","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c349d81b-9985-44ae-a8da-ff98d108ede8","type":"Microsoft.Authorization/policyDefinitions","name":"c349d81b-9985-44ae-a8da-ff98d108ede8"},{"properties":{"displayName":"Container + registries should be encrypted with a customer-managed key (CMK)","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys to manage the encryption at rest of the contents of + your registries. By default, the data is encrypted at rest with service-managed + keys, but customer-managed keys (CMK) are commonly required to meet regulatory + compliance standards. CMKs enable the data to be encrypted with an Azure Key + Vault key created and owned by you. You have full control and responsibility + for the key lifecycle, including rotation and management. Learn more about + CMK encryption at https://aka.ms/acr/CMK.","metadata":{"version":"1.1.2","category":"Container + Registry"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerRegistry/registries"},{"field":"Microsoft.ContainerRegistry/registries/encryption.status","notEquals":"enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b9159ae-1701-4a6f-9a7a-aa9c8ddd0580","type":"Microsoft.Authorization/policyDefinitions","name":"5b9159ae-1701-4a6f-9a7a-aa9c8ddd0580"},{"properties":{"displayName":"Azure + Data Box jobs should use a customer-managed key to encrypt the device unlock + password","policyType":"BuiltIn","mode":"Indexed","description":"Use a customer-managed + key to control the encryption of the device unlock password for Azure Data + Box. Customer-managed keys also help manage access to the device unlock password + by the Data Box service in order to prepare the device and copy data in an + automated manner. The data on the device itself is already encrypted at rest + with Advanced Encryption Standard 256-bit encryption, and the device unlock + password is encrypted by default with a Microsoft managed key.","metadata":{"version":"1.0.0","category":"Data + Box"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + desired effect of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"supportedSKUs":{"type":"Array","metadata":{"displayName":"Supported + SKUs","description":"The list of SKUs that support customer-managed key encryption + key"},"allowedValues":["DataBox","DataBoxHeavy"],"defaultValue":["DataBox","DataBoxHeavy"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DataBox/jobs"},{"field":"Microsoft.Databox/jobs/sku.name","in":"[parameters(''supportedSKUs'')]"},{"field":"Microsoft.DataBox/jobs/details.keyEncryptionKey.kekType","notEquals":"CustomerManaged"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86efb160-8de7-451d-bc08-5d475b0aadae","type":"Microsoft.Authorization/policyDefinitions","name":"86efb160-8de7-451d-bc08-5d475b0aadae"},{"properties":{"displayName":"Azure + Cosmos DB accounts should use customer-managed keys to encrypt data at rest","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys to manage the encryption at rest of your Azure Cosmos + DB. By default, the data is encrypted at rest with service-managed keys, but + customer-managed keys (CMK) are commonly required to meet regulatory compliance + standards. CMKs enable the data to be encrypted with an Azure Key Vault key + created and owned by you. You have full control and responsibility for the + key lifecycle, including rotation and management. Learn more about CMK encryption + at https://aka.ms/cosmosdb-cmk.","metadata":{"version":"1.0.2","category":"Cosmos + DB"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + desired effect of the policy."},"allowedValues":["audit","deny","disabled"],"defaultValue":"audit"}},"policyRule":{"if":{"allOf":[{"field":"Microsoft.DocumentDB/databaseAccounts/keyVaultKeyUri","exists":false},{"field":"type","equals":"Microsoft.DocumentDB/databaseAccounts"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1f905d99-2ab7-462c-a6b0-f709acca6c8f","type":"Microsoft.Authorization/policyDefinitions","name":"1f905d99-2ab7-462c-a6b0-f709acca6c8f"},{"properties":{"displayName":"Key + vaults should have soft delete enabled","policyType":"BuiltIn","mode":"Indexed","description":"Deleting + a key vault without soft delete enabled permanently deletes all secrets, keys, + and certificates stored in the key vault. Accidental deletion of a key vault + can lead to permanent data loss. Soft delete allows you to recover an accidently + deleted key vault for a configurable retention period.","metadata":{"version":"1.0.2","category":"Key + Vault"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"anyOf":[{"field":"Microsoft.KeyVault/vaults/enableSoftDelete","exists":"false"},{"field":"Microsoft.KeyVault/vaults/enableSoftDelete","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1e66c121-a66a-4b1f-9b83-0fd99bf0fc2d","type":"Microsoft.Authorization/policyDefinitions","name":"1e66c121-a66a-4b1f-9b83-0fd99bf0fc2d"},{"properties":{"displayName":"SQL + servers should be configured with 90 days auditing retention or higher.","policyType":"BuiltIn","mode":"Indexed","description":"SQL + servers should be configured with 90 days auditing retention or higher.","metadata":{"version":"2.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/auditingSettings","name":"default","existenceCondition":{"anyOf":[{"field":"Microsoft.Sql/servers/auditingSettings/retentionDays","equals":0},{"field":"Microsoft.Sql/servers/auditingSettings/retentionDays","greaterOrEquals":90}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/89099bee-89e0-4b26-a5f4-165451757743","type":"Microsoft.Authorization/policyDefinitions","name":"89099bee-89e0-4b26-a5f4-165451757743"},{"properties":{"displayName":"Key + vaults should have purge protection enabled","policyType":"BuiltIn","mode":"Indexed","description":"Malicious + deletion of a key vault can lead to permanent data loss. A malicious insider + in your organization can potentially delete and purge key vaults. Purge protection + protects you from insider attacks by enforcing a mandatory retention period + for soft deleted key vaults. No one inside your organization or Microsoft + will be able to purge your key vaults during the soft delete retention period.","metadata":{"version":"1.1.1","category":"Key + Vault"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"anyOf":[{"field":"Microsoft.KeyVault/vaults/enableSoftDelete","exists":"false"},{"field":"Microsoft.KeyVault/vaults/enablePurgeProtection","exists":"false"},{"field":"Microsoft.KeyVault/vaults/enableSoftDelete","equals":"false"},{"field":"Microsoft.KeyVault/vaults/enablePurgeProtection","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b60c0b2-2dc2-4e1c-b5c9-abbed971de53","type":"Microsoft.Authorization/policyDefinitions","name":"0b60c0b2-2dc2-4e1c-b5c9-abbed971de53"},{"properties":{"displayName":"SQL + managed instances should use customer-managed keys to encrypt data at rest","policyType":"BuiltIn","mode":"Indexed","description":"Implementing + Transparent Data Encryption (TDE) with your own key provides you with increased + transparency and control over the TDE Protector, increased security with an + HSM-backed external service, and promotion of separation of duties. This recommendation + applies to organizations with a related compliance requirement.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/encryptionProtector","name":"current","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/managedInstances/encryptionProtector/serverKeyType","equals":"AzureKeyVault"},{"field":"Microsoft.Sql/managedInstances/encryptionProtector/uri","notEquals":""},{"field":"Microsoft.Sql/managedInstances/encryptionProtector/uri","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/048248b0-55cd-46da-b1ff-39efd52db260","type":"Microsoft.Authorization/policyDefinitions","name":"048248b0-55cd-46da-b1ff-39efd52db260"},{"properties":{"displayName":"Azure + Cache for Redis should reside within a virtual network","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Virtual Network (VNet) deployment provides enhanced security and isolation + for your Azure Cache for Redis, as well as subnets, access control policies, + and other features to further restrict access.When an Azure Cache for Redis + instance is configured with a VNet, it is not publicly addressable and can + only be accessed from virtual machines and applications within the VNet.","metadata":{"version":"1.0.3","category":"Cache"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match."},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Cache/redis"},{"field":"Microsoft.Cache/Redis/subnetId","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7d092e0a-7acd-40d2-a975-dca21cae48c4","type":"Microsoft.Authorization/policyDefinitions","name":"7d092e0a-7acd-40d2-a975-dca21cae48c4"},{"properties":{"displayName":"Long-term + geo-redundant backup should be enabled for Azure SQL Databases","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Azure SQL Database with long-term geo-redundant backup not + enabled.","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers/databases"},{"field":"name","notEquals":"master"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies","name":"default","existenceCondition":{"anyOf":[{"field":"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/weeklyRetention","notEquals":"PT0S"},{"field":"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/monthlyRetention","notEquals":"PT0S"},{"field":"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/yearlyRetention","notEquals":"PT0S"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d38fc420-0735-4ef3-ac11-c806f651a570","type":"Microsoft.Authorization/policyDefinitions","name":"d38fc420-0735-4ef3-ac11-c806f651a570"},{"properties":{"displayName":"Auditing + on SQL server should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Auditing + on your SQL Server should be enabled to track database activities across all + databases on the server and save them in an audit log.","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"setting":{"type":"String","metadata":{"displayName":"Desired + Auditing setting"},"allowedValues":["enabled","disabled"],"defaultValue":"enabled"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/auditingSettings","name":"default","existenceCondition":{"field":"Microsoft.Sql/auditingSettings.state","equals":"[parameters(''setting'')]"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a6fb4358-5bf4-4ad7-ba82-2cd2f41ce5e9","type":"Microsoft.Authorization/policyDefinitions","name":"a6fb4358-5bf4-4ad7-ba82-2cd2f41ce5e9"},{"properties":{"displayName":"SQL + servers should use customer-managed keys to encrypt data at rest","policyType":"BuiltIn","mode":"Indexed","description":"Implementing + Transparent Data Encryption (TDE) with your own key provides increased transparency + and control over the TDE Protector, increased security with an HSM-backed + external service, and promotion of separation of duties. This recommendation + applies to organizations with a related compliance requirement.","metadata":{"version":"2.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/encryptionProtector","name":"current","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/servers/encryptionProtector/serverKeyType","equals":"AzureKeyVault"},{"field":"Microsoft.Sql/servers/encryptionProtector/uri","notEquals":""},{"field":"Microsoft.Sql/servers/encryptionProtector/uri","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0d134df8-db83-46fb-ad72-fe0c9428c8dd","type":"Microsoft.Authorization/policyDefinitions","name":"0d134df8-db83-46fb-ad72-fe0c9428c8dd"},{"properties":{"displayName":"Public + network access on Azure SQL Database should be disabled","policyType":"BuiltIn","mode":"Indexed","description":"Disabling + the public network access property improves security by ensuring your Azure + SQL Database can only be accessed from a private endpoint. This configuration + denies all logins that match IP or virtual network based firewall rules.","metadata":{"version":"1.1.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"Microsoft.Sql/servers/publicNetworkAccess","notEquals":"Disabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1b8ca024-1d5c-4dec-8995-b1a932b41780","type":"Microsoft.Authorization/policyDefinitions","name":"1b8ca024-1d5c-4dec-8995-b1a932b41780"},{"properties":{"displayName":"Private + endpoint connections on Azure SQL Database should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Private + endpoint connections enforce secure communication by enabling private connectivity + to Azure SQL Database.","metadata":{"version":"1.1.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"count":{"field":"Microsoft.Sql/servers/privateEndpointConnections[*]","where":{"field":"Microsoft.Sql/servers/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7698e800-9299-47a6-b3b6-5a0fee576eed","type":"Microsoft.Authorization/policyDefinitions","name":"7698e800-9299-47a6-b3b6-5a0fee576eed"},{"properties":{"displayName":"Storage + accounts should use customer-managed key (CMK) for encryption","policyType":"BuiltIn","mode":"Indexed","description":"Secure + your storage account with greater flexibility using customer-managed keys + (CMKs). When you specify a CMK, that key is used to protect and control access + to the key that encrypts your data. Using CMKs provides additional capabilities + to control rotation of the key encryption key or cryptographically erase data.","metadata":{"version":"1.0.2","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"not":{"field":"Microsoft.Storage/storageAccounts/encryption.keySource","equals":"Microsoft.Keyvault"}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6fac406b-40ca-413b-bf8e-0bf964659c25","type":"Microsoft.Authorization/policyDefinitions","name":"6fac406b-40ca-413b-bf8e-0bf964659c25"},{"properties":{"displayName":"Email + notification for high severity alerts should be enabled","policyType":"BuiltIn","mode":"All","description":"To + ensure the relevant people in your organization are notified when there is + a potential security breach in one of your subscriptions, enable email notifications + for high severity alerts in Security Center.","metadata":{"version":"1.0.1","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/securityContacts","existenceCondition":{"field":"Microsoft.Security/securityContacts/alertNotifications","notEquals":"Off"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6e2593d9-add6-4083-9c9b-4b7d2188c899","type":"Microsoft.Authorization/policyDefinitions","name":"6e2593d9-add6-4083-9c9b-4b7d2188c899"},{"properties":{"displayName":"Storage + accounts should restrict network access using virtual network rules","policyType":"BuiltIn","mode":"Indexed","description":"Protect + your storage accounts from potential threats using virtual network rules as + a preferred method instead of IP-based filtering. Disabling IP-based filtering + prevents public IPs from accessing your storage accounts.","metadata":{"version":"1.0.1","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the audit policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"anyOf":[{"field":"Microsoft.Storage/storageAccounts/networkAcls.defaultAction","notEquals":"Deny"},{"count":{"field":"Microsoft.Storage/storageAccounts/networkAcls.ipRules[*]"},"greaterOrEquals":1}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2a1a9cdf-e04d-429a-8416-3bfb72a1b26f","type":"Microsoft.Authorization/policyDefinitions","name":"2a1a9cdf-e04d-429a-8416-3bfb72a1b26f"},{"properties":{"displayName":"Email + notification to subscription owner for high severity alerts should be enabled","policyType":"BuiltIn","mode":"All","description":"To + ensure your subscription owners are notified when there is a potential security + breach in their subscription, set email notifications to subscription owners + for high severity alerts in Security Center.","metadata":{"version":"2.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/securityContacts","existenceScope":"subscription","existenceCondition":{"not":{"allOf":[{"field":"Microsoft.Security/securityContacts/alertsToAdmins","equals":"Off"},{"field":"Microsoft.Security/securityContacts/alertNotifications.minimalSeverity","equals":"High"}]}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b15565f-aa9e-48ba-8619-45960f2c314d","type":"Microsoft.Authorization/policyDefinitions","name":"0b15565f-aa9e-48ba-8619-45960f2c314d"},{"properties":{"displayName":"Auto + provisioning of the Log Analytics agent should be enabled on your subscription","policyType":"BuiltIn","mode":"All","description":"To + monitor for security vulnerabilities and threats, Azure Security Center collects + data from your Azure virtual machines. Data is collected by the Log Analytics + agent, formerly known as the Microsoft Monitoring Agent (MMA), which reads + various security-related configurations and event logs from the machine and + copies the data to your Log Analytics workspace for analysis. We recommend + enabling auto provisioning to automatically deploy the agent to all supported + Azure VMs and any new ones that are created.","metadata":{"version":"1.0.1","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/autoProvisioningSettings","existenceCondition":{"field":"Microsoft.Security/autoProvisioningSettings/autoProvision","equals":"On"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/475aae12-b88a-4572-8b36-9b712b2b3a17","type":"Microsoft.Authorization/policyDefinitions","name":"475aae12-b88a-4572-8b36-9b712b2b3a17"},{"properties":{"displayName":"Guest + Configuration extension should be installed on your machines","policyType":"BuiltIn","mode":"Indexed","description":"To + ensure secure configurations of in-guest settings of your machine, install + the Guest Configuration extension. In-guest settings that the extension monitors + include the configuration of the operating system, application configuration + or presence, and environment settings. Once installed, in-guest policies will + be available such as ''Windows Exploit guard should be enabled''. Learn more + at https://aka.ms/gcpol.","metadata":{"version":"1.0.1","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack","microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ae89ebca-1c92-4898-ac2c-9f63decb045c","type":"Microsoft.Authorization/policyDefinitions","name":"ae89ebca-1c92-4898-ac2c-9f63decb045c"},{"properties":{"displayName":"Deploy + export to Event Hub for Azure Security Center data","policyType":"BuiltIn","mode":"All","description":"Enable + export to Event Hub of Azure Security Center data. This policy deploys an + export to Event Hub configuration with your conditions and target Event Hub + on the assigned scope. To deploy this policy on newly created subscriptions, + open the Compliance tab, select the relevant non-compliant assignment and + create a remediation task.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"resourceGroupName":{"type":"String","metadata":{"displayName":"Resource + group name","description":"The resource group name where the export to Event + Hub configuration is created. If you enter a name for a resource group that + doesn''t exist, it''ll be created in the subscription. Note that each resource + group can only have one export to Event Hub configured."}},"resourceGroupLocation":{"type":"String","metadata":{"displayName":"Resource + group location","description":"The location where the resource group and the + export to Event Hub configuration are created.","strongType":"location"}},"exportedDataTypes":{"type":"Array","metadata":{"displayName":"Exported + data types","description":"The data types to be exported. To export a snapshot + (preview) of the data once a week, choose the data types which contains ''snapshot'', + other data types will be sent in real-time streaming."},"allowedValues":["Security + recommendations","Security alerts","Overall secure score","Secure score controls","Regulatory + compliance","Overall secure score - snapshot","Secure score controls - snapshot","Regulatory + compliance - snapshot"],"defaultValue":["Security recommendations","Security + alerts","Overall secure score","Secure score controls","Regulatory compliance","Overall + secure score - snapshot","Secure score controls - snapshot","Regulatory compliance + - snapshot"]},"recommendationNames":{"type":"Array","metadata":{"displayName":"Recommendation + IDs","description":"Applicable only for export of security recommendations. + To export all recommendations, leave this empty. To export specific recommendations, + enter a list of recommendation IDs separated by semicolons ('';''). Recommendation + IDs are available through the Assessments API (https://docs.microsoft.com/rest/api/securitycenter/assessments), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/assessments."},"defaultValue":[]},"recommendationSeverities":{"type":"Array","metadata":{"displayName":"Recommendation + severities","description":"Applicable only for export of security recommendations. + Determines recommendation severities. Example: High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"isSecurityFindingsEnabled":{"type":"Boolean","metadata":{"displayName":"Include + security findings","description":"Security findings are results from vulnerability + assessment solutions, and can be thought of as ''sub'' recommendations grouped + into a ''parent'' recommendation."},"allowedValues":[true,false],"defaultValue":true},"secureScoreControlsNames":{"type":"Array","metadata":{"displayName":"Secure + Score Controls IDs","description":"Applicable only for export of secure score + controls. To export all secure score controls, leave this empty. To export + specific secure score controls, enter a list of secure score controls IDs + separated by semicolons ('';''). Secure score controls IDs are available through + the Secure score controls API (https://docs.microsoft.com/rest/api/securitycenter/securescorecontrols), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/securescores/securescorecontrols."},"defaultValue":[]},"alertSeverities":{"type":"Array","metadata":{"displayName":"Alert + severities","description":"Applicable only for export of security alerts. + Determines alert severities. Example: High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"regulatoryComplianceStandardsNames":{"type":"Array","metadata":{"displayName":"Regulatory + compliance standards names","description":"Applicable only for export of regulatory + compliance. To export all regulatory compliance, leave this empty. To export + specific regulatory compliance standards, enter a list of these standards + names separated by semicolons ('';''). Regulatory compliance standards names + are available through the regulatory compliance standards API (https://docs.microsoft.com/rest/api/securitycenter/regulatorycompliancestandards), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/regulatorycompliancestandards."},"defaultValue":[]},"eventHubDetails":{"type":"String","metadata":{"displayName":"Event + Hub details","description":"The Event Hub details of where the data should + be exported to: Subscription, Event Hub Namespace, Event Hub, and Authorizations + rules with ''Send'' claim.","strongType":"Microsoft.EventHub/namespaces/eventhubs/authorizationrules","assignPermissions":true}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/automations","name":"exportToEventHub","existenceScope":"resourcegroup","ResourceGroupName":"[parameters(''resourceGroupName'')]","deploymentScope":"subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Security/automations/isEnabled","equals":true},{"count":{"field":"Microsoft.Security/automations/sources[*]"},"equals":"[if(parameters(''isSecurityFindingsEnabled''),add(length(parameters(''exportedDataTypes'')),1),length(parameters(''exportedDataTypes'')))]"},{"count":{"value":"[parameters(''exportedDataTypes'')]","name":"dataType","where":{"count":{"field":"Microsoft.Security/automations/sources[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"Assessments"},{"value":"[current(''dataType'')]","equals":"Security + recommendations"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"Alerts"},{"value":"[current(''dataType'')]","equals":"Security + alerts"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScores"},{"value":"[current(''dataType'')]","equals":"Overall + secure score"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoreControls"},{"value":"[current(''dataType'')]","equals":"Secure + score controls"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"RegulatoryComplianceAssessment"},{"value":"[current(''dataType'')]","equals":"Regulatory + compliance"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoresSnapshot"},{"value":"[current(''dataType'')]","equals":"Overall + secure score - snapshot"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoreControlsSnapshot"},{"value":"[current(''dataType'')]","equals":"Secure + score controls - snapshot"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"RegulatoryComplianceAssessmentSnapshot"},{"value":"[current(''dataType'')]","equals":"Regulatory + compliance - snapshot"}]}]}},"equals":1}},"equals":"[length(parameters(''exportedDataTypes''))]"}]},"deployment":{"location":"westeurope","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceGroupName":{"type":"string"},"resourceGroupLocation":{"type":"string"},"exportedDataTypes":{"type":"array"},"isSecurityFindingsEnabled":{"type":"bool"},"recommendationNames":{"type":"array"},"secureScoreControlsNames":{"type":"array"},"regulatoryComplianceStandardsNames":{"type":"array"},"recommendationSeverities":{"type":"array"},"alertSeverities":{"type":"array"},"eventHubDetails":{"type":"string"},"guidValue":{"type":"string","defaultValue":"[newGuid()]"}},"variables":{"scopeDescription":"scope + for subscription {0}","subAssessmentRuleExpectedValue":"/assessments/{0}/","recommendationNamesLength":"[length(parameters(''recommendationNames''))]","secureScoreControlsNamesLength":"[length(parameters(''secureScoreControlsNames''))]","secureScoreControlsLengthIfEmpty":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), 1, variables(''secureScoreControlsNamesLength''))]","regulatoryComplianceStandardsNamesLength":"[length(parameters(''regulatoryComplianceStandardsNames''))]","regulatoryComplianceStandardsNamesLengthIfEmpty":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), 1, variables(''regulatoryComplianceStandardsNamesLength''))]","recommendationSeveritiesLength":"[length(parameters(''recommendationSeverities''))]","alertSeveritiesLength":"[length(parameters(''alertSeverities''))]","recommendationNamesLengthIfEmpty":"[if(equals(variables(''recommendationNamesLength''), + 0), 1, variables(''recommendationNamesLength''))]","recommendationSeveritiesLengthIfEmpty":"[if(equals(variables(''recommendationSeveritiesLength''), + 0), 1, variables(''recommendationSeveritiesLength''))]","alertSeveritiesLengthIfEmpty":"[if(equals(variables(''alertSeveritiesLength''), + 0), 1, variables(''alertSeveritiesLength''))]","totalRuleCombinationsForOneRecommendationName":"[variables(''recommendationSeveritiesLengthIfEmpty'')]","totalRuleCombinationsForOneRecommendationSeverity":1,"exportedDataTypesLength":"[length(parameters(''exportedDataTypes''))]","exportedDataTypesLengthIfEmpty":"[if(equals(variables(''exportedDataTypesLength''), + 0), 1, variables(''exportedDataTypesLength''))]","SeperatedEventHubDetails":"[split(parameters(''eventHubDetails''),''/'')]","dataTypeMap":{"Security + recommendations":"Assessments","Security alerts":"Alerts","Overall secure + score":"SecureScores","Secure score controls":"SecureScoreControls","Regulatory + compliance":"RegulatoryComplianceAssessment","Overall secure score - snapshot":"SecureScoresSnapshot","Secure + score controls - snapshot":"SecureScoreControlsSnapshot","Regulatory compliance + - snapshot":"RegulatoryComplianceAssessmentSnapshot"},"alertSeverityMap":{"High":"high","Medium":"medium","Low":"low"},"ruleSetsForAssessmentsObj":{"copy":[{"name":"ruleSetsForAssessmentsArr","count":"[mul(variables(''recommendationNamesLengthIfEmpty''),variables(''recommendationSeveritiesLengthIfEmpty''))]","input":{"rules":[{"propertyJPath":"[if(equals(variables(''recommendationNamesLength''),0),''type'',''name'')]","propertyType":"string","expectedValue":"[if(equals(variables(''recommendationNamesLength''),0),''Microsoft.Security/assessments'',parameters(''recommendationNames'')[mod(div(copyIndex(''ruleSetsForAssessmentsArr''),variables(''totalRuleCombinationsForOneRecommendationName'')),variables(''recommendationNamesLength''))])]","operator":"Contains"},{"propertyJPath":"properties.metadata.severity","propertyType":"string","expectedValue":"[parameters(''recommendationSeverities'')[mod(div(copyIndex(''ruleSetsForAssessmentsArr''),variables(''totalRuleCombinationsForOneRecommendationSeverity'')),variables(''recommendationSeveritiesLength''))]]","operator":"Equals"}]}}]},"customRuleSetsForSubAssessmentsObj":{"copy":[{"name":"ruleSetsForSubAssessmentsArr","count":"[variables(''recommendationNamesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"id","propertyType":"string","expectedValue":"[if(equals(variables(''recommendationNamesLength''), + 0), json(''null''), replace(variables(''subAssessmentRuleExpectedValue''),''{0}'', + parameters(''recommendationNames'')[copyIndex(''ruleSetsForSubAssessmentsArr'')]))]","operator":"Contains"}]}}]},"ruleSetsForAlertsObj":{"copy":[{"name":"ruleSetsForAlertsArr","count":"[variables(''alertSeveritiesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"Severity","propertyType":"string","expectedValue":"[variables(''alertSeverityMap'')[parameters(''alertSeverities'')[mod(copyIndex(''ruleSetsForAlertsArr''),variables(''alertSeveritiesLengthIfEmpty''))]]]","operator":"Equals"}]}}]},"customRuleSetsForSecureScoreControlsObj":{"copy":[{"name":"ruleSetsForSecureScoreControlsArr","count":"[variables(''secureScoreControlsLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"name","propertyType":"string","expectedValue":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), json(''null''), parameters(''secureScoreControlsNames'')[copyIndex(''ruleSetsForSecureScoreControlsArr'')])]","operator":"Equals"}]}}]},"customRuleSetsForRegulatoryComplianceObj":{"copy":[{"name":"ruleSetsForRegulatoryCompliancArr","count":"[variables(''regulatoryComplianceStandardsNamesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"id","propertyType":"string","expectedValue":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), json(''null''), parameters(''regulatoryComplianceStandardsNames'')[copyIndex(''ruleSetsForRegulatoryCompliancArr'')])]","operator":"Contains"}]}}]},"ruleSetsForSecureScoreControlsObj":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), json(''null''), variables(''customRuleSetsForSecureScoreControlsObj'').ruleSetsForSecureScoreControlsArr)]","ruleSetsForSecureRegulatoryComplianceObj":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), json(''null''), variables(''customRuleSetsForRegulatoryComplianceObj'').ruleSetsForRegulatoryCompliancArr)]","ruleSetsForSubAssessmentsObj":"[if(equals(variables(''recommendationNamesLength''), + 0), json(''null''), variables(''customRuleSetsForSubAssessmentsObj'').ruleSetsForSubAssessmentsArr)]","subAssessmentSource":[{"eventSource":"SubAssessments","ruleSets":"[variables(''ruleSetsForSubAssessmentsObj'')]"}],"ruleSetsMap":{"Security + recommendations":"[variables(''ruleSetsForAssessmentsObj'').ruleSetsForAssessmentsArr]","Security + alerts":"[variables(''ruleSetsForAlertsObj'').ruleSetsForAlertsArr]","Overall + secure score":null,"Secure score controls":"[variables(''ruleSetsForSecureScoreControlsObj'')]","Regulatory + compliance":"[variables(''ruleSetsForSecureRegulatoryComplianceObj'')]","Overall + secure score - snapshot":null,"Secure score controls - snapshot":"[variables(''ruleSetsForSecureScoreControlsObj'')]","Regulatory + compliance - snapshot":"[variables(''ruleSetsForSecureRegulatoryComplianceObj'')]"},"sourcesWithoutSubAssessments":{"copy":[{"name":"sources","count":"[variables(''exportedDataTypesLengthIfEmpty'')]","input":{"eventSource":"[variables(''dataTypeMap'')[parameters(''exportedDataTypes'')[copyIndex(''sources'')]]]","ruleSets":"[variables(''ruleSetsMap'')[parameters(''exportedDataTypes'')[copyIndex(''sources'')]]]"}}]},"sourcesWithSubAssessments":"[concat(variables(''subAssessmentSource''),variables(''sourcesWithoutSubAssessments'').sources)]","sources":"[if(equals(parameters(''isSecurityFindingsEnabled''),bool(''true'')),variables(''sourcesWithSubAssessments''),variables(''sourcesWithoutSubAssessments'').sources)]"},"resources":[{"name":"[parameters(''resourceGroupName'')]","type":"Microsoft.Resources/resourceGroups","apiVersion":"2019-10-01","location":"[parameters(''resourceGroupLocation'')]","tags":{},"properties":{}},{"type":"Microsoft.Resources/deployments","apiVersion":"2019-10-01","name":"[concat(''nestedAutomationDeployment'', + ''_'', parameters(''guidValue''))]","resourceGroup":"[parameters(''resourceGroupName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups/'', + parameters(''resourceGroupName''))]"],"properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[{"tags":{},"apiVersion":"2019-01-01-preview","location":"[parameters(''resourceGroupLocation'')]","name":"exportToEventHub","type":"Microsoft.Security/automations","dependsOn":[],"properties":{"description":"Export + Azure Security Center data to Event Hub via policy","isEnabled":true,"scopes":[{"description":"[replace(variables(''scopeDescription''),''{0}'', + subscription().subscriptionId)]","scopePath":"[subscription().id]"}],"sources":"[variables(''sources'')]","actions":[{"actionType":"EventHub","eventHubResourceId":"[concat(''/'', + variables(''SeperatedEventHubDetails'')[1], ''/'', variables(''SeperatedEventHubDetails'')[2], + ''/'', variables(''SeperatedEventHubDetails'')[3], ''/'', variables(''SeperatedEventHubDetails'')[4], + ''/'', variables(''SeperatedEventHubDetails'')[5], ''/'', variables(''SeperatedEventHubDetails'')[6], + ''/'', variables(''SeperatedEventHubDetails'')[7], ''/'', variables(''SeperatedEventHubDetails'')[8], + ''/'', variables(''SeperatedEventHubDetails'')[9], ''/'', variables(''SeperatedEventHubDetails'')[10])]","connectionString":"[listkeys(parameters(''eventHubDetails''),''2017-04-01'').primaryConnectionString]"}]}}]}}}]},"parameters":{"resourceGroupName":{"value":"[parameters(''resourceGroupName'')]"},"resourceGroupLocation":{"value":"[parameters(''resourceGroupLocation'')]"},"exportedDataTypes":{"value":"[parameters(''exportedDataTypes'')]"},"recommendationNames":{"value":"[parameters(''recommendationNames'')]"},"isSecurityFindingsEnabled":{"value":"[parameters(''isSecurityFindingsEnabled'')]"},"secureScoreControlsNames":{"value":"[parameters(''secureScoreControlsNames'')]"},"recommendationSeverities":{"value":"[parameters(''recommendationSeverities'')]"},"alertSeverities":{"value":"[parameters(''alertSeverities'')]"},"regulatoryComplianceStandardsNames":{"value":"[parameters(''regulatoryComplianceStandardsNames'')]"},"eventHubDetails":{"value":"[parameters(''eventHubDetails'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cdfcce10-4578-4ecd-9703-530938e4abcb","type":"Microsoft.Authorization/policyDefinitions","name":"cdfcce10-4578-4ecd-9703-530938e4abcb"},{"properties":{"displayName":"Deploy + export to Log Analytics workspace for Azure Security Center data","policyType":"BuiltIn","mode":"All","description":"Enable + export to Log Analytics workspace of Azure Security Center data. This policy + deploys an export to Log Analytics workspace configuration with your conditions + and target workspace on the assigned scope. To deploy this policy on newly + created subscriptions, open the Compliance tab, select the relevant non-compliant + assignment and create a remediation task.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"resourceGroupName":{"type":"String","metadata":{"displayName":"Resource + group name","description":"The resource group name where the export to Log + Analytics workspace configuration is created. If you enter a name for a resource + group that doesn''t exist, it''ll be created in the subscription. Note that + each resource group can only have one export to Log Analytics workspace configured."}},"resourceGroupLocation":{"type":"String","metadata":{"displayName":"Resource + group location","description":"The location where the resource group and the + export to Log Analytics workspace configuration are created.","strongType":"location"}},"exportedDataTypes":{"type":"Array","metadata":{"displayName":"Exported + data types","description":"The data types to be exported. To export a snapshot + (preview) of the data once a week, choose the data types which contains ''snapshot'', + other data types will be sent in real-time streaming."},"allowedValues":["Security + recommendations","Security alerts","Overall secure score","Secure score controls","Regulatory + compliance","Overall secure score - snapshot","Secure score controls - snapshot","Regulatory + compliance - snapshot"],"defaultValue":["Security recommendations","Security + alerts","Overall secure score","Secure score controls","Regulatory compliance","Overall + secure score - snapshot","Secure score controls - snapshot","Regulatory compliance + - snapshot"]},"recommendationNames":{"type":"Array","metadata":{"displayName":"Recommendation + IDs","description":"Applicable only for export of security recommendations. + To export all recommendations, leave this empty. To export specific recommendations, + enter a list of recommendation IDs separated by semicolons ('';''). Recommendation + IDs are available through the Assessments API (https://docs.microsoft.com/rest/api/securitycenter/assessments), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/assessments."},"defaultValue":[]},"recommendationSeverities":{"type":"Array","metadata":{"displayName":"Recommendation + severities","description":"Applicable only for export of security recommendations. + Determines recommendation severities. Example: High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"isSecurityFindingsEnabled":{"type":"Boolean","metadata":{"displayName":"Include + security findings","description":"Security findings are results from vulnerability + assessment solutions, and can be thought of as ''sub'' recommendations grouped + into a ''parent'' recommendation."},"allowedValues":[true,false],"defaultValue":true},"secureScoreControlsNames":{"type":"Array","metadata":{"displayName":"Secure + Score Controls IDs","description":"Applicable only for export of secure score + controls. To export all secure score controls, leave this empty. To export + specific secure score controls, enter a list of secure score controls IDs + separated by semicolons ('';''). Secure score controls IDs are available through + the Secure score controls API (https://docs.microsoft.com/rest/api/securitycenter/securescorecontrols), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/securescores/securescorecontrols."},"defaultValue":[]},"alertSeverities":{"type":"Array","metadata":{"displayName":"Alert + severities","description":"Applicable only for export of security alerts. + Determines alert severities. Example: High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"regulatoryComplianceStandardsNames":{"type":"Array","metadata":{"displayName":"Regulatory + compliance standards names","description":"Applicable only for export of regulatory + compliance. To export all regulatory compliance, leave this empty. To export + specific regulatory compliance standards, enter a list of these standards + names separated by semicolons ('';''). Regulatory compliance standards names + are available through the regulatory compliance standards API (https://docs.microsoft.com/rest/api/securitycenter/regulatorycompliancestandards), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/regulatorycompliancestandards."},"defaultValue":[]},"workspaceResourceId":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"The Log Analytics workspace of where the + data should be exported to.","strongType":"Microsoft.OperationalInsights/workspaces","assignPermissions":true}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/automations","name":"ExportToWorkspace","existenceScope":"resourcegroup","ResourceGroupName":"[parameters(''resourceGroupName'')]","deploymentScope":"subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Security/automations/isEnabled","equals":true},{"count":{"field":"Microsoft.Security/automations/sources[*]"},"equals":"[if(parameters(''isSecurityFindingsEnabled''),add(length(parameters(''exportedDataTypes'')),1),length(parameters(''exportedDataTypes'')))]"},{"count":{"value":"[parameters(''exportedDataTypes'')]","name":"dataType","where":{"count":{"field":"Microsoft.Security/automations/sources[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"Assessments"},{"value":"[current(''dataType'')]","equals":"Security + recommendations"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"Alerts"},{"value":"[current(''dataType'')]","equals":"Security + alerts"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScores"},{"value":"[current(''dataType'')]","equals":"Overall + secure score"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoreControls"},{"value":"[current(''dataType'')]","equals":"Secure + score controls"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"RegulatoryComplianceAssessment"},{"value":"[current(''dataType'')]","equals":"Regulatory + compliance"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoresSnapshot"},{"value":"[current(''dataType'')]","equals":"Overall + secure score - snapshot"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"SecureScoreControlsSnapshot"},{"value":"[current(''dataType'')]","equals":"Secure + score controls - snapshot"}]},{"allOf":[{"field":"Microsoft.Security/automations/sources[*].eventSource","equals":"RegulatoryComplianceAssessmentSnapshot"},{"value":"[current(''dataType'')]","equals":"Regulatory + compliance - snapshot"}]}]}},"equals":1}},"equals":"[length(parameters(''exportedDataTypes''))]"}]},"deployment":{"location":"westeurope","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceGroupName":{"type":"string"},"resourceGroupLocation":{"type":"string"},"exportedDataTypes":{"type":"array"},"isSecurityFindingsEnabled":{"type":"bool"},"recommendationNames":{"type":"array"},"recommendationSeverities":{"type":"array"},"alertSeverities":{"type":"array"},"secureScoreControlsNames":{"type":"array"},"regulatoryComplianceStandardsNames":{"type":"array"},"workspaceResourceId":{"type":"string"},"guidValue":{"type":"string","defaultValue":"[newGuid()]"}},"variables":{"scopeDescription":"scope + for subscription {0}","subAssessmentRuleExpectedValue":"/assessments/{0}/","recommendationNamesLength":"[length(parameters(''recommendationNames''))]","secureScoreControlsNamesLength":"[length(parameters(''secureScoreControlsNames''))]","secureScoreControlsLengthIfEmpty":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), 1, variables(''secureScoreControlsNamesLength''))]","regulatoryComplianceStandardsNamesLength":"[length(parameters(''regulatoryComplianceStandardsNames''))]","regulatoryComplianceStandardsNamesLengthIfEmpty":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), 1, variables(''regulatoryComplianceStandardsNamesLength''))]","recommendationSeveritiesLength":"[length(parameters(''recommendationSeverities''))]","alertSeveritiesLength":"[length(parameters(''alertSeverities''))]","recommendationNamesLengthIfEmpty":"[if(equals(variables(''recommendationNamesLength''), + 0), 1, variables(''recommendationNamesLength''))]","recommendationSeveritiesLengthIfEmpty":"[if(equals(variables(''recommendationSeveritiesLength''), + 0), 1, variables(''recommendationSeveritiesLength''))]","alertSeveritiesLengthIfEmpty":"[if(equals(variables(''alertSeveritiesLength''), + 0), 1, variables(''alertSeveritiesLength''))]","totalRuleCombinationsForOneRecommendationName":"[variables(''recommendationSeveritiesLengthIfEmpty'')]","totalRuleCombinationsForOneRecommendationSeverity":1,"exportedDataTypesLength":"[length(parameters(''exportedDataTypes''))]","exportedDataTypesLengthIfEmpty":"[if(equals(variables(''exportedDataTypesLength''), + 0), 1, variables(''exportedDataTypesLength''))]","dataTypeMap":{"Security + recommendations":"Assessments","Security alerts":"Alerts","Overall secure + score":"SecureScores","Secure score controls":"SecureScoreControls","Regulatory + compliance":"RegulatoryComplianceAssessment","Overall secure score - snapshot":"SecureScoresSnapshot","Secure + score controls - snapshot":"SecureScoreControlsSnapshot","Regulatory compliance + - snapshot":"RegulatoryComplianceAssessmentSnapshot"},"alertSeverityMap":{"High":"high","Medium":"medium","Low":"low"},"ruleSetsForAssessmentsObj":{"copy":[{"name":"ruleSetsForAssessmentsArr","count":"[mul(variables(''recommendationNamesLengthIfEmpty''),variables(''recommendationSeveritiesLengthIfEmpty''))]","input":{"rules":[{"propertyJPath":"[if(equals(variables(''recommendationNamesLength''),0),''type'',''name'')]","propertyType":"string","expectedValue":"[if(equals(variables(''recommendationNamesLength''),0),''Microsoft.Security/assessments'',parameters(''recommendationNames'')[mod(div(copyIndex(''ruleSetsForAssessmentsArr''),variables(''totalRuleCombinationsForOneRecommendationName'')),variables(''recommendationNamesLength''))])]","operator":"Contains"},{"propertyJPath":"properties.metadata.severity","propertyType":"string","expectedValue":"[parameters(''recommendationSeverities'')[mod(div(copyIndex(''ruleSetsForAssessmentsArr''),variables(''totalRuleCombinationsForOneRecommendationSeverity'')),variables(''recommendationSeveritiesLength''))]]","operator":"Equals"}]}}]},"customRuleSetsForSubAssessmentsObj":{"copy":[{"name":"ruleSetsForSubAssessmentsArr","count":"[variables(''recommendationNamesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"id","propertyType":"string","expectedValue":"[if(equals(variables(''recommendationNamesLength''), + 0), json(''null''), replace(variables(''subAssessmentRuleExpectedValue''),''{0}'', + parameters(''recommendationNames'')[copyIndex(''ruleSetsForSubAssessmentsArr'')]))]","operator":"Contains"}]}}]},"ruleSetsForAlertsObj":{"copy":[{"name":"ruleSetsForAlertsArr","count":"[variables(''alertSeveritiesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"Severity","propertyType":"string","expectedValue":"[variables(''alertSeverityMap'')[parameters(''alertSeverities'')[mod(copyIndex(''ruleSetsForAlertsArr''),variables(''alertSeveritiesLengthIfEmpty''))]]]","operator":"Equals"}]}}]},"customRuleSetsForSecureScoreControlsObj":{"copy":[{"name":"ruleSetsForSecureScoreControlsArr","count":"[variables(''secureScoreControlsLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"name","propertyType":"string","expectedValue":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), json(''null''), parameters(''secureScoreControlsNames'')[copyIndex(''ruleSetsForSecureScoreControlsArr'')])]","operator":"Equals"}]}}]},"customRuleSetsForRegulatoryComplianceObj":{"copy":[{"name":"ruleSetsForRegulatoryCompliancArr","count":"[variables(''regulatoryComplianceStandardsNamesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"id","propertyType":"string","expectedValue":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), json(''null''), parameters(''regulatoryComplianceStandardsNames'')[copyIndex(''ruleSetsForRegulatoryCompliancArr'')])]","operator":"Contains"}]}}]},"ruleSetsForSecureScoreControlsObj":"[if(equals(variables(''secureScoreControlsNamesLength''), + 0), json(''null''), variables(''customRuleSetsForSecureScoreControlsObj'').ruleSetsForSecureScoreControlsArr)]","ruleSetsForSecureRegulatoryComplianceObj":"[if(equals(variables(''regulatoryComplianceStandardsNamesLength''), + 0), json(''null''), variables(''customRuleSetsForRegulatoryComplianceObj'').ruleSetsForRegulatoryCompliancArr)]","ruleSetsForSubAssessmentsObj":"[if(equals(variables(''recommendationNamesLength''), + 0), json(''null''), variables(''customRuleSetsForSubAssessmentsObj'').ruleSetsForSubAssessmentsArr)]","subAssessmentSource":[{"eventSource":"SubAssessments","ruleSets":"[variables(''ruleSetsForSubAssessmentsObj'')]"}],"ruleSetsMap":{"Security + recommendations":"[variables(''ruleSetsForAssessmentsObj'').ruleSetsForAssessmentsArr]","Security + alerts":"[variables(''ruleSetsForAlertsObj'').ruleSetsForAlertsArr]","Overall + secure score":null,"Secure score controls":"[variables(''ruleSetsForSecureScoreControlsObj'')]","Regulatory + compliance":"[variables(''ruleSetsForSecureRegulatoryComplianceObj'')]","Overall + secure score - snapshot":null,"Secure score controls - snapshot":"[variables(''ruleSetsForSecureScoreControlsObj'')]","Regulatory + compliance - snapshot":"[variables(''ruleSetsForSecureRegulatoryComplianceObj'')]"},"sourcesWithoutSubAssessments":{"copy":[{"name":"sources","count":"[variables(''exportedDataTypesLengthIfEmpty'')]","input":{"eventSource":"[variables(''dataTypeMap'')[parameters(''exportedDataTypes'')[copyIndex(''sources'')]]]","ruleSets":"[variables(''ruleSetsMap'')[parameters(''exportedDataTypes'')[copyIndex(''sources'')]]]"}}]},"sourcesWithSubAssessments":"[concat(variables(''subAssessmentSource''),variables(''sourcesWithoutSubAssessments'').sources)]","sources":"[if(equals(parameters(''isSecurityFindingsEnabled''),bool(''true'')),variables(''sourcesWithSubAssessments''),variables(''sourcesWithoutSubAssessments'').sources)]"},"resources":[{"name":"[parameters(''resourceGroupName'')]","type":"Microsoft.Resources/resourceGroups","apiVersion":"2019-10-01","location":"[parameters(''resourceGroupLocation'')]","tags":{},"properties":{}},{"type":"Microsoft.Resources/deployments","apiVersion":"2019-10-01","name":"[concat(''nestedAutomationDeployment'', + ''_'', parameters(''guidValue''))]","resourceGroup":"[parameters(''resourceGroupName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups/'', + parameters(''resourceGroupName''))]"],"properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[{"tags":{},"apiVersion":"2019-01-01-preview","location":"[parameters(''resourceGroupLocation'')]","name":"ExportToWorkspace","type":"Microsoft.Security/automations","dependsOn":[],"properties":{"description":"Export + Azure Security Center data to Log Analytics workspace via policy","isEnabled":true,"scopes":[{"description":"[replace(variables(''scopeDescription''),''{0}'', + subscription().subscriptionId)]","scopePath":"[subscription().id]"}],"sources":"[variables(''sources'')]","actions":[{"actionType":"Workspace","workspaceResourceId":"[parameters(''workspaceResourceId'')]"}]}}]}}}]},"parameters":{"resourceGroupName":{"value":"[parameters(''resourceGroupName'')]"},"resourceGroupLocation":{"value":"[parameters(''resourceGroupLocation'')]"},"exportedDataTypes":{"value":"[parameters(''exportedDataTypes'')]"},"isSecurityFindingsEnabled":{"value":"[parameters(''isSecurityFindingsEnabled'')]"},"recommendationNames":{"value":"[parameters(''recommendationNames'')]"},"secureScoreControlsNames":{"value":"[parameters(''secureScoreControlsNames'')]"},"recommendationSeverities":{"value":"[parameters(''recommendationSeverities'')]"},"alertSeverities":{"value":"[parameters(''alertSeverities'')]"},"regulatoryComplianceStandardsNames":{"value":"[parameters(''regulatoryComplianceStandardsNames'')]"},"workspaceResourceId":{"value":"[parameters(''workspaceResourceId'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ffb6f416-7bd2-4488-8828-56585fef2be9","type":"Microsoft.Authorization/policyDefinitions","name":"ffb6f416-7bd2-4488-8828-56585fef2be9"},{"properties":{"displayName":"Subscriptions + should have a contact email address for security issues","policyType":"BuiltIn","mode":"All","description":"To + ensure the relevant people in your organization are notified when there is + a potential security breach in one of your subscriptions, set a security contact + to receive email notifications from Security Center.","metadata":{"version":"1.0.1","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/securityContacts","existenceCondition":{"field":"Microsoft.Security/securityContacts/email","notEquals":""}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4f4f78b8-e367-4b10-a341-d9a4ad5cf1c7","type":"Microsoft.Authorization/policyDefinitions","name":"4f4f78b8-e367-4b10-a341-d9a4ad5cf1c7"},{"properties":{"displayName":"Virtual + machines'' Guest Configuration extension should be deployed with system-assigned + managed identity","policyType":"BuiltIn","mode":"Indexed","description":"The + Guest Configuration extension requires a system assigned managed identity. + Azure virtual machines in the scope of this policy will be non-compliant when + they have the Guest Configuration extension installed but do not have a system + assigned managed identity. Learn more at https://aka.ms/gcpol","metadata":{"version":"1.0.1","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines/extensions"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines","name":"[first(split(field(''fullName''), + ''/''))]","existenceCondition":{"field":"identity.type","contains":"SystemAssigned"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d26f7642-7545-4e18-9b75-8c9bbdee3a9a","type":"Microsoft.Authorization/policyDefinitions","name":"d26f7642-7545-4e18-9b75-8c9bbdee3a9a"},{"properties":{"displayName":"VM + Image Builder templates should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Audit + VM Image Builder templates that do not have a virtual network configured. + When a virtual network is not configured, a public IP is created and used + instead which may directly expose resources to the internet and increase the + potential attack surface.","metadata":{"version":"1.0.1","category":"VM Image + Builder"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.VirtualMachineImages/imageTemplates"},{"field":"Microsoft.VirtualMachineImages/imageTemplates/vmProfile.vnetConfig","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2154edb9-244f-4741-9970-660785bccdaa","type":"Microsoft.Authorization/policyDefinitions","name":"2154edb9-244f-4741-9970-660785bccdaa"},{"properties":{"displayName":"[Deprecated]: + Audit Windows virtual machines on which the Windows Guest Configuration extension + is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits Windows virtual machines hosted in Azure that are supported + by Guest Configuration but do not have the Guest Configuration extension enabled. + For more information on Guest Configuration, visit https://aka.ms/gcpol.","metadata":{"version":"2.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforWindows","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforWindows"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5fc23db3-dd4d-4c56-bcc7-43626243e601","type":"Microsoft.Authorization/policyDefinitions","name":"5fc23db3-dd4d-4c56-bcc7-43626243e601"},{"properties":{"displayName":"[Deprecated]: + Audit Linux virtual machines on which the Linux Guest Configuration extension + is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits Linux virtual machines hosted in Azure that are supported by + Guest Configuration but do not have the Guest Configuration extension enabled. + For more information on Guest Configuration, visit https://aka.ms/gcpol.","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforLinux","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/faf25c8c-9598-4305-b4de-0aee1317fb31","type":"Microsoft.Authorization/policyDefinitions","name":"faf25c8c-9598-4305-b4de-0aee1317fb31"},{"properties":{"displayName":"[Preview]: + Firewall should be enabled on Key Vault","policyType":"BuiltIn","mode":"Indexed","description":"Key + vault''s firewall prevents unauthorized traffic from reaching your key vault + and provides an additional layer of protection for your secrets. Enable the + firewall to make sure that only traffic from allowed networks can access your + key vault.","metadata":{"version":"1.0.2-preview","category":"Key Vault","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"field":"Microsoft.KeyVault/vaults/networkAcls.defaultAction","notEquals":"Deny"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/55615ac9-af46-4a59-874e-391cc3dfb490","type":"Microsoft.Authorization/policyDefinitions","name":"55615ac9-af46-4a59-874e-391cc3dfb490"},{"properties":{"displayName":"[Preview]: + Private endpoint should be configured for Key Vault","policyType":"BuiltIn","mode":"Indexed","description":"Private + link provides a way to connect Key Vault to your Azure resources without sending + traffic over the public internet. Private link provides defense in depth protection + against data exfiltration.","metadata":{"version":"1.1.0-preview","category":"Key + Vault","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"anyOf":[{"field":"Microsoft.KeyVault/vaults/privateEndpointConnections","exists":"false"},{"count":{"field":"Microsoft.KeyVault/vaults/privateEndpointConnections[*]"},"equals":0}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5f0bc445-3935-4915-9981-011aa2b46147","type":"Microsoft.Authorization/policyDefinitions","name":"5f0bc445-3935-4915-9981-011aa2b46147"},{"properties":{"displayName":"Azure + Event Grid domains should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network.By mapping private endpoints to your Event Grid domains instead + of the entire service, you''ll also be protected against data leakage risks.Learn + more at: https://aka.ms/privateendpoints.","metadata":{"version":"1.0.2","category":"Event + Grid"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.EventGrid/domains"},{"count":{"field":"Microsoft.EventGrid/domains/privateEndpointConnections[*]","where":{"field":"Microsoft.EventGrid/domains/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9830b652-8523-49cc-b1b3-e17dce1127ca","type":"Microsoft.Authorization/policyDefinitions","name":"9830b652-8523-49cc-b1b3-e17dce1127ca"},{"properties":{"displayName":"Public + network access should be disabled for MySQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Disable + the public network access property to improve security and ensure your Azure + Database for MySQL can only be accessed from a private endpoint. This configuration + strictly disables access from any public address space outside of Azure IP + range, and denies all logins that match IP or virtual network-based firewall + rules.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforMySQL/servers"},{"field":"Microsoft.DBforMySQL/servers/publicNetworkAccess","notEquals":"Disabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d9844e8a-1437-4aeb-a32c-0c992f056095","type":"Microsoft.Authorization/policyDefinitions","name":"d9844e8a-1437-4aeb-a32c-0c992f056095"},{"properties":{"displayName":"Azure + Event Grid topics should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network. By mapping private endpoints to your topics instead of the + entire service, you''ll also be protected against data leakage risks. Learn + more at: https://aka.ms/privateendpoints.","metadata":{"version":"1.0.2","category":"Event + Grid"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.EventGrid/topics"},{"field":"kind","notEquals":"AzureArc"},{"count":{"field":"Microsoft.EventGrid/topics/privateEndpointConnections[*]","where":{"field":"Microsoft.EventGrid/topics/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4b90e17e-8448-49db-875e-bd83fb6f804f","type":"Microsoft.Authorization/policyDefinitions","name":"4b90e17e-8448-49db-875e-bd83fb6f804f"},{"properties":{"displayName":"Bring + your own key data protection should be enabled for MySQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys to manage the encryption at rest of your MySQL servers. + By default, the data is encrypted at rest with service-managed keys, but customer-managed + keys (CMK) are commonly required to meet regulatory compliance standards. + CMKs enable the data to be encrypted with an Azure Key Vault key created and + owned by you. You have full control and responsibility for the key lifecycle, + including rotation and management.","metadata":{"version":"1.0.3","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforMySQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforMySQL/servers/keys","existenceCondition":{"allOf":[{"field":"Microsoft.DBforMySQL/servers/keys/serverKeyType","equals":"AzureKeyVault"},{"field":"Microsoft.DBforMySQL/servers/keys/uri","notEquals":""},{"field":"Microsoft.DBforMySQL/servers/keys/uri","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/83cef61d-dbd1-4b20-a4fc-5fbc7da10833","type":"Microsoft.Authorization/policyDefinitions","name":"83cef61d-dbd1-4b20-a4fc-5fbc7da10833"},{"properties":{"displayName":"Public + network access should be disabled for MariaDB servers","policyType":"BuiltIn","mode":"Indexed","description":"Disable + the public network access property to improve security and ensure your Azure + Database for MariaDB can only be accessed from a private endpoint. This configuration + strictly disables access from any public address space outside of Azure IP + range, and denies all logins that match IP or virtual network-based firewall + rules.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforMariaDB/servers"},{"field":"Microsoft.DBforMariaDB/servers/publicNetworkAccess","notEquals":"Disabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fdccbe47-f3e3-4213-ad5d-ea459b2fa077","type":"Microsoft.Authorization/policyDefinitions","name":"fdccbe47-f3e3-4213-ad5d-ea459b2fa077"},{"properties":{"displayName":"Bring + your own key data protection should be enabled for PostgreSQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Use + customer-managed keys to manage the encryption at rest of your PostgreSQL + servers. By default, the data is encrypted at rest with service-managed keys, + but customer-managed keys (CMK) are commonly required to meet regulatory compliance + standards. CMKs enable the data to be encrypted with an Azure Key Vault key + created and owned by you. You have full control and responsibility for the + key lifecycle, including rotation and management.","metadata":{"version":"1.0.3","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/keys","existenceCondition":{"allOf":[{"field":"Microsoft.DBforPostgreSQL/servers/keys/serverKeyType","equals":"AzureKeyVault"},{"field":"Microsoft.DBforPostgreSQL/servers/keys/uri","notEquals":""},{"field":"Microsoft.DBforPostgreSQL/servers/keys/uri","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/18adea5e-f416-4d0f-8aa8-d24321e3e274","type":"Microsoft.Authorization/policyDefinitions","name":"18adea5e-f416-4d0f-8aa8-d24321e3e274"},{"properties":{"displayName":"Azure + SignalR Service should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network. By mapping private endpoints to your SignalR resources + instead of the entire service, you''ll also be protected against data leakage + risks .Learn more at: https://aka.ms/asrs/privatelink.","metadata":{"version":"1.0.1","category":"SignalR"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.SignalRService/SignalR"},{"count":{"field":"Microsoft.SignalRService/SignalR/privateEndpointConnections[*]","where":{"field":"Microsoft.SignalRService/SignalR/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/53503636-bcc9-4748-9663-5348217f160f","type":"Microsoft.Authorization/policyDefinitions","name":"53503636-bcc9-4748-9663-5348217f160f"},{"properties":{"displayName":"Public + network access should be disabled for PostgreSQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Disable + the public network access property to improve security and ensure your Azure + Database for PostgreSQL can only be accessed from a private endpoint. This + configuration disables access from any public address space outside of Azure + IP range, and denies all logins that match IP or virtual network-based firewall + rules.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},{"field":"Microsoft.DBforPostgreSQL/servers/publicNetworkAccess","notEquals":"Disabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b52376f7-9612-48a1-81cd-1ffe4b61032c","type":"Microsoft.Authorization/policyDefinitions","name":"b52376f7-9612-48a1-81cd-1ffe4b61032c"},{"properties":{"displayName":"Azure + Machine Learning workspaces should be encrypted with a customer-managed key + (CMK)","policyType":"BuiltIn","mode":"Indexed","description":"Manage encryption + at rest of your Azure Machine Learning workspace data with customer-managed + keys (CMK). By default, customer data is encrypted with service-managed keys, + but CMKs are commonly required to meet regulatory compliance standards. CMKs + enable the data to be encrypted with an Azure Key Vault key created and owned + by you. You have full control and responsibility for the key lifecycle, including + rotation and management. Learn more about CMK encryption at https://aka.ms/azureml-workspaces-cmk.","metadata":{"version":"1.0.3","category":"Machine + Learning"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.MachineLearningServices/workspaces"},{"not":{"field":"Microsoft.MachineLearningServices/workspaces/encryption.status","equals":"enabled"}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ba769a63-b8cc-4b2d-abf6-ac33c7204be8","type":"Microsoft.Authorization/policyDefinitions","name":"ba769a63-b8cc-4b2d-abf6-ac33c7204be8"},{"properties":{"displayName":"Web + Application Firewall (WAF) should be enabled for Application Gateway","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Azure Web Application Firewall (WAF) in front of public facing web applications + for additional inspection of incoming traffic. Web Application Firewall (WAF) + provides centralized protection of your web applications from common exploits + and vulnerabilities such as SQL injections, Cross-Site Scripting, local and + remote file executions. You can also restrict access to your web applications + by countries, IP address ranges, and other http(s) parameters via custom rules.","metadata":{"version":"1.0.1","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/applicationGateways"},{"field":"Microsoft.Network/applicationGateways/webApplicationFirewallConfiguration","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/564feb30-bf6a-4854-b4bb-0d2d2d1e6c66","type":"Microsoft.Authorization/policyDefinitions","name":"564feb30-bf6a-4854-b4bb-0d2d2d1e6c66"},{"properties":{"displayName":"Web + Application Firewall (WAF) should be enabled for Azure Front Door Service + service","policyType":"BuiltIn","mode":"Indexed","description":"Deploy Azure + Web Application Firewall (WAF) in front of public facing web applications + for additional inspection of incoming traffic. Web Application Firewall (WAF) + provides centralized protection of your web applications from common exploits + and vulnerabilities such as SQL injections, Cross-Site Scripting, local and + remote file executions. You can also restrict access to your web applications + by countries, IP address ranges, and other http(s) parameters via custom rules.","metadata":{"version":"1.0.1","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/frontdoors"},{"field":"Microsoft.Network/frontdoors/frontendEndpoints[*].webApplicationFirewallPolicyLink.id","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/055aa869-bc98-4af8-bafc-23f1ab6ffe2c","type":"Microsoft.Authorization/policyDefinitions","name":"055aa869-bc98-4af8-bafc-23f1ab6ffe2c"},{"properties":{"displayName":"Azure + Machine Learning workspaces should use private link","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Private Link lets you connect your virtual network to Azure services without + a public IP address at the source or destination. The private link platform + handles the connectivity between the consumer and services over the Azure + backbone network. By mapping private endpoints to your Azure Machine Learning + workspaces instead of the entire service, you''ll also be protected against + data leakage risks. Learn more at: https://aka.ms/azureml-workspaces-privatelink.","metadata":{"version":"1.0.1","category":"Machine + Learning"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.MachineLearningServices/workspaces"},{"count":{"field":"Microsoft.MachineLearningServices/workspaces/privateEndpointConnections[*]","where":{"field":"Microsoft.MachineLearningServices/workspaces/privateEndpointConnections[*].privateLinkServiceConnectionState.status","equals":"Approved"}},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/40cec1dd-a100-4920-b15b-3024fe8901ab","type":"Microsoft.Authorization/policyDefinitions","name":"40cec1dd-a100-4920-b15b-3024fe8901ab"},{"properties":{"displayName":"An + activity log alert should exist for specific Policy operations","policyType":"BuiltIn","mode":"All","description":"This + policy audits specific Policy operations with no activity log alerts configured.","metadata":{"version":"3.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"operationName":{"type":"String","metadata":{"displayName":"Operation + Name","description":"Policy Operation name for which activity log alert should + exist"},"allowedValues":["Microsoft.Authorization/policyAssignments/write","Microsoft.Authorization/policyAssignments/delete"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/ActivityLogAlerts","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/enabled","equals":"true"},{"count":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"Administrative"}]},{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"[parameters(''operationName'')]"}]}]}},"equals":2},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"}},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c5447c04-a4d7-4ba8-a263-c9ee321a6858","type":"Microsoft.Authorization/policyDefinitions","name":"c5447c04-a4d7-4ba8-a263-c9ee321a6858"},{"properties":{"displayName":"Azure + Monitor log profile should collect logs for categories ''write,'' ''delete,'' + and ''action''","policyType":"BuiltIn","mode":"All","description":"This policy + ensures that a log profile collects logs for categories ''write,'' ''delete,'' + and ''action''","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/logprofiles","existenceCondition":{"allOf":[{"not":{"field":"Microsoft.Insights/logProfiles/categories[*]","notEquals":"Write"}},{"not":{"field":"Microsoft.Insights/logProfiles/categories[*]","notEquals":"Delete"}},{"not":{"field":"Microsoft.Insights/logProfiles/categories[*]","notEquals":"Action"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1a4e592a-6a6e-44a5-9814-e36264ca96e7","type":"Microsoft.Authorization/policyDefinitions","name":"1a4e592a-6a6e-44a5-9814-e36264ca96e7"},{"properties":{"displayName":"Azure + Monitor should collect activity logs from all regions","policyType":"BuiltIn","mode":"All","description":"This + policy audits the Azure Monitor log profile which does not export activities + from all Azure supported regions including global.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/logProfiles","existenceCondition":{"allOf":[{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"australiacentral"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"australiacentral2"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"australiaeast"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"australiasoutheast"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"brazilsouth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"canadacentral"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"canadaeast"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"centralindia"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"centralus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"eastasia"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"eastus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"eastus2"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"francecentral"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"francesouth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"japaneast"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"japanwest"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"koreacentral"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"koreasouth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"northcentralus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"northeurope"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"southafricanorth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"southafricawest"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"southcentralus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"southindia"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"southeastasia"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"uaecentral"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"uaenorth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"uksouth"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"ukwest"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"westcentralus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"westeurope"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"westindia"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"westus"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"westus2"}},{"not":{"field":"Microsoft.Insights/logProfiles/locations[*]","notEquals":"global"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/41388f1c-2db0-4c25-95b2-35d7f5ccbfa9","type":"Microsoft.Authorization/policyDefinitions","name":"41388f1c-2db0-4c25-95b2-35d7f5ccbfa9"},{"properties":{"displayName":"Activity + log should be retained for at least one year","policyType":"BuiltIn","mode":"All","description":"This + policy audits the activity log if the retention is not set for 365 days or + forever (retention days set to 0).","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/logProfiles","existenceCondition":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/logProfiles/retentionPolicy.enabled","equals":"true"},{"field":"Microsoft.Insights/logProfiles/retentionPolicy.days","equals":"365"}]},{"allOf":[{"field":"Microsoft.Insights/logProfiles/retentionPolicy.enabled","equals":"false"},{"field":"Microsoft.Insights/logProfiles/retentionPolicy.days","equals":"0"}]}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b02aacc0-b073-424e-8298-42b22829ee0a","type":"Microsoft.Authorization/policyDefinitions","name":"b02aacc0-b073-424e-8298-42b22829ee0a"},{"properties":{"displayName":"An + activity log alert should exist for specific Administrative operations","policyType":"BuiltIn","mode":"All","description":"This + policy audits specific Administrative operations with no activity log alerts + configured.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"operationName":{"type":"String","metadata":{"displayName":"Operation + Name","description":"Administrative Operation name for which activity log + alert should be configured"},"allowedValues":["Microsoft.Sql/servers/firewallRules/write","Microsoft.Sql/servers/firewallRules/delete","Microsoft.Network/networkSecurityGroups/write","Microsoft.Network/networkSecurityGroups/delete","Microsoft.ClassicNetwork/networkSecurityGroups/write","Microsoft.ClassicNetwork/networkSecurityGroups/delete","Microsoft.Network/networkSecurityGroups/securityRules/write","Microsoft.Network/networkSecurityGroups/securityRules/delete","Microsoft.ClassicNetwork/networkSecurityGroups/securityRules/write","Microsoft.ClassicNetwork/networkSecurityGroups/securityRules/delete"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/ActivityLogAlerts","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/enabled","equals":"true"},{"count":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"Administrative"}]},{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"[parameters(''operationName'')]"}]}]}},"equals":2},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"}},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b954148f-4c11-4c38-8221-be76711e194a","type":"Microsoft.Authorization/policyDefinitions","name":"b954148f-4c11-4c38-8221-be76711e194a"},{"properties":{"displayName":"Storage + account containing the container with activity logs must be encrypted with + BYOK","policyType":"BuiltIn","mode":"All","description":"This policy audits + if the Storage account containing the container with activity logs is encrypted + with BYOK. The policy works only if the storage account lies on the same subscription + as activity logs by design. More information on Azure Storage encryption at + rest can be found here https://aka.ms/azurestoragebyok. ","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Insights/logProfiles"},{"field":"Microsoft.Insights/logProfiles/storageAccountId","exists":"true"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Storage/storageAccounts","existenceScope":"subscription","existenceCondition":{"allOf":[{"value":"[contains(field(''Microsoft.Insights/logProfiles/storageAccountId''), + subscription().Id)]","equals":"true"},{"field":"name","equals":"[last(split(field(''Microsoft.Insights/logProfiles/storageAccountId''),''/''))]"},{"field":"Microsoft.Storage/storageAccounts/encryption.keySource","equals":"Microsoft.Keyvault"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fbb99e8e-e444-4da0-9ff1-75c92f5a85b2","type":"Microsoft.Authorization/policyDefinitions","name":"fbb99e8e-e444-4da0-9ff1-75c92f5a85b2"},{"properties":{"displayName":"Add + or replace a tag on resource groups","policyType":"BuiltIn","mode":"All","description":"Adds + or replaces the specified tag and value when any resource group is created + or updated. Existing resource groups can be remediated by triggering a remediation + task.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[parameters(''tagValue'')]"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d157c373-a6c4-483d-aaad-570756956268","type":"Microsoft.Authorization/policyDefinitions","name":"d157c373-a6c4-483d-aaad-570756956268"},{"properties":{"displayName":"Add + or replace a tag on resources","policyType":"BuiltIn","mode":"Indexed","description":"Adds + or replaces the specified tag and value when any resource is created or updated. + Existing resources can be remediated by triggering a remediation task. Does + not modify tags on resource groups.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[parameters(''tagValue'')]"},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5ffd78d9-436d-4b41-a421-5baa819e3008","type":"Microsoft.Authorization/policyDefinitions","name":"5ffd78d9-436d-4b41-a421-5baa819e3008"},{"properties":{"displayName":"Add + a tag to resource groups","policyType":"BuiltIn","mode":"All","description":"Adds + the specified tag and value when any resource group missing this tag is created + or updated. Existing resource groups can be remediated by triggering a remediation + task. If the tag exists with a different value it will not be changed.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/726aca4c-86e9-4b04-b0c5-073027359532","type":"Microsoft.Authorization/policyDefinitions","name":"726aca4c-86e9-4b04-b0c5-073027359532"},{"properties":{"displayName":"Add + a tag to resources","policyType":"BuiltIn","mode":"Indexed","description":"Adds + the specified tag and value when any resource missing this tag is created + or updated. Existing resources can be remediated by triggering a remediation + task. If the tag exists with a different value it will not be changed. Does + not modify tags on resource groups.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4f9dc7db-30c1-420c-b61a-e1d640128d26","type":"Microsoft.Authorization/policyDefinitions","name":"4f9dc7db-30c1-420c-b61a-e1d640128d26"},{"properties":{"displayName":"Allowed + locations","policyType":"BuiltIn","mode":"Indexed","description":"This policy + enables you to restrict the locations your organization can specify when deploying + resources. Use to enforce your geo-compliance requirements. Excludes resource + groups, Microsoft.AzureActiveDirectory/b2cDirectories, and resources that + use the ''global'' region.","metadata":{"version":"1.0.0","category":"General"},"parameters":{"listOfAllowedLocations":{"type":"Array","metadata":{"description":"The + list of locations that can be specified when deploying resources.","strongType":"location","displayName":"Allowed + locations"}}},"policyRule":{"if":{"allOf":[{"field":"location","notIn":"[parameters(''listOfAllowedLocations'')]"},{"field":"location","notEquals":"global"},{"field":"type","notEquals":"Microsoft.AzureActiveDirectory/b2cDirectories"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e56962a6-4747-49cd-b67b-bf8b01975c4c","type":"Microsoft.Authorization/policyDefinitions","name":"e56962a6-4747-49cd-b67b-bf8b01975c4c"},{"properties":{"displayName":"An + activity log alert should exist for specific Security operations","policyType":"BuiltIn","mode":"All","description":"This + policy audits specific Security operations with no activity log alerts configured.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"operationName":{"type":"String","metadata":{"displayName":"Operation + Name","description":"Security Operation name for which activity log alert + should exist"},"allowedValues":["Microsoft.Security/policies/write","Microsoft.Security/securitySolutions/write","Microsoft.Security/securitySolutions/delete"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/ActivityLogAlerts","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/enabled","equals":"true"},{"count":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"Security"}]},{"allOf":[{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"},{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals","equals":"[parameters(''operationName'')]"}]}]}},"equals":2},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"category"}},{"not":{"field":"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field","equals":"operationName"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3b980d31-7904-4bb7-8575-5665739a8052","type":"Microsoft.Authorization/policyDefinitions","name":"3b980d31-7904-4bb7-8575-5665739a8052"},{"properties":{"displayName":"Allowed + resource types","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables you to specify the resource types that your organization can + deploy. Only resource types that support ''tags'' and ''location'' will be + affected by this policy. To restrict all resources please duplicate this policy + and change the ''mode'' to ''All''.","metadata":{"version":"1.0.0","category":"General"},"parameters":{"listOfResourceTypesAllowed":{"type":"Array","metadata":{"description":"The + list of resource types that can be deployed.","displayName":"Allowed resource + types","strongType":"resourceTypes"}}},"policyRule":{"if":{"not":{"field":"type","in":"[parameters(''listOfResourceTypesAllowed'')]"}},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a08ec900-254a-4555-9bf5-e42af04b5c5c","type":"Microsoft.Authorization/policyDefinitions","name":"a08ec900-254a-4555-9bf5-e42af04b5c5c"},{"properties":{"displayName":"Allowed + storage account SKUs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables you to specify a set of storage account SKUs that your organization + can deploy.","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"listOfAllowedSKUs":{"type":"Array","metadata":{"description":"The + list of SKUs that can be specified for storage accounts.","displayName":"Allowed + SKUs","strongType":"StorageSKUs"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"not":{"field":"Microsoft.Storage/storageAccounts/sku.name","in":"[parameters(''listOfAllowedSKUs'')]"}}]},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7433c107-6db4-4ad1-b57a-a76dce0154a1","type":"Microsoft.Authorization/policyDefinitions","name":"7433c107-6db4-4ad1-b57a-a76dce0154a1"},{"properties":{"displayName":"Append + a tag and its value to resources","policyType":"BuiltIn","mode":"Indexed","description":"Appends + the specified tag and value when any resource which is missing this tag is + created or updated. Does not modify the tags of resources created before this + policy was applied until those resources are changed. Does not apply to resource + groups. New ''modify'' effect policies are available that support remediation + of tags on existing resources (see https://aka.ms/modifydoc).","metadata":{"version":"1.0.1","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},"then":{"effect":"append","details":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2a0e14a6-b0a6-4fab-991a-187a4f81c498","type":"Microsoft.Authorization/policyDefinitions","name":"2a0e14a6-b0a6-4fab-991a-187a4f81c498"},{"properties":{"displayName":"Virtual + machines should be connected to an approved virtual network","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any virtual machine connected to a virtual network that is not + approved.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"virtualNetworkId":{"type":"String","metadata":{"displayName":"Virtual + network Id","description":"Resource Id of the virtual network. Example: /subscriptions/YourSubscriptionId/resourceGroups/YourResourceGroupName/providers/Microsoft.Network/virtualNetworks/Name"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkInterfaces"},{"not":{"field":"Microsoft.Network/networkInterfaces/ipconfigurations[*].subnet.id","like":"[concat(parameters(''virtualNetworkId''),''/*'')]"}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d416745a-506c-48b6-8ab1-83cb814bcaa3","type":"Microsoft.Authorization/policyDefinitions","name":"d416745a-506c-48b6-8ab1-83cb814bcaa3"},{"properties":{"displayName":"API + App should only be accessible over HTTPS","policyType":"BuiltIn","mode":"Indexed","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"Microsoft.Web/sites/httpsOnly","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b7ddfbdc-1260-477d-91fd-98bd9be789a6","type":"Microsoft.Authorization/policyDefinitions","name":"b7ddfbdc-1260-477d-91fd-98bd9be789a6"},{"properties":{"displayName":"[Deprecated]: + Ensure that Register with Azure Active Directory is enabled on API app","policyType":"BuiltIn","mode":"Indexed","description":"This + policy is a duplicate of the respective Managed Identity policies. Please + use /providers/Microsoft.Authorization/policyDefinitions/c4d441f8-f9d9-4a9e-9cef-e82117cb3ee + instead.","metadata":{"version":"1.0.0-deprecated","category":"App Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.managedServiceIdentityId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86d97760-d216-4d81-a3ad-163087b2b6c3","type":"Microsoft.Authorization/policyDefinitions","name":"86d97760-d216-4d81-a3ad-163087b2b6c3"},{"properties":{"displayName":"Web + Application should only be accessible over HTTPS","policyType":"BuiltIn","mode":"Indexed","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"Microsoft.Web/sites/httpsOnly","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a4af4a39-4135-47fb-b175-47fbdf85311d","type":"Microsoft.Authorization/policyDefinitions","name":"a4af4a39-4135-47fb-b175-47fbdf85311d"},{"properties":{"displayName":"Ensure + that ''HTTP Version'' is the latest, if used to run the API app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for HTTP either due to security flaws or to include + additional functionality. Using the latest HTTP version for web apps to take + advantage of security fixes, if any, and/or new functionalities of the newer + version. Currently, this policy only applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.http20Enabled","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/991310cd-e9f3-47bc-b7b6-f57b557d07db","type":"Microsoft.Authorization/policyDefinitions","name":"991310cd-e9f3-47bc-b7b6-f57b557d07db"},{"properties":{"displayName":"[Deprecated]: + Ensure that ''.NET Framework'' version is the latest, if used as a part of + the API app","policyType":"BuiltIn","mode":"Indexed","description":"This policy + is not required since Azure App Service automatically updates and maintains + the .NET Framework versions installed on the platform.","metadata":{"version":"1.0.0-deprecated","category":"App + Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.netFrameworkVersion","in":["v3.0","v4.0"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c2e7ca55-f62c-49b2-89a4-d41eb661d2f0","type":"Microsoft.Authorization/policyDefinitions","name":"c2e7ca55-f62c-49b2-89a4-d41eb661d2f0"},{"properties":{"displayName":"Function + App should only be accessible over HTTPS","policyType":"BuiltIn","mode":"Indexed","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"},{"field":"Microsoft.Web/sites/httpsOnly","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6d555dd1-86f2-4f1c-8ed7-5abae7c6cbab","type":"Microsoft.Authorization/policyDefinitions","name":"6d555dd1-86f2-4f1c-8ed7-5abae7c6cbab"},{"properties":{"displayName":"Ensure + that ''Java version'' is the latest, if used as a part of the API app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Java either due to security flaws or to include + additional functionality. Using the latest Python version for API apps is + recommended in order to take advantage of security fixes, if any, and/or new + functionalities of the latest version. Currently, this policy only applies + to Linux web apps.","metadata":{"version":"2.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"JavaLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Java version","description":"Latest supported Java version for App Services"},"defaultValue":"11"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"JAVA"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","like":"[concat(''*'', + parameters(''JavaLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/88999f4c-376a-45c8-bcb3-4058f713cf39","type":"Microsoft.Authorization/policyDefinitions","name":"88999f4c-376a-45c8-bcb3-4058f713cf39"},{"properties":{"displayName":"Ensure + API app has ''Client Certificates (Incoming client certificates)'' set to + ''On''","policyType":"BuiltIn","mode":"Indexed","description":"Client certificates + allow for the app to request a certificate for incoming requests. Only clients + that have a valid certificate will be able to reach the app.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"Microsoft.Web/sites/clientCertEnabled","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0c192fe8-9cbb-4516-85b3-0ade8bd03886","type":"Microsoft.Authorization/policyDefinitions","name":"0c192fe8-9cbb-4516-85b3-0ade8bd03886"},{"properties":{"displayName":"Ensure + that ''PHP version'' is the latest, if used as a part of the API app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for PHP software either due to security flaws + or to include additional functionality. Using the latest PHP version for API + apps is recommended in order to take advantage of security fixes, if any, + and/or new functionalities of the latest version. Currently, this policy only + applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"PHPLatestVersion":{"type":"String","metadata":{"displayName":"Latest + PHP version","description":"Latest supported PHP version for App Services"},"defaultValue":"7.3"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PHP"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PHP|'', + parameters(''PHPLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1bc1795e-d44a-4d48-9b3b-6fff0fd5f9ba","type":"Microsoft.Authorization/policyDefinitions","name":"1bc1795e-d44a-4d48-9b3b-6fff0fd5f9ba"},{"properties":{"displayName":"Ensure + that ''Python version'' is the latest, if used as a part of the API app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Python software either due to security flaws + or to include additional functionality. Using the latest Python version for + API apps is recommended in order to take advantage of security fixes, if any, + and/or new functionalities of the latest version. Currently, this policy only + applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"WindowsPythonLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Windows Python version","description":"Latest supported Python version for + App Services","deprecated":true},"defaultValue":"3.6"},"LinuxPythonLatestVersion":{"type":"String","metadata":{"displayName":"Linux + Latest Python version","description":"Latest supported Python version for + App Services"},"defaultValue":"3.8"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PYTHON"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PYTHON|'', + parameters(''LinuxPythonLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/74c3584d-afae-46f7-a20a-6f8adba71a16","type":"Microsoft.Authorization/policyDefinitions","name":"74c3584d-afae-46f7-a20a-6f8adba71a16"},{"properties":{"displayName":"FTPS + only should be required in your API App","policyType":"BuiltIn","mode":"Indexed","description":"Enable + FTPS enforcement for enhanced security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/ftpsState","in":["FtpsOnly","Disabled"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9a1b8c48-453a-4044-86c3-d8bfd823e4f5","type":"Microsoft.Authorization/policyDefinitions","name":"9a1b8c48-453a-4044-86c3-d8bfd823e4f5"},{"properties":{"displayName":"FTPS + only should be required in your Function App","policyType":"BuiltIn","mode":"Indexed","description":"Enable + FTPS enforcement for enhanced security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/ftpsState","in":["FtpsOnly","Disabled"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/399b2637-a50f-4f95-96f8-3a145476eb15","type":"Microsoft.Authorization/policyDefinitions","name":"399b2637-a50f-4f95-96f8-3a145476eb15"},{"properties":{"displayName":"FTPS + should be required in your Web App","policyType":"BuiltIn","mode":"Indexed","description":"Enable + FTPS enforcement for enhanced security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/ftpsState","in":["FtpsOnly","Disabled"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4d24b6d4-5e53-4a4f-a7f4-618fa573ee4b","type":"Microsoft.Authorization/policyDefinitions","name":"4d24b6d4-5e53-4a4f-a7f4-618fa573ee4b"},{"properties":{"displayName":"Diagnostic + logs in App Services should be enabled","policyType":"BuiltIn","mode":"All","description":"Audit + enabling of diagnostic logs on the app. This enables you to recreate activity + trails for investigation purposes if a security incident occurs or your network + is compromised","metadata":{"version":"2.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","notContains":"functionapp"},{"field":"kind","notContains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"allOf":[{"field":"Microsoft.Web/sites/config/detailedErrorLoggingEnabled","equals":"true"},{"field":"Microsoft.Web/sites/config/httpLoggingEnabled","equals":"true"},{"field":"Microsoft.Web/sites/config/requestTracingEnabled","equals":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b607c5de-e7d9-4eee-9e5c-83f1bcee4fa0","type":"Microsoft.Authorization/policyDefinitions","name":"b607c5de-e7d9-4eee-9e5c-83f1bcee4fa0"},{"properties":{"displayName":"[Deprecated]: + Audit enabling of diagnostic logs in App Services","policyType":"BuiltIn","mode":"All","description":"Audit + enabling of diagnostic logs on the app. This enables you to recreate activity + trails for investigation purposes if a security incident occurs or your network + is compromised","metadata":{"version":"1.0.0-deprecated","category":"App Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites/config"},{"field":"name","equals":"web"},{"anyOf":[{"field":"Microsoft.Web/sites/config/detailedErrorLoggingEnabled","notEquals":"true"},{"field":"Microsoft.Web/sites/config/httpLoggingEnabled","notEquals":"true"},{"field":"Microsoft.Web/sites/config/requestTracingEnabled","notEquals":"true"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/752c6934-9bcc-4749-b004-655e676ae2ac","type":"Microsoft.Authorization/policyDefinitions","name":"752c6934-9bcc-4749-b004-655e676ae2ac"},{"properties":{"displayName":"Authentication + should be enabled on your Function app","policyType":"BuiltIn","mode":"Indexed","description":"Azure + App Service Authentication is a feature that can prevent anonymous HTTP requests + from reaching the Function app, or authenticate those that have tokens before + they reach the Function app","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","equals":"functionapp"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/siteAuthEnabled","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c75248c1-ea1d-4a9c-8fc9-29a6aabd5da8","type":"Microsoft.Authorization/policyDefinitions","name":"c75248c1-ea1d-4a9c-8fc9-29a6aabd5da8"},{"properties":{"displayName":"Authentication + should be enabled on your API app","policyType":"BuiltIn","mode":"Indexed","description":"Azure + App Service Authentication is a feature that can prevent anonymous HTTP requests + from reaching the API app, or authenticate those that have tokens before they + reach the API app","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/siteAuthEnabled","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c4ebc54a-46e1-481a-bee2-d4411e95d828","type":"Microsoft.Authorization/policyDefinitions","name":"c4ebc54a-46e1-481a-bee2-d4411e95d828"},{"properties":{"displayName":"Remote + debugging should be turned off for API Apps","policyType":"BuiltIn","mode":"Indexed","description":"Remote + debugging requires inbound ports to be opened on API apps. Remote debugging + should be turned off.","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/remoteDebuggingEnabled","equals":"false"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e9c8d085-d9cc-4b17-9cdc-059f1f01f19e","type":"Microsoft.Authorization/policyDefinitions","name":"e9c8d085-d9cc-4b17-9cdc-059f1f01f19e"},{"properties":{"displayName":"Authentication + should be enabled on your web app","policyType":"BuiltIn","mode":"Indexed","description":"Azure + App Service Authentication is a feature that can prevent anonymous HTTP requests + from reaching the web app, or authenticate those that have tokens before they + reach the web app","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/siteAuthEnabled","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/95bccee9-a7f8-4bec-9ee9-62c3473701fc","type":"Microsoft.Authorization/policyDefinitions","name":"95bccee9-a7f8-4bec-9ee9-62c3473701fc"},{"properties":{"displayName":"Remote + debugging should be turned off for Function Apps","policyType":"BuiltIn","mode":"Indexed","description":"Remote + debugging requires inbound ports to be opened on function apps. Remote debugging + should be turned off.","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.remoteDebuggingEnabled","equals":"false"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0e60b895-3786-45da-8377-9c6b4b6ac5f9","type":"Microsoft.Authorization/policyDefinitions","name":"0e60b895-3786-45da-8377-9c6b4b6ac5f9"},{"properties":{"displayName":"Remote + debugging should be turned off for Web Applications","policyType":"BuiltIn","mode":"Indexed","description":"Remote + debugging requires inbound ports to be opened on a web application. Remote + debugging should be turned off.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.remoteDebuggingEnabled","equals":"false"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cb510bfd-1cba-4d9f-a230-cb0976f4bb71","type":"Microsoft.Authorization/policyDefinitions","name":"cb510bfd-1cba-4d9f-a230-cb0976f4bb71"},{"properties":{"displayName":"[Deprecated]: + Ensure that Register with Azure Active Directory is enabled on Function App","policyType":"BuiltIn","mode":"Indexed","description":"This + policy is a duplicate of the respective Managed Identity policies. Please + use /providers/Microsoft.Authorization/policyDefinitions/0da106f2-4ca3-48e8-bc85-c638fe6aea8f + instead.","metadata":{"version":"1.0.0-deprecated","category":"App Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.managedServiceIdentityId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f0473e7a-a1ba-4e86-afb2-e829e11b01d8","type":"Microsoft.Authorization/policyDefinitions","name":"f0473e7a-a1ba-4e86-afb2-e829e11b01d8"},{"properties":{"displayName":"Ensure + that ''HTTP Version'' is the latest, if used to run the Function app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for HTTP either due to security flaws or to include + additional functionality. Using the latest HTTP version for web apps to take + advantage of security fixes, if any, and/or new functionalities of the newer + version. Currently, this policy only applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.http20Enabled","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e2c1c086-2d84-4019-bff3-c44ccd95113c","type":"Microsoft.Authorization/policyDefinitions","name":"e2c1c086-2d84-4019-bff3-c44ccd95113c"},{"properties":{"displayName":"[Deprecated]: + Ensure that ''.NET Framework'' version is the latest, if used as a part of + the Function App","policyType":"BuiltIn","mode":"Indexed","description":"This + policy is not required since Azure App Service automatically updates and maintains + the .NET Framework versions installed on the platform.","metadata":{"version":"1.0.0-deprecated","category":"App + Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.netFrameworkVersion","in":["v3.0","v4.0"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/10c1859c-e1a7-4df3-ab97-a487fa8059f6","type":"Microsoft.Authorization/policyDefinitions","name":"10c1859c-e1a7-4df3-ab97-a487fa8059f6"},{"properties":{"displayName":"Ensure + that ''Java version'' is the latest, if used as a part of the Function app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Java software either due to security flaws + or to include additional functionality. Using the latest Java version for + Function apps is recommended in order to take advantage of security fixes, + if any, and/or new functionalities of the latest version. Currently, this + policy only applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"JavaLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Java version","description":"Latest supported Java version for App Services"},"defaultValue":"11"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"JAVA"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","like":"[concat(''*'', + parameters(''JavaLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9d0b6ea4-93e2-4578-bf2f-6bb17d22b4bc","type":"Microsoft.Authorization/policyDefinitions","name":"9d0b6ea4-93e2-4578-bf2f-6bb17d22b4bc"},{"properties":{"displayName":"[Deprecated]: + Ensure that ''PHP version'' is the latest, if used as a part of the Function + app","policyType":"BuiltIn","mode":"Indexed","description":"PHP cannot be + used with Function apps.","metadata":{"version":"1.0.0-deprecated","category":"App + Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"PHPLatestVersion":{"type":"String","metadata":{"displayName":"[Deprecated]: + Latest PHP version","description":"Latest supported PHP version for App Services"},"defaultValue":"7.3"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"allOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PHP"},{"field":"Microsoft.Web/sites/config/web.phpVersion","equals":""}]},{"allOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PHP|'', + parameters(''PHPLatestVersion''))]"},{"field":"Microsoft.Web/sites/config/web.phpVersion","equals":""}]},{"allOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":""},{"field":"Microsoft.Web/sites/config/web.phpVersion","equals":"[parameters(''PHPLatestVersion'')]"}]}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ab965db2-d2bf-4b64-8b39-c38ec8179461","type":"Microsoft.Authorization/policyDefinitions","name":"ab965db2-d2bf-4b64-8b39-c38ec8179461"},{"properties":{"displayName":"Latest + TLS version should be used in your API App","policyType":"BuiltIn","mode":"Indexed","description":"Upgrade + to the latest TLS version","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/minTlsVersion","equals":"1.2"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8cb6aa8b-9e41-4f4e-aa25-089a7ac2581e","type":"Microsoft.Authorization/policyDefinitions","name":"8cb6aa8b-9e41-4f4e-aa25-089a7ac2581e"},{"properties":{"displayName":"Ensure + that ''Python version'' is the latest, if used as a part of the Function app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Python software either due to security flaws + or to include additional functionality. Using the latest Python version for + Function apps is recommended in order to take advantage of security fixes, + if any, and/or new functionalities of the latest version. Currently, this + policy only applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"WindowsPythonLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Windows Python version","description":"Latest supported Python version for + App Services","deprecated":true},"defaultValue":"3.6"},"LinuxPythonLatestVersion":{"type":"String","metadata":{"displayName":"Linux + Latest Python version","description":"Latest supported Python version for + App Services"},"defaultValue":"3.8"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PYTHON"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PYTHON|'', + parameters(''LinuxPythonLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7238174a-fd10-4ef0-817e-fc820a951d73","type":"Microsoft.Authorization/policyDefinitions","name":"7238174a-fd10-4ef0-817e-fc820a951d73"},{"properties":{"displayName":"Latest + TLS version should be used in your Function App","policyType":"BuiltIn","mode":"Indexed","description":"Upgrade + to the latest TLS version","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/minTlsVersion","equals":"1.2"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f9d614c5-c173-4d56-95a7-b4437057d193","type":"Microsoft.Authorization/policyDefinitions","name":"f9d614c5-c173-4d56-95a7-b4437057d193"},{"properties":{"displayName":"Latest + TLS version should be used in your Web App","policyType":"BuiltIn","mode":"Indexed","description":"Upgrade + to the latest TLS version","metadata":{"version":"1.0.0","category":"App Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/minTlsVersion","equals":"1.2"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b","type":"Microsoft.Authorization/policyDefinitions","name":"f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b"},{"properties":{"displayName":"CORS + should not allow every resource to access your Function Apps","policyType":"BuiltIn","mode":"Indexed","description":"Cross-Origin + Resource Sharing (CORS) should not allow all domains to access your Function + app. Allow only required domains to interact with your Function app.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]","notEquals":"*"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0820b7b9-23aa-4725-a1ce-ae4558f718e5","type":"Microsoft.Authorization/policyDefinitions","name":"0820b7b9-23aa-4725-a1ce-ae4558f718e5"},{"properties":{"displayName":"CORS + should not allow every resource to access your API App","policyType":"BuiltIn","mode":"Indexed","description":"Cross-Origin + Resource Sharing (CORS) should not allow all domains to access your API app. + Allow only required domains to interact with your API app.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]","notEquals":"*"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/358c20a6-3f9e-4f0e-97ff-c6ce485e2aac","type":"Microsoft.Authorization/policyDefinitions","name":"358c20a6-3f9e-4f0e-97ff-c6ce485e2aac"},{"properties":{"displayName":"CORS + should not allow every resource to access your Web Applications","policyType":"BuiltIn","mode":"Indexed","description":"Cross-Origin + Resource Sharing (CORS) should not allow all domains to access your web application. + Allow only required domains to interact with your web app.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]","notEquals":"*"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5744710e-cc2f-4ee8-8809-3b11e89f4bc9","type":"Microsoft.Authorization/policyDefinitions","name":"5744710e-cc2f-4ee8-8809-3b11e89f4bc9"},{"properties":{"displayName":"Managed + identity should be used in your API App","policyType":"BuiltIn","mode":"Indexed","description":"Use + a managed identity for enhanced authentication security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"*api"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/managedServiceIdentityId","exists":"true"},{"field":"Microsoft.Web/sites/config/xmanagedServiceIdentityId","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c4d441f8-f9d9-4a9e-9cef-e82117cb3eef","type":"Microsoft.Authorization/policyDefinitions","name":"c4d441f8-f9d9-4a9e-9cef-e82117cb3eef"},{"properties":{"displayName":"Managed + identity should be used in your Function App","policyType":"BuiltIn","mode":"Indexed","description":"Use + a managed identity for enhanced authentication security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"functionapp*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/managedServiceIdentityId","exists":"true"},{"field":"Microsoft.Web/sites/config/xmanagedServiceIdentityId","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0da106f2-4ca3-48e8-bc85-c638fe6aea8f","type":"Microsoft.Authorization/policyDefinitions","name":"0da106f2-4ca3-48e8-bc85-c638fe6aea8f"},{"properties":{"displayName":"[Deprecated]: + Ensure that Register with Azure Active Directory is enabled on WEB App","policyType":"BuiltIn","mode":"Indexed","description":"This + policy is a duplicate of the respective Managed Identity policies. Please + use /providers/Microsoft.Authorization/policyDefinitions/2b9ad585-36bc-4615-b300-fd4435808332 + instead.","metadata":{"version":"1.0.0-deprecated","category":"App Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.managedServiceIdentityId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/aa81768c-cb87-4ce2-bfaa-00baa10d760c","type":"Microsoft.Authorization/policyDefinitions","name":"aa81768c-cb87-4ce2-bfaa-00baa10d760c"},{"properties":{"displayName":"Managed + identity should be used in your Web App","policyType":"BuiltIn","mode":"Indexed","description":"Use + a managed identity for enhanced authentication security","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/managedServiceIdentityId","exists":"true"},{"field":"Microsoft.Web/sites/config/xmanagedServiceIdentityId","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2b9ad585-36bc-4615-b300-fd4435808332","type":"Microsoft.Authorization/policyDefinitions","name":"2b9ad585-36bc-4615-b300-fd4435808332"},{"properties":{"displayName":"Ensure + WEB app has ''Client Certificates (Incoming client certificates)'' set to + ''On''","policyType":"BuiltIn","mode":"Indexed","description":"Client certificates + allow for the app to request a certificate for incoming requests. Only clients + that have a valid certificate will be able to reach the app.","metadata":{"version":"1.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"Microsoft.Web/sites/clientCertEnabled","equals":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5bb220d9-2698-4ee4-8404-b9c30c9df609","type":"Microsoft.Authorization/policyDefinitions","name":"5bb220d9-2698-4ee4-8404-b9c30c9df609"},{"properties":{"displayName":"Ensure + that ''HTTP Version'' is the latest, if used to run the Web app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for HTTP either due to security flaws or to include + additional functionality. Using the latest HTTP version for web apps to take + advantage of security fixes, if any, and/or new functionalities of the newer + version. Currently, this policy only applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"field":"Microsoft.Web/sites/config/web.http20Enabled","Equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8c122334-9d20-4eb8-89ea-ac9a705b74ae","type":"Microsoft.Authorization/policyDefinitions","name":"8c122334-9d20-4eb8-89ea-ac9a705b74ae"},{"properties":{"displayName":"Ensure + that ''Java version'' is the latest, if used as a part of the Web app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Java software either due to security flaws + or to include additional functionality. Using the latest Java version for + web apps is recommended in order to take advantage of security fixes, if any, + and/or new functionalities of the latest version. Currently, this policy only + applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"JavaLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Java version","description":"Latest supported Java version for App Services"},"defaultValue":"11"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"JAVA"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","like":"[concat(''*'', + parameters(''JavaLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/496223c3-ad65-4ecd-878a-bae78737e9ed","type":"Microsoft.Authorization/policyDefinitions","name":"496223c3-ad65-4ecd-878a-bae78737e9ed"},{"properties":{"displayName":"[Deprecated]: + Ensure that ''.NET Framework'' version is the latest, if used as a part of + the Web app","policyType":"BuiltIn","mode":"Indexed","description":"This policy + is not required since Azure App Service automatically updates and maintains + the .NET Framework versions installed on the platform.","metadata":{"version":"1.0.0-deprecated","category":"App + Service","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","existenceCondition":{"field":"Microsoft.Web/sites/config/web.netFrameworkVersion","in":["v3.0","v4.0"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/843664e0-7563-41ee-a9cb-7522c382d2c4","type":"Microsoft.Authorization/policyDefinitions","name":"843664e0-7563-41ee-a9cb-7522c382d2c4"},{"properties":{"displayName":"Ensure + that ''PHP version'' is the latest, if used as a part of the WEB app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for PHP software either due to security flaws + or to include additional functionality. Using the latest PHP version for web + apps is recommended in order to take advantage of security fixes, if any, + and/or new functionalities of the latest version. Currently, this policy only + applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"PHPLatestVersion":{"type":"String","metadata":{"displayName":"Latest + PHP version","description":"Latest supported PHP version for App Services"},"defaultValue":"7.3"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PHP"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PHP|'', + parameters(''PHPLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7261b898-8a84-4db8-9e04-18527132abb3","type":"Microsoft.Authorization/policyDefinitions","name":"7261b898-8a84-4db8-9e04-18527132abb3"},{"properties":{"displayName":"[Preview]: + Network traffic data collection agent should be installed on Linux virtual + machines","policyType":"BuiltIn","mode":"Indexed","description":"Security + Center uses the Microsoft Dependency agent to collect network traffic data + from your Azure virtual machines to enable advanced network protection features + such as traffic visualization on the network map, network hardening recommendations + and specific network threats.","metadata":{"version":"1.0.1-preview","category":"Monitoring","preview":"true"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable Dependency Agent for Linux VMs monitoring"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["14.04.0-LTS","14.04.1-LTS","14.04.5-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["16.04-LTS","16.04.0-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["12-SP2","12-SP3","12-SP4"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"DependencyAgentLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/04c4380f-3fae-46e8-96c9-30193528f602","type":"Microsoft.Authorization/policyDefinitions","name":"04c4380f-3fae-46e8-96c9-30193528f602"},{"properties":{"displayName":"Ensure + that ''Python version'' is the latest, if used as a part of the Web app","policyType":"BuiltIn","mode":"Indexed","description":"Periodically, + newer versions are released for Python software either due to security flaws + or to include additional functionality. Using the latest Python version for + web apps is recommended in order to take advantage of security fixes, if any, + and/or new functionalities of the latest version. Currently, this policy only + applies to Linux web apps.","metadata":{"version":"2.0.0","category":"App + Service"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"WindowsPythonLatestVersion":{"type":"String","metadata":{"displayName":"Latest + Windows Python version","description":"Latest supported Python version for + App Services","deprecated":true},"defaultValue":"3.6"},"LinuxPythonLatestVersion":{"type":"String","metadata":{"displayName":"Linux + Latest Python version","description":"Latest supported Python version for + App Services"},"defaultValue":"3.8"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"},{"field":"kind","contains":"linux"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/config","name":"web","existenceCondition":{"anyOf":[{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","notContains":"PYTHON"},{"field":"Microsoft.Web/sites/config/web.linuxFxVersion","equals":"[concat(''PYTHON|'', + parameters(''LinuxPythonLatestVersion''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7008174a-fd10-4ef0-817e-fc820a951d73","type":"Microsoft.Authorization/policyDefinitions","name":"7008174a-fd10-4ef0-817e-fc820a951d73"},{"properties":{"displayName":"[Preview]: + Network traffic data collection agent should be installed on Windows virtual + machines","policyType":"BuiltIn","mode":"Indexed","description":"Security + Center uses the Microsoft Dependency agent to collect network traffic data + from your Azure virtual machines to enable advanced network protection features + such as traffic visualization on the network map, network hardening recommendations + and specific network threats.","metadata":{"version":"1.0.1-preview","category":"Monitoring","preview":"true"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable Dependency Agent for Windows VMs + monitoring"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"DependencyAgentWindows"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2f2ee1de-44aa-4762-b6bd-0893fc3f306d","type":"Microsoft.Authorization/policyDefinitions","name":"2f2ee1de-44aa-4762-b6bd-0893fc3f306d"},{"properties":{"displayName":"Automation + account variables should be encrypted","policyType":"BuiltIn","mode":"All","description":"It + is important to enable encryption of Automation account variable assets when + storing sensitive data","metadata":{"version":"1.1.0","category":"Automation"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Automation/automationAccounts/variables"},{"field":"Microsoft.Automation/automationAccounts/variables/isEncrypted","notEquals":"true"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3657f5a0-770e-44a3-b44e-9431ba1e9735","type":"Microsoft.Authorization/policyDefinitions","name":"3657f5a0-770e-44a3-b44e-9431ba1e9735"},{"properties":{"displayName":"Diagnostic + logs in Batch accounts should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Batch"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Batch/batchAccounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/428256e6-1fac-4f48-a757-df34c2b3336d","type":"Microsoft.Authorization/policyDefinitions","name":"428256e6-1fac-4f48-a757-df34c2b3336d"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Batch Account to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Batch Account to stream to a regional Event Hub + when any Batch Account which is missing this diagnostic settings is created + or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Batch + Accounts in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Batch/batchAccounts"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Batch/batchAccounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"ServiceLog","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/db51110f-0865-4a6e-b274-e2e07a5b2cd7","type":"Microsoft.Authorization/policyDefinitions","name":"db51110f-0865-4a6e-b274-e2e07a5b2cd7"},{"properties":{"displayName":"Metric + alert rules should be configured on Batch accounts","policyType":"BuiltIn","mode":"Indexed","description":"Audit + configuration of metric alert rules on Batch account to enable the required + metric","metadata":{"version":"1.0.0","category":"Batch"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"metricName":{"type":"String","metadata":{"displayName":"Metric + name","description":"The metric name that an alert rule must be enabled on"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Batch/batchAccounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/alertRules","existenceScope":"Subscription","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/alertRules/isEnabled","equals":"true"},{"field":"Microsoft.Insights/alertRules/condition.dataSource.metricName","equals":"[parameters(''metricName'')]"},{"field":"Microsoft.Insights/alertRules/condition.dataSource.resourceUri","equals":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourcegroups/'', resourceGroup().name, + ''/providers/Microsoft.Batch/batchAccounts/'', field(''name''))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/26ee67a2-f81a-4ba8-b9ce-8550bd5ee1a7","type":"Microsoft.Authorization/policyDefinitions","name":"26ee67a2-f81a-4ba8-b9ce-8550bd5ee1a7"},{"properties":{"displayName":"Virtual + machines should be migrated to new Azure Resource Manager resources","policyType":"BuiltIn","mode":"All","description":"Use + new Azure Resource Manager for your virtual machines to provide security enhancements + such as: stronger access control (RBAC), better auditing, Azure Resource Manager + based deployment and governance, access to managed identities, access to key + vault for secrets, Azure AD-based authentication and support for tags and + resource groups for easier security management","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.ClassicCompute/virtualMachines","Microsoft.Compute/virtualMachines"]},{"value":"[field(''type'')]","equals":"Microsoft.ClassicCompute/virtualMachines"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1d84d5fb-01f6-4d12-ba4f-4a26081d403d","type":"Microsoft.Authorization/policyDefinitions","name":"1d84d5fb-01f6-4d12-ba4f-4a26081d403d"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Batch Account to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Batch Account to stream to a regional Log Analytics + workspace when any Batch Account which is missing this diagnostic settings + is created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Batch/batchAccounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Batch/batchAccounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"ServiceLog","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c84e5349-db6d-4769-805e-e14037dab9b5","type":"Microsoft.Authorization/policyDefinitions","name":"c84e5349-db6d-4769-805e-e14037dab9b5"},{"properties":{"displayName":"Storage + accounts should be migrated to new Azure Resource Manager resources","policyType":"BuiltIn","mode":"All","description":"Use + new Azure Resource Manager for your storage accounts to provide security enhancements + such as: stronger access control (RBAC), better auditing, Azure Resource Manager + based deployment and governance, access to managed identities, access to key + vault for secrets, Azure AD-based authentication and support for tags and + resource groups for easier security management","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.ClassicStorage/storageAccounts","Microsoft.Storage/StorageAccounts"]},{"value":"[field(''type'')]","equals":"Microsoft.ClassicStorage/storageAccounts"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/37e0d2fe-28a5-43d6-a273-67d37d1f5606","type":"Microsoft.Authorization/policyDefinitions","name":"37e0d2fe-28a5-43d6-a273-67d37d1f5606"},{"properties":{"displayName":"Public + network access should be disabled for Cognitive Services accounts","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Cognitive Services account in your environment with public + network access enabled. Public network access should be disabled so that only + connections from private endpoints are allowed.","metadata":{"version":"1.0.0","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"field":"Microsoft.CognitiveServices/accounts/publicNetworkAccess","notEquals":"Disabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0725b4dd-7e76-479c-a735-68e7ee23d5ca","type":"Microsoft.Authorization/policyDefinitions","name":"0725b4dd-7e76-479c-a735-68e7ee23d5ca"},{"properties":{"displayName":"Cognitive + Services accounts should use customer owned storage or enable data encryption.","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Cognitive Services account not using customer owned storage + nor data encryption. For each Cognitive Services account with storage, use + either customer owned storage or enable data encryption.","metadata":{"version":"1.0.0","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"count":{"field":"Microsoft.CognitiveServices/accounts/userOwnedStorage[*]"},"less":1},{"field":"Microsoft.CognitiveServices/accounts/encryption.keySource","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/11566b39-f7f7-4b82-ab06-68d8700eb0a4","type":"Microsoft.Authorization/policyDefinitions","name":"11566b39-f7f7-4b82-ab06-68d8700eb0a4"},{"properties":{"displayName":"Cognitive + Services accounts should restrict network access","policyType":"BuiltIn","mode":"Indexed","description":"Network + access to Cognitive Services accounts should be restricted. Configure network + rules so only applications from allowed networks can access the Cognitive + Services account. To allow connections from specific internet or on-premises + clients, access can be granted to traffic from specific Azure virtual networks + or to public internet IP address ranges.","metadata":{"version":"1.0.0","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"field":"Microsoft.CognitiveServices/accounts/networkAcls.defaultAction","notEquals":"Deny"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/037eea7a-bd0a-46c5-9a66-03aea78705d3","type":"Microsoft.Authorization/policyDefinitions","name":"037eea7a-bd0a-46c5-9a66-03aea78705d3"},{"properties":{"displayName":"Cognitive + Services accounts should enable data encryption","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Cognitive Services account not using data encryption. For + each Cognitive Services account with storage, should enable data encryption + with either customer managed or Microsoft managed key.","metadata":{"version":"1.0.0","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"field":"Microsoft.CognitiveServices/accounts/encryption.keySource","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2bdd0062-9d75-436e-89df-487dd8e4b3c7","type":"Microsoft.Authorization/policyDefinitions","name":"2bdd0062-9d75-436e-89df-487dd8e4b3c7"},{"properties":{"displayName":"Cognitive + Services accounts should use customer owned storage","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Cognitive Services account not using customer owned storage.","metadata":{"version":"1.0.0","category":"Cognitive + Services"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.CognitiveServices/accounts"},{"count":{"field":"Microsoft.CognitiveServices/accounts/userOwnedStorage[*]"},"less":1}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/46aa9b05-0e60-4eae-a88b-1e9d374fa515","type":"Microsoft.Authorization/policyDefinitions","name":"46aa9b05-0e60-4eae-a88b-1e9d374fa515"},{"properties":{"displayName":"Azure + Cosmos DB allowed locations","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables you to restrict the locations your organization can specify + when deploying Azure Cosmos DB resources. Use to enforce your geo-compliance + requirements.","metadata":{"version":"1.0.0","category":"Cosmos DB"},"parameters":{"listOfAllowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying Azure Cosmos DB resources.","strongType":"location"}},"policyEffect":{"type":"String","metadata":{"displayName":"Policy + Effect","description":"The desired effect of the policy."},"allowedValues":["deny","audit","disabled"],"defaultValue":"deny"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DocumentDB/databaseAccounts"},{"count":{"field":"Microsoft.DocumentDB/databaseAccounts/Locations[*]","where":{"value":"[replace(toLower(first(field(''Microsoft.DocumentDB/databaseAccounts/Locations[*].locationName''))), + '' '', '''')]","in":"[parameters(''listOfAllowedLocations'')]"}},"notEquals":"[length(field(''Microsoft.DocumentDB/databaseAccounts/Locations[*]''))]"}]},"then":{"effect":"[parameters(''policyEffect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0473574d-2d43-4217-aefe-941fcdf7e684","type":"Microsoft.Authorization/policyDefinitions","name":"0473574d-2d43-4217-aefe-941fcdf7e684"},{"properties":{"displayName":"Azure + Cosmos DB key based metadata write access should be disabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables you to ensure all Azure Cosmos DB accounts disable key based + metadata write access.","metadata":{"version":"1.0.0","category":"Cosmos DB"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DocumentDB/databaseAccounts"},{"field":"Microsoft.DocumentDB/databaseAccounts/disableKeyBasedMetadataWriteAccess","notEquals":true}]},"then":{"effect":"append","details":[{"field":"Microsoft.DocumentDB/databaseAccounts/disableKeyBasedMetadataWriteAccess","value":true}]}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4750c32b-89c0-46af-bfcb-2e4541a818d5","type":"Microsoft.Authorization/policyDefinitions","name":"4750c32b-89c0-46af-bfcb-2e4541a818d5"},{"properties":{"displayName":"Azure + Cosmos DB throughput should be limited","policyType":"BuiltIn","mode":"All","description":"This + policy enables you to restrict the maximum throughput your organization can + specify when creating Azure Cosmos DB databases and containers through the + resource provider. It blocks the creation of autoscale resources.","metadata":{"version":"1.0.0","category":"Cosmos + DB"},"parameters":{"throughputMax":{"type":"Integer","metadata":{"displayName":"Max + RUs","description":"The maximum throughput (RU/s) that can be assigned to + a container via the Resource Provider during create or update."}},"effect":{"type":"String","metadata":{"displayName":"Policy + Effect","description":"The desired effect of the policy."},"allowedValues":["audit","deny","disabled"],"defaultValue":"deny"}},"policyRule":{"if":{"allOf":[{"anyOf":[{"field":"type","like":"Microsoft.DocumentDB/databaseAccounts/*/throughputSettings"},{"field":"type","in":["Microsoft.DocumentDB/databaseAccounts/sqlDatabases","Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers","Microsoft.DocumentDB/databaseAccounts/mongodbDatabases","Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections","Microsoft.DocumentDB/databaseAccounts/gremlinDatabases","Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs","Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces","Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables","Microsoft.DocumentDB/databaseAccounts/tables"]}]},{"anyOf":[{"value":"[requestContext().apiVersion]","less":"2019-08-01"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"},{"value":"[if(equals(field(''Microsoft.DocumentDB/databaseAccounts/tables/options.throughput''), + ''''), 0, int(field(''Microsoft.DocumentDB/databaseAccounts/tables/options.throughput'')))]","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/tables/options","containsKey":"ProvisionedThroughputSettings"},{"field":"Microsoft.DocumentDB/databaseAccounts/tables/throughputSettings/default.resource.throughput","greater":"[parameters(''throughputMax'')]"},{"field":"Microsoft.DocumentDB/databaseAccounts/tables/throughputSettings/default.resource.provisionedThroughputSettings","exists":"true"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b7ef78e-a035-4f23-b9bd-aff122a1b1cf","type":"Microsoft.Authorization/policyDefinitions","name":"0b7ef78e-a035-4f23-b9bd-aff122a1b1cf"},{"properties":{"displayName":"Custom + subscription owner roles should not exist","policyType":"BuiltIn","mode":"All","description":"This + policy ensures that no custom subscription owner roles exist.","metadata":{"version":"2.0.0","category":"General"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Authorization/roleDefinitions"},{"field":"Microsoft.Authorization/roleDefinitions/type","equals":"CustomRole"},{"anyOf":[{"not":{"field":"Microsoft.Authorization/roleDefinitions/permissions[*].actions[*]","notEquals":"*"}},{"not":{"field":"Microsoft.Authorization/roleDefinitions/permissions.actions[*]","notEquals":"*"}}]},{"anyOf":[{"not":{"field":"Microsoft.Authorization/roleDefinitions/assignableScopes[*]","notIn":["[concat(subscription().id,''/'')]","[subscription().id]","/"]}},{"not":{"field":"Microsoft.Authorization/roleDefinitions/assignableScopes[*]","notLike":"/providers/Microsoft.Management/*"}}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/10ee2ea2-fb4d-45b8-a7e9-a2e770044cd9","type":"Microsoft.Authorization/policyDefinitions","name":"10ee2ea2-fb4d-45b8-a7e9-a2e770044cd9"},{"properties":{"displayName":"Azure + Cosmos DB accounts should have firewall rules","policyType":"BuiltIn","mode":"All","description":"Firewall + rules should be defined on your Azure Cosmos DB accounts to prevent traffic + from unauthorized sources. Accounts that have at least one IP rule defined + with the virtual network filter enabled are deemed compliant. Accounts disabling + public access are also deemed compliant.","metadata":{"version":"1.0.1","category":"Cosmos + DB"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Policy + Effect","description":"The desired effect of the policy."},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Deny"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DocumentDB/databaseAccounts"},{"anyOf":[{"field":"Microsoft.DocumentDB/databaseAccounts/publicNetworkAccess","exists":"false"},{"field":"Microsoft.DocumentDB/databaseAccounts/publicNetworkAccess","equals":"Enabled"}]},{"anyOf":[{"field":"Microsoft.DocumentDB/databaseAccounts/isVirtualNetworkFilterEnabled","exists":"false"},{"field":"Microsoft.DocumentDB/databaseAccounts/isVirtualNetworkFilterEnabled","equals":"false"},{"allOf":[{"anyOf":[{"field":"Microsoft.DocumentDB/databaseAccounts/ipRules","exists":"false"},{"count":{"field":"Microsoft.DocumentDB/databaseAccounts/ipRules[*]"},"equals":0}]},{"anyOf":[{"field":"Microsoft.DocumentDB/databaseAccounts/ipRangeFilter","exists":"false"},{"field":"Microsoft.DocumentDB/databaseAccounts/ipRangeFilter","equals":""}]}]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/862e97cf-49fc-4a5c-9de4-40d4e2e7c8eb","type":"Microsoft.Authorization/policyDefinitions","name":"862e97cf-49fc-4a5c-9de4-40d4e2e7c8eb"},{"properties":{"displayName":"Diagnostic + logs in Data Lake Analytics should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Data + Lake"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DataLakeAnalytics/accounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c95c74d9-38fe-4f0d-af86-0c7d626a315c","type":"Microsoft.Authorization/policyDefinitions","name":"c95c74d9-38fe-4f0d-af86-0c7d626a315c"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Data Lake Storage Gen1 to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Data Lake Storage Gen1 to stream to a regional + Event Hub when any Data Lake Storage Gen1 which is missing this diagnostic + settings is created or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Data + Lake Storage in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DataLakeStore/accounts"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.DataLakeStore/accounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Audit","enabled":"[parameters(''logsEnabled'')]"},{"category":"Requests","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e8d096bc-85de-4c5f-8cfb-857bd1b9d62d","type":"Microsoft.Authorization/policyDefinitions","name":"e8d096bc-85de-4c5f-8cfb-857bd1b9d62d"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Data Lake Analytics to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Data Lake Analytics to stream to a regional Log + Analytics workspace when any Data Lake Analytics which is missing this diagnostic + settings is created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DataLakeAnalytics/accounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.DataLakeAnalytics/accounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Audit","enabled":"[parameters(''logsEnabled'')]"},{"category":"Requests","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d56a5a7c-72d7-42bc-8ceb-3baf4c0eae03","type":"Microsoft.Authorization/policyDefinitions","name":"d56a5a7c-72d7-42bc-8ceb-3baf4c0eae03"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Data Lake Storage Gen1 to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Data Lake Storage Gen1 to stream to a regional + Log Analytics workspace when any Data Lake Storage Gen1 which is missing this + diagnostic settings is created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DataLakeStore/accounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.DataLakeStore/accounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Audit","enabled":"[parameters(''logsEnabled'')]"},{"category":"Requests","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/25763a0a-5783-4f14-969e-79d4933eb74b","type":"Microsoft.Authorization/policyDefinitions","name":"25763a0a-5783-4f14-969e-79d4933eb74b"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Data Lake Analytics to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Data Lake Analytics to stream to a regional Event + Hub when any Data Lake Analytics which is missing this diagnostic settings + is created or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Data + Lake Analytics in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DataLakeAnalytics/accounts"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.DataLakeAnalytics/accounts/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Audit","enabled":"[parameters(''logsEnabled'')]"},{"category":"Requests","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4daddf25-4823-43d4-88eb-2419eb6dcc08","type":"Microsoft.Authorization/policyDefinitions","name":"4daddf25-4823-43d4-88eb-2419eb6dcc08"},{"properties":{"displayName":"Diagnostic + logs in Azure Data Lake Store should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Data + Lake"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DataLakeStore/accounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/057ef27e-665e-4328-8ea3-04b3122bd9fb","type":"Microsoft.Authorization/policyDefinitions","name":"057ef27e-665e-4328-8ea3-04b3122bd9fb"},{"properties":{"displayName":"[Deprecated]: + Allow resource creation if ''department'' tag set","policyType":"BuiltIn","mode":"Indexed","description":"Allows + resource creation only if the ''department'' tag is set","metadata":{"version":"1.0.0-deprecated","category":"Tags","deprecated":true},"parameters":{},"policyRule":{"if":{"not":{"field":"tags","containsKey":"department"}},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cd8dc879-a2ae-43c3-8211-1877c5755064","type":"Microsoft.Authorization/policyDefinitions","name":"cd8dc879-a2ae-43c3-8211-1877c5755064"},{"properties":{"displayName":"Deploy + Dependency agent for Linux virtual machine scale sets","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Dependency agent for Linux virtual machine scale sets if the VM Image (OS) + is in the list defined and the agent is not installed. Note: if your scale + set upgradePolicy is set to Manual, you need to apply the extension to the + all virtual machines in the set by calling upgrade on them. In CLI this would + be az vmss update-instances.","metadata":{"version":"1.3.0","category":"Monitoring"},"parameters":{"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["14.04.0-LTS","14.04.1-LTS","14.04.5-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["16.04-LTS","16.04.0-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["12-SP2","12-SP3","12-SP4"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"DependencyAgentLinux"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"variables":{"vmExtensionName":"DependencyAgentLinux","vmExtensionPublisher":"Microsoft.Azure.Monitoring.DependencyAgent","vmExtensionType":"DependencyAgentLinux","vmExtensionTypeHandlerVersion":"9.7"},"resources":[{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","apiVersion":"2018-06-01","location":"[parameters(''location'')]","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for: '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/765266ab-e40e-4c61-bcb2-5a5275d0b7c0","type":"Microsoft.Authorization/policyDefinitions","name":"765266ab-e40e-4c61-bcb2-5a5275d0b7c0"},{"properties":{"displayName":"Deploy + Dependency agent for Linux virtual machines","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Dependency agent for Linux virtual machines if the VM Image (OS) is in the + list defined and the agent is not installed.","metadata":{"version":"1.3.0","category":"Monitoring"},"parameters":{"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["14.04.0-LTS","14.04.1-LTS","14.04.5-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["16.04-LTS","16.04.0-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["12-SP2","12-SP3","12-SP4"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"DependencyAgentLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"variables":{"vmExtensionName":"DependencyAgentLinux","vmExtensionPublisher":"Microsoft.Azure.Monitoring.DependencyAgent","vmExtensionType":"DependencyAgentLinux","vmExtensionTypeHandlerVersion":"9.6"},"resources":[{"type":"Microsoft.Compute/virtualMachines/extensions","name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","apiVersion":"2018-06-01","location":"[parameters(''location'')]","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for VM'', '': '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4da21710-ce6f-4e06-8cdb-5cc4c93ffbee","type":"Microsoft.Authorization/policyDefinitions","name":"4da21710-ce6f-4e06-8cdb-5cc4c93ffbee"},{"properties":{"displayName":"Audit + Dependency agent deployment - VM Image (OS) unlisted","policyType":"BuiltIn","mode":"Indexed","description":"Reports + VMs as non-compliant if the VM Image (OS) is not in the list defined and the + agent is not installed. The list of OS images will be updated over time as + support is updated.","metadata":{"version":"1.0.1","category":"Monitoring"},"parameters":{"listOfImageIdToInclude_windows":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]},"listOfImageIdToInclude_linux":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"not":{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_windows'')]"},{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_linux'')]"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["12-SP2","12-SP3","12-SP4"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["14.04.0-LTS","14.04.1-LTS","14.04.5-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["16.04-LTS","16.04.0-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["Centos","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/11ac78e3-31bc-4f0c-8434-37ab963cea07","type":"Microsoft.Authorization/policyDefinitions","name":"11ac78e3-31bc-4f0c-8434-37ab963cea07"},{"properties":{"displayName":"Deploy + Dependency agent for Windows virtual machines","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Dependency agent for Windows virtual machines if the VM Image (OS) is in the + list defined and the agent is not installed. The list of OS images will be + updated over time as support is updated.","metadata":{"version":"1.3.0","category":"Monitoring"},"parameters":{"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"DependencyAgentWindows"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"variables":{"vmExtensionName":"DependencyAgentWindows","vmExtensionPublisher":"Microsoft.Azure.Monitoring.DependencyAgent","vmExtensionType":"DependencyAgentWindows","vmExtensionTypeHandlerVersion":"9.6"},"resources":[{"type":"Microsoft.Compute/virtualMachines/extensions","name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","apiVersion":"2018-06-01","location":"[parameters(''location'')]","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for VM'', '': '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1c210e94-a481-4beb-95fa-1571b434fb04","type":"Microsoft.Authorization/policyDefinitions","name":"1c210e94-a481-4beb-95fa-1571b434fb04"},{"properties":{"displayName":"Audit + diagnostic setting","policyType":"BuiltIn","mode":"All","description":"Audit + diagnostic setting for selected resource types","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"listOfResourceTypes":{"type":"Array","metadata":{"displayName":"Resource + Types","strongType":"resourceTypes"}}},"policyRule":{"if":{"field":"type","in":"[parameters(''listOfResourceTypes'')]"},"then":{"effect":"AuditIfNotExists","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7f89b1eb-583c-429a-8828-af049802c1d9","type":"Microsoft.Authorization/policyDefinitions","name":"7f89b1eb-583c-429a-8828-af049802c1d9"},{"properties":{"displayName":"Deploy + Dependency agent for Windows virtual machine scale sets","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Dependency agent for Windows virtual machine scale sets if the VM Image (OS) + is in the list defined and the agent is not installed. The list of OS images + will be updated over time as support is updated. Note: if your scale set upgradePolicy + is set to Manual, you need to apply the extension to the all virtual machines + in the set by calling upgrade on them. In CLI this would be az vmss update-instances.","metadata":{"version":"1.3.0","category":"Monitoring"},"parameters":{"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"DependencyAgentWindows"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"variables":{"vmExtensionName":"DependencyAgentWindows","vmExtensionPublisher":"Microsoft.Azure.Monitoring.DependencyAgent","vmExtensionType":"DependencyAgentWindows","vmExtensionTypeHandlerVersion":"9.7"},"resources":[{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","apiVersion":"2018-06-01","location":"[parameters(''location'')]","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for: '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3be22e3b-d919-47aa-805e-8985dbeb0ad9","type":"Microsoft.Authorization/policyDefinitions","name":"3be22e3b-d919-47aa-805e-8985dbeb0ad9"},{"properties":{"displayName":"Deploy + Threat Detection on SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy ensures that Threat Detection is enabled on SQL Servers.","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"Default","existenceCondition":{"field":"Microsoft.Sql/securityAlertPolicies.state","equals":"Enabled"},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"serverName":{"type":"string"}},"variables":{},"resources":[{"name":"[concat(parameters(''serverName''), + ''/Default'')]","type":"Microsoft.Sql/servers/securityAlertPolicies","apiVersion":"2017-03-01-preview","properties":{"state":"Enabled","emailAccountAdmins":false}}]},"parameters":{"serverName":{"value":"[field(''name'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/36d49e87-48c4-4f2e-beed-ba4ed02b71f5","type":"Microsoft.Authorization/policyDefinitions","name":"36d49e87-48c4-4f2e-beed-ba4ed02b71f5"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Network Security Groups","policyType":"BuiltIn","mode":"Indexed","description":"This + policy automatically deploys diagnostic settings to network security groups. + A storage account with name ''{storagePrefixParameter}{NSGLocation}'' will + be automatically created.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"storagePrefix":{"type":"String","metadata":{"displayName":"Storage + Account Prefix for Regional Storage Account","description":"This prefix will + be combined with the network security group location to form the created storage + account name."}},"rgName":{"type":"String","metadata":{"displayName":"Resource + Group Name for Storage Account (must exist)","description":"The resource group + that the storage account will be created in. This resource group must already + exist.","strongType":"ExistingResourceGroups"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"setbypolicy","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"location":{"type":"string"},"storagePrefix":{"type":"string"},"nsgName":{"type":"string"},"rgName":{"type":"string"}},"variables":{"storageDeployName":"[concat(''policyStorage_'', + uniqueString(parameters(''location''), parameters(''nsgName'')))]"},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/providers/diagnosticSettings","name":"[concat(parameters(''nsgName''),''/Microsoft.Insights/setbypolicy'')]","apiVersion":"2017-05-01-preview","location":"[parameters(''location'')]","dependsOn":["[variables(''storageDeployName'')]"],"properties":{"storageAccountId":"[reference(variables(''storageDeployName'')).outputs.storageAccountId.value]","logs":[{"category":"NetworkSecurityGroupEvent","enabled":true,"retentionPolicy":{"enabled":false,"days":0}},{"category":"NetworkSecurityGroupRuleCounter","enabled":true,"retentionPolicy":{"enabled":false,"days":0}}]}},{"apiVersion":"2017-05-10","name":"[variables(''storageDeployName'')]","type":"Microsoft.Resources/deployments","resourceGroup":"[parameters(''rgName'')]","properties":{"mode":"incremental","parameters":{"location":{"value":"[parameters(''location'')]"},"storagePrefix":{"value":"[parameters(''storagePrefix'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json","contentVersion":"1.0.0.0","parameters":{"location":{"type":"string"},"storagePrefix":{"type":"string"}},"resources":[{"apiVersion":"2017-06-01","type":"Microsoft.Storage/storageAccounts","name":"[concat(parameters(''storageprefix''), + parameters(''location''))]","sku":{"name":"Standard_LRS","tier":"Standard"},"kind":"Storage","location":"[parameters(''location'')]","tags":{"created-by":"policy"},"scale":null,"properties":{"networkAcls":{"bypass":"AzureServices","defaultAction":"Allow","ipRules":[],"virtualNetworkRules":[]},"supportsHttpsTrafficOnly":true}}],"outputs":{"storageAccountId":{"type":"string","value":"[resourceId(parameters(''rgName''), + ''Microsoft.Storage/storageAccounts'',concat(parameters(''storagePrefix''), + parameters(''location'')))]"}}}}}]},"parameters":{"location":{"value":"[field(''location'')]"},"storagePrefix":{"value":"[parameters(''storagePrefix'')]"},"rgName":{"value":"[parameters(''rgName'')]"},"nsgName":{"value":"[field(''name'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c9c29499-c1d1-4195-99bd-2ec9e3a9dc89","type":"Microsoft.Authorization/policyDefinitions","name":"c9c29499-c1d1-4195-99bd-2ec9e3a9dc89"},{"properties":{"displayName":"Audit + Dependency agent deployment in virtual machine scale sets - VM Image (OS) + unlisted","policyType":"BuiltIn","mode":"Indexed","description":"Reports virtual + machine scale sets as non-compliant if the VM Image (OS) is not in the list + defined and the agent is not installed. The list of OS images will be updated + over time as support is updated.","metadata":{"version":"1.0.1","category":"Monitoring"},"parameters":{"listOfImageIdToInclude_windows":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]},"listOfImageIdToInclude_linux":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"not":{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_windows'')]"},{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_linux'')]"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["12-SP2","12-SP3","12-SP4"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","in":["14.04.0-LTS","14.04.1-LTS","14.04.5-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["16.04-LTS","16.04.0-LTS"]},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS"]}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["Centos","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","existenceCondition":{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Monitoring.DependencyAgent"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e2dd799a-a932-4e9d-ac17-d473bc3c6c10","type":"Microsoft.Authorization/policyDefinitions","name":"e2dd799a-a932-4e9d-ac17-d473bc3c6c10"},{"properties":{"displayName":"[Deprecated]: + Allow resource creation if ''environment'' tag value in allowed values","policyType":"BuiltIn","mode":"Indexed","description":"Allows + resource creation if the ''environment'' tag is set to one of the following + values: production, dev, test, staging","metadata":{"version":"1.0.0-deprecated","category":"Tags","deprecated":true},"parameters":{},"policyRule":{"if":{"not":{"field":"tags[''environment'']","in":["production","dev","test","staging"]}},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ac7e5fc0-c029-4b12-91d4-a8500ce697f9","type":"Microsoft.Authorization/policyDefinitions","name":"ac7e5fc0-c029-4b12-91d4-a8500ce697f9"},{"properties":{"displayName":"Diagnostic + logs in Event Hub should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Event + Hub"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.EventHub/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/83a214f7-d01a-484b-91a9-ed54470c9a6a","type":"Microsoft.Authorization/policyDefinitions","name":"83a214f7-d01a-484b-91a9-ed54470c9a6a"},{"properties":{"displayName":"Authorization + rules on the Event Hub instance should be defined","policyType":"BuiltIn","mode":"All","description":"Audit + existence of authorization rules on Event Hub entities to grant least-privileged + access","metadata":{"version":"1.0.0","category":"Event Hub"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.EventHub/namespaces/eventhubs"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.EventHub/namespaces/eventHubs/authorizationRules"}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f4826e5f-6a27-407c-ae3e-9582eb39891d","type":"Microsoft.Authorization/policyDefinitions","name":"f4826e5f-6a27-407c-ae3e-9582eb39891d"},{"properties":{"displayName":"All + authorization rules except RootManageSharedAccessKey should be removed from + Event Hub namespace","policyType":"BuiltIn","mode":"All","description":"Event + Hub clients should not use a namespace level access policy that provides access + to all queues and topics in a namespace. To align with the least privilege + security model, you should create access policies at the entity level for + queues and topics to provide access to only the specific entity","metadata":{"version":"1.0.1","category":"Event + Hub"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.EventHub/namespaces/authorizationRules"},{"field":"name","notEquals":"RootManageSharedAccessKey"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b278e460-7cfc-4451-8294-cccc40a940d7","type":"Microsoft.Authorization/policyDefinitions","name":"b278e460-7cfc-4451-8294-cccc40a940d7"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Event Hub to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Event Hub to stream to a regional Event Hub when + any Event Hub which is missing this diagnostic settings is created or updated.","metadata":{"version":"2.1.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Destination Location","description":"The location the Event Hub that will + get diagnostic data resides in. Only source Event Hubs in this location will + be linked to this destination Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.EventHub/namespaces"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.EventHub/namespaces/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"ArchiveLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"OperationalLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"AutoScaleLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"KafkaCoordinatorLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"KafkaUserErrorLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"EventHubVNetConnectionEvent","enabled":"[parameters(''logsEnabled'')]"},{"category":"CustomerManagedKeyUserLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef7b61ef-b8e4-4c91-8e78-6946c6b0023f","type":"Microsoft.Authorization/policyDefinitions","name":"ef7b61ef-b8e4-4c91-8e78-6946c6b0023f"},{"properties":{"displayName":"Geo-redundant + backup should be enabled for Azure Database for MariaDB","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Database for MariaDB allows you to choose the redundancy option for your database + server. It can be set to a geo-redundant backup storage in which the data + is not only stored within the region in which your server is hosted, but is + also replicated to a paired region to provide recovery option in case of a + region failure. Configuring geo-redundant storage for backup is only allowed + during server create.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforMariaDB/servers"},{"field":"Microsoft.DBforMariaDB/servers/storageProfile.geoRedundantBackup","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0ec47710-77ff-4a3d-9181-6aa50af424d0","type":"Microsoft.Authorization/policyDefinitions","name":"0ec47710-77ff-4a3d-9181-6aa50af424d0"},{"properties":{"displayName":"Geo-redundant + backup should be enabled for Azure Database for MySQL","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Database for MySQL allows you to choose the redundancy option for your database + server. It can be set to a geo-redundant backup storage in which the data + is not only stored within the region in which your server is hosted, but is + also replicated to a paired region to provide recovery option in case of a + region failure. Configuring geo-redundant storage for backup is only allowed + during server create.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforMySQL/servers"},{"field":"Microsoft.DBforMySQL/servers/storageProfile.geoRedundantBackup","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/82339799-d096-41ae-8538-b108becf0970","type":"Microsoft.Authorization/policyDefinitions","name":"82339799-d096-41ae-8538-b108becf0970"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Event Hub to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Event Hub to stream to a regional Log Analytics + workspace when any Event Hub which is missing this diagnostic settings is + created or updated.","metadata":{"version":"1.1.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.EventHub/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.EventHub/namespaces/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"ArchiveLogs","enabled":true,"retentionPolicy":{"enabled":false,"days":0}},{"category":"OperationalLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"AutoScaleLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"KafkaCoordinatorLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"KafkaUserErrorLogs","enabled":"[parameters(''logsEnabled'')]"},{"category":"EventHubVNetConnectionEvent","enabled":"[parameters(''logsEnabled'')]"},{"category":"CustomerManagedKeyUserLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1f6e93e8-6b31-41b1-83f6-36e449a42579","type":"Microsoft.Authorization/policyDefinitions","name":"1f6e93e8-6b31-41b1-83f6-36e449a42579"},{"properties":{"displayName":"Geo-redundant + backup should be enabled for Azure Database for PostgreSQL","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Database for PostgreSQL allows you to choose the redundancy option for your + database server. It can be set to a geo-redundant backup storage in which + the data is not only stored within the region in which your server is hosted, + but is also replicated to a paired region to provide recovery option in case + of a region failure. Configuring geo-redundant storage for backup is only + allowed during server create.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},{"field":"Microsoft.DBforPostgreSQL/servers/storageProfile.geoRedundantBackup","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/48af4db5-9b8b-401c-8e74-076be876a430","type":"Microsoft.Authorization/policyDefinitions","name":"48af4db5-9b8b-401c-8e74-076be876a430"},{"properties":{"displayName":"Geo-redundant + storage should be enabled for Storage Accounts","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Storage Account with geo-redundant storage not enabled.","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"not":{"field":"Microsoft.Storage/storageAccounts/sku.name","in":["Standard_GRS","Standard_RAGRS","Standard_GZRS","Standard_RAGZRS"]}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bf045164-79ba-4215-8f95-f8048dc1780b","type":"Microsoft.Authorization/policyDefinitions","name":"bf045164-79ba-4215-8f95-f8048dc1780b"},{"properties":{"displayName":"Inherit + a tag from the subscription","policyType":"BuiltIn","mode":"Indexed","description":"Adds + or replaces the specified tag and value from the containing subscription when + any resource is created or updated. Existing resources can be remediated by + triggering a remediation task.","metadata":{"category":"Tags","version":"1.0.0"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[subscription().tags[parameters(''tagName'')]]"},{"value":"[subscription().tags[parameters(''tagName'')]]","notEquals":""}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[subscription().tags[parameters(''tagName'')]]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b27a0cbd-a167-4dfa-ae64-4337be671140","type":"Microsoft.Authorization/policyDefinitions","name":"b27a0cbd-a167-4dfa-ae64-4337be671140"},{"properties":{"displayName":"Inherit + a tag from the subscription if missing","policyType":"BuiltIn","mode":"Indexed","description":"Adds + the specified tag with its value from the containing subscription when any + resource missing this tag is created or updated. Existing resources can be + remediated by triggering a remediation task. If the tag exists with a different + value it will not be changed.","metadata":{"category":"Tags","version":"1.0.0"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[subscription().tags[parameters(''tagName'')]]","notEquals":""}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[subscription().tags[parameters(''tagName'')]]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/40df99da-1232-49b1-a39a-6da8d878f469","type":"Microsoft.Authorization/policyDefinitions","name":"40df99da-1232-49b1-a39a-6da8d878f469"},{"properties":{"displayName":"Not + allowed resource types","policyType":"BuiltIn","mode":"All","description":"This + policy enables you to specify the resource types that your organization cannot + deploy.","metadata":{"version":"1.0.0","category":"General"},"parameters":{"listOfResourceTypesNotAllowed":{"type":"Array","metadata":{"description":"The + list of resource types that cannot be deployed.","displayName":"Not allowed + resource types","strongType":"resourceTypes"}}},"policyRule":{"if":{"field":"type","in":"[parameters(''listOfResourceTypesNotAllowed'')]"},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6c112d4e-5bc7-47ae-a041-ea2d9dccd749","type":"Microsoft.Authorization/policyDefinitions","name":"6c112d4e-5bc7-47ae-a041-ea2d9dccd749"},{"properties":{"displayName":"Append + a tag and its value from the resource group","policyType":"BuiltIn","mode":"Indexed","description":"Appends + the specified tag with its value from the resource group when any resource + which is missing this tag is created or updated. Does not modify the tags + of resources created before this policy was applied until those resources + are changed. New ''modify'' effect policies are available that support remediation + of tags on existing resources (see https://aka.ms/modifydoc).","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagName'')]]","notEquals":""}]},"then":{"effect":"append","details":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[resourceGroup().tags[parameters(''tagName'')]]"}]}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9ea02ca2-71db-412d-8b00-7c7ca9fcd32d","type":"Microsoft.Authorization/policyDefinitions","name":"9ea02ca2-71db-412d-8b00-7c7ca9fcd32d"},{"properties":{"displayName":"Inherit + a tag from the resource group if missing","policyType":"BuiltIn","mode":"Indexed","description":"Adds + the specified tag with its value from the parent resource group when any resource + missing this tag is created or updated. Existing resources can be remediated + by triggering a remediation task. If the tag exists with a different value + it will not be changed.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagName'')]]","notEquals":""}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[resourceGroup().tags[parameters(''tagName'')]]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ea3f2387-9b95-492a-a190-fcdc54f7b070","type":"Microsoft.Authorization/policyDefinitions","name":"ea3f2387-9b95-492a-a190-fcdc54f7b070"},{"properties":{"displayName":"Diagnostic + logs in Key Vault should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Key + Vault"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.KeyVault/vaults"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cf820ca0-f99e-4f3e-84fb-66e913812d21","type":"Microsoft.Authorization/policyDefinitions","name":"cf820ca0-f99e-4f3e-84fb-66e913812d21"},{"properties":{"displayName":"Inherit + a tag from the resource group","policyType":"BuiltIn","mode":"Indexed","description":"Adds + or replaces the specified tag and value from the parent resource group when + any resource is created or updated. Existing resources can be remediated by + triggering a remediation task.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[resourceGroup().tags[parameters(''tagName'')]]"},{"value":"[resourceGroup().tags[parameters(''tagName'')]]","notEquals":""}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[resourceGroup().tags[parameters(''tagName'')]]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cd3aa116-8754-49c9-a813-ad46512ece54","type":"Microsoft.Authorization/policyDefinitions","name":"cd3aa116-8754-49c9-a813-ad46512ece54"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Key Vault to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Key Vault to stream to a regional Event Hub when + any Key Vault which is missing this diagnostic settings is created or updated.","metadata":{"version":"2.0.0","category":"Key + Vault"},"parameters":{"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Key + Vaults in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vaultName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"resources":[{"type":"Microsoft.KeyVault/vaults/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''vaultName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"AuditEvent","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + diagnostic settings for '', parameters(''vaultName''))]"}}},"parameters":{"location":{"value":"[field(''location'')]"},"vaultName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ed7c8c13-51e7-49d1-8a43-8490431a0da2","type":"Microsoft.Authorization/policyDefinitions","name":"ed7c8c13-51e7-49d1-8a43-8490431a0da2"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Key Vault to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Key Vault to stream to a regional Log Analytics + workspace when any Key Vault which is missing this diagnostic settings is + created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.KeyVault/vaults"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.KeyVault/vaults/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"AuditEvent","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bef3f64c-5290-43b7-85b0-9b254eef4c47","type":"Microsoft.Authorization/policyDefinitions","name":"bef3f64c-5290-43b7-85b0-9b254eef4c47"},{"properties":{"displayName":"Deploy + Log Analytics agent for Windows virtual machine scale sets","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Log Analytics agent for Windows virtual machine scale sets if the VM Image + (OS) is in the list defined and the agent is not installed. The list of OS + images will be updated over time as support is updated. Note: if your scale + set upgradePolicy is set to Manual, you need to apply the extension to the + all VMs in the set by calling upgrade on them. In CLI this would be az vmss + update-instances.","metadata":{"version":"1.1.0","category":"Monitoring"},"parameters":{"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293","/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"MicrosoftMonitoringAgent"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"}},"variables":{"vmExtensionName":"MicrosoftMonitoringAgent","vmExtensionPublisher":"Microsoft.EnterpriseCloud.Monitoring","vmExtensionType":"MicrosoftMonitoringAgent","vmExtensionTypeHandlerVersion":"1.0"},"resources":[{"name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","type":"Microsoft.Compute/virtualMachineScaleSets/extensions","location":"[parameters(''location'')]","apiVersion":"2018-06-01","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true,"settings":{"workspaceId":"[reference(parameters(''logAnalytics''), + ''2015-03-20'').customerId]","stopOnMultipleConnections":"true"},"protectedSettings":{"workspaceKey":"[listKeys(parameters(''logAnalytics''), + ''2015-03-20'').primarySharedKey]"}}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for: '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3c1b3629-c8f8-4bf6-862c-037cb9094038","type":"Microsoft.Authorization/policyDefinitions","name":"3c1b3629-c8f8-4bf6-862c-037cb9094038"},{"properties":{"displayName":"Deploy + Log Analytics agent for Windows VMs","policyType":"BuiltIn","mode":"Indexed","description":"Deploy + Log Analytics agent for Windows VMs if the VM Image (OS) is in the list defined + and the agent is not installed. The list of OS images will be updated over + time as support is updated.","metadata":{"version":"1.1.0","category":"Monitoring"},"parameters":{"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"listOfImageIdToInclude":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + values: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"MicrosoftMonitoringAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"}},"variables":{"vmExtensionName":"MicrosoftMonitoringAgent","vmExtensionPublisher":"Microsoft.EnterpriseCloud.Monitoring","vmExtensionType":"MicrosoftMonitoringAgent","vmExtensionTypeHandlerVersion":"1.0"},"resources":[{"name":"[concat(parameters(''vmName''), + ''/'', variables(''vmExtensionName''))]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","apiVersion":"2018-06-01","properties":{"publisher":"[variables(''vmExtensionPublisher'')]","type":"[variables(''vmExtensionType'')]","typeHandlerVersion":"[variables(''vmExtensionTypeHandlerVersion'')]","autoUpgradeMinorVersion":true,"settings":{"workspaceId":"[reference(parameters(''logAnalytics''), + ''2015-03-20'').customerId]","stopOnMultipleConnections":"true"},"protectedSettings":{"workspaceKey":"[listKeys(parameters(''logAnalytics''), + ''2015-03-20'').primarySharedKey]"}}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + extension for VM'', '': '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0868462e-646c-4fe3-9ced-a733534b6a2c","type":"Microsoft.Authorization/policyDefinitions","name":"0868462e-646c-4fe3-9ced-a733534b6a2c"},{"properties":{"displayName":"[Preview]: + Audit Log Analytics Agent Deployment - VM Image (OS) unlisted","policyType":"BuiltIn","mode":"Indexed","description":"Reports + VMs as non-compliant if the VM Image (OS) is not in the list defined and the + agent is not installed. The list of OS images will be updated over time as + support is updated.","metadata":{"version":"1.0.0-preview","category":"Monitoring","preview":true},"parameters":{"listOfImageIdToInclude_windows":{"type":"Array","metadata":{"displayName":"[Preview]: + Optional: List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]},"listOfImageIdToInclude_linux":{"type":"Array","metadata":{"displayName":"[Preview]: + Optional: List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"not":{"anyOf":[{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_windows'')]"},{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_linux'')]"},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/32133ab0-ee4b-4b44-98d6-042180979d50","type":"Microsoft.Authorization/policyDefinitions","name":"32133ab0-ee4b-4b44-98d6-042180979d50"},{"properties":{"displayName":"Audit + Log Analytics workspace for VM - Report Mismatch","policyType":"BuiltIn","mode":"Indexed","description":"Reports + VMs as non-compliant if they aren''t logging to the Log Analytics workspace + specified in the policy/initiative assignment.","metadata":{"version":"1.0.1","category":"Monitoring"},"parameters":{"logAnalyticsWorkspaceId":{"type":"String","metadata":{"displayName":"Log + Analytics Workspace Id that VMs should be configured for","description":"This + is the Id (GUID) of the Log Analytics Workspace that the VMs should be configured + for."}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines/extensions"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/settings.workspaceId","notEquals":"[parameters(''logAnalyticsWorkspaceId'')]"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f47b5582-33ec-4c5c-87c0-b010a6b2e917","type":"Microsoft.Authorization/policyDefinitions","name":"f47b5582-33ec-4c5c-87c0-b010a6b2e917"},{"properties":{"displayName":"Diagnostic + logs in Logic Apps should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Logic + Apps"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Logic/workflows"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/34f95f76-5386-4de7-b824-0d8478470c9d","type":"Microsoft.Authorization/policyDefinitions","name":"34f95f76-5386-4de7-b824-0d8478470c9d"},{"properties":{"displayName":"Audit + Log Analytics agent deployment in virtual machine scale sets - VM Image (OS) + unlisted","policyType":"BuiltIn","mode":"Indexed","description":"Reports virtual + machine scale sets as non-compliant if the VM Image (OS) is not in the list + defined and the agent is not installed. The list of OS images will be updated + over time as support is updated.","metadata":{"version":"1.0.1","category":"Monitoring"},"parameters":{"listOfImageIdToInclude_windows":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Windows OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]},"listOfImageIdToInclude_linux":{"type":"Array","metadata":{"displayName":"Optional: + List of VM images that have supported Linux OS to add to scope","description":"Example + value: ''/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage''"},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"not":{"anyOf":[{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_windows'')]"},{"field":"Microsoft.Compute/imageId","in":"[parameters(''listOfImageIdToInclude_linux'')]"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk","2019-Datacenter-zhcn"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerSemiAnnual"},{"field":"Microsoft.Compute/imageSKU","in":["Datacenter-Core-1709-smalldisk","Datacenter-Core-1709-with-Containers-smalldisk","Datacenter-Core-1803-with-Containers-smalldisk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServerHPCPack"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServerHPCPack"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"anyOf":[{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2016-BYOL"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2"},{"field":"Microsoft.Compute/imageOffer","like":"*-WS2012R2-BYOL"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","equals":"MLServer-WS2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftVisualStudio"},{"field":"Microsoft.Compute/imageOffer","in":["VisualStudio","Windows"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftDynamicsAX"},{"field":"Microsoft.Compute/imageOffer","equals":"Dynamics"},{"field":"Microsoft.Compute/imageSKU","equals":"Pre-Req-AX7-Onebox-U8"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","equals":"windows-data-science-vm"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsDesktop"},{"field":"Microsoft.Compute/imageOffer","equals":"Windows-10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["SLES","SLES-HPC","SLES-HPC-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-Priority","SLES-BYOS","SLES-SAPCAL","SLES-Standard"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"14.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7.*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","Centos-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"6.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","like":"7*"}]}]}}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","existenceCondition":{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5c3bc7b8-a64c-4e08-a9cd-7ff0f31e1138","type":"Microsoft.Authorization/policyDefinitions","name":"5c3bc7b8-a64c-4e08-a9cd-7ff0f31e1138"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Logic Apps to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Logic Apps to stream to a regional Log Analytics + workspace when any Logic Apps which is missing this diagnostic settings is + created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Logic/workflows"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Logic/workflows/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"WorkflowRuntime","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b889a06c-ec72-4b03-910a-cb169ee18721","type":"Microsoft.Authorization/policyDefinitions","name":"b889a06c-ec72-4b03-910a-cb169ee18721"},{"properties":{"displayName":"MariaDB + server should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"Virtual + network based firewall rules are used to enable traffic from a specific subnet + to Azure Database for MariaDB while ensuring the traffic stays within the + Azure boundary. This policy provides a way to audit if the Azure Database + for MariaDB has virtual network service endpoint being used.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforMariaDB/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforMariaDB/servers/virtualNetworkRules","existenceCondition":{"field":"Microsoft.DBforMariaDB/servers/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dfbd9a64-6114-48de-a47d-90574dc2e489","type":"Microsoft.Authorization/policyDefinitions","name":"dfbd9a64-6114-48de-a47d-90574dc2e489"},{"properties":{"displayName":"Azure + subscriptions should have a log profile for Activity Log","policyType":"BuiltIn","mode":"All","description":"This + policy ensures if a log profile is enabled for exporting activity logs. It + audits if there is no log profile created to export the logs either to a storage + account or to an event hub.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/logProfiles","existenceCondition":{"field":"Microsoft.Insights/logProfiles/categories","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7796937f-307b-4598-941c-67d3a05ebfe7","type":"Microsoft.Authorization/policyDefinitions","name":"7796937f-307b-4598-941c-67d3a05ebfe7"},{"properties":{"displayName":"Gateway + subnets should not be configured with a network security group","policyType":"BuiltIn","mode":"All","description":"This + policy denies if a gateway subnet is configured with a network security group. + Assigning a network security group to a gateway subnet will cause the gateway + to stop functioning.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"field":"name","equals":"GatewaySubnet"},{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","exists":"true"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/35f9c03a-cc27-418e-9c0c-539ff999d010","type":"Microsoft.Authorization/policyDefinitions","name":"35f9c03a-cc27-418e-9c0c-539ff999d010"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Logic Apps to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Logic Apps to stream to a regional Event Hub when + any Logic Apps which is missing this diagnostic settings is created or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Logic + Apps in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Logic/workflows"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Logic/workflows/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"WorkflowRuntime","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a1dae6c7-13f3-48ea-a149-ff8442661f60","type":"Microsoft.Authorization/policyDefinitions","name":"a1dae6c7-13f3-48ea-a149-ff8442661f60"},{"properties":{"displayName":"Enforce + SSL connection should be enabled for MySQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Database for MySQL supports connecting your Azure Database for MySQL server + to client applications using Secure Sockets Layer (SSL). Enforcing SSL connections + between your database server and your client applications helps protect against + ''man in the middle'' attacks by encrypting the data stream between the server + and your application. This configuration enforces that SSL is always enabled + for accessing your database server.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforMySQL/servers"},{"field":"Microsoft.DBforMySQL/servers/sslEnforcement","exists":"true"},{"field":"Microsoft.DBforMySQL/servers/sslEnforcement","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e802a67a-daf5-4436-9ea6-f6d821dd0c5d","type":"Microsoft.Authorization/policyDefinitions","name":"e802a67a-daf5-4436-9ea6-f6d821dd0c5d"},{"properties":{"displayName":"Network + interfaces should not have public IPs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy denies the network interfaces which are configured with any public + IP. Public IP addresses allow internet resources to communicate inbound to + Azure resources, and Azure resources to communicate outbound to the internet. + This should be reviewed by the network security team.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkInterfaces"},{"not":{"field":"Microsoft.Network/networkInterfaces/ipconfigurations[*].publicIpAddress.id","notLike":"*"}}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/83a86a26-fd1f-447c-b59d-e51f44264114","type":"Microsoft.Authorization/policyDefinitions","name":"83a86a26-fd1f-447c-b59d-e51f44264114"},{"properties":{"displayName":"Network + interfaces should disable IP forwarding","policyType":"BuiltIn","mode":"Indexed","description":"This + policy denies the network interfaces which enabled IP forwarding. The setting + of IP forwarding disables Azure''s check of the source and destination for + a network interface. This should be reviewed by the network security team.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkInterfaces"},{"field":"Microsoft.Network/networkInterfaces/enableIpForwarding","equals":"true"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/88c0b9da-ce96-4b03-9635-f29a937e2900","type":"Microsoft.Authorization/policyDefinitions","name":"88c0b9da-ce96-4b03-9635-f29a937e2900"},{"properties":{"displayName":"MySQL + server should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"Virtual + network based firewall rules are used to enable traffic from a specific subnet + to Azure Database for MySQL while ensuring the traffic stays within the Azure + boundary. This policy provides a way to audit if the Azure Database for MySQL + has virtual network service endpoint being used.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforMySQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforMySQL/servers/virtualNetworkRules","existenceCondition":{"field":"Microsoft.DBforMySQL/servers/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3375856c-3824-4e0e-ae6a-79e011dd4c47","type":"Microsoft.Authorization/policyDefinitions","name":"3375856c-3824-4e0e-ae6a-79e011dd4c47"},{"properties":{"displayName":"Flow + log should be configured for every network security group","policyType":"BuiltIn","mode":"Indexed","description":"Audit + for network security groups to verify if flow log resource is configured. + Flow log allows to log information about IP traffic flowing through network + security group. It can be used for optimizing network flows, monitoring throughput, + verifying compliance, detecting intrusions and more.","metadata":{"version":"1.0.0","category":"Network"},"policyRule":{"if":{"allof":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"count":{"field":"Microsoft.Network/networkSecurityGroups/flowLogs[*]"},"equals":0}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c251913d-7d24-4958-af87-478ed3b9ba41","type":"Microsoft.Authorization/policyDefinitions","name":"c251913d-7d24-4958-af87-478ed3b9ba41"},{"properties":{"displayName":"SSH + access from the Internet should be blocked","policyType":"BuiltIn","mode":"All","description":"This + policy audits any network security rule that allows SSH access from Internet","metadata":{"version":"2.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups/securityRules"},{"allOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Allow"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"},{"anyOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange","equals":"*"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange","equals":"22"},{"value":"[if(and(not(empty(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''))), + contains(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''),''-'')), + and(lessOrEquals(int(first(split(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''), + ''-''))),22),greaterOrEquals(int(last(split(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''), + ''-''))),22)), ''false'')]","equals":"true"},{"count":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","where":{"value":"[if(and(not(empty(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')))), + contains(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')),''-'')), + and(lessOrEquals(int(first(split(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')), + ''-''))),22),greaterOrEquals(int(last(split(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')), + ''-''))),22)) , ''false'')]","equals":"true"}},"greater":0},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","notEquals":"*"}},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","notEquals":"22"}}]},{"anyOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"*"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Internet"},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]","notEquals":"*"}},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]","notEquals":"Internet"}}]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2c89a2e5-7285-40fe-afe0-ae8654b92fab","type":"Microsoft.Authorization/policyDefinitions","name":"2c89a2e5-7285-40fe-afe0-ae8654b92fab"},{"properties":{"displayName":"Deploy + a flow log resource with target network security group","policyType":"BuiltIn","mode":"Indexed","description":"Configures + flow log for specific network security group. It will allow to log information + about IP traffic flowing through an network security group. Flow log helps + to identify unknown or undesired traffic, verify network isolation and compliance + with enterprise access rules, analyze network flows from compromised IPs and + network interfaces.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"nsgRegion":{"type":"String","metadata":{"displayName":"NSG + Region","description":"This Policy will review NSGs only in the selected region. + You can create other assignments to include other regions.","strongType":"location"}},"storageId":{"type":"String","metadata":{"displayName":"Storage + id","description":"A string with the storage id for the flowlogs to be sent + to. It will be used for deployment purposes only. Make sure this storage account + is located in the same region as the NSG. The format must be: ''/subscriptions/{subscription + id}/resourceGroups/{resourceGroup name}/providers/Microsoft.Storage/storageAccounts/{storage + account name}","assignPermissions":"true"}},"networkWatcherRG":{"type":"String","metadata":{"displayName":"Network + Watchers RG","description":"The name of the resource group where the flowLog + resources will be created. This will be used only if a deployment is required. + This is the resource group where the Network Watchers are located.","strongType":"existingResourceGroups"}},"networkWatcherName":{"type":"String","metadata":{"displayName":"Network + Watcher name","description":"The name of the network watcher under which the + flowLog resources will be created. Make sure it belongs to the same region + as the NSG."}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","equals":"[parameters(''nsgRegion'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkWatchers/flowlogs","resourceGroupName":"[if(empty(coalesce(field(''Microsoft.Network/networkSecurityGroups/flowLogs''))), + parameters(''networkWatcherRG''), split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[4])]","name":"[if(empty(coalesce(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id''))), + ''null/null'', concat(split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[8], ''/'', split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[10]))]","existenceCondition":{"allOf":[{"field":"Microsoft.Network/networkWatchers/flowLogs/enabled","equals":"true"},{"field":"Microsoft.Network/networkWatchers/flowLogs/storageId","equals":"[parameters(''storageId'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"storageId":{"type":"String"},"networkWatcherRG":{"type":"String"},"networkWatcherName":{"type":"String"},"flowlogName":{"type":"String"},"location":{"type":"String"},"targetResource":{"type":"string"}},"resources":[{"type":"Microsoft.Resources/deployments","name":"[concat(''flowlogDeployment-'', + uniqueString(parameters(''flowlogName'')))]","apiVersion":"2019-10-01","resourceGroup":"[parameters(''networkWatcherRG'')]","properties":{"mode":"incremental","parameters":{},"template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"resources":[{"type":"Microsoft.Network/networkWatchers/flowLogs","name":"[concat(parameters(''networkWatcherName''), + ''/'', parameters(''flowlogName''))]","apiVersion":"2019-11-01","location":"[parameters(''location'')]","properties":{"targetResourceId":"[parameters(''targetResource'')]","storageId":"[parameters(''storageId'')]","enabled":"true","retentionPolicy":{"days":"0","enabled":"false"}}}]}}}]},"parameters":{"storageId":{"value":"[parameters(''storageId'')]"},"networkWatcherRG":{"value":"[if(empty(coalesce(field(''Microsoft.Network/networkSecurityGroups/flowLogs''))), + parameters(''networkWatcherRG''), split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[4])]"},"networkWatcherName":{"value":"[if(empty(coalesce(field(''Microsoft.Network/networkSecurityGroups/flowLogs''))), + parameters(''networkWatcherName''), split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[8])]"},"flowlogName":{"value":"[if(empty(coalesce(field(''Microsoft.Network/networkSecurityGroups/flowLogs''))), + concat(field(''name''), ''-'', resourceGroup().name, ''-'', ''flowlog''), + split(first(field(''Microsoft.Network/networkSecurityGroups/flowLogs[*].id'')), + ''/'')[10])]"},"location":{"value":"[field(''location'')]"},"targetResource":{"value":"[concat(resourceGroup().id, + ''/providers/Microsoft.Network/networkSecurityGroups/'', field(''name''))]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0db34a60-64f4-4bf6-bd44-f95c16cf34b9","type":"Microsoft.Authorization/policyDefinitions","name":"0db34a60-64f4-4bf6-bd44-f95c16cf34b9"},{"properties":{"displayName":"Network + Watcher should be enabled","policyType":"BuiltIn","mode":"All","description":"Network + Watcher is a regional service that enables you to monitor and diagnose conditions + at a network scenario level in, to, and from Azure. Scenario level monitoring + enables you to diagnose problems at an end to end network level view. Network + diagnostic and visualization tools available with Network Watcher help you + understand, diagnose, and gain insights to your network in Azure.","metadata":{"version":"2.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"listOfLocations":{"type":"Array","metadata":{"displayName":"Locations","description":"Audit + if Network Watcher is not enabled for region(s).","strongType":"location"}},"resourceGroupName":{"type":"String","metadata":{"displayName":"NetworkWatcher + resource group name","description":"Name of the resource group of NetworkWatcher, + such as NetworkWatcherRG. This is the resource group where the Network Watchers + are located."},"defaultValue":"NetworkWatcherRG"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Network/networkWatchers","resourceGroupName":"[parameters(''resourceGroupName'')]","existenceCondition":{"field":"location","in":"[parameters(''listOfLocations'')]"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b6e2945c-0b7b-40f5-9233-7a5323b5cdc6","type":"Microsoft.Authorization/policyDefinitions","name":"b6e2945c-0b7b-40f5-9233-7a5323b5cdc6"},{"properties":{"displayName":"Deploy + network watcher when virtual networks are created","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a network watcher resource in regions with virtual networks. + You need to ensure existence of a resource group named networkWatcherRG, which + will be used to deploy network watcher instances.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{},"policyRule":{"if":{"field":"type","equals":"Microsoft.Network/virtualNetworks"},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Network/networkWatchers","resourceGroupName":"networkWatcherRG","existenceCondition":{"field":"location","equals":"[field(''location'')]"},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json","contentVersion":"1.0.0.0","parameters":{"location":{"type":"string"}},"resources":[{"apiVersion":"2016-09-01","type":"Microsoft.Network/networkWatchers","name":"[concat(''networkWatcher_'', + parameters(''location''))]","location":"[parameters(''location'')]"}]},"parameters":{"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a9b99dd8-06c5-4317-8629-9d86a3c6e7d9","type":"Microsoft.Authorization/policyDefinitions","name":"a9b99dd8-06c5-4317-8629-9d86a3c6e7d9"},{"properties":{"displayName":"Log + checkpoints should be enabled for PostgreSQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy helps audit any PostgreSQL databases in your environment without log_checkpoints + setting enabled.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/configurations","name":"log_checkpoints","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/configurations/value","equals":"ON"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e43d","type":"Microsoft.Authorization/policyDefinitions","name":"eb6f77b9-bd53-4e35-a23d-7f65d5f0e43d"},{"properties":{"displayName":"Connection + throttling should be enabled for PostgreSQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy helps audit any PostgreSQL databases in your environment without Connection + throttling enabled. This setting enables temporary connection throttling per + IP for too many invalid password login failures.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/configurations","name":"connection_throttling","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/configurations/value","equals":"ON"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5345bb39-67dc-4960-a1bf-427e16b9a0bd","type":"Microsoft.Authorization/policyDefinitions","name":"5345bb39-67dc-4960-a1bf-427e16b9a0bd"},{"properties":{"displayName":"Log + connections should be enabled for PostgreSQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy helps audit any PostgreSQL databases in your environment without log_connections + setting enabled.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/configurations","name":"log_connections","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/configurations/value","equals":"ON"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e442","type":"Microsoft.Authorization/policyDefinitions","name":"eb6f77b9-bd53-4e35-a23d-7f65d5f0e442"},{"properties":{"displayName":"Disconnections + should be logged for PostgreSQL database servers.","policyType":"BuiltIn","mode":"Indexed","description":"This + policy helps audit any PostgreSQL databases in your environment without log_disconnections + enabled.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/configurations","name":"log_disconnections","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/configurations/value","equals":"ON"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e446","type":"Microsoft.Authorization/policyDefinitions","name":"eb6f77b9-bd53-4e35-a23d-7f65d5f0e446"},{"properties":{"displayName":"Log + duration should be enabled for PostgreSQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy helps audit any PostgreSQL databases in your environment without log_duration + setting enabled.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/configurations","name":"log_duration","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/configurations/value","equals":"ON"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e8f3","type":"Microsoft.Authorization/policyDefinitions","name":"eb6f77b9-bd53-4e35-a23d-7f65d5f0e8f3"},{"properties":{"displayName":"RDP + access from the Internet should be blocked","policyType":"BuiltIn","mode":"All","description":"This + policy audits any network security rule that allows RDP access from Internet","metadata":{"version":"2.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups/securityRules"},{"allOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Allow"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"},{"anyOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange","equals":"*"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange","equals":"3389"},{"value":"[if(and(not(empty(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''))), + contains(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''),''-'')), + and(lessOrEquals(int(first(split(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''), + ''-''))),3389),greaterOrEquals(int(last(split(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange''), + ''-''))),3389)), ''false'')]","equals":"true"},{"count":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","where":{"value":"[if(and(not(empty(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')))), + contains(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')),''-'')), + and(lessOrEquals(int(first(split(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')), + ''-''))),3389),greaterOrEquals(int(last(split(first(field(''Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]'')), + ''-''))),3389)) , ''false'')]","equals":"true"}},"greater":0},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","notEquals":"*"}},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]","notEquals":"3389"}}]},{"anyOf":[{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"*"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Internet"},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]","notEquals":"*"}},{"not":{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]","notEquals":"Internet"}}]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e372f825-a257-4fb8-9175-797a8a8627d6","type":"Microsoft.Authorization/policyDefinitions","name":"e372f825-a257-4fb8-9175-797a8a8627d6"},{"properties":{"displayName":"Enforce + SSL connection should be enabled for PostgreSQL database servers","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Database for PostgreSQL supports connecting your Azure Database for PostgreSQL + server to client applications using Secure Sockets Layer (SSL). Enforcing + SSL connections between your database server and your client applications + helps protect against ''man in the middle'' attacks by encrypting the data + stream between the server and your application. This configuration enforces + that SSL is always enabled for accessing your database server.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},{"field":"Microsoft.DBforPostgreSQL/servers/sslEnforcement","exists":"true"},{"field":"Microsoft.DBforPostgreSQL/servers/sslEnforcement","notEquals":"Enabled"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d158790f-bfb0-486c-8631-2dc6b4e8e6af","type":"Microsoft.Authorization/policyDefinitions","name":"d158790f-bfb0-486c-8631-2dc6b4e8e6af"},{"properties":{"displayName":"Audit + virtual machines without disaster recovery configured","policyType":"BuiltIn","mode":"All","description":"Audit + virtual machines which do not have disaster recovery configured. To learn + more about disaster recovery, visit https://aka.ms/asr-doc.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.Resources/links","existenceCondition":{"field":"name","like":"ASR-Protect-*"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0015ea4d-51ff-4ce3-8d8c-f3f8f0179a56","type":"Microsoft.Authorization/policyDefinitions","name":"0015ea4d-51ff-4ce3-8d8c-f3f8f0179a56"},{"properties":{"displayName":"PostgreSQL + server should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"Virtual + network based firewall rules are used to enable traffic from a specific subnet + to Azure Database for PostgreSQL while ensuring the traffic stays within the + Azure boundary. This policy provides a way to audit if the Azure Database + for PostgreSQL has virtual network service endpoint being used.","metadata":{"version":"1.0.2","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.DBforPostgreSQL/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.DBforPostgreSQL/servers/virtualNetworkRules","existenceCondition":{"field":"Microsoft.DBforPostgreSQL/servers/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3c14b034-bcb6-4905-94e7-5b8e98a47b65","type":"Microsoft.Authorization/policyDefinitions","name":"3c14b034-bcb6-4905-94e7-5b8e98a47b65"},{"properties":{"displayName":"Only + secure connections to your Azure Cache for Redis should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of only connections via SSL to Azure Cache for Redis. Use of secure + connections ensures authentication between the server and the service and + protects data in transit from network layer attacks such as man-in-the-middle, + eavesdropping, and session-hijacking","metadata":{"version":"1.0.0","category":"Cache"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Cache/redis"},{"field":"Microsoft.Cache/Redis/enableNonSslPort","equals":"true"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/22bee202-a82f-4305-9a2a-6d7f44d4dedb","type":"Microsoft.Authorization/policyDefinitions","name":"22bee202-a82f-4305-9a2a-6d7f44d4dedb"},{"properties":{"displayName":"Require + a tag on resources","policyType":"BuiltIn","mode":"Indexed","description":"Enforces + existence of a tag. Does not apply to resource groups.","metadata":{"version":"1.0.1","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/871b6d14-10aa-478d-b590-94f262ecfa99","type":"Microsoft.Authorization/policyDefinitions","name":"871b6d14-10aa-478d-b590-94f262ecfa99"},{"properties":{"displayName":"Allowed + locations for resource groups","policyType":"BuiltIn","mode":"All","description":"This + policy enables you to restrict the locations your organization can create + resource groups in. Use to enforce your geo-compliance requirements.","metadata":{"version":"1.0.0","category":"General"},"parameters":{"listOfAllowedLocations":{"type":"Array","metadata":{"description":"The + list of locations that resource groups can be created in.","strongType":"location","displayName":"Allowed + locations"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"location","notIn":"[parameters(''listOfAllowedLocations'')]"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e765b5de-1225-4ba3-bd56-1ac6695af988","type":"Microsoft.Authorization/policyDefinitions","name":"e765b5de-1225-4ba3-bd56-1ac6695af988"},{"properties":{"displayName":"Append + a tag and its value to resource groups","policyType":"BuiltIn","mode":"All","description":"Appends + the specified tag and value when any resource group which is missing this + tag is created or updated. Does not modify the tags of resource groups created + before this policy was applied until those resource groups are changed. New + ''modify'' effect policies are available that support remediation of tags + on existing resources (see https://aka.ms/modifydoc).","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"append","details":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/49c88fc8-6fd1-46fd-a676-f12d1d3a4c71","type":"Microsoft.Authorization/policyDefinitions","name":"49c88fc8-6fd1-46fd-a676-f12d1d3a4c71"},{"properties":{"displayName":"Require + a tag and its value on resources","policyType":"BuiltIn","mode":"Indexed","description":"Enforces + a required tag and its value. Does not apply to resource groups.","metadata":{"version":"1.0.1","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"not":{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","equals":"[parameters(''tagValue'')]"}},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1e30110a-5ceb-460c-a204-c1c3969c6d62","type":"Microsoft.Authorization/policyDefinitions","name":"1e30110a-5ceb-460c-a204-c1c3969c6d62"},{"properties":{"displayName":"Require + a tag and its value on resource groups","policyType":"BuiltIn","mode":"All","description":"Enforces + a required tag and its value on resource groups.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}},"tagValue":{"type":"String","metadata":{"displayName":"Tag + Value","description":"Value of the tag, such as ''production''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","notEquals":"[parameters(''tagValue'')]"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8ce3da23-7156-49e4-b145-24f95f9dcb46","type":"Microsoft.Authorization/policyDefinitions","name":"8ce3da23-7156-49e4-b145-24f95f9dcb46"},{"properties":{"displayName":"Require + a tag on resource groups","policyType":"BuiltIn","mode":"All","description":"Enforces + existence of a tag on resource groups.","metadata":{"version":"1.0.0","category":"Tags"},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Name of the tag, such as ''environment''"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Resources/subscriptions/resourceGroups"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/96670d01-0a4d-4649-9c89-2d3abc0a5025","type":"Microsoft.Authorization/policyDefinitions","name":"96670d01-0a4d-4649-9c89-2d3abc0a5025"},{"properties":{"displayName":"Audit + resource location matches resource group location","policyType":"BuiltIn","mode":"Indexed","description":"Audit + that the resource location matches its resource group location","metadata":{"version":"2.0.0","category":"General"},"policyRule":{"if":{"allOf":[{"field":"location","notEquals":"[resourcegroup().location]"},{"field":"location","notEquals":"global"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0a914e76-4921-4c19-b460-a2d36003525a","type":"Microsoft.Authorization/policyDefinitions","name":"0a914e76-4921-4c19-b460-a2d36003525a"},{"properties":{"displayName":"Diagnostic + logs in Search services should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Search"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Search/searchServices"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b4330a05-a843-4bc8-bf9a-cacce50c67f4","type":"Microsoft.Authorization/policyDefinitions","name":"b4330a05-a843-4bc8-bf9a-cacce50c67f4"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Search Services to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Search Services to stream to a regional Event + Hub when any Search Services which is missing this diagnostic settings is + created or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Search + Services in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Search/searchServices"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Search/searchServices/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"OperationLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3d5da587-71bd-41f5-ac95-dd3330c2d58d","type":"Microsoft.Authorization/policyDefinitions","name":"3d5da587-71bd-41f5-ac95-dd3330c2d58d"},{"properties":{"displayName":"Azure + Monitor solution ''Security and Audit'' must be deployed","policyType":"BuiltIn","mode":"All","description":"This + policy ensures that Security and Audit is deployed.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.OperationsManagement/solutions","existenceCondition":{"allOf":[{"field":"Microsoft.OperationsManagement/solutions/provisioningState","equals":"Succeeded"},{"field":"name","like":"Security(*)"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3e596b57-105f-48a6-be97-03e9243bad6e","type":"Microsoft.Authorization/policyDefinitions","name":"3e596b57-105f-48a6-be97-03e9243bad6e"},{"properties":{"displayName":"Diagnostic + logs in Service Bus should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Service + Bus"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.ServiceBus/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f8d36e2f-389b-4ee4-898d-21aeb69a0f45","type":"Microsoft.Authorization/policyDefinitions","name":"f8d36e2f-389b-4ee4-898d-21aeb69a0f45"},{"properties":{"displayName":"All + authorization rules except RootManageSharedAccessKey should be removed from + Service Bus namespace","policyType":"BuiltIn","mode":"All","description":"Service + Bus clients should not use a namespace level access policy that provides access + to all queues and topics in a namespace. To align with the least privilege + security model, you should create access policies at the entity level for + queues and topics to provide access to only the specific entity","metadata":{"version":"1.0.1","category":"Service + Bus"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ServiceBus/namespaces/authorizationRules"},{"field":"name","notEquals":"RootManageSharedAccessKey"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a1817ec0-a368-432a-8057-8371e17ac6ee","type":"Microsoft.Authorization/policyDefinitions","name":"a1817ec0-a368-432a-8057-8371e17ac6ee"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Search Services to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Search Services to stream to a regional Log Analytics + workspace when any Search Services which is missing this diagnostic settings + is created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Search/searchServices"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Search/searchServices/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"OperationLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/08ba64b8-738f-4918-9686-730d2ed79c7d","type":"Microsoft.Authorization/policyDefinitions","name":"08ba64b8-738f-4918-9686-730d2ed79c7d"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Service Bus to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Service Bus to stream to a regional Event Hub + when any Service Bus which is missing this diagnostic settings is created + or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Service + Bus in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ServiceBus/namespaces"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.ServiceBus/namespaces/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"OperationalLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6b51af03-9277-49a9-a3f8-1c69c9ff7403","type":"Microsoft.Authorization/policyDefinitions","name":"6b51af03-9277-49a9-a3f8-1c69c9ff7403"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Service Bus to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Service Bus to stream to a regional Log Analytics + workspace when any Service Bus which is missing this diagnostic settings is + created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.ServiceBus/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.ServiceBus/namespaces/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"OperationalLogs","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/04d53d87-841c-4f23-8a5b-21564380b55e","type":"Microsoft.Authorization/policyDefinitions","name":"04d53d87-841c-4f23-8a5b-21564380b55e"},{"properties":{"displayName":"Diagnostic + logs in Virtual Machine Scale Sets should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"It + is recommended to enable Logs so that activity trail can be recreated when + investigations are required in the event of an incident or a compromise.","metadata":{"version":"2.0.1","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"includeAKSClusters":{"type":"Boolean","metadata":{"displayName":"Include + AKS Clusters","description":"Whether to include AKS Clusters to Diagnostic + logs extension - True or False"},"defaultValue":false}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"value":"[parameters(''includeAKSClusters'')]","equals":true}]},{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"value":"[parameters(''includeAKSClusters'')]","equals":false},{"field":"Microsoft.Compute/imagePublisher","notEquals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","notEquals":"aks"},{"field":"Microsoft.Compute/imageSKU","notLike":"aks*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","existenceCondition":{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"IaaSDiagnostics"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Diagnostics"}]},{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"LinuxDiagnostic"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","in":["Microsoft.OSTCExtensions","Microsoft.Azure.Diagnostics"]}]}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7c1b1214-f927-48bf-8882-84f0af6588b1","type":"Microsoft.Authorization/policyDefinitions","name":"7c1b1214-f927-48bf-8882-84f0af6588b1"},{"properties":{"displayName":"Service + Fabric clusters should have the ClusterProtectionLevel property set to EncryptAndSign","policyType":"BuiltIn","mode":"Indexed","description":"Service + Fabric provides three levels of protection (None, Sign and EncryptAndSign) + for node-to-node communication using a primary cluster certificate. Set the + protection level to ensure that all node-to-node messages are encrypted and + digitally signed","metadata":{"version":"1.1.0","category":"Service Fabric"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ServiceFabric/clusters"},{"anyOf":[{"field":"Microsoft.ServiceFabric/clusters/fabricSettings[*].name","notEquals":"Security"},{"field":"Microsoft.ServiceFabric/clusters/fabricSettings[*].parameters[*].name","notEquals":"ClusterProtectionLevel"},{"field":"Microsoft.ServiceFabric/clusters/fabricSettings[*].parameters[*].value","notEquals":"EncryptAndSign"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/617c02be-7f02-4efd-8836-3180d47b6c68","type":"Microsoft.Authorization/policyDefinitions","name":"617c02be-7f02-4efd-8836-3180d47b6c68"},{"properties":{"displayName":"Service + Fabric clusters should only use Azure Active Directory for client authentication","policyType":"BuiltIn","mode":"Indexed","description":"Audit + usage of client authentication only via Azure Active Directory in Service + Fabric","metadata":{"version":"1.1.0","category":"Service Fabric"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ServiceFabric/clusters"},{"anyOf":[{"field":"Microsoft.ServiceFabric/clusters/azureActiveDirectory.tenantId","exists":"false"},{"field":"Microsoft.ServiceFabric/clusters/azureActiveDirectory.tenantId","equals":""}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b54ed75b-3e1a-44ac-a333-05ba39b99ff0","type":"Microsoft.Authorization/policyDefinitions","name":"b54ed75b-3e1a-44ac-a333-05ba39b99ff0"},{"properties":{"displayName":"[Deprecated]: + Audit SQL DB Level Audit Setting","policyType":"BuiltIn","mode":"All","description":"Audit + DB level audit setting for SQL databases","metadata":{"version":"1.0.0-deprecated","category":"SQL","deprecated":true},"parameters":{"setting":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Setting"},"allowedValues":["enabled","disabled"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers/databases"},{"field":"name","notEquals":"master"}]},"then":{"effect":"AuditIfNotExists","details":{"type":"Microsoft.Sql/servers/databases/auditingSettings","name":"default","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/auditingSettings.state","equals":"[parameters(''setting'')]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a12","type":"Microsoft.Authorization/policyDefinitions","name":"06a78e20-9358-41c9-923c-fb736d382a12"},{"properties":{"displayName":"SQL + Database should avoid using GRS backup redundancy","policyType":"BuiltIn","mode":"Indexed","description":"Databases + should avoid using the default geo-redundant storage for backups, if data + residency rules require data to stay within a specific region. Note: Azure + Policy is not enforced when creating a database using T-SQL. If not explicitly + specified, database with geo-redundant backup storage is created via T-SQL.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Deny","Disabled"],"defaultValue":"Deny"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers/databases"},{"field":"Microsoft.Sql/servers/databases/edition","notEquals":"DataWarehouse"},{"not":{"anyOf":[{"field":"Microsoft.Sql/servers/databases/storageAccountType","equals":"LRS"},{"field":"Microsoft.Sql/servers/databases/storageAccountType","equals":"ZRS"}]}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b219b9cf-f672-4f96-9ab0-f5a3ac5e1c13","type":"Microsoft.Authorization/policyDefinitions","name":"b219b9cf-f672-4f96-9ab0-f5a3ac5e1c13"},{"properties":{"displayName":"Transparent + Data Encryption on SQL databases should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Transparent + data encryption should be enabled to protect data-at-rest and meet compliance + requirements","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers/databases"},{"field":"name","notEquals":"master"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/databases/transparentDataEncryption","name":"current","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/transparentDataEncryption.status","equals":"enabled"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/17k78e20-9358-41c9-923c-fb736d382a12","type":"Microsoft.Authorization/policyDefinitions","name":"17k78e20-9358-41c9-923c-fb736d382a12"},{"properties":{"displayName":"Deploy + SQL DB transparent data encryption","policyType":"BuiltIn","mode":"Indexed","description":"Enables + transparent data encryption on SQL databases","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers/databases"},{"field":"name","notEquals":"master"}]},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Sql/servers/databases/transparentDataEncryption","name":"current","existenceCondition":{"field":"Microsoft.Sql/transparentDataEncryption.status","equals":"Enabled"},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9b7fa17d-e63e-47b0-bb0a-15c516ac86ec"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullDbName":{"type":"string"}},"resources":[{"name":"[concat(parameters(''fullDbName''), + ''/current'')]","type":"Microsoft.Sql/servers/databases/transparentDataEncryption","apiVersion":"2014-04-01","properties":{"status":"Enabled"}}]},"parameters":{"fullDbName":{"value":"[field(''fullName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86a912f6-9a06-4e26-b447-11b16ba8659f","type":"Microsoft.Authorization/policyDefinitions","name":"86a912f6-9a06-4e26-b447-11b16ba8659f"},{"properties":{"displayName":"[Deprecated]: + Email notifications to admins should be enabled in SQL Managed Instance advanced + data security settings","policyType":"BuiltIn","mode":"Indexed","description":"Audit + that ''email notification to admins and subscription owners'' is enabled in + SQL Managed Instance advanced threat protection settings. This setting ensures + that any detections of anomalous activities on SQL Managed Instance are reported + as soon as possible to the admins.","metadata":{"version":"1.0.1-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAccountAdmins","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/aeb23562-188d-47cb-80b8-551f16ef9fff","type":"Microsoft.Authorization/policyDefinitions","name":"aeb23562-188d-47cb-80b8-551f16ef9fff"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Azure SQL Database to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Azure SQL Database to stream to a regional Event + Hub on any Azure SQL Database which is missing this diagnostic settings is + created or updated.","metadata":{"version":"1.1.0","category":"SQL"},"parameters":{"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers/databases"},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"resources":[{"type":"Microsoft.Sql/servers/databases/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''fullName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"QueryStoreRuntimeStatistics","enabled":"[parameters(''logsEnabled'')]"},{"category":"QueryStoreWaitStatistics","enabled":"[parameters(''logsEnabled'')]"},{"category":"Errors","enabled":"[parameters(''logsEnabled'')]"},{"category":"DatabaseWaitStatistics","enabled":"[parameters(''logsEnabled'')]"},{"category":"Blocks","enabled":"[parameters(''logsEnabled'')]"},{"category":"SQLInsights","enabled":"[parameters(''logsEnabled'')]"},{"category":"SQLSecurityAuditEvents","enabled":"[parameters(''logsEnabled'')]"},{"category":"Timeouts","enabled":"[parameters(''logsEnabled'')]"},{"category":"AutomaticTuning","enabled":"[parameters(''logsEnabled'')]"},{"category":"Deadlocks","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + diagnostic settings for '', parameters(''fullName''))]"}}},"parameters":{"location":{"value":"[field(''location'')]"},"fullName":{"value":"[field(''fullName'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9a7c7a7d-49e5-4213-bea8-6a502b6272e0","type":"Microsoft.Authorization/policyDefinitions","name":"9a7c7a7d-49e5-4213-bea8-6a502b6272e0"},{"properties":{"displayName":"Advanced + data security should be enabled on SQL Managed Instance","policyType":"BuiltIn","mode":"Indexed","description":"Audit + each SQL Managed Instance without advanced data security.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/securityAlertPolicies","name":"Default","existenceCondition":{"field":"Microsoft.Sql/managedInstances/securityAlertPolicies/state","equals":"Enabled"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/abfb7388-5bf4-4ad7-ba99-2cd2f41cebb9","type":"Microsoft.Authorization/policyDefinitions","name":"abfb7388-5bf4-4ad7-ba99-2cd2f41cebb9"},{"properties":{"displayName":"[Deprecated]: + Advanced data security settings for SQL Managed Instance should contain an + email address for security alerts","policyType":"BuiltIn","mode":"Indexed","description":"Ensure + that an email address is provided for the ''Send alerts to'' field in the + advanced data security settings. This email address receives alert notifications + when anomalous activities are detected on SQL Managed Instance.","metadata":{"version":"1.0.1-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/securityAlertPolicies","name":"default","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAddresses[*]","notEquals":""},{"field":"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAddresses[*]","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3965c43d-b5f4-482e-b74a-d89ee0e0b3a8","type":"Microsoft.Authorization/policyDefinitions","name":"3965c43d-b5f4-482e-b74a-d89ee0e0b3a8"},{"properties":{"displayName":"[Deprecated]: + Advanced Threat Protection types should be set to ''All'' in SQL Managed Instance + advanced data security settings","policyType":"BuiltIn","mode":"Indexed","description":"It''s + recommended to enable all Advanced Threat Protection types on your SQL Managed + Instance. Enabling all types protects against SQL injection, database vulnerabilities, + and any other anomalous activities.","metadata":{"version":"1.0.1-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/managedInstances/securityAlertPolicies/disabledAlerts[*]","equals":""}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bda18df3-5e41-4709-add9-2554ce68c966","type":"Microsoft.Authorization/policyDefinitions","name":"bda18df3-5e41-4709-add9-2554ce68c966"},{"properties":{"displayName":"SQL + Managed Instance should have the minimal TLS version of 1.2","policyType":"BuiltIn","mode":"Indexed","description":"Setting + minimal TLS version to 1.2 improves security by ensuring your SQL Managed + Instance can only be accessed from clients using TLS 1.2. Using versions of + TLS less than 1.2 is not recommended since they have well documented security + vulnerabilities.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/managedInstances"},{"anyOf":[{"field":"Microsoft.Sql/managedInstances/minimalTlsVersion","exists":false},{"field":"Microsoft.Sql/managedInstances/minimalTlsVersion","notEquals":"1.2"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a8793640-60f7-487c-b5c3-1d37215905c4","type":"Microsoft.Authorization/policyDefinitions","name":"a8793640-60f7-487c-b5c3-1d37215905c4"},{"properties":{"displayName":"SQL + Managed Instances should avoid using GRS backup redundancy","policyType":"BuiltIn","mode":"Indexed","description":"Managed + Instances should avoid using the default geo-redundant storage for backups, + if data residency rules require data to stay within a specific region. Note: + Azure Policy is not enforced when creating a database using T-SQL. If not + explicitly specified, database with geo-redundant backup storage is created + via T-SQL.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Deny","Disabled"],"defaultValue":"Deny"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/managedInstances"},{"not":{"anyOf":[{"field":"Microsoft.Sql/managedInstances/storageAccountType","equals":"LRS"},{"field":"Microsoft.Sql/managedInstances/storageAccountType","equals":"ZRS"}]}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a9934fd7-29f2-4e6d-ab3d-607ea38e9079","type":"Microsoft.Authorization/policyDefinitions","name":"a9934fd7-29f2-4e6d-ab3d-607ea38e9079"},{"properties":{"displayName":"Deploy + Advanced Data Security on SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables Advanced Data Security on SQL Servers. This includes turning + on Threat Detection and Vulnerability Assessment. It will automatically create + a storage account in the same region and resource group as the SQL server + to store scan results, with a ''sqlva'' prefix.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"Default","existenceCondition":{"field":"Microsoft.Sql/securityAlertPolicies.state","equals":"Enabled"},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3","/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"serverName":{"type":"string"},"location":{"type":"string"}},"variables":{"serverResourceGroupName":"[resourceGroup().name]","subscriptionId":"[subscription().subscriptionId]","uniqueStorage":"[uniqueString(variables(''subscriptionId''), + variables(''serverResourceGroupName''), parameters(''location''))]","storageName":"[tolower(concat(''sqlva'', + variables(''uniqueStorage'')))]"},"resources":[{"type":"Microsoft.Storage/storageAccounts","name":"[variables(''storageName'')]","apiVersion":"2019-04-01","location":"[parameters(''location'')]","sku":{"name":"Standard_LRS"},"kind":"StorageV2","properties":{}},{"name":"[concat(parameters(''serverName''), + ''/Default'')]","type":"Microsoft.Sql/servers/securityAlertPolicies","apiVersion":"2017-03-01-preview","properties":{"state":"Enabled","emailAccountAdmins":true}},{"name":"[concat(parameters(''serverName''), + ''/Default'')]","type":"Microsoft.Sql/servers/vulnerabilityAssessments","apiVersion":"2018-06-01-preview","properties":{"storageContainerPath":"[concat(reference(resourceId(''Microsoft.Storage/storageAccounts'', + variables(''storageName''))).primaryEndpoints.blob, ''vulnerability-assessment'')]","storageAccountAccessKey":"[listKeys(resourceId(''Microsoft.Storage/storageAccounts'', + variables(''storageName'')), ''2018-02-01'').keys[0].value]","recurringScans":{"isEnabled":true,"emailSubscriptionAdmins":true,"emails":[]}},"dependsOn":["[concat(''Microsoft.Storage/storageAccounts/'', + variables(''storageName''))]","[concat(''Microsoft.Sql/servers/'', parameters(''serverName''), + ''/securityAlertPolicies/Default'')]"]}]},"parameters":{"serverName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6134c3db-786f-471e-87bc-8f479dc890f6","type":"Microsoft.Authorization/policyDefinitions","name":"6134c3db-786f-471e-87bc-8f479dc890f6"},{"properties":{"displayName":"SQL + Auditing settings should have Action-Groups configured to capture critical + activities","policyType":"BuiltIn","mode":"Indexed","description":"The AuditActionsAndGroups + property should contain at least SUCCESSFUL_DATABASE_AUTHENTICATION_GROUP, + FAILED_DATABASE_AUTHENTICATION_GROUP, BATCH_COMPLETED_GROUP to ensure a thorough + audit logging","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/auditingSettings","name":"default","existenceCondition":{"allOf":[{"not":{"field":"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]","notEquals":"SUCCESSFUL_DATABASE_AUTHENTICATION_GROUP"}},{"not":{"field":"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]","notEquals":"FAILED_DATABASE_AUTHENTICATION_GROUP"}},{"not":{"field":"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]","notEquals":"BATCH_COMPLETED_GROUP"}}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7ff426e2-515f-405a-91c8-4f2333442eb5","type":"Microsoft.Authorization/policyDefinitions","name":"7ff426e2-515f-405a-91c8-4f2333442eb5"},{"properties":{"displayName":"Deploy + Auditing on SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy ensures that Auditing is enabled on SQL Servers for enhanced security + and compliance. It will automatically create a storage account in the same + region as the SQL server to store audit records.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"retentionDays":{"type":"String","metadata":{"description":"The + value in days of the retention period (0 indicates unlimited retention)","displayName":"Retention + days (optional, 180 days if unspecified)"},"defaultValue":"180"},"storageAccountsResourceGroup":{"type":"String","metadata":{"displayName":"Resource + group name for storage accounts","description":"Auditing writes database events + to an audit log in your Azure Storage account (a storage account will be created + in each region where a SQL Server is created that will be shared by all servers + in that region). Important - for proper operation of Auditing do not delete + or rename the resource group or the storage accounts.","strongType":"existingResourceGroups"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.Sql/servers/auditingSettings","name":"Default","existenceCondition":{"field":"Microsoft.Sql/auditingSettings.state","equals":"Enabled"},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3","/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"serverName":{"type":"string"},"auditRetentionDays":{"type":"string"},"storageAccountsResourceGroup":{"type":"string"},"location":{"type":"string"}},"variables":{"retentionDays":"[int(parameters(''auditRetentionDays''))]","subscriptionId":"[subscription().subscriptionId]","uniqueStorage":"[uniqueString(variables(''subscriptionId''), + parameters(''location''), parameters(''storageAccountsResourceGroup''))]","locationCode":"[substring(parameters(''location''), + 0, 3)]","storageName":"[tolower(concat(''sqlaudit'', variables(''locationCode''), + variables(''uniqueStorage'')))]","createStorageAccountDeploymentName":"[concat(''sqlServerAuditingStorageAccount-'', + uniqueString(variables(''locationCode''), parameters(''serverName'')))]"},"resources":[{"apiVersion":"2017-05-10","name":"[variables(''createStorageAccountDeploymentName'')]","type":"Microsoft.Resources/deployments","resourceGroup":"[parameters(''storageAccountsResourceGroup'')]","properties":{"mode":"Incremental","parameters":{"location":{"value":"[parameters(''location'')]"},"storageName":{"value":"[variables(''storageName'')]"}},"templateLink":{"uri":"https://raw.githubusercontent.com/Azure/azure-policy/master/samples/SQL/deploy-sql-server-auditing/createStorage.template.json","contentVersion":"1.0.0.0"}}},{"name":"[concat(parameters(''serverName''), + ''/Default'')]","type":"Microsoft.Sql/servers/auditingSettings","apiVersion":"2017-03-01-preview","properties":{"state":"Enabled","storageEndpoint":"[reference(variables(''createStorageAccountDeploymentName'')).outputs.storageAccountEndPoint.value]","storageAccountAccessKey":"[reference(variables(''createStorageAccountDeploymentName'')).outputs.storageAccountKey.value]","retentionDays":"[variables(''retentionDays'')]","auditActionsAndGroups":null,"storageAccountSubscriptionId":"[subscription().subscriptionId]","isStorageSecondaryKeyInUse":false}}]},"parameters":{"serverName":{"value":"[field(''name'')]"},"auditRetentionDays":{"value":"[parameters(''retentionDays'')]"},"storageAccountsResourceGroup":{"value":"[parameters(''storageAccountsResourceGroup'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f4c68484-132f-41f9-9b6d-3e4b1cb55036","type":"Microsoft.Authorization/policyDefinitions","name":"f4c68484-132f-41f9-9b6d-3e4b1cb55036"},{"properties":{"displayName":"[Deprecated]: + Email notifications to admins should be enabled in SQL server advanced data + security settings","policyType":"BuiltIn","mode":"Indexed","description":"Audit + that ''email notification to admins and subscription owners'' is enabled in + the SQL server advanced threat protection settings. This ensures that any + detections of anomalous activities on SQL server are reported as soon as possible + to the admins.","metadata":{"version":"1.0.0-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/emailAccountAdmins","equals":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c8343d2f-fdc9-4a97-b76f-fc71d1163bfc","type":"Microsoft.Authorization/policyDefinitions","name":"c8343d2f-fdc9-4a97-b76f-fc71d1163bfc"},{"properties":{"displayName":"[Deprecated]: + Advanced data security settings for SQL server should contain an email address + to receive security alerts","policyType":"BuiltIn","mode":"Indexed","description":"Ensure + that an email address is provided for the ''Send alerts to'' field in the + Advanced Data Security server settings. This email address receives alert + notifications when anomalous activities are detected on SQL servers.","metadata":{"version":"1.0.0-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/emailAddresses[*]","notEquals":""}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9677b740-f641-4f3c-b9c5-466005c85278","type":"Microsoft.Authorization/policyDefinitions","name":"9677b740-f641-4f3c-b9c5-466005c85278"},{"properties":{"displayName":"Advanced + data security should be enabled on your SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Audit + SQL servers without Advanced Data Security","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"Default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/state","equals":"Enabled"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/abfb4388-5bf4-4ad7-ba82-2cd2f41ceae9","type":"Microsoft.Authorization/policyDefinitions","name":"abfb4388-5bf4-4ad7-ba82-2cd2f41ceae9"},{"properties":{"displayName":"[Deprecated]: + Advanced Threat Protection types should be set to ''All'' in SQL server Advanced + Data Security settings","policyType":"BuiltIn","mode":"Indexed","description":"It + is recommended to enable all Advanced Threat Protection types on your SQL + servers. Enabling all types protects against SQL injection, database vulnerabilities, + and any other anomalous activities.","metadata":{"version":"1.0.0-deprecated","category":"SQL","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/disabledAlerts[*]","equals":""}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e756b945-1b1b-480b-8de8-9a0859d5f7ad","type":"Microsoft.Authorization/policyDefinitions","name":"e756b945-1b1b-480b-8de8-9a0859d5f7ad"},{"properties":{"displayName":"Azure + SQL Database should have the minimal TLS version of 1.2","policyType":"BuiltIn","mode":"Indexed","description":"Setting + minimal TLS version to 1.2 improves security by ensuring your Azure SQL Database + can only be accessed from clients using TLS 1.2. Using versions of TLS less + than 1.2 is not recommended since they have well documented security vulnerabilities.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"anyOf":[{"field":"Microsoft.Sql/servers/minimalTlsVersion","exists":false},{"field":"Microsoft.Sql/servers/minimalTlsVersion","notEquals":"1.2"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/32e6bbec-16b6-44c2-be37-c5b672d103cf","type":"Microsoft.Authorization/policyDefinitions","name":"32e6bbec-16b6-44c2-be37-c5b672d103cf"},{"properties":{"displayName":"Vulnerability + Assessment settings for SQL server should contain an email address to receive + scan reports","policyType":"BuiltIn","mode":"Indexed","description":"Ensure + that an email address is provided for the ''Send scan reports to'' field in + the Vulnerability Assessment settings. This email address receives scan result + summary after a periodic scan runs on SQL servers.","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/vulnerabilityAssessments","name":"default","existenceCondition":{"allOf":[{"field":"Microsoft.Sql/servers/vulnerabilityAssessments/default.recurringScans.emails[*]","notEquals":""},{"count":{"field":"Microsoft.Sql/servers/vulnerabilityAssessments/default.recurringScans.emails[*]"},"notEquals":0}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/057d6cfe-9c4f-4a6d-bc60-14420ea1f1a9","type":"Microsoft.Authorization/policyDefinitions","name":"057d6cfe-9c4f-4a6d-bc60-14420ea1f1a9"},{"properties":{"displayName":"[Deprecated]: + Require SQL Server version 12.0","policyType":"BuiltIn","mode":"Indexed","description":"This + policy ensures all SQL servers use version 12.0. This policy is deprecated + because it is no longer possible to create an Azure SQL server with any version + other than 12.0.","metadata":{"version":"1.0.0-deprecated","category":"SQL","deprecated":true},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"not":{"field":"Microsoft.Sql/servers/version","equals":"12.0"}}]},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/464dbb85-3d5f-4a1d-bb09-95a9b5dd19cf","type":"Microsoft.Authorization/policyDefinitions","name":"464dbb85-3d5f-4a1d-bb09-95a9b5dd19cf"},{"properties":{"displayName":"Virtual + network firewall rule on Azure SQL Database should be enabled to allow traffic + from the specified subnet","policyType":"BuiltIn","mode":"Indexed","description":"Virtual + network based firewall rules are used to enable traffic from a specific subnet + to Azure SQL Database while ensuring the traffic stays within the Azure boundary.","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"subnetId":{"type":"String","metadata":{"displayName":"Subnet + ID","strongType":"Microsoft.Network/virtualNetworks/subnets","description":"The + resource ID of the virtual network subnet that should have a rule enabled. + Example: /subscriptions/00000000-1111-2222-3333-444444444444/resourceGroups/Default/providers/Microsoft.Network/virtualNetworks/testvnet/subnets/testsubnet"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"AuditIfNotExists","details":{"type":"Microsoft.Sql/servers/virtualNetworkRules","existenceCondition":{"field":"Microsoft.Sql/servers/virtualNetworkRules/virtualNetworkSubnetId","equals":"[parameters(''subnetId'')]"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/77e8b146-0078-4fb2-b002-e112381199f0","type":"Microsoft.Authorization/policyDefinitions","name":"77e8b146-0078-4fb2-b002-e112381199f0"},{"properties":{"displayName":"An + Azure Active Directory administrator should be provisioned for SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Audit + provisioning of an Azure Active Directory administrator for your SQL server + to enable Azure AD authentication. Azure AD authentication enables simplified + permission management and centralized identity management of database users + and other Microsoft services","metadata":{"version":"1.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/administrators"}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1f314764-cb73-4fc9-b863-8eca98ac36e9","type":"Microsoft.Authorization/policyDefinitions","name":"1f314764-cb73-4fc9-b863-8eca98ac36e9"},{"properties":{"displayName":"Storage + accounts should allow access from trusted Microsoft services","policyType":"BuiltIn","mode":"Indexed","description":"Some + Microsoft services that interact with storage accounts operate from networks + that can''t be granted access through network rules. To help this type of + service work as intended, allow the set of trusted Microsoft services to bypass + the network rules. These services will then use strong authentication to access + the storage account.","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"field":"Microsoft.Storage/storageAccounts/networkAcls.bypass","exists":"true"},{"field":"Microsoft.Storage/storageAccounts/networkAcls.bypass","notContains":"AzureServices"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c9d007d0-c057-4772-b18c-01e546713bcd","type":"Microsoft.Authorization/policyDefinitions","name":"c9d007d0-c057-4772-b18c-01e546713bcd"},{"properties":{"displayName":"Storage + account should use a private link connection","policyType":"BuiltIn","mode":"Indexed","description":"Private + links enforce secure communication, by providing private connectivity to the + storage account","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Storage/storageAccounts"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Storage/storageAccounts/privateEndpointConnections","existenceCondition":{"allOf":[{"field":"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateEndpoint","exists":"true"},{"field":"Microsoft.Storage/storageAccounts/privateEndpointConnections/provisioningState","equals":"Succeeded"},{"field":"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateLinkServiceConnectionState","exists":"true"},{"field":"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateLinkServiceConnectionState.status","equals":"Approved"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6edd7eda-6dd8-40f7-810d-67160c639cd9","type":"Microsoft.Authorization/policyDefinitions","name":"6edd7eda-6dd8-40f7-810d-67160c639cd9"},{"properties":{"displayName":"[Deprecated]: + Require blob encryption for storage accounts","policyType":"BuiltIn","mode":"Indexed","description":"This + policy ensures blob encryption for storage accounts is turned on. It only + applies to Microsoft.Storage resource types, not other storage providers. + This policy is deprecated because storage blob encryption is now enabled by + default, and can no longer be disabled.","metadata":{"version":"1.0.0-deprecated","category":"Storage","deprecated":true},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"field":"Microsoft.Storage/storageAccounts/enableBlobEncryption","equals":"false"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7c5a74bf-ae94-4a74-8fcf-644d1e0e6e6f","type":"Microsoft.Authorization/policyDefinitions","name":"7c5a74bf-ae94-4a74-8fcf-644d1e0e6e6f"},{"properties":{"displayName":"Storage + accounts should have infrastructure encryption","policyType":"BuiltIn","mode":"Indexed","description":"Enable + infrastructure encryption for higher level of assurance that the data is secure. + When infrastructure encryption is enabled, data in a storage account is encrypted + twice.","metadata":{"version":"1.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the audit policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"field":"Microsoft.Storage/storageAccounts/encryption.requireInfrastructureEncryption","notEquals":"true"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4733ea7b-a883-42fe-8cac-97454c2a9e4a","type":"Microsoft.Authorization/policyDefinitions","name":"4733ea7b-a883-42fe-8cac-97454c2a9e4a"},{"properties":{"displayName":"Secure + transfer to storage accounts should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + requirement of Secure transfer in your storage account. Secure transfer is + an option that forces your storage account to accept requests only from secure + connections (HTTPS). Use of HTTPS ensures authentication between the server + and the service and protects data in transit from network layer attacks such + as man-in-the-middle, eavesdropping, and session-hijacking","metadata":{"version":"2.0.0","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"anyOf":[{"allOf":[{"value":"[requestContext().apiVersion]","less":"2019-04-01"},{"field":"Microsoft.Storage/storageAccounts/supportsHttpsTrafficOnly","exists":"false"}]},{"field":"Microsoft.Storage/storageAccounts/supportsHttpsTrafficOnly","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/404c3081-a854-4457-ae30-26a93ef643f9","type":"Microsoft.Authorization/policyDefinitions","name":"404c3081-a854-4457-ae30-26a93ef643f9"},{"properties":{"displayName":"Diagnostic + logs in Azure Stream Analytics should be enabled","policyType":"BuiltIn","mode":"Indexed","description":"Audit + enabling of diagnostic logs. This enables you to recreate activity trails + to use for investigation purposes; when a security incident occurs or when + your network is compromised","metadata":{"version":"4.0.1","category":"Stream + Analytics"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"requiredRetentionDays":{"type":"String","metadata":{"displayName":"Required + retention (days)","description":"The required diagnostic logs retention in + days"},"defaultValue":"365"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.StreamAnalytics/streamingJobs"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","existenceCondition":{"count":{"field":"Microsoft.Insights/diagnosticSettings/logs[*]","where":{"anyOf":[{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","equals":"0"},{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days","greaterOrEquals":"[parameters(''requiredRetentionDays'')]"}]},{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"}]},{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"true"},{"anyOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled","notEquals":"true"},{"field":"Microsoft.Insights/diagnosticSettings/storageAccountId","exists":false}]}]}]}},"greaterOrEquals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f9be5368-9bf5-4b84-9e0a-7850da98bb46","type":"Microsoft.Authorization/policyDefinitions","name":"f9be5368-9bf5-4b84-9e0a-7850da98bb46"},{"properties":{"displayName":"Storage + accounts should restrict network access","policyType":"BuiltIn","mode":"Indexed","description":"Network + access to storage accounts should be restricted. Configure network rules so + only applications from allowed networks can access the storage account. To + allow connections from specific internet or on-premise clients, access can + be granted to traffic from specific Azure virtual networks or to public internet + IP address ranges","metadata":{"version":"1.1.1","category":"Storage"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"field":"Microsoft.Storage/storageAccounts/networkAcls.defaultAction","notEquals":"Deny"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/34c877ad-507e-4c82-993e-3452a6e0ad3c","type":"Microsoft.Authorization/policyDefinitions","name":"34c877ad-507e-4c82-993e-3452a6e0ad3c"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Stream Analytics to Log Analytics workspace","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Stream Analytics to stream to a regional Log Analytics + workspace when any Stream Analytics which is missing this diagnostic settings + is created or updated.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_logAnalytics"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Select Log Analytics workspace from dropdown + list. If this workspace is outside of the scope of the assignment you must + manually grant ''Log Analytics Contributor'' permissions (or similar) to the + policy assignment''s principal ID.","strongType":"omsWorkspace","assignPermissions":true}},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Log Analytics + workspace - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Log Analytics workspace + - True or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.StreamAnalytics/streamingjobs"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa","/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.StreamAnalytics/streamingjobs/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"workspaceId":"[parameters(''logAnalytics'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Execution","enabled":"[parameters(''logsEnabled'')]"},{"category":"Authoring","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/237e0f7e-b0e8-4ec4-ad46-8c12cb66d673","type":"Microsoft.Authorization/policyDefinitions","name":"237e0f7e-b0e8-4ec4-ad46-8c12cb66d673"},{"properties":{"displayName":"Audit + usage of custom RBAC rules","policyType":"BuiltIn","mode":"All","description":"Audit + built-in roles such as ''Owner, Contributer, Reader'' instead of custom RBAC + roles, which are error prone. Using custom roles is treated as an exception + and requires a rigorous review and threat modeling","metadata":{"version":"1.0.0","category":"General"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Authorization/roleDefinitions"},{"field":"Microsoft.Authorization/roleDefinitions/type","equals":"CustomRole"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a451c1ef-c6ca-483d-87ed-f49761e3ffb5","type":"Microsoft.Authorization/policyDefinitions","name":"a451c1ef-c6ca-483d-87ed-f49761e3ffb5"},{"properties":{"displayName":"Deploy + Diagnostic Settings for Stream Analytics to Event Hub","policyType":"BuiltIn","mode":"Indexed","description":"Deploys + the diagnostic settings for Stream Analytics to stream to a regional Event + Hub when any Stream Analytics which is missing this diagnostic settings is + created or updated.","metadata":{"version":"2.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"profileName":{"type":"String","metadata":{"displayName":"Profile + name","description":"The diagnostic settings profile name"},"defaultValue":"setbypolicy_eventHub"},"eventHubRuleId":{"type":"String","metadata":{"displayName":"Event + Hub Authorization Rule Id","description":"The Event Hub authorization rule + Id for Azure Diagnostics. The authorization rule needs to be at Event Hub + namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource + group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization + rule}","strongType":"Microsoft.EventHub/Namespaces/AuthorizationRules","assignPermissions":true}},"eventHubLocation":{"type":"String","metadata":{"displayName":"Event + Hub Location","description":"The location the Event Hub resides in. Only Stream + Analytics in this location will be linked to this Event Hub.","strongType":"location"},"defaultValue":""},"metricsEnabled":{"type":"String","metadata":{"displayName":"Enable + metrics","description":"Whether to enable metrics stream to the Event Hub + - True or False"},"allowedValues":["True","False"],"defaultValue":"False"},"logsEnabled":{"type":"String","metadata":{"displayName":"Enable + logs","description":"Whether to enable logs stream to the Event Hub - True + or False"},"allowedValues":["True","False"],"defaultValue":"True"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.StreamAnalytics/streamingjobs"},{"anyOf":[{"value":"[parameters(''eventHubLocation'')]","equals":""},{"field":"location","equals":"[parameters(''eventHubLocation'')]"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Insights/diagnosticSettings","name":"[parameters(''profileName'')]","existenceCondition":{"allOf":[{"field":"Microsoft.Insights/diagnosticSettings/logs.enabled","equals":"[parameters(''logsEnabled'')]"},{"field":"Microsoft.Insights/diagnosticSettings/metrics.enabled","equals":"[parameters(''metricsEnabled'')]"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"eventHubRuleId":{"type":"string"},"metricsEnabled":{"type":"string"},"logsEnabled":{"type":"string"},"profileName":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.StreamAnalytics/streamingjobs/providers/diagnosticSettings","apiVersion":"2017-05-01-preview","name":"[concat(parameters(''resourceName''), + ''/'', ''Microsoft.Insights/'', parameters(''profileName''))]","location":"[parameters(''location'')]","dependsOn":[],"properties":{"eventHubAuthorizationRuleId":"[parameters(''eventHubRuleId'')]","metrics":[{"category":"AllMetrics","enabled":"[parameters(''metricsEnabled'')]","retentionPolicy":{"enabled":false,"days":0}}],"logs":[{"category":"Execution","enabled":"[parameters(''logsEnabled'')]"},{"category":"Authoring","enabled":"[parameters(''logsEnabled'')]"}]}}],"outputs":{}},"parameters":{"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"},"eventHubRuleId":{"value":"[parameters(''eventHubRuleId'')]"},"metricsEnabled":{"value":"[parameters(''metricsEnabled'')]"},"logsEnabled":{"value":"[parameters(''logsEnabled'')]"},"profileName":{"value":"[parameters(''profileName'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/edf3780c-3d70-40fe-b17e-ab72013dafca","type":"Microsoft.Authorization/policyDefinitions","name":"edf3780c-3d70-40fe-b17e-ab72013dafca"},{"properties":{"displayName":"Microsoft + Antimalware for Azure should be configured to automatically update protection + signatures","policyType":"BuiltIn","mode":"Indexed","description":"This policy + audits any Windows virtual machine not configured with automatic update of + Microsoft Antimalware protection signatures.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","equals":"Windows"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"IaaSAntimalware"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Security"},{"field":"Microsoft.Compute/virtualMachines/extensions/autoUpgradeMinorVersion","equals":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c43e4a30-77cb-48ab-a4dd-93f175c63b57","type":"Microsoft.Authorization/policyDefinitions","name":"c43e4a30-77cb-48ab-a4dd-93f175c63b57"},{"properties":{"displayName":"Unattached + disks should be encrypted","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any unattached disk without encryption enabled.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/disks"},{"field":"Microsoft.Compute/disks/diskState","equals":"Unattached"},{"anyOf":[{"field":"Microsoft.Compute/disks/encryptionSettingsCollection.enabled","exists":"false"},{"field":"Microsoft.Compute/disks/encryptionSettingsCollection.enabled","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2c89a2e5-7285-40fe-afe0-ae8654b92fb2","type":"Microsoft.Authorization/policyDefinitions","name":"2c89a2e5-7285-40fe-afe0-ae8654b92fb2"},{"properties":{"displayName":"Only + approved VM extensions should be installed","policyType":"BuiltIn","mode":"Indexed","description":"This + policy governs the virtual machine extensions that are not approved.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"The + effect determines what happens when the policy rule is evaluated to match"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"approvedExtensions":{"type":"Array","metadata":{"description":"The + list of approved extension types that can be installed. Example: AzureDiskEncryption","displayName":"Approved + extensions"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines/extensions"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","notIn":"[parameters(''approvedExtensions'')]"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c0e996f8-39cf-4af9-9f45-83fbde810432","type":"Microsoft.Authorization/policyDefinitions","name":"c0e996f8-39cf-4af9-9f45-83fbde810432"},{"properties":{"displayName":"Azure + Backup should be enabled for Virtual Machines","policyType":"BuiltIn","mode":"Indexed","description":"Ensure + protection of your Azure Virtual Machines by enabling Azure Backup. Azure + Backup is a secure and cost effective data protection solution for Azure.","metadata":{"version":"1.0.1","category":"Backup"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachines"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.RecoveryServices/backupprotecteditems"}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/013e242c-8828-4970-87b3-ab247555486d","type":"Microsoft.Authorization/policyDefinitions","name":"013e242c-8828-4970-87b3-ab247555486d"},{"properties":{"displayName":"The + Log Analytics agent should be installed on virtual machines","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Windows/Linux virtual machines if the Log Analytics agent + is not installed.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachines"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","in":["MicrosoftMonitoringAgent","OmsAgentForLinux"]},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"},{"field":"Microsoft.Compute/virtualMachines/extensions/settings.workspaceId","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a70ca396-0a34-413a-88e1-b956c1e683be","type":"Microsoft.Authorization/policyDefinitions","name":"a70ca396-0a34-413a-88e1-b956c1e683be"},{"properties":{"displayName":"App + Service should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any App Service not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Web/sites"},{"field":"kind","like":"app*"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Web/sites/virtualNetworkConnections","existenceCondition":{"field":"Microsoft.Web/sites/virtualnetworkconnections/vnetResourceId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2d21331d-a4c2-4def-a9ad-ee4e1e023beb","type":"Microsoft.Authorization/policyDefinitions","name":"2d21331d-a4c2-4def-a9ad-ee4e1e023beb"},{"properties":{"displayName":"[Preview]: + Container Registry should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Container Registry not configured to use a virtual network + service endpoint.","metadata":{"version":"1.0.0-preview","category":"Network","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerRegistry/registries"},{"anyOf":[{"field":"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction","notEquals":"Deny"},{"field":"Microsoft.ContainerRegistry/registries/networkRuleSet.virtualNetworkRules[*].action","exists":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c4857be7-912a-4c75-87e6-e30292bcdf78","type":"Microsoft.Authorization/policyDefinitions","name":"c4857be7-912a-4c75-87e6-e30292bcdf78"},{"properties":{"displayName":"Cosmos + DB should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Cosmos DB not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.DocumentDB/databaseAccounts"},{"field":"Microsoft.DocumentDB/databaseAccounts/virtualNetworkRules[*].id","exists":"false"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e0a2b1a3-f7f9-4569-807f-2a9edebdf4d9","type":"Microsoft.Authorization/policyDefinitions","name":"e0a2b1a3-f7f9-4569-807f-2a9edebdf4d9"},{"properties":{"displayName":"Event + Hub should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Event Hub not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.EventHub/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.EventHub/namespaces/virtualNetworkRules","existenceCondition":{"field":"Microsoft.EventHub/namespaces/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d63edb4a-c612-454d-b47d-191a724fcbf0","type":"Microsoft.Authorization/policyDefinitions","name":"d63edb4a-c612-454d-b47d-191a724fcbf0"},{"properties":{"displayName":"Service + Bus should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Service Bus not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.ServiceBus/namespaces"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.ServiceBus/namespaces/virtualNetworkRules","existenceCondition":{"field":"Microsoft.ServiceBus/namespaces/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/235359c5-7c52-4b82-9055-01c75cf9f60e","type":"Microsoft.Authorization/policyDefinitions","name":"235359c5-7c52-4b82-9055-01c75cf9f60e"},{"properties":{"displayName":"Key + Vault should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Key Vault not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.KeyVault/vaults"},{"anyOf":[{"field":"Microsoft.KeyVault/vaults/networkAcls.defaultAction","notEquals":"Deny"},{"field":"Microsoft.KeyVault/vaults/networkAcls.virtualNetworkRules[*].id","exists":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ea4d6841-2173-4317-9747-ff522a45120f","type":"Microsoft.Authorization/policyDefinitions","name":"ea4d6841-2173-4317-9747-ff522a45120f"},{"properties":{"displayName":"SQL + Server should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any SQL Server not configured to use a virtual network service + endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/servers"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/virtualNetworkRules","existenceCondition":{"field":"Microsoft.Sql/servers/virtualNetworkRules/virtualNetworkSubnetId","exists":"true"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ae5d2f14-d830-42b6-9899-df6cfe9c71a3","type":"Microsoft.Authorization/policyDefinitions","name":"ae5d2f14-d830-42b6-9899-df6cfe9c71a3"},{"properties":{"displayName":"Storage + Accounts should use a virtual network service endpoint","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Storage Account not configured to use a virtual network + service endpoint.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"anyOf":[{"field":"Microsoft.Storage/storageAccounts/networkAcls.defaultAction","notEquals":"Deny"},{"field":"Microsoft.Storage/storageAccounts/networkAcls.virtualNetworkRules[*].id","exists":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/60d21c4f-21a3-4d94-85f4-b924e6aeeda4","type":"Microsoft.Authorization/policyDefinitions","name":"60d21c4f-21a3-4d94-85f4-b924e6aeeda4"},{"properties":{"displayName":"Virtual + networks should use specified virtual network gateway","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any virtual network if the default route does not point to the + specified virtual network gateway.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"virtualNetworkGatewayId":{"type":"String","metadata":{"displayName":"Virtual + network gateway Id","description":"Resource Id of the virtual network gateway. + Example: /subscriptions/YourSubscriptionId/resourceGroups/YourResourceGroup/providers/Microsoft.Network/virtualNetworkGateways/Name"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Network/virtualNetworks"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Network/virtualNetworks/subnets","name":"GatewaySubnet","existenceCondition":{"not":{"field":"Microsoft.Network/virtualNetworks/subnets/ipConfigurations[*].id","notContains":"[concat(parameters(''virtualNetworkGatewayId''), + ''/'')]"}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f1776c76-f58c-4245-a8d0-2b207198dc8b","type":"Microsoft.Authorization/policyDefinitions","name":"f1776c76-f58c-4245-a8d0-2b207198dc8b"},{"properties":{"displayName":"Deploy + default Microsoft IaaSAntimalware extension for Windows Server","policyType":"BuiltIn","mode":"Indexed","description":"This + policy deploys a Microsoft IaaSAntimalware extension with a default configuration + when a VM is not configured with the antimalware extension.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk"]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"IaaSAntimalware"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Security"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"ExclusionsPaths":{"type":"string","defaultValue":"","metadata":{"description":"Semicolon + delimited list of file paths or locations to exclude from scanning"}},"ExclusionsExtensions":{"type":"string","defaultValue":"","metadata":{"description":"Semicolon + delimited list of file extensions to exclude from scanning"}},"ExclusionsProcesses":{"type":"string","defaultValue":"","metadata":{"description":"Semicolon + delimited list of process names to exclude from scanning"}},"RealtimeProtectionEnabled":{"type":"string","defaultValue":"true","metadata":{"description":"Indicates + whether or not real time protection is enabled (default is true)"}},"ScheduledScanSettingsIsEnabled":{"type":"string","defaultValue":"false","metadata":{"description":"Indicates + whether or not custom scheduled scan settings are enabled (default is false)"}},"ScheduledScanSettingsScanType":{"type":"string","defaultValue":"Quick","metadata":{"description":"Indicates + whether scheduled scan setting type is set to Quick or Full (default is Quick)"}},"ScheduledScanSettingsDay":{"type":"string","defaultValue":"7","metadata":{"description":"Day + of the week for scheduled scan (1-Sunday, 2-Monday, ..., 7-Saturday)"}},"ScheduledScanSettingsTime":{"type":"string","defaultValue":"120","metadata":{"description":"When + to perform the scheduled scan, measured in minutes from midnight (0-1440). + For example: 0 = 12AM, 60 = 1AM, 120 = 2AM."}}},"resources":[{"name":"[concat(parameters(''vmName''),''/IaaSAntimalware'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","apiVersion":"2017-12-01","properties":{"publisher":"Microsoft.Azure.Security","type":"IaaSAntimalware","typeHandlerVersion":"1.3","autoUpgradeMinorVersion":true,"settings":{"AntimalwareEnabled":true,"RealtimeProtectionEnabled":"[parameters(''RealtimeProtectionEnabled'')]","ScheduledScanSettings":{"isEnabled":"[parameters(''ScheduledScanSettingsIsEnabled'')]","day":"[parameters(''ScheduledScanSettingsDay'')]","time":"[parameters(''ScheduledScanSettingsTime'')]","scanType":"[parameters(''ScheduledScanSettingsScanType'')]"},"Exclusions":{"Extensions":"[parameters(''ExclusionsExtensions'')]","Paths":"[parameters(''ExclusionsPaths'')]","Processes":"[parameters(''ExclusionsProcesses'')]"}}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"RealtimeProtectionEnabled":{"value":"true"},"ScheduledScanSettingsIsEnabled":{"value":"true"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2835b622-407b-4114-9198-6f7064cbe0dc","type":"Microsoft.Authorization/policyDefinitions","name":"2835b622-407b-4114-9198-6f7064cbe0dc"},{"properties":{"displayName":"[Deprecated]: + Deploy default Log Analytics Agent for Ubuntu VMs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy deploys the Log Analytics Agent on Ubuntu VMs, and connects to the + selected Log Analytics workspace","metadata":{"version":"1.0.0-deprecated","category":"Compute","deprecated":true},"parameters":{"logAnalytics":{"type":"String","metadata":{"displayName":"[Deprecated]: + Log Analytics workspace","description":"Select Log Analytics workspace from + dropdown list. If this workspace is outside of the scope of the assignment + you must manually grant ''Log Analytics Contributor'' permissions (or similar) + to the policy assignment''s principal ID.","strongType":"omsWorkspace"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","in":["18.04-LTS","16.04-LTS","16.04.0-LTS","14.04.2-LTS","12.04.5-LTS"]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"OmsAgentForLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"logAnalytics":{"type":"string"}},"resources":[{"name":"[concat(parameters(''vmName''),''/omsPolicy'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","apiVersion":"2017-12-01","properties":{"publisher":"Microsoft.EnterpriseCloud.Monitoring","type":"OmsAgentForLinux","typeHandlerVersion":"1.4","autoUpgradeMinorVersion":true,"settings":{"workspaceId":"[reference(parameters(''logAnalytics''), + ''2015-03-20'').customerId]"},"protectedSettings":{"workspaceKey":"[listKeys(parameters(''logAnalytics''), + ''2015-03-20'').primarySharedKey]"}}}],"outputs":{"policy":{"type":"string","value":"[concat(''Enabled + monitoring for Linux VM'', '': '', parameters(''vmName''))]"}}},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3d8640fc-63f6-4734-8dcb-cfd3d8c78f38","type":"Microsoft.Authorization/policyDefinitions","name":"3d8640fc-63f6-4734-8dcb-cfd3d8c78f38"},{"properties":{"displayName":"Audit + VMs that do not use managed disks","policyType":"BuiltIn","mode":"All","description":"This + policy audits VMs that do not use managed disks","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/virtualMachines/osDisk.uri","exists":"True"}]},{"allOf":[{"field":"type","equals":"Microsoft.Compute/VirtualMachineScaleSets"},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osDisk.vhdContainers","exists":"True"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/osdisk.imageUrl","exists":"True"}]}]}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d","type":"Microsoft.Authorization/policyDefinitions","name":"06a78e20-9358-41c9-923c-fb736d382a4d"},{"properties":{"displayName":"Allowed + virtual machine size SKUs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy enables you to specify a set of virtual machine size SKUs that your + organization can deploy.","metadata":{"version":"1.0.1","category":"Compute"},"parameters":{"listOfAllowedSKUs":{"type":"Array","metadata":{"description":"The + list of size SKUs that can be specified for virtual machines.","displayName":"Allowed + Size SKUs","strongType":"VMSKUs"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"not":{"field":"Microsoft.Compute/virtualMachines/sku.name","in":"[parameters(''listOfAllowedSKUs'')]"}}]},"then":{"effect":"Deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cccc23c7-8427-4f53-ad12-b6a63eb452b3","type":"Microsoft.Authorization/policyDefinitions","name":"cccc23c7-8427-4f53-ad12-b6a63eb452b3"},{"properties":{"displayName":"The + Log Analytics agent should be installed on Virtual Machine Scale Sets","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Windows/Linux Virtual Machine Scale Sets if the Log Analytics + agent is not installed.","metadata":{"version":"1.0.0","category":"Monitoring"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.EnterpriseCloud.Monitoring"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","in":["MicrosoftMonitoringAgent","OmsAgentForLinux"]},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/provisioningState","equals":"Succeeded"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/settings.workspaceId","exists":"true"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/efbde977-ba53-4479-b8e9-10b957924fbf","type":"Microsoft.Authorization/policyDefinitions","name":"efbde977-ba53-4479-b8e9-10b957924fbf"},{"properties":{"displayName":"Require + automatic OS image patching on Virtual Machine Scale Sets","policyType":"BuiltIn","mode":"All","description":"This + policy enforces enabling automatic OS image patching on Virtual Machine Scale + Sets to always keep Virtual Machines secure by safely applying latest security + patches every month.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/upgradePolicy.automaticOSUpgradePolicy.enableAutomaticOSUpgrade","notEquals":"True"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/upgradePolicy.automaticOSUpgrade","notEquals":"True"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/465f0161-0087-490a-9ad9-ad6217f4f43a","type":"Microsoft.Authorization/policyDefinitions","name":"465f0161-0087-490a-9ad9-ad6217f4f43a"},{"properties":{"displayName":"Azure + VPN gateways should not use ''basic'' SKU","policyType":"BuiltIn","mode":"All","description":"This + policy ensures that VPN gateways do not use ''basic'' SKU.","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworkGateways"},{"field":"Microsoft.Network/virtualNetworkGateways/gatewayType","equals":"Vpn"},{"field":"Microsoft.Network/virtualNetworkGateways/sku.tier","equals":"Basic"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e345b6c3-24bd-4c93-9bbb-7e5e49a17b78","type":"Microsoft.Authorization/policyDefinitions","name":"e345b6c3-24bd-4c93-9bbb-7e5e49a17b78"},{"properties":{"displayName":"A + custom IPsec/IKE policy must be applied to all Azure virtual network gateway + connections","policyType":"BuiltIn","mode":"All","description":"This policy + ensures that all Azure virtual network gateway connections use a custom Internet + Protocol Security(Ipsec)/Internet Key Exchange(IKE) policy. Supported algorithms + and key strengths - https://aka.ms/AA62kb0","metadata":{"version":"1.0.0","category":"Network"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"},"IPsecEncryption":{"type":"Array","metadata":{"displayName":"IPsec + Encryption","description":"IPsec Encryption"}},"IPsecIntegrity":{"type":"Array","metadata":{"displayName":"IPsec + Integrity","description":"IPsec Integrity"}},"IKEEncryption":{"type":"Array","metadata":{"displayName":"IKE + Encryption","description":"IKE Encryption"}},"IKEIntegrity":{"type":"Array","metadata":{"displayName":"IKE + Integrity","description":"IKE Integrity"}},"DHGroup":{"type":"Array","metadata":{"displayName":"DH + Group","description":"DH Group"}},"PFSGroup":{"type":"Array","metadata":{"displayName":"PFS + Group","description":"PFS Group"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/connections"},{"anyOf":[{"field":"Microsoft.Network/connections/ipsecPolicies[*].ipsecEncryption","notIn":"[parameters(''IPsecEncryption'')]"},{"field":"Microsoft.Network/connections/ipsecPolicies[*].ipsecIntegrity","notIn":"[parameters(''IPsecIntegrity'')]"},{"field":"Microsoft.Network/connections/ipsecPolicies[*].ikeEncryption","notIn":"[parameters(''IKEEncryption'')]"},{"field":"Microsoft.Network/connections/ipsecPolicies[*].ikeIntegrity","notIn":"[parameters(''IKEIntegrity'')]"},{"field":"Microsoft.Network/connections/ipsecPolicies[*].dhGroup","notIn":"[parameters(''DHGroup'')]"},{"field":"Microsoft.Network/connections/ipsecPolicies[*].pfsGroup","notIn":"[parameters(''PFSGroup'')]"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/50b83b09-03da-41c1-b656-c293c914862b","type":"Microsoft.Authorization/policyDefinitions","name":"50b83b09-03da-41c1-b656-c293c914862b"},{"properties":{"displayName":"Vulnerability + assessment should be enabled on your SQL servers","policyType":"BuiltIn","mode":"Indexed","description":"Audit + Azure SQL servers which do not have recurring vulnerability assessment scans + enabled. Vulnerability assessment can discover, track, and help you remediate + potential database vulnerabilities.","metadata":{"version":"2.0.0","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"kind","notContains":"analytics"}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/vulnerabilityAssessments","name":"default","existenceCondition":{"field":"Microsoft.Sql/servers/vulnerabilityAssessments/recurringScans.isEnabled","equals":"True"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef2a8f2a-b3d9-49cd-a8a8-9a3aaaf647d9","type":"Microsoft.Authorization/policyDefinitions","name":"ef2a8f2a-b3d9-49cd-a8a8-9a3aaaf647d9"},{"properties":{"displayName":"Vulnerability + assessment should be enabled on SQL Managed Instance","policyType":"BuiltIn","mode":"Indexed","description":"Audit + each SQL Managed Instance which doesn''t have recurring vulnerability assessment + scans enabled. Vulnerability assessment can discover, track, and help you + remediate potential database vulnerabilities.","metadata":{"version":"1.0.1","category":"SQL"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Sql/managedInstances"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/managedInstances/vulnerabilityAssessments","name":"default","existenceCondition":{"field":"Microsoft.Sql/managedInstances/vulnerabilityAssessments/recurringScans.isEnabled","equals":"True"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1b7aa243-30e4-4c9e-bca8-d0d3022b634a","type":"Microsoft.Authorization/policyDefinitions","name":"1b7aa243-30e4-4c9e-bca8-d0d3022b634a"},{"properties":{"displayName":"Microsoft + IaaSAntimalware extension should be deployed on Windows servers","policyType":"BuiltIn","mode":"Indexed","description":"This + policy audits any Windows server VM without Microsoft IaaSAntimalware extension + deployed.","metadata":{"version":"1.0.0","category":"Compute"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageOffer","equals":"WindowsServer"},{"field":"Microsoft.Compute/imageSKU","in":["2008-R2-SP1","2008-R2-SP1-smalldisk","2012-Datacenter","2012-Datacenter-smalldisk","2012-R2-Datacenter","2012-R2-Datacenter-smalldisk","2016-Datacenter","2016-Datacenter-Server-Core","2016-Datacenter-Server-Core-smalldisk","2016-Datacenter-smalldisk","2016-Datacenter-with-Containers","2016-Datacenter-with-RDSH","2019-Datacenter","2019-Datacenter-Core","2019-Datacenter-Core-smalldisk","2019-Datacenter-Core-with-Containers","2019-Datacenter-Core-with-Containers-smalldisk","2019-Datacenter-smalldisk","2019-Datacenter-with-Containers","2019-Datacenter-with-Containers-smalldisk"]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Compute/virtualMachines/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"IaaSAntimalware"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Security"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9b597639-28e4-48eb-b506-56b05d366257","type":"Microsoft.Authorization/policyDefinitions","name":"9b597639-28e4-48eb-b506-56b05d366257"},{"properties":{"displayName":"Allowlist + rules in your adaptive application control policy should be updated","policyType":"BuiltIn","mode":"All","description":"Monitor + for changes in behavior on groups of machines configured for auditing by Azure + Security Center''s adaptive application controls. Security Center uses machine + learning to analyze the running processes on your machines and suggest a list + of known-safe applications. These are presented as recommended apps to allow + in adaptive application control policies.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"1234abcd-1b53-4fd4-9835-2c2fa3935313","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/123a3936-f020-408a-ba0c-47873faf1534","type":"Microsoft.Authorization/policyDefinitions","name":"123a3936-f020-408a-ba0c-47873faf1534"},{"properties":{"displayName":"API + Management services should use a virtual network","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Virtual Network deployment provides enhanced security, isolation and allows + you to place your API Management service in a non-internet routable network + that you control access to. These networks can then be connected to your on-premises + networks using various VPN technologies, which enables access to your backend + services within the network and/or on-premises. The developer portal and API + gateway, can be configured to be accessible either from the Internet or only + within the virtual network.","metadata":{"version":"1.0.1","category":"API + Management"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"},"evaluatedSkuNames":{"type":"Array","metadata":{"displayName":"API + Management SKU Names","description":"List of API Management SKUs against which + this policy will be evaluated."},"allowedValues":["Developer","Basic","Standard","Premium","Consumption"],"defaultValue":["Developer","Premium"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ApiManagement/service"},{"field":"Microsoft.ApiManagement/service/sku.name","in":"[parameters(''evaluatedSkuNames'')]"},{"anyOf":[{"field":"Microsoft.ApiManagement/service/virtualNetworkType","exists":"false"},{"field":"Microsoft.ApiManagement/service/virtualNetworkType","equals":"None"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef619a2c-cc4d-4d03-b2ba-8c94a834d85b","type":"Microsoft.Authorization/policyDefinitions","name":"ef619a2c-cc4d-4d03-b2ba-8c94a834d85b"},{"properties":{"displayName":"Azure + Spring Cloud should use network injection","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Spring Cloud instances should use virtual network injection for the following + purposes: 1. Isolate Azure Spring Cloud from Internet. 2. Enable Azure Spring + Cloud to interact with systems in either on premises data centers or Azure + service in other virtual networks. 3. Empower customers to control inbound + and outbound network communications for Azure Spring Cloud.","metadata":{"version":"1.0.0","category":"App + Platform"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled","Deny"],"defaultValue":"Audit"},"evaluatedSkuNames":{"type":"Array","metadata":{"displayName":"Azure + Spring Cloud SKU Names","description":"List of Azure Spring Cloud SKUs against + which this policy will be evaluated."},"allowedValues":["Standard"],"defaultValue":["Standard"]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.AppPlatform/Spring"},{"field":"Microsoft.AppPlatform/Spring/sku.tier","in":"[parameters(''evaluatedSkuNames'')]"},{"field":"Microsoft.AppPlatform/Spring/networkProfile.serviceRuntimeSubnetId","exists":false}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/af35e2a4-ef96-44e7-a9ae-853dd97032c4","type":"Microsoft.Authorization/policyDefinitions","name":"af35e2a4-ef96-44e7-a9ae-853dd97032c4"},{"properties":{"displayName":"[Preview]: + Audit Azure Spring Cloud instances where distributed tracing is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"Distributed + tracing tools in Azure Spring Cloud allow debugging and monitoring the complex + interconnections between microservices in an application. Distributed tracing + tools should be enabled and in a healthy state.","metadata":{"version":"1.0.0-preview","category":"App + Platform","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.AppPlatform/Spring"},{"anyOf":[{"field":"Microsoft.AppPlatform/Spring/trace.enabled","notEquals":"true"},{"field":"Microsoft.AppPlatform/Spring/trace.state","notEquals":"Succeeded"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0f2d8593-4667-4932-acca-6a9f187af109","type":"Microsoft.Authorization/policyDefinitions","name":"0f2d8593-4667-4932-acca-6a9f187af109"},{"properties":{"displayName":"[Preview]: + All Internet traffic should be routed via your deployed Azure Firewall","policyType":"BuiltIn","mode":"All","description":"Azure + Security Center has identified that some of your subnets aren''t protected + with a next generation firewall. Protect your subnets from potential threats + by restricting access to them with Azure Firewall or a supported next generation + firewall","metadata":{"version":"3.0.0-preview","category":"Network","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable All Internet traffic should be routed + via your deployed Azure Firewall"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks"},{"count":{"field":"Microsoft.Network/virtualNetworks/subnets[*]","where":{"allOf":[{"count":{"field":"Microsoft.Network/virtualNetworks/subnets[*].ipConfigurations[*]","where":{"value":"[empty(field(''Microsoft.Network/virtualNetworks/subnets[*].ipConfigurations[*].id''))]","equals":false}},"greaterOrEquals":2},{"field":"Microsoft.Network/virtualNetworks/subnets[*].routeTable","exists":false},{"not":{"anyOf":[{"field":"Microsoft.Network/virtualNetworks/subnets[*].name","equals":"AzureBastionSubnet"},{"field":"Microsoft.Network/virtualNetworks/subnets[*].name","equals":"GatewaySubnet"}]}}]}},"greater":0}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Network/azureFirewalls","existenceCondition":{"count":{"field":"Microsoft.Network/azureFirewalls/ipConfigurations[*]","where":{"field":"Microsoft.Network/azureFirewalls/ipConfigurations[*].subnet.id","like":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/*/providers/Microsoft.Network/virtualNetworks/'', + first(split(field(''fullName''), ''/'')), ''/subnets/AzureFirewallSubnet'')]"}},"equals":1}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fc5e4038-4584-4632-8c85-c0448d374b2c","type":"Microsoft.Authorization/policyDefinitions","name":"fc5e4038-4584-4632-8c85-c0448d374b2c"},{"properties":{"displayName":"[Deprecated]: + Audit IP restrictions configuration for an API App","policyType":"BuiltIn","mode":"All","description":"IP + Restrictions allow you to define a list of IP addresses that are allowed to + access your app. Use of IP Restrictions protects an API app from common attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"ConfigureIPRestrictions","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/48893b84-a2c8-4d9a-badf-835d5d1b7d53","type":"Microsoft.Authorization/policyDefinitions","name":"48893b84-a2c8-4d9a-badf-835d5d1b7d53"},{"properties":{"displayName":"[Deprecated]: + Audit IP restrictions configuration for a Web Application","policyType":"BuiltIn","mode":"All","description":"IP + Restrictions allow you to define a list of IP addresses that are allowed to + access your app. Use of IP Restrictions protects a web application from common + attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"ConfigureIPRestrictions","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6a8450e2-6c61-43b4-be65-62e3a197bffe","type":"Microsoft.Authorization/policyDefinitions","name":"6a8450e2-6c61-43b4-be65-62e3a197bffe"},{"properties":{"displayName":"Adaptive + application controls for defining safe applications should be enabled on your + machines","policyType":"BuiltIn","mode":"All","description":"Enable application + controls to define the list of known-safe applications running on your machines, + and alert you when other applications run. This helps harden your machines + against malware. To simplify the process of configuring and maintaining your + rules, Security Center uses machine learning to analyze the applications running + on each machine and suggest the list of known-safe applications.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"35f45c95-27cf-4e52-891f-8390d1de5828","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/47a6b606-51aa-4496-8bb7-64b11cf66adc","type":"Microsoft.Authorization/policyDefinitions","name":"47a6b606-51aa-4496-8bb7-64b11cf66adc"},{"properties":{"displayName":"Vulnerabilities + in container security configurations should be remediated","policyType":"BuiltIn","mode":"All","description":"Audit + vulnerabilities in security configuration on machines with Docker installed + and display as recommendations in Azure Security Center.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"0677209d-e675-2c6f-e91a-54cef2878663","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e8cbc669-f12d-49eb-93e7-9273119e9933","type":"Microsoft.Authorization/policyDefinitions","name":"e8cbc669-f12d-49eb-93e7-9273119e9933"},{"properties":{"displayName":"[Deprecated]: + Audit missing blob encryption for storage accounts","policyType":"BuiltIn","mode":"All","description":"This + policy is no longer necessary because storage blob encryption is enabled by + default and cannot be turned off.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Storage/storageAccounts"},{"not":{"field":"Microsoft.Storage/storageAccounts/enableBlobEncryption","equals":"True"}}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/655cb504-bcee-4362-bd4c-402e6aa38759","type":"Microsoft.Authorization/policyDefinitions","name":"655cb504-bcee-4362-bd4c-402e6aa38759"},{"properties":{"displayName":"[Deprecated]: + Audit IP restrictions configuration for a Function App","policyType":"BuiltIn","mode":"All","description":"IP + Restrictions allow you to define a list of IP addresses that are allowed to + access your app. Use of IP Restrictions protects a Function app from common + attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"functionapp"},{"field":"kind","equals":"functionapp,linux"},{"field":"kind","equals":"functionapp,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"ConfigureIPRestrictions","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/664346d9-be92-43fb-a219-d595eeb76a90","type":"Microsoft.Authorization/policyDefinitions","name":"664346d9-be92-43fb-a219-d595eeb76a90"},{"properties":{"displayName":"Vulnerabilities + in Azure Container Registry images should be remediated","policyType":"BuiltIn","mode":"All","description":"Container + image vulnerability assessment scans your registry for security vulnerabilities + on each pushed container image and exposes detailed findings for each image + (powered by Qualys). Resolving the vulnerabilities can greatly improve your + containers'' security posture and protect them from attacks.","metadata":{"version":"2.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.ContainerRegistry/registries"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"dbd0cb49-b563-45e7-9724-889e799fa648","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5f0f936f-2f01-4bf5-b6be-d423792fa562","type":"Microsoft.Authorization/policyDefinitions","name":"5f0f936f-2f01-4bf5-b6be-d423792fa562"},{"properties":{"displayName":"There + should be more than one owner assigned to your subscription","policyType":"BuiltIn","mode":"All","description":"It + is recommended to designate more than one subscription owner in order to have + administrator access redundancy.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"2c79b4af-f830-b61e-92b9-63dfa30f16e4","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/09024ccc-0c5f-475e-9457-b7c0d9ed487b","type":"Microsoft.Authorization/policyDefinitions","name":"09024ccc-0c5f-475e-9457-b7c0d9ed487b"},{"properties":{"displayName":"Enable + Security Center''s auto provisioning of the Log Analytics agent on your subscriptions + with default workspace.","policyType":"BuiltIn","mode":"All","description":"Allow + Security Center to auto provision the Log Analytics agent on your subscriptions + to monitor and collect security data using ASC default workspace.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/autoProvisioningSettings","deploymentScope":"Subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"field":"Microsoft.Security/autoProvisioningSettings/autoProvision","equals":"On"},"deployment":{"location":"westus","properties":{"mode":"incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[{"type":"Microsoft.Security/autoProvisioningSettings","name":"default","apiVersion":"2017-08-01-preview","properties":{"autoProvision":"On"}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6df2fee6-a9ed-4fef-bced-e13be1b25f1c","type":"Microsoft.Authorization/policyDefinitions","name":"6df2fee6-a9ed-4fef-bced-e13be1b25f1c"},{"properties":{"displayName":"A + maximum of 3 owners should be designated for your subscription","policyType":"BuiltIn","mode":"All","description":"It + is recommended to designate up to 3 subscription owners in order to reduce + the potential for breach by a compromised owner.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"6f90a6d6-d4d6-0794-0ec1-98fa77878c2e","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4f11b553-d42e-4e3a-89be-32ca364cad4c","type":"Microsoft.Authorization/policyDefinitions","name":"4f11b553-d42e-4e3a-89be-32ca364cad4c"},{"properties":{"displayName":"[Deprecated]: + Audit Web Sockets state for a Web Application","policyType":"BuiltIn","mode":"All","description":"The + Web Sockets protocol is vulnerable to different types of security threats. + Use of Web Sockets within a web application must be carefully reviewed.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"DisableWebSockets","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e797f851-8be7-4c40-bb56-2e3395215b0e","type":"Microsoft.Authorization/policyDefinitions","name":"e797f851-8be7-4c40-bb56-2e3395215b0e"},{"properties":{"displayName":"[Deprecated]: + Audit Web Sockets state for a Function App","policyType":"BuiltIn","mode":"All","description":"The + Web Sockets protocol is vulnerable to different types of security threats. + Use of Web Sockets within an Function app must be carefully reviewed.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"functionapp"},{"field":"kind","equals":"functionapp,linux"},{"field":"kind","equals":"functionapp,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"DisableWebSockets","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/001802d1-4969-4c82-a700-c29c6c6f9bbd","type":"Microsoft.Authorization/policyDefinitions","name":"001802d1-4969-4c82-a700-c29c6c6f9bbd"},{"properties":{"displayName":"[Deprecated]: + Audit Web Sockets state for an API App","policyType":"BuiltIn","mode":"All","description":"The + Web Sockets protocol is vulnerable to different types of security threats. + Use of Web Sockets within an API app must be carefully reviewed.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"DisableWebSockets","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b48334a4-911b-4084-b1ab-3e6a4e50b951","type":"Microsoft.Authorization/policyDefinitions","name":"b48334a4-911b-4084-b1ab-3e6a4e50b951"},{"properties":{"displayName":"Enable + Security Center''s auto provisioning of the Log Analytics agent on your subscriptions + with custom workspace.","policyType":"BuiltIn","mode":"All","description":"Allow + Security Center to auto provision the Log Analytics agent on your subscriptions + to monitor and collect security data using a custom workspace.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["DeployIfNotExists","Disabled"],"defaultValue":"DeployIfNotExists"},"logAnalytics":{"type":"String","metadata":{"displayName":"Log + Analytics workspace","description":"Auto provision the Log Analytics agent + on your subscriptions to monitor and collect security data using a custom + workspace.","strongType":"omsWorkspace"}}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/autoProvisioningSettings","deploymentScope":"Subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"field":"Microsoft.Security/autoProvisioningSettings/autoProvision","equals":"On"},"deployment":{"location":"westus","properties":{"mode":"incremental","parameters":{"logAnalytics":{"value":"[parameters(''logAnalytics'')]"}},"template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"logAnalytics":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.Security/autoProvisioningSettings","name":"default","apiVersion":"2017-08-01-preview","properties":{"autoProvision":"On"}},{"type":"Microsoft.Security/workspaceSettings","apiVersion":"2017-08-01-preview","name":"default","properties":{"workspaceId":"[parameters(''logAnalytics'')]","scope":"[subscription().id]"}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8e7da0a5-0a0e-4bbc-bfc0-7773c018b616","type":"Microsoft.Authorization/policyDefinitions","name":"8e7da0a5-0a0e-4bbc-bfc0-7773c018b616"},{"properties":{"displayName":"Azure + Defender for Azure SQL Database servers should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for SQL provides functionality for surfacing and mitigating potential + database vulnerabilities, detecting anomalous activities that could indicate + threats to SQL databases, and discovering and classifying sensitive data.","metadata":{"version":"1.0.2","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"SqlServers","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7fe3b40f-802b-4cdd-8bd4-fd799c948cc2","type":"Microsoft.Authorization/policyDefinitions","name":"7fe3b40f-802b-4cdd-8bd4-fd799c948cc2"},{"properties":{"displayName":"Azure + Defender for App Service should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for App Service leverages the scale of the cloud, and the visibility + that Azure has as a cloud provider, to monitor for common web app attacks.","metadata":{"version":"1.0.3","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"AppServices","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2913021d-f2fd-4f3d-b958-22354e2bdbcb","type":"Microsoft.Authorization/policyDefinitions","name":"2913021d-f2fd-4f3d-b958-22354e2bdbcb"},{"properties":{"displayName":"Azure + Defender for container registries should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for container registries provides vulnerability scanning of any images + pulled within the last 30 days, pushed to your registry, or imported, and + exposes detailed findings per image.","metadata":{"version":"1.0.3","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"ContainerRegistry","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c25d9a16-bc35-4e15-a7e5-9db606bf9ed4","type":"Microsoft.Authorization/policyDefinitions","name":"c25d9a16-bc35-4e15-a7e5-9db606bf9ed4"},{"properties":{"displayName":"Azure + Defender for Key Vault should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for Key Vault provides an additional layer of protection and security + intelligence by detecting unusual and potentially harmful attempts to access + or exploit key vault accounts.","metadata":{"version":"1.0.3","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"KeyVaults","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0e6763cc-5078-4e64-889d-ff4d9a839047","type":"Microsoft.Authorization/policyDefinitions","name":"0e6763cc-5078-4e64-889d-ff4d9a839047"},{"properties":{"displayName":"Azure + Defender for Kubernetes should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for Kubernetes provides real-time threat protection for containerized + environments and generates alerts for suspicious activities.","metadata":{"version":"1.0.3","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"KubernetesService","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/523b5cd1-3e23-492f-a539-13118b6d1e3a","type":"Microsoft.Authorization/policyDefinitions","name":"523b5cd1-3e23-492f-a539-13118b6d1e3a"},{"properties":{"displayName":"Azure + Defender for servers should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for servers provides real-time threat protection for server workloads + and generates hardening recommendations as well as alerts about suspicious + activities.","metadata":{"version":"1.0.3","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"VirtualMachines","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4da35fc9-c9e7-4960-aec9-797fe7d9051d","type":"Microsoft.Authorization/policyDefinitions","name":"4da35fc9-c9e7-4960-aec9-797fe7d9051d"},{"properties":{"displayName":"Azure + Defender for Storage should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for Storage provides detections of unusual and potentially harmful + attempts to access or exploit storage accounts.","metadata":{"version":"1.0.3","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"StorageAccounts","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/308fbb08-4ab8-4e67-9b29-592e93fb94fa","type":"Microsoft.Authorization/policyDefinitions","name":"308fbb08-4ab8-4e67-9b29-592e93fb94fa"},{"properties":{"displayName":"Authorized + IP ranges should be defined on Kubernetes Services","policyType":"BuiltIn","mode":"All","description":"Restrict + access to the Kubernetes Service Management API by granting API access only + to IP addresses in specific ranges. It is recommended to limit access to authorized + IP ranges to ensure that only applications from allowed networks can access + the cluster.","metadata":{"version":"2.0.1","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"field":"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.authorizedIPRanges","exists":"false"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.enablePrivateCluster","exists":"false"},{"field":"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.enablePrivateCluster","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0e246bcf-5f6f-4f87-bc6f-775d4712c7ea","type":"Microsoft.Authorization/policyDefinitions","name":"0e246bcf-5f6f-4f87-bc6f-775d4712c7ea"},{"properties":{"displayName":"MFA + should be enabled on accounts with owner permissions on your subscription","policyType":"BuiltIn","mode":"All","description":"Multi-Factor + Authentication (MFA) should be enabled for all subscription accounts with + owner permissions to prevent a breach of accounts or resources.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"94290b00-4d0c-d7b4-7cea-064a9554e681","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/aa633080-8b72-40c4-a2d7-d00c03e80bed","type":"Microsoft.Authorization/policyDefinitions","name":"aa633080-8b72-40c4-a2d7-d00c03e80bed"},{"properties":{"displayName":"Azure + Defender for SQL servers on machines should be enabled","policyType":"BuiltIn","mode":"All","description":"Azure + Defender for SQL provides functionality for surfacing and mitigating potential + database vulnerabilities, detecting anomalous activities that could indicate + threats to SQL databases, and discovering and classifying sensitive data.","metadata":{"version":"1.0.2","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/pricings","name":"SqlServerVirtualMachines","existenceScope":"subscription","existenceCondition":{"field":"Microsoft.Security/pricings/pricingTier","equals":"Standard"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6581d072-105e-4418-827f-bd446d56421b","type":"Microsoft.Authorization/policyDefinitions","name":"6581d072-105e-4418-827f-bd446d56421b"},{"properties":{"displayName":"Azure + DDoS Protection Standard should be enabled","policyType":"BuiltIn","mode":"All","description":"DDoS + protection standard should be enabled for all virtual networks with a subnet + that is part of an application gateway with a public IP.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"microsoft.network/virtualNetworks"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"e3de1cc0-f4dd-3b34-e496-8b5381ba2d70","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a7aca53f-2ed4-4466-a25e-0b45ade68efd","type":"Microsoft.Authorization/policyDefinitions","name":"a7aca53f-2ed4-4466-a25e-0b45ade68efd"},{"properties":{"displayName":"MFA + should be enabled accounts with write permissions on your subscription","policyType":"BuiltIn","mode":"All","description":"Multi-Factor + Authentication (MFA) should be enabled for all subscription accounts with + write privileges to prevent a breach of accounts or resources.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"57e98606-6b1e-6193-0e3d-fe621387c16b","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9297c21d-2ed6-4474-b48f-163f75654ce3","type":"Microsoft.Authorization/policyDefinitions","name":"9297c21d-2ed6-4474-b48f-163f75654ce3"},{"properties":{"displayName":"MFA + should be enabled on accounts with read permissions on your subscription","policyType":"BuiltIn","mode":"All","description":"Multi-Factor + Authentication (MFA) should be enabled for all subscription accounts with + read privileges to prevent a breach of accounts or resources.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"151e82c5-5341-a74b-1eb0-bc38d2c84bb5","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e3576e28-8b17-4677-84c3-db2990658d64","type":"Microsoft.Authorization/policyDefinitions","name":"e3576e28-8b17-4677-84c3-db2990658d64"},{"properties":{"displayName":"[Deprecated]: + Pod Security Policies should be defined on Kubernetes Services","policyType":"BuiltIn","mode":"All","description":"Define + Pod Security Policies to reduce the attack vector by removing unnecessary + application privileges. It is recommended to configure Pod Security Policies + to only allow pods to access the resources which they have permissions to + access.","metadata":{"version":"1.0.0-deprecated","category":"Security Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/enablePodSecurityPolicy","exists":"false"},{"field":"Microsoft.ContainerService/managedClusters/enablePodSecurityPolicy","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3abeb944-26af-43ee-b83d-32aaf060fb94","type":"Microsoft.Authorization/policyDefinitions","name":"3abeb944-26af-43ee-b83d-32aaf060fb94"},{"properties":{"displayName":"[Deprecated]: + API App should only be accessible over HTTPS","policyType":"BuiltIn","mode":"All","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"OnlyHttpsForApiApp","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c85538c1-b527-4ce4-bdb4-1dabcb3fd90d","type":"Microsoft.Authorization/policyDefinitions","name":"c85538c1-b527-4ce4-bdb4-1dabcb3fd90d"},{"properties":{"displayName":"[Deprecated]: + Web Application should only be accessible over HTTPS","policyType":"BuiltIn","mode":"All","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"OnlyHttpsForWebApplication","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2fde8a98-6892-426a-83ba-050e640c0ce0","type":"Microsoft.Authorization/policyDefinitions","name":"2fde8a98-6892-426a-83ba-050e640c0ce0"},{"properties":{"displayName":"Role-Based + Access Control (RBAC) should be used on Kubernetes Services","policyType":"BuiltIn","mode":"All","description":"To + provide granular filtering on the actions that users can perform, use Role-Based + Access Control (RBAC) to manage permissions in Kubernetes Service Clusters + and configure relevant authorization policies.","metadata":{"version":"1.0.2","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/enableRBAC","exists":"false"},{"field":"Microsoft.ContainerService/managedClusters/enableRBAC","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ac4a19c2-fa67-49b4-8ae5-0b2e78c49457","type":"Microsoft.Authorization/policyDefinitions","name":"ac4a19c2-fa67-49b4-8ae5-0b2e78c49457"},{"properties":{"displayName":"[Deprecated]: + Function App should only be accessible over HTTPS","policyType":"BuiltIn","mode":"All","description":"Use + of HTTPS ensures server/service authentication and protects data in transit + from network layer eavesdropping attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"functionapp"},{"field":"kind","equals":"functionapp,linux"},{"field":"kind","equals":"functionapp,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"OnlyHttpsForFunctionApp","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5df82f4f-773a-4a2d-97a2-422a806f1a55","type":"Microsoft.Authorization/policyDefinitions","name":"5df82f4f-773a-4a2d-97a2-422a806f1a55"},{"properties":{"displayName":"Log + Analytics agent should be installed on your virtual machine scale sets for + Azure Security Center monitoring","policyType":"BuiltIn","mode":"All","description":"Security + Center collects data from your Azure virtual machines (VMs) to monitor for + security vulnerabilities and threats.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachineScaleSets"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"45cfe080-ceb1-a91e-9743-71551ed24e94","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a3a6ea0c-e018-4933-9ef0-5aaa1501449b","type":"Microsoft.Authorization/policyDefinitions","name":"a3a6ea0c-e018-4933-9ef0-5aaa1501449b"},{"properties":{"displayName":"Log + Analytics agent should be installed on your virtual machine for Azure Security + Center monitoring","policyType":"BuiltIn","mode":"All","description":"This + policy audits any Windows/Linux virtual machines (VMs) if the Log Analytics + agent is not installed which Security Center uses to monitor for security + vulnerabilities and threats","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.ClassicCompute/virtualMachines","Microsoft.Compute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"d1db3318-01ff-16de-29eb-28b344515626","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a4fe33eb-e377-4efb-ab31-0784311bc499","type":"Microsoft.Authorization/policyDefinitions","name":"a4fe33eb-e377-4efb-ab31-0784311bc499"},{"properties":{"displayName":"Management + ports of virtual machines should be protected with just-in-time network access + control","policyType":"BuiltIn","mode":"All","description":"Possible network + Just In Time (JIT) access will be monitored by Azure Security Center as recommendations","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachines"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"805651bc-6ecd-4c73-9b55-97a19d0582d0","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b0f33259-77d7-4c9e-aac6-3aabcfae693c","type":"Microsoft.Authorization/policyDefinitions","name":"b0f33259-77d7-4c9e-aac6-3aabcfae693c"},{"properties":{"displayName":"IP + Forwarding on your virtual machine should be disabled","policyType":"BuiltIn","mode":"All","description":"Enabling + IP forwarding on a virtual machine''s NIC allows the machine to receive traffic + addressed to other destinations. IP forwarding is rarely required (e.g., when + using the VM as a network virtual appliance), and therefore, this should be + reviewed by the network security team.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"c3b51c94-588b-426b-a892-24696f9e54cc","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bd352bd5-2853-4985-bf0d-73806b4a5744","type":"Microsoft.Authorization/policyDefinitions","name":"bd352bd5-2853-4985-bf0d-73806b4a5744"},{"properties":{"displayName":"Non-internet-facing + virtual machines should be protected with network security groups","policyType":"BuiltIn","mode":"All","description":"Protect + your non-internet-facing virtual machines from potential threats by restricting + access with network security groups (NSG). Learn more about controlling traffic + with NSGs at https://aka.ms/nsg-doc","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"a9341235-9389-42f0-a0bf-9bfb57960d44","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bb91dfba-c30d-4263-9add-9c2384e659a6","type":"Microsoft.Authorization/policyDefinitions","name":"bb91dfba-c30d-4263-9add-9c2384e659a6"},{"properties":{"displayName":"Subnets + should be associated with a Network Security Group","policyType":"BuiltIn","mode":"All","description":"Protect + your subnet from potential threats by restricting access to it with a Network + Security Group (NSG). NSGs contain a list of Access Control List (ACL) rules + that allow or deny network traffic to your subnet.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"eade5b56-eefd-444f-95c8-23f29e5d93cb","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e71308d3-144b-4262-b144-efdc3cc90517","type":"Microsoft.Authorization/policyDefinitions","name":"e71308d3-144b-4262-b144-efdc3cc90517"},{"properties":{"displayName":"Monitor + missing Endpoint Protection in Azure Security Center","policyType":"BuiltIn","mode":"All","description":"Servers + without an installed Endpoint Protection agent will be monitored by Azure + Security Center as recommendations","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"3bcd234d-c9c7-c2a2-89e0-c01f419c1a8a","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/af6cd1bd-1635-48cb-bde7-5b15693900b9","type":"Microsoft.Authorization/policyDefinitions","name":"af6cd1bd-1635-48cb-bde7-5b15693900b9"},{"properties":{"displayName":"System + updates should be installed on your machines","policyType":"BuiltIn","mode":"All","description":"Missing + security system updates on your servers will be monitored by Azure Security + Center as recommendations","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"c0f5316d-5ac5-9218-b77a-b96e16ccfd66","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86b3d65f-7626-441e-b690-81a8b71cff60","type":"Microsoft.Authorization/policyDefinitions","name":"86b3d65f-7626-441e-b690-81a8b71cff60"},{"properties":{"displayName":"Internet-facing + virtual machines should be protected with network security groups","policyType":"BuiltIn","mode":"All","description":"Protect + your virtual machines from potential threats by restricting access to them + with network security groups (NSG). Learn more about controlling traffic with + NSGs at https://aka.ms/nsg-doc","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"483f12ed-ae23-447e-a2de-a67a10db4353","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f6de0be7-9a8a-4b8a-b349-43cf02d22f7c","type":"Microsoft.Authorization/policyDefinitions","name":"f6de0be7-9a8a-4b8a-b349-43cf02d22f7c"},{"properties":{"displayName":"Management + ports should be closed on your virtual machines","policyType":"BuiltIn","mode":"All","description":"Open + remote management ports are exposing your VM to a high level of risk from + Internet-based attacks. These attacks attempt to brute force credentials to + gain admin access to the machine.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"bc303248-3d14-44c2-96a0-55f5c326b5fe","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/22730e10-96f6-4aac-ad84-9383d35b5917","type":"Microsoft.Authorization/policyDefinitions","name":"22730e10-96f6-4aac-ad84-9383d35b5917"},{"properties":{"displayName":"Vulnerabilities + in security configuration on your machines should be remediated","policyType":"BuiltIn","mode":"All","description":"Servers + which do not satisfy the configured baseline will be monitored by Azure Security + Center as recommendations","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"181ac480-f7c4-544b-9865-11b8ffe87f47","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e1e5fd5d-3e4c-4ce1-8661-7d1873ae6b15","type":"Microsoft.Authorization/policyDefinitions","name":"e1e5fd5d-3e4c-4ce1-8661-7d1873ae6b15"},{"properties":{"displayName":"[Deprecated]: + Access to App Services should be restricted","policyType":"BuiltIn","mode":"All","description":"Azure + security center has discovered that the networking configuration of some of + your app services are overly permissive and allow inbound traffic from ranges + that are too broad","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Web/sites"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"restrictAccessToAppServices","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1a833ff1-d297-4a0f-9944-888428f8e0ff","type":"Microsoft.Authorization/policyDefinitions","name":"1a833ff1-d297-4a0f-9944-888428f8e0ff"},{"properties":{"displayName":"Enable + Azure Security Center on your subscription","policyType":"BuiltIn","mode":"All","description":"Identifies + existing subscriptions that are not monitored by Azure Security Center (ASC).\r\nSubscriptions + not monitored by ASC will be registered to the free pricing tier.\r\nSubscriptions + already monitored by ASC (free or standard), will be considered compliant.\r\nTo + register newly created subscriptions, open the compliance tab, select the + relevant non-compliant assignment and create a remediation task.\r\nRepeat + this step when you have one or more new subscriptions you want to monitor + with Security Center.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/pricings","name":"VirtualMachines","deploymentScope":"subscription","existenceScope":"subscription","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd"],"existenceCondition":{"anyof":[{"field":"microsoft.security/pricings/pricingTier","equals":"standard"},{"field":"microsoft.security/pricings/pricingTier","equals":"free"}]},"deployment":{"location":"westeurope","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","variables":{},"resources":[{"type":"Microsoft.Security/pricings","apiVersion":"2018-06-01","name":"VirtualMachines","properties":{"pricingTier":"free"}}],"outputs":{}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ac076320-ddcf-4066-b451-6154267e8ad2","type":"Microsoft.Authorization/policyDefinitions","name":"ac076320-ddcf-4066-b451-6154267e8ad2"},{"properties":{"displayName":"[Deprecated]: + Monitor permissive network access in Azure Security Center","policyType":"BuiltIn","mode":"All","description":"Network + Security Groups with too permissive rules will be monitored by Azure Security + Center as recommendations","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"permissiveNetworkAccess","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/44452482-524f-4bf4-b852-0bff7cc4a3ed","type":"Microsoft.Authorization/policyDefinitions","name":"44452482-524f-4bf4-b852-0bff7cc4a3ed"},{"properties":{"displayName":"Deprecated + accounts with owner permissions should be removed from your subscription","policyType":"BuiltIn","mode":"All","description":"Deprecated + accounts with owner permissions should be removed from your subscription. Deprecated + accounts are accounts that have been blocked from signing in.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"e52064aa-6853-e252-a11e-dffc675689c2","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ebb62a0c-3560-49e1-89ed-27e074e9f8ad","type":"Microsoft.Authorization/policyDefinitions","name":"ebb62a0c-3560-49e1-89ed-27e074e9f8ad"},{"properties":{"displayName":"External + accounts with write permissions should be removed from your subscription","policyType":"BuiltIn","mode":"All","description":"External + accounts with write privileges should be removed from your subscription in + order to prevent unmonitored access.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"04e7147b-0deb-9796-2e5c-0336343ceb3d","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5c607a2e-c700-4744-8254-d77e7c9eb5e4","type":"Microsoft.Authorization/policyDefinitions","name":"5c607a2e-c700-4744-8254-d77e7c9eb5e4"},{"properties":{"displayName":"External + accounts with owner permissions should be removed from your subscription","policyType":"BuiltIn","mode":"All","description":"External + accounts with owner permissions should be removed from your subscription in + order to prevent unmonitored access.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"c3b6ae71-f1f0-31b4-e6c1-d5951285d03d","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f8456c1c-aa66-4dfb-861a-25d127b775c9","type":"Microsoft.Authorization/policyDefinitions","name":"f8456c1c-aa66-4dfb-861a-25d127b775c9"},{"properties":{"displayName":"Deprecated + accounts should be removed from your subscription","policyType":"BuiltIn","mode":"All","description":"Deprecated + accounts should be removed from your subscriptions. Deprecated accounts are + accounts that have been blocked from signing in.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"00c6d40b-e990-6acf-d4f3-471e747a27c4","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6b1cbf55-e8b6-442f-ba4c-7246b6381474","type":"Microsoft.Authorization/policyDefinitions","name":"6b1cbf55-e8b6-442f-ba4c-7246b6381474"},{"properties":{"displayName":"External + accounts with read permissions should be removed from your subscription","policyType":"BuiltIn","mode":"All","description":"External + accounts with read privileges should be removed from your subscription in + order to prevent unmonitored access.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"a8c6a4ad-d51e-88fe-2979-d3ee3c864f8b","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5f76cf89-fbf2-47fd-a3f4-b891fa780b60","type":"Microsoft.Authorization/policyDefinitions","name":"5f76cf89-fbf2-47fd-a3f4-b891fa780b60"},{"properties":{"displayName":"Log + Analytics agent health issues should be resolved on your machines","policyType":"BuiltIn","mode":"All","description":"Security + Center uses the Log Analytics agent, formerly known as the Microsoft Monitoring + Agent (MMA). To make sure your virtual machines are successfully monitored, + you need to make sure the agent is installed on the virtual machines and properly + collects security events to the configured workspace.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.ClassicCompute/virtualMachines","Microsoft.Compute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"8e2b96ff-3de2-289b-b5c1-3b9921a3441e","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d62cfe2b-3ab0-4d41-980d-76803b58ca65","type":"Microsoft.Authorization/policyDefinitions","name":"d62cfe2b-3ab0-4d41-980d-76803b58ca65"},{"properties":{"displayName":"[Deprecated]: + Automatic provisioning of security monitoring agent","policyType":"BuiltIn","mode":"All","description":"Installs + security agent on VMs for advanced security alerts and preventions in Azure + Security Center. Applies only for subscriptions that use Azure Security Center.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"AuditIfNotExists","details":{"type":"Microsoft.Security/complianceResults","name":"securityAgent","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/abcc6037-1fc4-47f6-aac5-89706589be24","type":"Microsoft.Authorization/policyDefinitions","name":"abcc6037-1fc4-47f6-aac5-89706589be24"},{"properties":{"displayName":"A + vulnerability assessment solution should be enabled on your virtual machines","policyType":"BuiltIn","mode":"All","description":"Audits + virtual machines to detect whether they are running a supported vulnerability + assessment solution. A core component of every cyber risk and security program + is the identification and analysis of vulnerabilities. Azure Security Center''s + standard pricing tier includes vulnerability scanning for your virtual machines + at no extra cost. Additionally, Security Center can automatically deploy this + tool for you.","metadata":{"version":"3.0.0","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"ffff0522-1e88-47fc-8382-2a80ba848f5d","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/501541f7-f7e7-4cd6-868c-4190fdad3ac9","type":"Microsoft.Authorization/policyDefinitions","name":"501541f7-f7e7-4cd6-868c-4190fdad3ac9"},{"properties":{"displayName":"[Deprecated]: + A security contact phone number should be provided for your subscription","policyType":"BuiltIn","mode":"All","description":"Enter + a phone number to receive notifications when Azure Security Center detects + compromised resources - This policy is deprecated because phone numbers are + no longer used in any scenario by Azure Security Center","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/securityContacts","existenceCondition":{"field":"Microsoft.Security/securityContacts/phone","notEquals":""}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b4d66858-c922-44e3-9566-5cdb7a7be744","type":"Microsoft.Authorization/policyDefinitions","name":"b4d66858-c922-44e3-9566-5cdb7a7be744"},{"properties":{"displayName":"[Preview]: + Sensitive data in your SQL databases should be classified","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Security Center monitors the data discovery and classification scan results + for your SQL databases and provides recommendations to classify the sensitive + data in your databases for better monitoring and security","metadata":{"version":"3.0.0-preview","category":"Security + Center","preview":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Sql/servers/databases","Microsoft.Sql/managedInstances/databases"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"b0df6f56-862d-4730-8597-38c0fd4ebd59","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cc9835f2-9f6b-4cc8-ab4a-f8ef615eb349","type":"Microsoft.Authorization/policyDefinitions","name":"cc9835f2-9f6b-4cc8-ab4a-f8ef615eb349"},{"properties":{"displayName":"Security + Center standard pricing tier should be selected","policyType":"BuiltIn","mode":"All","description":"The + standard pricing tier enables threat detection for networks and virtual machines, + providing threat intelligence, anomaly detection, and behavior analytics in + Azure Security Center","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Security/pricings"},{"field":"Microsoft.Security/pricings/pricingTier","exists":"true"},{"field":"Microsoft.Security/pricings/pricingTier","notEquals":"Standard"}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a1181c5f-672a-477a-979a-7d58aa086233","type":"Microsoft.Authorization/policyDefinitions","name":"a1181c5f-672a-477a-979a-7d58aa086233"},{"properties":{"displayName":"[Deprecated]: + Monitor unaudited SQL servers in Azure Security Center","policyType":"BuiltIn","mode":"All","description":"SQL + servers which don''t have SQL auditing turned on will be monitored by Azure + Security Center as recommendations. This policy is deprecated and replaced + by the following policy: ''Auditing should be enabled on advanced data security + settings on SQL Server''","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.SQL/servers"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"auditing","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/af8051bf-258b-44e2-a2bf-165330459f9d","type":"Microsoft.Authorization/policyDefinitions","name":"af8051bf-258b-44e2-a2bf-165330459f9d"},{"properties":{"displayName":"[Deprecated]: + Monitor unencrypted SQL databases in Azure Security Center","policyType":"BuiltIn","mode":"All","description":"Unencrypted + SQL databases will be monitored by Azure Security Center as recommendations. + This policy is deprecated and replaced by the following policy: Transparent + Data Encryption on SQL databases should be enabled''","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.SQL/servers/databases"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"encryption","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a8bef009-a5c9-4d0f-90d7-6018734e8a16","type":"Microsoft.Authorization/policyDefinitions","name":"a8bef009-a5c9-4d0f-90d7-6018734e8a16"},{"properties":{"displayName":"Disk + encryption should be applied on virtual machines","policyType":"BuiltIn","mode":"All","description":"Virtual + machines without an enabled disk encryption will be monitored by Azure Security + Center as recommendations.","metadata":{"version":"2.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.ClassicCompute/virtualMachines","Microsoft.Compute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"d57a4221-a804-52ca-3dea-768284f06bb7","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0961003e-5a0a-4549-abde-af6a37f2724d","type":"Microsoft.Authorization/policyDefinitions","name":"0961003e-5a0a-4549-abde-af6a37f2724d"},{"properties":{"displayName":"[Deprecated]: + Web ports should be restricted on Network Security Groups associated to your + VM","policyType":"BuiltIn","mode":"All","description":"Azure security center + has discovered that some of your virtual machines are running web applications, + and the NSGs associated to these virtual machines are overly permissive with + regards to the web application ports","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"unprotectedWebApplication","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/201ea587-7c90-41c3-910f-c280ae01cfd6","type":"Microsoft.Authorization/policyDefinitions","name":"201ea587-7c90-41c3-910f-c280ae01cfd6"},{"properties":{"displayName":"All + network ports should be restricted on network security groups associated to + your virtual machine","policyType":"BuiltIn","mode":"All","description":"Azure + Security Center has identified some of your network security groups'' inbound + rules to be too permissive. Inbound rules should not allow access from ''Any'' + or ''Internet'' ranges. This can potentially enable attackers to target your + resources.","metadata":{"version":"3.0.0","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"3b20e985-f71f-483b-b078-f30d73936d43","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9daedab3-fb2d-461e-b861-71790eead4f6","type":"Microsoft.Authorization/policyDefinitions","name":"9daedab3-fb2d-461e-b861-71790eead4f6"},{"properties":{"displayName":"Operating + system version should be the most current version for your cloud service roles","policyType":"BuiltIn","mode":"All","description":"Keeping + the operating system (OS) on the most recent supported version for your cloud + service roles enhances the systems security posture.","metadata":{"version":"1.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.ClassicCompute/domainNames/slots/roles"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"8bc390da-9eb6-938d-25ed-44a35d9bcc9d","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5a913c68-0590-402c-a531-e57e19379da3","type":"Microsoft.Authorization/policyDefinitions","name":"5a913c68-0590-402c-a531-e57e19379da3"},{"properties":{"displayName":"Kubernetes + Services should be upgraded to a non-vulnerable Kubernetes version","policyType":"BuiltIn","mode":"Indexed","description":"Upgrade + your Kubernetes service cluster to a later Kubernetes version to protect against + known vulnerabilities in your current Kubernetes version. Vulnerability CVE-2019-9946 + has been patched in Kubernetes versions 1.11.9+, 1.12.7+, 1.13.5+, and 1.14.0+","metadata":{"version":"1.0.2","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","in":["1.13.4","1.13.3","1.13.2","1.13.1","1.13.0"]},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","in":["1.12.6","1.12.5","1.12.4","1.12.3","1.12.2","1.12.1","1.12.0"]},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","in":["1.11.8","1.11.7","1.11.6","1.11.5","1.11.4","1.11.3","1.11.2","1.11.1","1.11.0"]},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.10.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.9.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.8.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.7.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.6.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.5.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.4.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.3.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.2.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.1.*"},{"field":"Microsoft.ContainerService/managedClusters/kubernetesVersion","Like":"1.0.*"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fb893a29-21bb-418c-a157-e99480ec364c","type":"Microsoft.Authorization/policyDefinitions","name":"fb893a29-21bb-418c-a157-e99480ec364c"},{"properties":{"displayName":"[Deprecated]: + Audit Function Apps that are not using custom domains","policyType":"BuiltIn","mode":"All","description":"Use + of custom domains protects a Function app from common attacks such as phishing + and other DNS-related attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"functionapp"},{"field":"kind","equals":"functionapp,linux"},{"field":"kind","equals":"functionapp,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UsedCustomDomains","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d1cb47db-b7a1-4c46-814e-aad1c0e84f3c","type":"Microsoft.Authorization/policyDefinitions","name":"d1cb47db-b7a1-4c46-814e-aad1c0e84f3c"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using custom domains","policyType":"BuiltIn","mode":"All","description":"Use + of custom domains protects a web application from common attacks such as phishing + and other DNS-related attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UsedCustomDomains","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dd2ea520-6b06-45c3-806e-ea297c23e06a","type":"Microsoft.Authorization/policyDefinitions","name":"dd2ea520-6b06-45c3-806e-ea297c23e06a"},{"properties":{"displayName":"[Deprecated]: + Audit API Apps that are not using custom domains","policyType":"BuiltIn","mode":"All","description":"Use + of custom domains protects a API app from common attacks such as phishing + and other DNS-related attacks.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UsedCustomDomains","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/224da9fe-0d38-4e79-adb3-0a6e2af942ac","type":"Microsoft.Authorization/policyDefinitions","name":"224da9fe-0d38-4e79-adb3-0a6e2af942ac"},{"properties":{"displayName":"[Deprecated]: + Audit API Applications that are not using latest supported .NET Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported .NET Framework version for the latest security classes. + Using older classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestDotNet","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1de7b11d-1870-41a5-8181-507e7c663cfb","type":"Microsoft.Authorization/policyDefinitions","name":"1de7b11d-1870-41a5-8181-507e7c663cfb"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using latest supported .NET Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported .NET Framework version for the latest security classes. + Using older classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestDotNet","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5e3315e0-a414-4efb-a4d2-c7bd2b0443d2","type":"Microsoft.Authorization/policyDefinitions","name":"5e3315e0-a414-4efb-a4d2-c7bd2b0443d2"},{"properties":{"displayName":"[Deprecated]: + Audit API Applications that are not using latest supported Java Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported Java version for the latest security classes. Using older + classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestJava","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9bfe3727-0a17-471f-a2fe-eddd6b668745","type":"Microsoft.Authorization/policyDefinitions","name":"9bfe3727-0a17-471f-a2fe-eddd6b668745"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using latest supported Java Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported Java version for the latest security classes. Using older + classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestJava","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/be0a7681-bed4-48dc-9ff3-f0171ee170b6","type":"Microsoft.Authorization/policyDefinitions","name":"be0a7681-bed4-48dc-9ff3-f0171ee170b6"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using latest supported Node.js Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported Node.js version for the latest security classes. Using + older classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestNodeJS","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e67687e8-08d5-4e7f-8226-5b4753bba008","type":"Microsoft.Authorization/policyDefinitions","name":"e67687e8-08d5-4e7f-8226-5b4753bba008"},{"properties":{"displayName":"[Deprecated]: + Audit API Applications that are not using latest supported PHP Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported PHP version for the latest security classes. Using older + classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestPHP","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3fe37002-5d00-4b37-a301-da09e3a0ca66","type":"Microsoft.Authorization/policyDefinitions","name":"3fe37002-5d00-4b37-a301-da09e3a0ca66"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using latest supported PHP Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported PHP version for the latest security classes. Using older + classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"},{"field":"kind","equals":"app,linux"},{"field":"kind","equals":"app,linux,container"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestPHP","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/08b17839-76c6-4015-90e0-33d9d54d219c","type":"Microsoft.Authorization/policyDefinitions","name":"08b17839-76c6-4015-90e0-33d9d54d219c"},{"properties":{"displayName":"[Deprecated]: + Audit Web Applications that are not using latest supported Python Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported Python version for the latest security classes. Using + older classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"app"},{"field":"kind","equals":"WebApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestPython","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/46544d7b-1f0d-46f5-81da-5c1351de1b06","type":"Microsoft.Authorization/policyDefinitions","name":"46544d7b-1f0d-46f5-81da-5c1351de1b06"},{"properties":{"displayName":"[Deprecated]: + Audit API Applications that are not using latest supported Python Framework","policyType":"BuiltIn","mode":"All","description":"Use + the latest supported Python version for the latest security classes. Using + older classes and types can make your application vulnerable.","metadata":{"version":"1.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allof":[{"field":"type","equals":"microsoft.Web/sites"},{"anyof":[{"field":"kind","equals":"api"},{"field":"kind","equals":"apiApp"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/complianceResults","name":"UseLatestPython","existenceCondition":{"field":"Microsoft.Security/complianceResults/resourceStatus","in":["OffByPolicy","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bc0378bb-d7ab-4614-a0f6-5a6e3f02d644","type":"Microsoft.Authorization/policyDefinitions","name":"bc0378bb-d7ab-4614-a0f6-5a6e3f02d644"},{"properties":{"displayName":"Service + principals should be used to protect your subscriptions instead of management + certificates","policyType":"BuiltIn","mode":"All","description":"Management + certificates allow anyone who authenticates with them to manage the subscription(s) + they are associated with. To manage subscriptions more securely, use of service + principals with Resource Manager is recommended to limit the impact of a certificate + compromise.","metadata":{"version":"1.0.0","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Resources/subscriptions"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"2acd365d-e8b5-4094-bce4-244b7c51d67c","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6646a0bd-e110-40ca-bb97-84fcee63c414","type":"Microsoft.Authorization/policyDefinitions","name":"6646a0bd-e110-40ca-bb97-84fcee63c414"},{"properties":{"displayName":"Endpoint + protection solution should be installed on virtual machine scale sets","policyType":"BuiltIn","mode":"Indexed","description":"Audit + the existence and health of an endpoint protection solution on your virtual + machines scale sets, to protect them from threats and vulnerabilities.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"e71020c2-860c-3235-cd39-04f3f8c936d2","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/26a828e1-e88f-464e-bbb3-c134a282b9de","type":"Microsoft.Authorization/policyDefinitions","name":"26a828e1-e88f-464e-bbb3-c134a282b9de"},{"properties":{"displayName":"System + updates on virtual machine scale sets should be installed","policyType":"BuiltIn","mode":"Indexed","description":"Audit + whether there are any missing system security updates and critical updates + that should be installed to ensure that your Windows and Linux virtual machine + scale sets are secure.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"bd20bd91-aaf1-7f14-b6e4-866de2f43146","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c3f317a7-a95c-4547-b7e7-11017ebdf2fe","type":"Microsoft.Authorization/policyDefinitions","name":"c3f317a7-a95c-4547-b7e7-11017ebdf2fe"},{"properties":{"displayName":"Vulnerabilities + in security configuration on your virtual machine scale sets should be remediated","policyType":"BuiltIn","mode":"Indexed","description":"Audit + the OS vulnerabilities on your virtual machine scale sets to protect them + from attacks.","metadata":{"version":"3.0.0","category":"Security Center"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"8941d121-f740-35f6-952c-6561d2b38d36","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3c735d8a-a4ba-4a3a-b7cf-db7754cf57f4","type":"Microsoft.Authorization/policyDefinitions","name":"3c735d8a-a4ba-4a3a-b7cf-db7754cf57f4"},{"properties":{"displayName":"[Deprecated]: + Vulnerabilities should be remediated by a Vulnerability Assessment solution","policyType":"BuiltIn","mode":"All","description":"Monitors + vulnerabilities detected by Vulnerability Assessment solution and VMs without + a Vulnerability Assessment solution in Azure Security Center as recommendations.","metadata":{"version":"3.0.0-deprecated","category":"Security + Center","deprecated":true},"parameters":{"effect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Effect","description":"Enable or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"Disabled"}},"policyRule":{"if":{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.ClassicCompute/virtualMachines"]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Security/assessments","name":"71992a2a-d168-42e0-b10e-6b45fa2ecddb","existenceCondition":{"field":"Microsoft.Security/assessments/status.code","in":["NotApplicable","Healthy"]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/760a85ff-6162-42b3-8d70-698e268f648c","type":"Microsoft.Authorization/policyDefinitions","name":"760a85ff-6162-42b3-8d70-698e268f648c"},{"properties":{"displayName":"Deploy + Workflow Automation for Azure Security Center alerts","policyType":"BuiltIn","mode":"All","description":"Enable + automation of Azure Security Center alerts. This policy deploys a workflow + automation with your conditions and triggers on the assigned scope. To deploy + this policy on newly created subscriptions, open the Compliance tab, select + the relevant non-compliant assignment and create a remediation task.","metadata":{"version":"3.0.0","category":"Security + Center"},"parameters":{"automationName":{"type":"String","metadata":{"displayName":"Automation + name","description":"This is the automation name."}},"resourceGroupName":{"type":"String","metadata":{"displayName":"Resource + group name","description":"The resource group name where the workflow automation + is created. If you enter a name for a resource group that doesn''t exist, + it''ll be created in the subscription."}},"resourceGroupLocation":{"type":"String","metadata":{"displayName":"Resource + group location","description":"The location where the resource group and the + workflow automation are created.","strongType":"location"}},"alertName":{"type":"String","metadata":{"displayName":"Alert + name contains","description":"String included in the required alert name. + For a full reference list of Security Center''s alerts, see https://docs.microsoft.com/azure/security-center/alerts-reference."},"defaultValue":""},"alertSeverities":{"type":"Array","metadata":{"displayName":"Alert + severities","description":"Determines alert severities. Example: High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"logicAppResourceId":{"type":"String","metadata":{"displayName":"Logic + App","description":"The Logic App that is triggered.","strongType":"Microsoft.Logic/workflows","assignPermissions":true}},"logicAppTrigger":{"type":"String","metadata":{"displayName":"Logic + app trigger","description":"The trigger connector of the logic app that is + triggered. Possible values: ''Manual (Incoming HTTP request)'', ''When an + Azure Security Center Alert is created or triggered''."},"allowedValues":["Manual + (Incoming HTTP request)","When an Azure Security Center Alert is created or + triggered"]}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/automations","name":"[parameters(''automationName'')]","existenceScope":"resourcegroup","ResourceGroupName":"[parameters(''resourceGroupName'')]","deploymentScope":"subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Security/automations/isEnabled","equals":true},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","in":"[union(parameters(''alertSeverities''),if(equals(parameters(''alertName''), + ''''), array(''3.''), array(parameters(''alertName''))))]"},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath","in":"[union(array(''Severity''),if(equals(parameters(''alertName''), + ''''), array(''Version''), array(''AlertDisplayName'')))]"},{"count":{"value":"[parameters(''alertSeverities'')]","name":"alertSeverity","where":{"count":{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]","where":{"allOf":[{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath","equals":"Severity"},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","equals":"[current(''alertSeverity'')]"}]}},"equals":1}},"equals":"[length(parameters(''alertSeverities''))]"}]},"deployment":{"location":"westeurope","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"automationName":{"type":"string"},"resourceGroupName":{"type":"string"},"resourceGroupLocation":{"type":"string"},"alertName":{"type":"string"},"alertSeverities":{"type":"array"},"logicAppResourceId":{"type":"string"},"logicAppTrigger":{"type":"string"},"guidValue":{"type":"string","defaultValue":"[newGuid()]"}},"variables":{"scopeDescription":"scope + for subscription {0}","alertSeveritiesLength":"[length(parameters(''alertSeverities''))]","alertSeveritiesLengthIfEmpty":"[if(equals(variables(''alertSeveritiesLength''), + 0), 1, variables(''alertSeveritiesLength''))]","severityMap":{"High":"high","Medium":"medium","Low":"low"},"triggerMap":{"Manual + (Incoming HTTP request)":"manual","When an Azure Security Center Alert is + created or triggered":"When_an_Azure_Security_Center_Alert_is_created_or_triggered"}},"resources":[{"name":"[parameters(''resourceGroupName'')]","type":"Microsoft.Resources/resourceGroups","apiVersion":"2019-10-01","location":"[parameters(''resourceGroupLocation'')]","tags":{},"properties":{}},{"type":"Microsoft.Resources/deployments","apiVersion":"2019-10-01","name":"[concat(''nestedAutomationDeployment'', + ''_'', parameters(''guidValue''))]","resourceGroup":"[parameters(''resourceGroupName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups/'', + parameters(''resourceGroupName''))]"],"properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[{"tags":{},"apiVersion":"2019-01-01-preview","location":"[parameters(''resourceGroupLocation'')]","name":"[parameters(''automationName'')]","type":"Microsoft.Security/automations","dependsOn":[],"properties":{"description":"Workflow + Automation for Azure Security Center alerts via policy","isEnabled":true,"scopes":[{"description":"[replace(variables(''scopeDescription''),''{0}'', + subscription().subscriptionId)]","scopePath":"[subscription().id]"}],"sources":[{"eventSource":"Alerts","copy":[{"name":"ruleSets","count":"[variables(''alertSeveritiesLengthIfEmpty'')]","input":{"rules":[{"propertyJPath":"[if(equals(parameters(''alertName''), + ''''), ''Version'', ''AlertDisplayName'')]","propertyType":"string","expectedValue":"[if(equals(parameters(''alertName''), + ''''), ''3.'', parameters(''alertName''))]","operator":"Contains"},{"propertyJPath":"Severity","propertyType":"string","expectedValue":"[variables(''severityMap'')[parameters(''alertSeverities'')[mod(copyIndex(''ruleSets''), + variables(''alertSeveritiesLengthIfEmpty''))]]]","operator":"Equals"}]}}]}],"actions":[{"actionType":"LogicApp","logicAppResourceId":"[parameters(''logicAppResourceId'')]","uri":"[listCallbackUrl(concat(parameters(''logicAppResourceId''), + ''/triggers/'', variables(''triggerMap'')[parameters(''logicAppTrigger'')]),''2016-06-01'').value]"}]}}]}}}]},"parameters":{"automationName":{"value":"[parameters(''automationName'')]"},"resourceGroupName":{"value":"[parameters(''resourceGroupName'')]"},"resourceGroupLocation":{"value":"[parameters(''resourceGroupLocation'')]"},"alertName":{"value":"[parameters(''alertName'')]"},"alertSeverities":{"value":"[parameters(''alertSeverities'')]"},"logicAppResourceId":{"value":"[parameters(''logicAppResourceId'')]"},"logicAppTrigger":{"value":"[parameters(''logicAppTrigger'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f1525828-9a90-4fcf-be48-268cdd02361e","type":"Microsoft.Authorization/policyDefinitions","name":"f1525828-9a90-4fcf-be48-268cdd02361e"},{"properties":{"displayName":"Deploy + Workflow Automation for Azure Security Center recommendations","policyType":"BuiltIn","mode":"All","description":"Enable + automation of Azure Security Center recommendations. This policy deploys a + workflow automation with your conditions and triggers on the assigned scope. + To deploy this policy on newly created subscriptions, open the Compliance + tab, select the relevant non-compliant assignment and create a remediation + task.","metadata":{"version":"3.0.0","category":"Security Center"},"parameters":{"automationName":{"type":"String","metadata":{"displayName":"Automation + name","description":"This is the automation name."}},"resourceGroupName":{"type":"String","metadata":{"displayName":"Resource + group name","description":"The resource group name where the workflow automation + is created. If you enter a name for a resource group that doesn''t exist, + it''ll be created in the subscription."}},"resourceGroupLocation":{"type":"String","metadata":{"displayName":"Resource + group location","description":"The location where the resource group and the + workflow automation are created.","strongType":"location"}},"recommendationNames":{"type":"Array","metadata":{"displayName":"Recommendation + IDs","description":"For all recommendations, leave empty. For specific recommendations, + enter a list of recommendation IDs separated by semicolons ('';''). Recommendation + IDs are available through the Assessments API (https://docs.microsoft.com/en-us/rest/api/securitycenter/assessments), + or Azure Resource Graph Explorer, choose securityresources and microsoft.security/assessments."},"defaultValue":[]},"recommendationSeverities":{"type":"Array","metadata":{"displayName":"Recommendation + severities","description":"Determines recommendation severities. Example: + High;Medium;Low;"},"allowedValues":["High","Medium","Low"],"defaultValue":["High","Medium","Low"]},"recommendationStates":{"type":"Array","metadata":{"displayName":"Recommendation + states","description":"Determines recommendation states. Recommendations with + unhealthy state require your attention to resolve. When a recommendation state + is healthy, it no longer applies to the resource as Security Center detects + it as healthy. A recommendation is not-applicable if, for example, it was + disabled in the Security Policy. Example: Healthy;Unhealthy;Not Applicable;"},"allowedValues":["Healthy","Unhealthy","Not + Applicable"],"defaultValue":["Healthy","Unhealthy","Not Applicable"]},"logicAppResourceId":{"type":"String","metadata":{"displayName":"Logic + App","description":"The Logic App that is triggered.","strongType":"Microsoft.Logic/workflows","assignPermissions":true}},"logicAppTrigger":{"type":"String","metadata":{"displayName":"Logic + app trigger","description":"The trigger connector of the logic app that is + triggered. Possible values: ''Manual (Incoming HTTP request)'', ''When an + Azure Security Center Recommendation is created or triggered''."},"allowedValues":["Manual + (Incoming HTTP request)","When an Azure Security Center Recommendation is + created or triggered"]}},"policyRule":{"if":{"field":"type","equals":"Microsoft.Resources/subscriptions"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Security/automations","name":"[parameters(''automationName'')]","existenceScope":"resourcegroup","ResourceGroupName":"[parameters(''resourceGroupName'')]","deploymentScope":"subscription","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"existenceCondition":{"allOf":[{"field":"Microsoft.Security/automations/isEnabled","equals":true},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","in":"[union(if(equals(length(parameters(''recommendationNames'')),0),array(''Microsoft.Security/assessments''),parameters(''recommendationNames'')),parameters(''recommendationSeverities''),if(contains(parameters(''recommendationStates''),''Not + Applicable''),union(parameters(''recommendationStates''), array(''notapplicable'')),parameters(''recommendationStates'')))]"},{"count":{"value":"[parameters(''recommendationSeverities'')]","name":"recommendationSeverity","where":{"count":{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]","where":{"allOf":[{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath","equals":"properties.metadata.severity"},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","equals":"[current(''recommendationSeverity'')]"}]}},"equals":"[mul(max(1,length(parameters(''recommendationNames''))),length(parameters(''recommendationStates'')))]"}},"equals":"[length(parameters(''recommendationSeverities''))]"},{"count":{"value":"[parameters(''recommendationStates'')]","name":"recommendationState","where":{"count":{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]","where":{"allOf":[{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath","equals":"properties.status.code"},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","equals":"[replace(current(''recommendationState''), + '' '','''')]"}]}},"equals":"[mul(max(1,length(parameters(''recommendationNames''))),length(parameters(''recommendationSeverities'')))]"}},"equals":"[length(parameters(''recommendationStates''))]"},{"count":{"value":"[parameters(''recommendationNames'')]","name":"recommendationName","where":{"count":{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]","where":{"allOf":[{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath","equals":"name"},{"field":"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue","equals":"[current(''recommendationName'')]"}]}},"equals":"[mul(length(parameters(''recommendationSeverities'')),length(parameters(''recommendationStates'')))]"}},"equals":"[length(parameters(''recommendationNames''))]"}]},"deployment":{"location":"westeurope","properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"automationName":{"type":"string"},"resourceGroupName":{"type":"string"},"resourceGroupLocation":{"type":"string"},"recommendationNames":{"type":"array"},"recommendationSeverities":{"type":"array"},"recommendationStates":{"type":"array"},"logicAppResourceId":{"type":"string"},"logicAppTrigger":{"type":"string"},"guidValue":{"type":"string","defaultValue":"[newGuid()]"}},"variables":{"scopeDescription":"scope + for subscription {0}","recommendationNamesLength":"[length(parameters(''recommendationNames''))]","recommendationSeveritiesLength":"[length(parameters(''recommendationSeverities''))]","recommendationStatesLength":"[length(parameters(''recommendationStates''))]","recommendationNamesLengthIfEmpty":"[if(equals(variables(''recommendationNamesLength''), + 0), 1, variables(''recommendationNamesLength''))]","recommendationSeveritiesLengthIfEmpty":"[if(equals(variables(''recommendationSeveritiesLength''), + 0), 1, variables(''recommendationSeveritiesLength''))]","recommendationStatesLengthIfEmpty":"[if(equals(variables(''recommendationStatesLength''), + 0), 1, variables(''recommendationStatesLength''))]","totalRuleCombinationsForOneRecommendationName":"[mul(variables(''recommendationSeveritiesLengthIfEmpty''),variables(''recommendationStatesLengthIfEmpty''))]","totalRuleCombinationsForOneRecommendationSeverity":"[variables(''recommendationStatesLengthIfEmpty'')]","totalRuleCombinationsForOneRecommendationState":1,"stateMap":{"Healthy":"healthy","Unhealthy":"unhealthy","Not + Applicable":"notapplicable"},"triggerMap":{"Manual (Incoming HTTP request)":"manual","When + an Azure Security Center Recommendation is created or triggered":"When_an_Azure_Security_Center_Recommendation_is_created_or_triggered"}},"resources":[{"name":"[parameters(''resourceGroupName'')]","type":"Microsoft.Resources/resourceGroups","apiVersion":"2019-10-01","location":"[parameters(''resourceGroupLocation'')]","tags":{},"properties":{}},{"type":"Microsoft.Resources/deployments","apiVersion":"2019-10-01","name":"[concat(''nestedAutomationDeployment'', + ''_'', parameters(''guidValue''))]","resourceGroup":"[parameters(''resourceGroupName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups/'', + parameters(''resourceGroupName''))]"],"properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{},"variables":{},"resources":[{"tags":{},"apiVersion":"2019-01-01-preview","location":"[parameters(''resourceGroupLocation'')]","name":"[parameters(''automationName'')]","type":"Microsoft.Security/automations","dependsOn":[],"properties":{"description":"Workflow + Automation for Azure Security Center recommendations via policy","isEnabled":true,"scopes":[{"description":"[replace(variables(''scopeDescription''),''{0}'', + subscription().subscriptionId)]","scopePath":"[subscription().id]"}],"sources":[{"eventSource":"Assessments","copy":[{"name":"ruleSets","count":"[mul(variables(''recommendationNamesLengthIfEmpty''), + mul(variables(''recommendationSeveritiesLengthIfEmpty''),variables(''recommendationStatesLengthIfEmpty'')))]","input":{"rules":[{"propertyJPath":"[if(equals(variables(''recommendationNamesLength''), + 0), ''type'', ''name'')]","propertyType":"string","expectedValue":"[if(equals(variables(''recommendationNamesLength''), + 0), ''Microsoft.Security/assessments'', parameters(''recommendationNames'')[mod(div(copyIndex(''ruleSets''), + variables(''totalRuleCombinationsForOneRecommendationName'')), variables(''recommendationNamesLength''))])]","operator":"Contains"},{"propertyJPath":"properties.metadata.severity","propertyType":"string","expectedValue":"[parameters(''recommendationSeverities'')[mod(div(copyIndex(''ruleSets''), + variables(''totalRuleCombinationsForOneRecommendationSeverity'')), variables(''recommendationSeveritiesLength''))]]","operator":"Equals"},{"propertyJPath":"properties.status.code","propertyType":"string","expectedValue":"[variables(''stateMap'')[parameters(''recommendationStates'')[mod(div(copyIndex(''ruleSets''), + variables(''totalRuleCombinationsForOneRecommendationState'')), variables(''recommendationStatesLength''))]]]","operator":"Contains"}]}}]}],"actions":[{"actionType":"LogicApp","logicAppResourceId":"[parameters(''logicAppResourceId'')]","uri":"[listCallbackUrl(concat(parameters(''logicAppResourceId''), + ''/triggers/'', variables(''triggerMap'')[parameters(''logicAppTrigger'')]),''2016-06-01'').value]"}]}}]}}}]},"parameters":{"automationName":{"value":"[parameters(''automationName'')]"},"resourceGroupName":{"value":"[parameters(''resourceGroupName'')]"},"resourceGroupLocation":{"value":"[parameters(''resourceGroupLocation'')]"},"recommendationNames":{"value":"[parameters(''recommendationNames'')]"},"recommendationSeverities":{"value":"[parameters(''recommendationSeverities'')]"},"recommendationStates":{"value":"[parameters(''recommendationStates'')]"},"logicAppResourceId":{"value":"[parameters(''logicAppResourceId'')]"},"logicAppTrigger":{"value":"[parameters(''logicAppTrigger'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/73d6ab6c-2475-4850-afd6-43795f3492ef","type":"Microsoft.Authorization/policyDefinitions","name":"73d6ab6c-2475-4850-afd6-43795f3492ef"},{"properties":{"displayName":"Add + system-assigned managed identity to enable Guest Configuration assignments + on virtual machines with no identities","policyType":"BuiltIn","mode":"Indexed","description":"This + policy adds a system-assigned managed identity to virtual machines hosted + in Azure that are supported by Guest Configuration but do not have any managed + identities. A system-assigned managed identity is a prerequisite for all Guest + Configuration assignments and must be added to machines before using any Guest + Configuration policy definitions. For more information on Guest Configuration, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"1.0.0"},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"value":"[requestContext().apiVersion]","greaterOrEquals":"2018-10-01"},{"anyOf":[{"field":"identity.type","exists":"false"},{"field":"identity.type","equals":"None"}]}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"identity.type","value":"SystemAssigned"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3cf2ab00-13f1-4d0c-8971-2ac904541a7e","type":"Microsoft.Authorization/policyDefinitions","name":"3cf2ab00-13f1-4d0c-8971-2ac904541a7e"},{"properties":{"displayName":"Add + system-assigned managed identity to enable Guest Configuration assignments + on VMs with a user-assigned identity","policyType":"BuiltIn","mode":"Indexed","description":"This + policy adds a system-assigned managed identity to virtual machines hosted + in Azure that are supported by Guest Configuration and have at least one user-assigned + identity but do not have a system-assigned managed identity. A system-assigned + managed identity is a prerequisite for all Guest Configuration assignments + and must be added to machines before using any Guest Configuration policy + definitions. For more information on Guest Configuration, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"1.0.0"},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"value":"[requestContext().apiVersion]","greaterOrEquals":"2018-10-01"},{"field":"identity.type","contains":"UserAssigned"},{"field":"identity.type","notContains":"SystemAssigned"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"operations":[{"operation":"addOrReplace","field":"identity.type","value":"[concat(field(''identity.type''), + '',SystemAssigned'')]"}]}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/497dff13-db2a-4c0f-8603-28fa3b331ab6","type":"Microsoft.Authorization/policyDefinitions","name":"497dff13-db2a-4c0f-8603-28fa3b331ab6"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Administrative Templates + - Control Panel''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Administrative Templates - Control Panel''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesControlPanel","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/87b590fe-4a1d-4697-ae74-d4fe72ab786c","type":"Microsoft.Authorization/policyDefinitions","name":"87b590fe-4a1d-4697-ae74-d4fe72ab786c"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Administrative + Templates - Control Panel''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Administrative Templates + - Control Panel''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesControlPanel","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_AdministrativeTemplatesControlPanel"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ec7ac234-2af5-4729-94d2-c557c071799d","type":"Microsoft.Authorization/policyDefinitions","name":"ec7ac234-2af5-4729-94d2-c557c071799d"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Administrative Templates - Control + Panel''","policyType":"BuiltIn","mode":"Indexed","description":"Windows machines + should have the specified Group Policy settings in the category ''Administrative + Templates - Control Panel'' for input personalization and prevention of enabling + lock screens. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_AdministrativeTemplatesControlPanel","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesControlPanel","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3aa2661b-02d7-4ba6-99bc-dc36b10489fd","type":"Microsoft.Authorization/policyDefinitions","name":"3aa2661b-02d7-4ba6-99bc-dc36b10489fd"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Administrative Templates + - Network''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Administrative + Templates - Network''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesNetwork","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7229bd6a-693d-478a-87f0-1dc1af06f3b8","type":"Microsoft.Authorization/policyDefinitions","name":"7229bd6a-693d-478a-87f0-1dc1af06f3b8"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Administrative Templates - Network''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Administrative + Templates - Network'' for guest logons, simultaneous connections, network + bridge, ICS, and multicast name resolution. This policy requires that the + Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_AdministrativeTemplatesNetwork","version":"1.*","configurationParameter":{"EnableInsecureGuestLogons":"Enable + insecure guest logons;ExpectedValue","AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain":"Minimize + the number of simultaneous connections to the Internet or a Windows Domain;ExpectedValue","TurnOffMulticastNameResolution":"Turn + off multicast name resolution;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"EnableInsecureGuestLogons":{"type":"String","metadata":{"displayName":"Enable + insecure guest logons","description":"Specifies whether the SMB client will + allow insecure guest logons to an SMB server."},"defaultValue":"0"},"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain":{"type":"String","metadata":{"displayName":"Allow + simultaneous connections to the Internet or a Windows Domain","description":"Specify + whether to prevent computers from connecting to both a domain based network + and a non-domain based network at the same time. A value of 0 allows simultaneous + connections, and a value of 1 blocks them."},"defaultValue":"1"},"TurnOffMulticastNameResolution":{"type":"String","metadata":{"displayName":"Turn + off multicast name resolution","description":"Specifies whether LLMNR, a secondary + name resolution protocol that transmits using multicast over a local subnet + link on a single subnet, is enabled."},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesNetwork","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Enable + insecure guest logons;ExpectedValue'', ''='', parameters(''EnableInsecureGuestLogons''), + '','', ''Minimize the number of simultaneous connections to the Internet or + a Windows Domain;ExpectedValue'', ''='', parameters(''AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain''), + '','', ''Turn off multicast name resolution;ExpectedValue'', ''='', parameters(''TurnOffMulticastNameResolution'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/67e010c1-640d-438e-a3a5-feaccb533a98","type":"Microsoft.Authorization/policyDefinitions","name":"67e010c1-640d-438e-a3a5-feaccb533a98"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Administrative Templates - MSS (Legacy)''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Administrative + Templates - MSS (Legacy)'' for automatic logon, screen saver, network behavior, + safe DLL, and event log. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_AdminstrativeTemplatesMSSLegacy","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdminstrativeTemplatesMSSLegacy","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e0a7e899-2ce2-4253-8a13-d808fdeb75af","type":"Microsoft.Authorization/policyDefinitions","name":"e0a7e899-2ce2-4253-8a13-d808fdeb75af"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Administrative + Templates - Network''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Administrative Templates + - Network''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.1.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"EnableInsecureGuestLogons":{"type":"String","metadata":{"displayName":"[Deprecated]: + Enable insecure guest logons","description":"Specifies whether the SMB client + will allow insecure guest logons to an SMB server."},"defaultValue":"0"},"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain":{"type":"String","metadata":{"displayName":"[Deprecated]: + Allow simultaneous connections to the Internet or a Windows Domain","description":"Specify + whether to prevent computers from connecting to both a domain based network + and a non-domain based network at the same time. A value of 0 allows simultaneous + connections, and a value of 1 blocks them."},"defaultValue":"1"},"TurnOffMulticastNameResolution":{"type":"String","metadata":{"displayName":"[Deprecated]: + Turn off multicast name resolution","description":"Specifies whether LLMNR, + a secondary name resolution protocol that transmits using multicast over a + local subnet link on a single subnet, is enabled."},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesNetwork","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Enable + insecure guest logons;ExpectedValue'', ''='', parameters(''EnableInsecureGuestLogons''), + '','', ''Minimize the number of simultaneous connections to the Internet or + a Windows Domain;ExpectedValue'', ''='', parameters(''AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain''), + '','', ''Turn off multicast name resolution;ExpectedValue'', ''='', parameters(''TurnOffMulticastNameResolution'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_AdministrativeTemplatesNetwork"},"EnableInsecureGuestLogons":{"value":"[parameters(''EnableInsecureGuestLogons'')]"},"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain":{"value":"[parameters(''AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain'')]"},"TurnOffMulticastNameResolution":{"value":"[parameters(''TurnOffMulticastNameResolution'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"EnableInsecureGuestLogons":{"type":"string"},"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain":{"type":"string"},"TurnOffMulticastNameResolution":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Enable + insecure guest logons;ExpectedValue","value":"[parameters(''EnableInsecureGuestLogons'')]"},{"name":"Minimize + the number of simultaneous connections to the Internet or a Windows Domain;ExpectedValue","value":"[parameters(''AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain'')]"},{"name":"Turn + off multicast name resolution;ExpectedValue","value":"[parameters(''TurnOffMulticastNameResolution'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Enable + insecure guest logons;ExpectedValue","value":"[parameters(''EnableInsecureGuestLogons'')]"},{"name":"Minimize + the number of simultaneous connections to the Internet or a Windows Domain;ExpectedValue","value":"[parameters(''AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain'')]"},{"name":"Turn + off multicast name resolution;ExpectedValue","value":"[parameters(''TurnOffMulticastNameResolution'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/985285b7-b97a-419c-8d48-c88cc934c8d8","type":"Microsoft.Authorization/policyDefinitions","name":"985285b7-b97a-419c-8d48-c88cc934c8d8"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Administrative Templates - System''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Administrative + Templates - System'' for settings that control the administrative experience + and Remote Assistance. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_AdministrativeTemplatesSystem","version":"1.*","configurationParameter":{"AlwaysUseClassicLogon":"Always + use classic logon;ExpectedValue","BootStartDriverInitializationPolicy":"Boot-Start + Driver Initialization Policy;ExpectedValue","EnableWindowsNTPClient":"Enable + Windows NTP Client;ExpectedValue","TurnOnConveniencePINSignin":"Turn on convenience + PIN sign-in;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AlwaysUseClassicLogon":{"type":"String","metadata":{"displayName":"Always + use classic logon","description":"Specifies whether to force the user to log + on to the computer using the classic logon screen. This setting only works + when the computer is not on a domain."},"defaultValue":"0"},"BootStartDriverInitializationPolicy":{"type":"String","metadata":{"displayName":"Boot-Start + Driver Initialization Policy","description":"Specifies which boot-start drivers + are initialized based on a classification determined by an Early Launch Antimalware + boot-start driver."},"defaultValue":"3"},"EnableWindowsNTPClient":{"type":"String","metadata":{"displayName":"Enable + Windows NTP Client","description":"Specifies whether the Windows NTP Client + is enabled. Enabling the Windows NTP Client allows your computer to synchronize + its computer clock with other NTP servers."},"defaultValue":"1"},"TurnOnConveniencePINSignin":{"type":"String","metadata":{"displayName":"Turn + on convenience PIN sign-in","description":"Specifies whether a domain user + can sign in using a convenience PIN."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesSystem","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Always + use classic logon;ExpectedValue'', ''='', parameters(''AlwaysUseClassicLogon''), + '','', ''Boot-Start Driver Initialization Policy;ExpectedValue'', ''='', parameters(''BootStartDriverInitializationPolicy''), + '','', ''Enable Windows NTP Client;ExpectedValue'', ''='', parameters(''EnableWindowsNTPClient''), + '','', ''Turn on convenience PIN sign-in;ExpectedValue'', ''='', parameters(''TurnOnConveniencePINSignin'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/968410dc-5ca0-4518-8a5b-7b55f0530ea9","type":"Microsoft.Authorization/policyDefinitions","name":"968410dc-5ca0-4518-8a5b-7b55f0530ea9"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Administrative Templates + - System''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Administrative + Templates - System''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesSystem","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a1e8dda3-9fd2-4835-aec3-0e55531fde33","type":"Microsoft.Authorization/policyDefinitions","name":"a1e8dda3-9fd2-4835-aec3-0e55531fde33"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Administrative + Templates - System''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Administrative Templates + - System''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AlwaysUseClassicLogon":{"type":"String","metadata":{"displayName":"[Deprecated]: + Always use classic logon","description":"Specifies whether to force the user + to log on to the computer using the classic logon screen. This setting only + works when the computer is not on a domain."},"defaultValue":"0"},"BootStartDriverInitializationPolicy":{"type":"String","metadata":{"displayName":"[Deprecated]: + Boot-Start Driver Initialization Policy","description":"Specifies which boot-start + drivers are initialized based on a classification determined by an Early Launch + Antimalware boot-start driver."},"defaultValue":"3"},"EnableWindowsNTPClient":{"type":"String","metadata":{"displayName":"[Deprecated]: + Enable Windows NTP Client","description":"Specifies whether the Windows NTP + Client is enabled. Enabling the Windows NTP Client allows your computer to + synchronize its computer clock with other NTP servers."},"defaultValue":"1"},"TurnOnConveniencePINSignin":{"type":"String","metadata":{"displayName":"[Deprecated]: + Turn on convenience PIN sign-in","description":"Specifies whether a domain + user can sign in using a convenience PIN."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdministrativeTemplatesSystem","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Always + use classic logon;ExpectedValue'', ''='', parameters(''AlwaysUseClassicLogon''), + '','', ''Boot-Start Driver Initialization Policy;ExpectedValue'', ''='', parameters(''BootStartDriverInitializationPolicy''), + '','', ''Enable Windows NTP Client;ExpectedValue'', ''='', parameters(''EnableWindowsNTPClient''), + '','', ''Turn on convenience PIN sign-in;ExpectedValue'', ''='', parameters(''TurnOnConveniencePINSignin'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_AdministrativeTemplatesSystem"},"AlwaysUseClassicLogon":{"value":"[parameters(''AlwaysUseClassicLogon'')]"},"BootStartDriverInitializationPolicy":{"value":"[parameters(''BootStartDriverInitializationPolicy'')]"},"EnableWindowsNTPClient":{"value":"[parameters(''EnableWindowsNTPClient'')]"},"TurnOnConveniencePINSignin":{"value":"[parameters(''TurnOnConveniencePINSignin'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AlwaysUseClassicLogon":{"type":"string"},"BootStartDriverInitializationPolicy":{"type":"string"},"EnableWindowsNTPClient":{"type":"string"},"TurnOnConveniencePINSignin":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Always + use classic logon;ExpectedValue","value":"[parameters(''AlwaysUseClassicLogon'')]"},{"name":"Boot-Start + Driver Initialization Policy;ExpectedValue","value":"[parameters(''BootStartDriverInitializationPolicy'')]"},{"name":"Enable + Windows NTP Client;ExpectedValue","value":"[parameters(''EnableWindowsNTPClient'')]"},{"name":"Turn + on convenience PIN sign-in;ExpectedValue","value":"[parameters(''TurnOnConveniencePINSignin'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Always + use classic logon;ExpectedValue","value":"[parameters(''AlwaysUseClassicLogon'')]"},{"name":"Boot-Start + Driver Initialization Policy;ExpectedValue","value":"[parameters(''BootStartDriverInitializationPolicy'')]"},{"name":"Enable + Windows NTP Client;ExpectedValue","value":"[parameters(''EnableWindowsNTPClient'')]"},{"name":"Turn + on convenience PIN sign-in;ExpectedValue","value":"[parameters(''TurnOnConveniencePINSignin'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/40917425-69db-4018-8dae-2a0556cef899","type":"Microsoft.Authorization/policyDefinitions","name":"40917425-69db-4018-8dae-2a0556cef899"},{"properties":{"displayName":"Audit + Windows machines that have the specified members in the Administrators group","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the local Administrators + group contains one or more of the members listed in the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AdministratorsGroupMembersToExclude","version":"1.*","configurationParameter":{"MembersToExclude":"[LocalGroup]AdministratorsGroup;MembersToExclude"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"MembersToExclude":{"type":"String","metadata":{"displayName":"Members + to exclude","description":"A semicolon-separated list of members that should + be excluded in the Administrators local group. Ex: Administrator; myUser1; + myUser2"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToExclude","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;MembersToExclude'', + ''='', parameters(''MembersToExclude'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/69bf4abd-ca1e-4cf6-8b5a-762d42e61d4f","type":"Microsoft.Authorization/policyDefinitions","name":"69bf4abd-ca1e-4cf6-8b5a-762d42e61d4f"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs if the Administrators group contains any + of the specified members","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines in which the Administrators group contains + any of the specified members. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToExclude","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bde62c94-ccca-4821-a815-92c1d31a76de","type":"Microsoft.Authorization/policyDefinitions","name":"bde62c94-ccca-4821-a815-92c1d31a76de"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs if the Administrators group doesn''t contain + all of the specified members","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines in which the Administrators group does not + contain all of the specified members. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToInclude","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f3b44e5d-1456-475f-9c67-c66c4618e85a","type":"Microsoft.Authorization/policyDefinitions","name":"f3b44e5d-1456-475f-9c67-c66c4618e85a"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs if the Administrators group doesn''t + contain all the specified members","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + in which the Administrators group does not contain all of the specified members. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"MembersToInclude":{"type":"String","metadata":{"displayName":"[Deprecated]: + Members to include","description":"A semicolon-separated list of members that + should be included in the Administrators local group. Ex: Administrator; myUser1; + myUser2"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToInclude","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;MembersToInclude'', + ''='', parameters(''MembersToInclude'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AdministratorsGroupMembersToInclude"},"MembersToInclude":{"value":"[parameters(''MembersToInclude'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"MembersToInclude":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;MembersToInclude","value":"[parameters(''MembersToInclude'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;MembersToInclude","value":"[parameters(''MembersToInclude'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/93507a81-10a4-4af0-9ee2-34cf25a96e98","type":"Microsoft.Authorization/policyDefinitions","name":"93507a81-10a4-4af0-9ee2-34cf25a96e98"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs if the Administrators group contains + any of the specified members","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + in which the Administrators group contains any of the specified members. It + also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"MembersToExclude":{"type":"String","metadata":{"displayName":"[Deprecated]: + Members to exclude","description":"A semicolon-separated list of members that + should be excluded in the Administrators local group. Ex: Administrator; myUser1; + myUser2"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToExclude","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;MembersToExclude'', + ''='', parameters(''MembersToExclude'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AdministratorsGroupMembersToExclude"},"MembersToExclude":{"value":"[parameters(''MembersToExclude'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"MembersToExclude":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;MembersToExclude","value":"[parameters(''MembersToExclude'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;MembersToExclude","value":"[parameters(''MembersToExclude'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/144f1397-32f9-4598-8c88-118decc3ccba","type":"Microsoft.Authorization/policyDefinitions","name":"144f1397-32f9-4598-8c88-118decc3ccba"},{"properties":{"displayName":"Audit + Windows machines that have extra accounts in the Administrators group","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the local Administrators + group contains members that are not listed in the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AdministratorsGroupMembers","version":"1.*","configurationParameter":{"Members":"[LocalGroup]AdministratorsGroup;Members"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"Members":{"type":"String","metadata":{"displayName":"Members","description":"A + semicolon-separated list of all the expected members of the Administrators + local group. Ex: Administrator; myUser1; myUser2"},"allowedValues":[],"defaultValue":"Administrator"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembers","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;Members'', + ''='', parameters(''Members'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3d2a3320-2a72-4c67-ac5f-caa40fbee2b2","type":"Microsoft.Authorization/policyDefinitions","name":"3d2a3320-2a72-4c67-ac5f-caa40fbee2b2"},{"properties":{"displayName":"Audit + Windows machines missing any of specified members in the Administrators group","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the local Administrators + group does not contain one or more members that are listed in the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AdministratorsGroupMembersToInclude","version":"1.*","configurationParameter":{"MembersToInclude":"[LocalGroup]AdministratorsGroup;MembersToInclude"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"MembersToInclude":{"type":"String","metadata":{"displayName":"Members + to include","description":"A semicolon-separated list of members that should + be included in the Administrators local group. Ex: Administrator; myUser1; + myUser2"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembersToInclude","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;MembersToInclude'', + ''='', parameters(''MembersToInclude'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/30f71ea1-ac77-4f26-9fc5-2d926bbd4ba7","type":"Microsoft.Authorization/policyDefinitions","name":"30f71ea1-ac77-4f26-9fc5-2d926bbd4ba7"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs if the Administrators group doesn''t contain + only specified members","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines in which the Administrators group does not + contain only the specified members. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembers","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cc7cda28-f867-4311-8497-a526129a8d19","type":"Microsoft.Authorization/policyDefinitions","name":"cc7cda28-f867-4311-8497-a526129a8d19"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs if the Administrators group doesn''t + contain only specified members","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + in which the Administrators group does not contain only the specified members. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"Members":{"type":"String","metadata":{"displayName":"[Deprecated]: + Members","description":"A semicolon-separated list of all the expected members + of the Administrators local group. Ex: Administrator; myUser1; myUser2"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AdministratorsGroupMembers","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LocalGroup]AdministratorsGroup;Members'', + ''='', parameters(''Members'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AdministratorsGroupMembers"},"Members":{"value":"[parameters(''Members'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"Members":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;Members","value":"[parameters(''Members'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LocalGroup]AdministratorsGroup;Members","value":"[parameters(''Members'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b821191b-3a12-44bc-9c38-212138a29ff3","type":"Microsoft.Authorization/policyDefinitions","name":"b821191b-3a12-44bc-9c38-212138a29ff3"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Administrative Templates + - MSS (Legacy)''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Administrative Templates - MSS (Legacy)''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.1-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdminstrativeTemplatesMSSLegacy","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/97646672-5efa-4622-9b54-740270ad60bf","type":"Microsoft.Authorization/policyDefinitions","name":"97646672-5efa-4622-9b54-740270ad60bf"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Administrative + Templates - MSS (Legacy)''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Administrative Templates + - MSS (Legacy)''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_AdminstrativeTemplatesMSSLegacy","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_AdminstrativeTemplatesMSSLegacy"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f1f4825d-58fb-4257-8016-8c00e3c9ed9d","type":"Microsoft.Authorization/policyDefinitions","name":"f1f4825d-58fb-4257-8016-8c00e3c9ed9d"},{"properties":{"displayName":"[Preview]: + Linux machines should meet requirements for the Azure security baseline","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Linux machines should + meet the requirements for the Azure security baseline","metadata":{"category":"Guest + Configuration","version":"1.1.0-preview","preview":true,"requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureLinuxBaseline","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"[Preview]: + Include Arc connected servers","description":"By selecting this option, you + agree to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"[Preview]: + Effect","description":"Enable or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureLinuxBaseline","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fc9b3da7-8347-4380-8e70-0a0361d8dedd","type":"Microsoft.Authorization/policyDefinitions","name":"fc9b3da7-8347-4380-8e70-0a0361d8dedd"},{"properties":{"displayName":"Audit + Windows machines that contain certificates expiring within the specified number + of days","policyType":"BuiltIn","mode":"Indexed","description":"Requires that + prerequisites are deployed to the policy assignment scope. For details, visit + https://aka.ms/gcpol. Machines are non-compliant if certificates in the specified + store have an expiration date out of range for the number of days given as + parameter. The policy also provides the option to only check for specific + certificates or exclude specific certificates, and whether to report on expired + certificates.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"CertificateExpiration","version":"1.*","configurationParameter":{"CertificateStorePath":"[CertificateStore]CertificateStore1;CertificateStorePath","ExpirationLimitInDays":"[CertificateStore]CertificateStore1;ExpirationLimitInDays","CertificateThumbprintsToInclude":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude","CertificateThumbprintsToExclude":"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude","IncludeExpiredCertificates":"[CertificateStore]CertificateStore1;IncludeExpiredCertificates"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"CertificateStorePath":{"type":"String","metadata":{"displayName":"Certificate + store path","description":"The path to the certificate store containing the + certificates to check the expiration dates of. Default value is ''Cert:'' + which is the root certificate store path, so all certificates on the machine + will be checked. Other example paths: ''Cert:\\LocalMachine'', ''Cert:\\LocalMachine\\TrustedPublisher'', + ''Cert:\\CurrentUser''"},"defaultValue":"Cert:"},"ExpirationLimitInDays":{"type":"String","metadata":{"displayName":"Expiration + limit in days","description":"An integer indicating the number of days within + which to check for certificates that are expiring. For example, if this value + is 30, any certificate expiring within the next 30 days will cause this policy + to be non-compliant."},"defaultValue":"30"},"CertificateThumbprintsToInclude":{"type":"String","metadata":{"displayName":"Certificate + thumbprints to include","description":"A semicolon-separated list of certificate + thumbprints to check under the specified path. If a value is not specified, + all certificates under the certificate store path will be checked. If a value + is specified, no certificates other than those with the thumbprints specified + will be checked. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"},"defaultValue":""},"CertificateThumbprintsToExclude":{"type":"String","metadata":{"displayName":"Certificate + thumbprints to exclude","description":"A semicolon-separated list of certificate + thumbprints to ignore. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"},"defaultValue":""},"IncludeExpiredCertificates":{"type":"String","metadata":{"displayName":"Include + expired certificates","description":"Must be ''true'' or ''false''. True indicates + that any found certificates that have already expired will also make this + policy non-compliant. False indicates that certificates that have expired + will be be ignored."},"allowedValues":["true","false"],"defaultValue":"false"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"CertificateExpiration","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[CertificateStore]CertificateStore1;CertificateStorePath'', + ''='', parameters(''CertificateStorePath''), '','', ''[CertificateStore]CertificateStore1;ExpirationLimitInDays'', + ''='', parameters(''ExpirationLimitInDays''), '','', ''[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude'', + ''='', parameters(''CertificateThumbprintsToInclude''), '','', ''[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude'', + ''='', parameters(''CertificateThumbprintsToExclude''), '','', ''[CertificateStore]CertificateStore1;IncludeExpiredCertificates'', + ''='', parameters(''IncludeExpiredCertificates'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1417908b-4bff-46ee-a2a6-4acc899320ab","type":"Microsoft.Authorization/policyDefinitions","name":"1417908b-4bff-46ee-a2a6-4acc899320ab"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that contain certificates expiring within + the specified number of days","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that contain certificates expiring within + the specified number of days. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"CertificateExpiration","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9328f27e-611e-44a7-a244-39109d7d35ab","type":"Microsoft.Authorization/policyDefinitions","name":"9328f27e-611e-44a7-a244-39109d7d35ab"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that contain certificates expiring + within the specified number of days","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that contain certificates expiring within the specified number of days. It + also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"CertificateStorePath":{"type":"String","metadata":{"displayName":"[Deprecated]: + Certificate store path","description":"The path to the certificate store containing + the certificates to check the expiration dates of. Default value is ''Cert:'' + which is the root certificate store path, so all certificates on the machine + will be checked. Other example paths: ''Cert:\\LocalMachine'', ''Cert:\\LocalMachine\\TrustedPublisher'', + ''Cert:\\CurrentUser''"},"defaultValue":"Cert:"},"ExpirationLimitInDays":{"type":"String","metadata":{"displayName":"[Deprecated]: + Expiration limit in days","description":"An integer indicating the number + of days within which to check for certificates that are expiring. For example, + if this value is 30, any certificate expiring within the next 30 days will + cause this policy to be non-compliant."},"defaultValue":"30"},"CertificateThumbprintsToInclude":{"type":"String","metadata":{"displayName":"[Deprecated]: + Certificate thumbprints to include","description":"A semicolon-separated list + of certificate thumbprints to check under the specified path. If a value is + not specified, all certificates under the certificate store path will be checked. + If a value is specified, no certificates other than those with the thumbprints + specified will be checked. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"},"defaultValue":""},"CertificateThumbprintsToExclude":{"type":"String","metadata":{"displayName":"[Deprecated]: + Certificate thumbprints to exclude","description":"A semicolon-separated list + of certificate thumbprints to ignore. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"},"defaultValue":""},"IncludeExpiredCertificates":{"type":"String","metadata":{"displayName":"[Deprecated]: + Include expired certificates","description":"Must be ''true'' or ''false''. + True indicates that any found certificates that have already expired will + also make this policy non-compliant. False indicates that certificates that + have expired will be be ignored."},"allowedValues":["true","false"],"defaultValue":"false"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"CertificateExpiration","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[CertificateStore]CertificateStore1;CertificateStorePath'', + ''='', parameters(''CertificateStorePath''), '','', ''[CertificateStore]CertificateStore1;ExpirationLimitInDays'', + ''='', parameters(''ExpirationLimitInDays''), '','', ''[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude'', + ''='', parameters(''CertificateThumbprintsToInclude''), '','', ''[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude'', + ''='', parameters(''CertificateThumbprintsToExclude''), '','', ''[CertificateStore]CertificateStore1;IncludeExpiredCertificates'', + ''='', parameters(''IncludeExpiredCertificates'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"CertificateExpiration"},"CertificateStorePath":{"value":"[parameters(''CertificateStorePath'')]"},"ExpirationLimitInDays":{"value":"[parameters(''ExpirationLimitInDays'')]"},"CertificateThumbprintsToInclude":{"value":"[parameters(''CertificateThumbprintsToInclude'')]"},"CertificateThumbprintsToExclude":{"value":"[parameters(''CertificateThumbprintsToExclude'')]"},"IncludeExpiredCertificates":{"value":"[parameters(''IncludeExpiredCertificates'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"CertificateStorePath":{"type":"string"},"ExpirationLimitInDays":{"type":"string"},"CertificateThumbprintsToInclude":{"type":"string"},"CertificateThumbprintsToExclude":{"type":"string"},"IncludeExpiredCertificates":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[CertificateStore]CertificateStore1;CertificateStorePath","value":"[parameters(''CertificateStorePath'')]"},{"name":"[CertificateStore]CertificateStore1;ExpirationLimitInDays","value":"[parameters(''ExpirationLimitInDays'')]"},{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude","value":"[parameters(''CertificateThumbprintsToInclude'')]"},{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude","value":"[parameters(''CertificateThumbprintsToExclude'')]"},{"name":"[CertificateStore]CertificateStore1;IncludeExpiredCertificates","value":"[parameters(''IncludeExpiredCertificates'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[CertificateStore]CertificateStore1;CertificateStorePath","value":"[parameters(''CertificateStorePath'')]"},{"name":"[CertificateStore]CertificateStore1;ExpirationLimitInDays","value":"[parameters(''ExpirationLimitInDays'')]"},{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude","value":"[parameters(''CertificateThumbprintsToInclude'')]"},{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude","value":"[parameters(''CertificateThumbprintsToExclude'')]"},{"name":"[CertificateStore]CertificateStore1;IncludeExpiredCertificates","value":"[parameters(''IncludeExpiredCertificates'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c5fbc59e-fb6f-494f-81e2-d99a671bdaa8","type":"Microsoft.Authorization/policyDefinitions","name":"c5fbc59e-fb6f-494f-81e2-d99a671bdaa8"},{"properties":{"displayName":"Deploy + the Linux Guest Configuration extension to enable Guest Configuration assignments + on Linux VMs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy deploys the Linux Guest Configuration extension to Linux virtual machines + hosted in Azure that are supported by Guest Configuration. The Linux Guest + Configuration extension is a prerequisite for all Linux Guest Configuration + assignments and must deployed to machines before using any Linux Guest Configuration + policy definition. For more information on Guest Configuration, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"1.0.0"},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforLinux","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/331e8ea8-378a-410f-a2e5-ae22f38bb0da","type":"Microsoft.Authorization/policyDefinitions","name":"331e8ea8-378a-410f-a2e5-ae22f38bb0da"},{"properties":{"displayName":"Deploy + the Windows Guest Configuration extension to enable Guest Configuration assignments + on Windows VMs","policyType":"BuiltIn","mode":"Indexed","description":"This + policy deploys the Windows Guest Configuration extension to Windows virtual + machines hosted in Azure that are supported by Guest Configuration. The Windows + Guest Configuration extension is a prerequisite for all Windows Guest Configuration + assignments and must deployed to machines before using any Windows Guest Configuration + policy definition. For more information on Guest Configuration, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"1.0.0"},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforWindows","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforWindows"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/385f5831-96d4-41db-9a3c-cd3af78aaae6","type":"Microsoft.Authorization/policyDefinitions","name":"385f5831-96d4-41db-9a3c-cd3af78aaae6"},{"properties":{"displayName":"Audit + Windows machines that don''t have the specified applications installed","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the application + name is not found in any of the following registry paths: HKLM:SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall, + HKLM:SOFTWARE\\Wow6432node\\Microsoft\\Windows\\CurrentVersion\\Uninstall, + HKCU:Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WhitelistedApplication","version":"1.*","configurationParameter":{"installedApplication":"[InstalledApplication]bwhitelistedapp;Name"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"installedApplication":{"type":"String","metadata":{"displayName":"Application + names (supports wildcards)","description":"A semicolon-separated list of the + names of the applications that should be installed. e.g. ''Microsoft SQL Server + 2014 (64-bit); Microsoft Visual Studio Code'' or ''Microsoft SQL Server 2014*'' + (to match any application starting with ''Microsoft SQL Server 2014'')"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WhitelistedApplication","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[InstalledApplication]bwhitelistedapp;Name'', + ''='', parameters(''installedApplication'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ebb67efd-3c46-49b0-adfe-5599eb944998","type":"Microsoft.Authorization/policyDefinitions","name":"ebb67efd-3c46-49b0-adfe-5599eb944998"},{"properties":{"displayName":"Audit + Linux machines that don''t have the specified applications installed","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the Chef InSpec + resource indicates that one or more of the packages provided by the parameter + are not installed.","metadata":{"category":"Guest Configuration","version":"3.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"installed_application_linux","version":"1.*","configurationParameter":{"ApplicationName":"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ApplicationName":{"type":"String","metadata":{"displayName":"Application + names","description":"A semicolon-separated list of the names of the applications + that should be installed. e.g. ''python; powershell''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"installed_application_linux","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent'', + ''='', parameters(''ApplicationName'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d3b823c9-e0fc-4453-9fb2-8213b7338523","type":"Microsoft.Authorization/policyDefinitions","name":"d3b823c9-e0fc-4453-9fb2-8213b7338523"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Linux VMs that do not have the specified applications + installed","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Linux + virtual machines that do not have the specified applications installed. For + more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"installed_application_linux","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fee5cb2b-9d9b-410e-afe3-2902d90d0004","type":"Microsoft.Authorization/policyDefinitions","name":"fee5cb2b-9d9b-410e-afe3-2902d90d0004"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Linux VMs that do not have the specified applications + installed","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Linux virtual machines that + do not have the specified applications installed. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ApplicationName":{"type":"String","metadata":{"displayName":"[Deprecated]: + Application names","description":"A semicolon-separated list of the names + of the applications that should be installed. e.g. ''python; powershell''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"installed_application_linux","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent'', + ''='', concat(''packages: ['', replace(parameters(''ApplicationName''), '';'', + '',''), '']'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"installed_application_linux"},"ApplicationName":{"value":"[parameters(''ApplicationName'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ApplicationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent","value":"[concat(''packages: + ['', replace(parameters(''ApplicationName''), '';'', '',''), '']'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent","value":"[concat(''packages: + ['', replace(parameters(''ApplicationName''), '';'', '',''), '']'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4d1c04de-2172-403f-901b-90608c35c721","type":"Microsoft.Authorization/policyDefinitions","name":"4d1c04de-2172-403f-901b-90608c35c721"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have the specified applications + installed","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that do not have the specified applications installed. For + more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WhitelistedApplication","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5e393799-e3ca-4e43-a9a5-0ec4648a57d9","type":"Microsoft.Authorization/policyDefinitions","name":"5e393799-e3ca-4e43-a9a5-0ec4648a57d9"},{"properties":{"displayName":"Audit + Linux machines that allow remote connections from accounts without passwords","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Linux machines that + allow remote connections from accounts without passwords","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"PasswordPolicy_msid110","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid110","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ea53dbee-c6c9-4f0e-9f9e-de0039b78023","type":"Microsoft.Authorization/policyDefinitions","name":"ea53dbee-c6c9-4f0e-9f9e-de0039b78023"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Linux VMs that allow remote connections from accounts + without passwords","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Linux virtual machines that allow remote connections from accounts + without passwords. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid110","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2d67222d-05fd-4526-a171-2ee132ad9e83","type":"Microsoft.Authorization/policyDefinitions","name":"2d67222d-05fd-4526-a171-2ee132ad9e83"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have the specified applications + installed","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + that do not have the specified applications installed. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"installedApplication":{"type":"String","metadata":{"displayName":"[Deprecated]: + Application names (supports wildcards)","description":"A semicolon-separated + list of the names of the applications that should be installed. e.g. ''Microsoft + SQL Server 2014 (64-bit); Microsoft Visual Studio Code'' or ''Microsoft SQL + Server 2014*'' (to match any application starting with ''Microsoft SQL Server + 2014'')"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WhitelistedApplication","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[InstalledApplication]bwhitelistedapp;Name'', + ''='', parameters(''installedApplication'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WhitelistedApplication"},"installedApplication":{"value":"[parameters(''installedApplication'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"installedApplication":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[InstalledApplication]bwhitelistedapp;Name","value":"[parameters(''installedApplication'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[InstalledApplication]bwhitelistedapp;Name","value":"[parameters(''installedApplication'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/12f7e5d0-42a7-4630-80d8-54fb7cff9bd6","type":"Microsoft.Authorization/policyDefinitions","name":"12f7e5d0-42a7-4630-80d8-54fb7cff9bd6"},{"properties":{"displayName":"Authentication + to Linux machines should require SSH keys","policyType":"BuiltIn","mode":"Indexed","description":"Although + SSH itself provides an encrypted connection, using passwords with SSH still + leaves the VM vulnerable to brute-force attacks. The most secure option for + authenticating to an Azure Linux virtual machine over SSH is with a public-private + key pair, also known as SSH keys. Learn more: https://docs.microsoft.com/azure/virtual-machines/linux/create-ssh-keys-detailed.","metadata":{"category":"Guest + Configuration","version":"2.0.1","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"LinuxNoPasswordForSSH","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"LinuxNoPasswordForSSH","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/630c64f9-8b6b-4c64-b511-6544ceff6fd6","type":"Microsoft.Authorization/policyDefinitions","name":"630c64f9-8b6b-4c64-b511-6544ceff6fd6"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Linux VMs that allow remote connections from + accounts without passwords","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Linux virtual machines + that allow remote connections from accounts without passwords. It also creates + a system-assigned managed identity and deploys the VM extension for Guest + Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid110","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"PasswordPolicy_msid110"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ec49586f-4939-402d-a29e-6ff502b20592","type":"Microsoft.Authorization/policyDefinitions","name":"ec49586f-4939-402d-a29e-6ff502b20592"},{"properties":{"displayName":"Audit + Linux machines that do not have the passwd file permissions set to 0644","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Linux machines that + do not have the passwd file permissions set to 0644","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"PasswordPolicy_msid121","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid121","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e6955644-301c-44b5-a4c4-528577de6861","type":"Microsoft.Authorization/policyDefinitions","name":"e6955644-301c-44b5-a4c4-528577de6861"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Linux VMs that do not have the passwd file permissions + set to 0644","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Linux + virtual machines that do not have the passwd file permissions set to 0644. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid121","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b18175dd-c599-4c64-83ba-bb018a06d35b","type":"Microsoft.Authorization/policyDefinitions","name":"b18175dd-c599-4c64-83ba-bb018a06d35b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Linux VMs that do not have the passwd file permissions + set to 0644","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Linux virtual machines that + do not have the passwd file permissions set to 0644. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid121","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"PasswordPolicy_msid121"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f19aa1c1-6b91-4c27-ae6a-970279f03db9","type":"Microsoft.Authorization/policyDefinitions","name":"f19aa1c1-6b91-4c27-ae6a-970279f03db9"},{"properties":{"displayName":"Audit + Linux machines that have accounts without passwords","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Linux machines that + have accounts without passwords","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"PasswordPolicy_msid232","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid232","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f6ec09a3-78bf-4f8f-99dc-6c77182d0f99","type":"Microsoft.Authorization/policyDefinitions","name":"f6ec09a3-78bf-4f8f-99dc-6c77182d0f99"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Linux VMs that have accounts without passwords","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Linux virtual machines that have accounts without passwords. For + more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid232","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c40c9087-1981-4e73-9f53-39743eda9d05","type":"Microsoft.Authorization/policyDefinitions","name":"c40c9087-1981-4e73-9f53-39743eda9d05"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Linux VMs that have accounts without passwords","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Linux virtual machines + that have accounts without passwords. It also creates a system-assigned managed + identity and deploys the VM extension for Guest Configuration. This policy + should only be used along with its corresponding audit policy in an initiative. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordPolicy_msid232","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"PasswordPolicy_msid232"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3470477a-b35a-49db-aca5-1073d04524fe","type":"Microsoft.Authorization/policyDefinitions","name":"3470477a-b35a-49db-aca5-1073d04524fe"},{"properties":{"displayName":"Audit + Windows machines that have not restarted within the specified number of days","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the WMI property + LastBootUpTime in class Win32_Operatingsystem is outside the range of days + provided by the policy parameter.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"MachineLastBootUpTime","version":"1.*","configurationParameter":{"NumberOfDays":"[MachineUpTime]MachineLastBootUpTime;NumberOfDays"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"NumberOfDays":{"type":"String","metadata":{"displayName":"Number + of days","description":"The number of days without restart until the machine + is considered non-compliant"},"defaultValue":"12"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MachineLastBootUpTime","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[MachineUpTime]MachineLastBootUpTime;NumberOfDays'', + ''='', parameters(''NumberOfDays'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/beb6ccee-b6b8-4e91-9801-a5fa4260a104","type":"Microsoft.Authorization/policyDefinitions","name":"beb6ccee-b6b8-4e91-9801-a5fa4260a104"},{"properties":{"displayName":"Audit + Linux machines that have the specified applications installed","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the Chef InSpec + resource indicates that one or more of the packages provided by the parameter + are installed.","metadata":{"category":"Guest Configuration","version":"3.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"not_installed_application_linux","version":"1.*","configurationParameter":{"ApplicationName":"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ApplicationName":{"type":"String","metadata":{"displayName":"Application + names","description":"A semicolon-separated list of the names of the applications + that should not be installed. e.g. ''python; powershell''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"not_installed_application_linux","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent'', + ''='', parameters(''ApplicationName'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0447bc18-e2f7-4c0d-aa20-bff034275be1","type":"Microsoft.Authorization/policyDefinitions","name":"0447bc18-e2f7-4c0d-aa20-bff034275be1"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that have not restarted within the specified + number of days","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that have not restarted within the specified number of days. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MachineLastBootUpTime","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7e84ba44-6d03-46fd-950e-5efa5a1112fa","type":"Microsoft.Authorization/policyDefinitions","name":"7e84ba44-6d03-46fd-950e-5efa5a1112fa"},{"properties":{"displayName":"Audit + Windows machines that have the specified applications installed","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the application + name is found in any of the following registry paths: HKLM:SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall, + HKLM:SOFTWARE\\Wow6432node\\Microsoft\\Windows\\CurrentVersion\\Uninstall, + HKCU:Software\\Microsoft\\Windows\\CurrentVersion\\Uninstall.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"NotInstalledApplicationForWindows","version":"1.*","configurationParameter":{"ApplicationName":"[InstalledApplication]NotInstalledApplicationResource1;Name"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ApplicationName":{"type":"String","metadata":{"displayName":"Application + names (supports wildcards)","description":"A semicolon-separated list of the + names of the applications that should not be installed. e.g. ''Microsoft SQL + Server 2014 (64-bit); Microsoft Visual Studio Code'' or ''Microsoft SQL Server + 2014*'' (to match any application starting with ''Microsoft SQL Server 2014'')"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"NotInstalledApplicationForWindows","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[InstalledApplication]NotInstalledApplicationResource1;Name'', + ''='', parameters(''ApplicationName'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c5b85cba-6e6f-4de4-95e1-f0233cd712ac","type":"Microsoft.Authorization/policyDefinitions","name":"c5b85cba-6e6f-4de4-95e1-f0233cd712ac"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that have not restarted within the + specified number of days","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that have not restarted within the specified number of days. It also creates + a system-assigned managed identity and deploys the VM extension for Guest + Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.1.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"NumberOfDays":{"type":"String","metadata":{"displayName":"[Deprecated]: + Number of days","description":"The number of days without restart until the + machine is considered non-compliant"},"defaultValue":"12"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MachineLastBootUpTime","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[MachineUpTime]MachineLastBootUpTime;NumberOfDays'', + ''='', parameters(''NumberOfDays'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"MachineLastBootUpTime"},"NumberOfDays":{"value":"[parameters(''NumberOfDays'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"NumberOfDays":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[MachineUpTime]MachineLastBootUpTime;NumberOfDays","value":"[parameters(''NumberOfDays'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[MachineUpTime]MachineLastBootUpTime;NumberOfDays","value":"[parameters(''NumberOfDays'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f4b245d4-46c9-42be-9b1a-49e2b5b94194","type":"Microsoft.Authorization/policyDefinitions","name":"f4b245d4-46c9-42be-9b1a-49e2b5b94194"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Linux VMs that have the specified applications installed","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Linux virtual machines that have the specified applications installed. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"not_installed_application_linux","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b842acb-0fe7-41b0-9f40-880ec4ad84d8","type":"Microsoft.Authorization/policyDefinitions","name":"5b842acb-0fe7-41b0-9f40-880ec4ad84d8"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Linux VMs that have the specified applications + installed","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Linux virtual machines that + have the specified applications installed. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ApplicationName":{"type":"String","metadata":{"displayName":"[Deprecated]: + Application names","description":"A semicolon-separated list of the names + of the applications that should not be installed. e.g. ''python; powershell''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"linux*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"not_installed_application_linux","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent'', + ''='', concat(''packages: ['', replace(parameters(''ApplicationName''), '';'', + '',''), '']'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"not_installed_application_linux"},"ApplicationName":{"value":"[parameters(''ApplicationName'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ApplicationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent","value":"[concat(''packages: + ['', replace(parameters(''ApplicationName''), '';'', '',''), '']'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent","value":"[concat(''packages: + ['', replace(parameters(''ApplicationName''), '';'', '',''), '']'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/884b209a-963b-4520-8006-d20cb3c213e0","type":"Microsoft.Authorization/policyDefinitions","name":"884b209a-963b-4520-8006-d20cb3c213e0"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that have the specified applications installed","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that have the specified applications installed. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"NotInstalledApplication","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7e56b49b-5990-4159-a734-511ea19b731c","type":"Microsoft.Authorization/policyDefinitions","name":"7e56b49b-5990-4159-a734-511ea19b731c"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that have the specified applications + installed","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + that have the specified applications installed. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ApplicationName":{"type":"String","metadata":{"displayName":"[Deprecated]: + Application names (supports wildcards)","description":"A semicolon-separated + list of the names of the applications that should not be installed. e.g. ''Microsoft + SQL Server 2014 (64-bit); Microsoft Visual Studio Code'' or ''Microsoft SQL + Server 2014*'' (to match any application starting with ''Microsoft SQL Server + 2014'')"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"NotInstalledApplication","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[InstalledApplication]NotInstalledApplicationResource1;Name'', + ''='', parameters(''ApplicationName'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"NotInstalledApplication"},"ApplicationName":{"value":"[parameters(''ApplicationName'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ApplicationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[InstalledApplication]NotInstalledApplicationResource1;Name","value":"[parameters(''ApplicationName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[InstalledApplication]NotInstalledApplicationResource1;Name","value":"[parameters(''ApplicationName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f0633351-c7b2-41ff-9981-508fc08553c2","type":"Microsoft.Authorization/policyDefinitions","name":"f0633351-c7b2-41ff-9981-508fc08553c2"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Accounts''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Accounts'' for limiting local account use of blank passwords and + guest account status. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsAccounts","version":"1.*","configurationParameter":{"AccountsGuestAccountStatus":"Accounts: + Guest account status;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AccountsGuestAccountStatus":{"type":"String","metadata":{"displayName":"Accounts: + Guest account status","description":"Specifies whether the local Guest account + is disabled."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAccounts","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Accounts: + Guest account status;ExpectedValue'', ''='', parameters(''AccountsGuestAccountStatus'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ee984370-154a-4ee8-9726-19d900e56fc0","type":"Microsoft.Authorization/policyDefinitions","name":"ee984370-154a-4ee8-9726-19d900e56fc0"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to enable Guest Configuration Policy on Linux VMs.","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration on Linux VMs. This is a prerequisite for Guest Configuration + Policy and must be assigned to the scope before using any Guest Configuration + policy. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol.","metadata":{"version":"3.0.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["microsoft-aks","qubole-inc","datastax","couchbase","scalegrid","checkpoint","paloaltonetworks","debian"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","like":"CentOS*"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","equals":"Oracle-Linux"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["RHEL","RHEL-HA","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HA","RHEL-SAP-HANA"]},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","rhel-byos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-7-l1","cis-centos-7-v2-1-1-l1","cis-centos-8-l1","cis-debian-linux-8-l1","cis-debian-linux-9-l1","cis-nginx-centos-7-v1-1-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-oracle-linux-8-l1","cis-postgresql-11-centos-linux-7-level-1","cis-rhel-7-l2","cis-rhel-7-v2-2-0-l1","cis-rhel-8-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1","cis-ubuntu-linux-1804-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","equals":"Debian"},{"field":"Microsoft.Compute/imageSKU","notLike":"7*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Suse"},{"field":"Microsoft.Compute/imageOffer","like":"SLES*"},{"field":"Microsoft.Compute/imageSKU","notLike":"11*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","equals":"UbuntuServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"12*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm-ubuntu","azureml"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-centos-os"},{"field":"Microsoft.Compute/imageSKU","notLike":"6*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","equals":"cloudera-altus-centos-os"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","like":"linux*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Linux*"}]},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","exists":"false"},{"field":"Microsoft.Compute/imagePublisher","notIn":["OpenLogic","RedHat","credativ","Suse","Canonical","microsoft-dsvm","cloudera","microsoft-ads","center-for-internet-security-inc","Oracle"]}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforLinux","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforLinux"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforLinux'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforLinux","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fb27e9e0-526e-4ae1-89f2-a2a0bf0f8a50","type":"Microsoft.Authorization/policyDefinitions","name":"fb27e9e0-526e-4ae1-89f2-a2a0bf0f8a50"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to enable Guest Configuration Policy on Windows VMs.","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration on Windows VMs. This is a prerequisite for Guest Configuration + Policy and must be assigned to the scope before using any Guest Configuration + policy. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol.","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.Compute/virtualMachines/extensions","name":"AzurePolicyforWindows","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.GuestConfiguration"},{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"ConfigurationforWindows"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","equals":"Succeeded"}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0ecd903d-91e7-4726-83d3-a229d7f2e293","type":"Microsoft.Authorization/policyDefinitions","name":"0ecd903d-91e7-4726-83d3-a229d7f2e293"},{"properties":{"displayName":"Windows + web servers should be configured to use secure communication protocols","policyType":"BuiltIn","mode":"Indexed","description":"To + protect the privacy of information communicated over the Internet, your web + servers should use the latest version of the industry-standard cryptographic + protocol, Transport Layer Security (TLS). TLS secures communications over + a network by using security certificates to encrypt a connection between machines. + TLS 1.3 is faster and more secure than the earlier versions: TLS 1.0-1.2 and + SSL 2-3, which are all considered legacy protocols.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AuditSecureProtocol","version":"1.*","configurationParameter":{"MinimumTLSVersion":"[SecureWebServer]s1;MinimumTLSVersion"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"MinimumTLSVersion":{"type":"String","metadata":{"displayName":"Minimum + TLS version","description":"The minimum TLS protocol version that should be + enabled. Windows web servers with lower TLS versions will be marked as non-compliant."},"allowedValues":["1.1","1.2"],"defaultValue":"1.1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AuditSecureProtocol","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[SecureWebServer]s1;MinimumTLSVersion'', + ''='', parameters(''MinimumTLSVersion'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5752e6d6-1206-46d8-8ab1-ecc2f71a8112","type":"Microsoft.Authorization/policyDefinitions","name":"5752e6d6-1206-46d8-8ab1-ecc2f71a8112"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Accounts''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Accounts''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AccountsGuestAccountStatus":{"type":"String","metadata":{"displayName":"[Deprecated]: + Accounts: Guest account status","description":"Specifies whether the local + Guest account is disabled."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAccounts","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Accounts: + Guest account status;ExpectedValue'', ''='', parameters(''AccountsGuestAccountStatus'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsAccounts"},"AccountsGuestAccountStatus":{"value":"[parameters(''AccountsGuestAccountStatus'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AccountsGuestAccountStatus":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Accounts: + Guest account status;ExpectedValue","value":"[parameters(''AccountsGuestAccountStatus'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Accounts: + Guest account status;ExpectedValue","value":"[parameters(''AccountsGuestAccountStatus'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e5b81f87-9185-4224-bf00-9f505e9f89f3","type":"Microsoft.Authorization/policyDefinitions","name":"e5b81f87-9185-4224-bf00-9f505e9f89f3"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Audit''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Audit'' for forcing audit policy subcategory and shutting down if + unable to log security audits. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsAudit","version":"1.*","configurationParameter":{"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits":"Audit: + Shut down system immediately if unable to log security audits;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits":{"type":"String","metadata":{"displayName":"Audit: + Shut down system immediately if unable to log security audits","description":"Audits + if the system will shut down when unable to log Security events."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAudit","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit: + Shut down system immediately if unable to log security audits;ExpectedValue'', + ''='', parameters(''AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/33936777-f2ac-45aa-82ec-07958ec9ade4","type":"Microsoft.Authorization/policyDefinitions","name":"33936777-f2ac-45aa-82ec-07958ec9ade4"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Accounts''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Security + Options - Accounts''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAccounts","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b872a447-cc6f-43b9-bccf-45703cd81607","type":"Microsoft.Authorization/policyDefinitions","name":"b872a447-cc6f-43b9-bccf-45703cd81607"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Audit''","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Audit''. It also creates a system-assigned managed identity and deploys the + VM extension for Guest Configuration. This policy should only be used along + with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit: Shut down system immediately if unable to log security audits","description":"Audits + if the system will shut down when unable to log Security events."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAudit","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit: + Shut down system immediately if unable to log security audits;ExpectedValue'', + ''='', parameters(''AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsAudit"},"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits":{"value":"[parameters(''AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit: + Shut down system immediately if unable to log security audits;ExpectedValue","value":"[parameters(''AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit: + Shut down system immediately if unable to log security audits;ExpectedValue","value":"[parameters(''AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/498b810c-59cd-4222-9338-352ba146ccf3","type":"Microsoft.Authorization/policyDefinitions","name":"498b810c-59cd-4222-9338-352ba146ccf3"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Devices''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Devices'' for undocking without logging on, installing print drivers, + and formatting/ejecting media. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsDevices","version":"1.*","configurationParameter":{"DevicesAllowedToFormatAndEjectRemovableMedia":"Devices: + Allowed to format and eject removable media;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"DevicesAllowedToFormatAndEjectRemovableMedia":{"type":"String","metadata":{"displayName":"Devices: + Allowed to format and eject removable media","description":"Specifies who + is allowed to format and eject removable NTFS media. You can use this policy + setting to prevent unauthorized users from removing data on one computer to + access it on another computer on which they have local administrator privileges."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsDevices","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Devices: + Allowed to format and eject removable media;ExpectedValue'', ''='', parameters(''DevicesAllowedToFormatAndEjectRemovableMedia'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8794ff4f-1a35-4e18-938f-0b22055067cd","type":"Microsoft.Authorization/policyDefinitions","name":"8794ff4f-1a35-4e18-938f-0b22055067cd"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Audit''","policyType":"BuiltIn","mode":"All","description":"This policy should + only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Security + Options - Audit''. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsAudit","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/21e2995e-683e-497a-9e81-2f42ad07050a","type":"Microsoft.Authorization/policyDefinitions","name":"21e2995e-683e-497a-9e81-2f42ad07050a"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Devices''","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Devices''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"DevicesAllowedToFormatAndEjectRemovableMedia":{"type":"String","metadata":{"displayName":"[Deprecated]: + Devices: Allowed to format and eject removable media","description":"Specifies + who is allowed to format and eject removable NTFS media. You can use this + policy setting to prevent unauthorized users from removing data on one computer + to access it on another computer on which they have local administrator privileges."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsDevices","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Devices: + Allowed to format and eject removable media;ExpectedValue'', ''='', parameters(''DevicesAllowedToFormatAndEjectRemovableMedia'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsDevices"},"DevicesAllowedToFormatAndEjectRemovableMedia":{"value":"[parameters(''DevicesAllowedToFormatAndEjectRemovableMedia'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"DevicesAllowedToFormatAndEjectRemovableMedia":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Devices: + Allowed to format and eject removable media;ExpectedValue","value":"[parameters(''DevicesAllowedToFormatAndEjectRemovableMedia'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Devices: + Allowed to format and eject removable media;ExpectedValue","value":"[parameters(''DevicesAllowedToFormatAndEjectRemovableMedia'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6481cc21-ed6e-4480-99dd-ea7c5222e897","type":"Microsoft.Authorization/policyDefinitions","name":"6481cc21-ed6e-4480-99dd-ea7c5222e897"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Devices''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Security + Options - Devices''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsDevices","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3d7b154e-2700-4c8c-9e46-cb65ac1578c2","type":"Microsoft.Authorization/policyDefinitions","name":"3d7b154e-2700-4c8c-9e46-cb65ac1578c2"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Interactive Logon''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Interactive Logon''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsInteractiveLogon","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c8abcef9-fc26-482f-b8db-5fa60ee4586d","type":"Microsoft.Authorization/policyDefinitions","name":"c8abcef9-fc26-482f-b8db-5fa60ee4586d"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Interactive Logon''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Interactive Logon'' for displaying last user name and requiring + ctrl-alt-del. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsInteractiveLogon","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsInteractiveLogon","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d472d2c9-d6a3-4500-9f5f-b15f123005aa","type":"Microsoft.Authorization/policyDefinitions","name":"d472d2c9-d6a3-4500-9f5f-b15f123005aa"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Microsoft Network Client''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Microsoft Network Client''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkClient","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fcbc55c9-f25a-4e55-a6cb-33acb3be778b","type":"Microsoft.Authorization/policyDefinitions","name":"fcbc55c9-f25a-4e55-a6cb-33acb3be778b"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Microsoft Network + Client''","policyType":"BuiltIn","mode":"Indexed","description":"Windows machines + should have the specified Group Policy settings in the category ''Security + Options - Microsoft Network Client'' for Microsoft network client/server and + SMB v1. This policy requires that the Guest Configuration prerequisites have + been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsMicrosoftNetworkClient","version":"1.*","configurationParameter":{"MicrosoftNetworkClientDigitallySignCommunicationsAlways":"Microsoft + network client: Digitally sign communications (always);ExpectedValue","MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers":"Microsoft + network client: Send unencrypted password to third-party SMB servers;ExpectedValue","MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession":"Microsoft + network server: Amount of idle time required before suspending session;ExpectedValue","MicrosoftNetworkServerDigitallySignCommunicationsAlways":"Microsoft + network server: Digitally sign communications (always);ExpectedValue","MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire":"Microsoft + network server: Disconnect clients when logon hours expire;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"MicrosoftNetworkClientDigitallySignCommunicationsAlways":{"type":"String","metadata":{"displayName":"Microsoft + network client: Digitally sign communications (always)","description":"Specifies + whether packet signing is required by the SMB client component."},"defaultValue":"1"},"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers":{"type":"String","metadata":{"displayName":"Microsoft + network client: Send unencrypted password to third-party SMB servers","description":"Specifies + whether the SMB redirector will send plaintext passwords during authentication + to third-party SMB servers that do not support password encryption. It is + recommended that you disable this policy setting unless there is a strong + business case to enable it."},"defaultValue":"0"},"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession":{"type":"String","metadata":{"displayName":"Microsoft + network server: Amount of idle time required before suspending session","description":"Specifies + the amount of continuous idle time that must pass in an SMB session before + the session is suspended because of inactivity. The format of the value is + two integers separated by a comma, denoting an inclusive range."},"defaultValue":"1,15"},"MicrosoftNetworkServerDigitallySignCommunicationsAlways":{"type":"String","metadata":{"displayName":"Microsoft + network server: Digitally sign communications (always)","description":"Specifies + whether packet signing is required by the SMB server component."},"defaultValue":"1"},"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire":{"type":"String","metadata":{"displayName":"Microsoft + network server: Disconnect clients when logon hours expire","description":"Specifies + whether to disconnect users who are connected to the local computer outside + their user account''s valid logon hours. This setting affects the Server Message + Block (SMB) component. If you enable this policy setting you should also enable + ''Network security: Force logoff when logon hours expire''"},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkClient","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Microsoft + network client: Digitally sign communications (always);ExpectedValue'', ''='', + parameters(''MicrosoftNetworkClientDigitallySignCommunicationsAlways''), '','', + ''Microsoft network client: Send unencrypted password to third-party SMB servers;ExpectedValue'', + ''='', parameters(''MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers''), + '','', ''Microsoft network server: Amount of idle time required before suspending + session;ExpectedValue'', ''='', parameters(''MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession''), + '','', ''Microsoft network server: Digitally sign communications (always);ExpectedValue'', + ''='', parameters(''MicrosoftNetworkServerDigitallySignCommunicationsAlways''), + '','', ''Microsoft network server: Disconnect clients when logon hours expire;ExpectedValue'', + ''='', parameters(''MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d6c69680-54f0-4349-af10-94dd05f4225e","type":"Microsoft.Authorization/policyDefinitions","name":"d6c69680-54f0-4349-af10-94dd05f4225e"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Interactive Logon''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Interactive Logon''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsInteractiveLogon","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsInteractiveLogon"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3750712b-43d0-478e-9966-d2c26f6141b9","type":"Microsoft.Authorization/policyDefinitions","name":"3750712b-43d0-478e-9966-d2c26f6141b9"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Microsoft Network + Server''","policyType":"BuiltIn","mode":"Indexed","description":"Windows machines + should have the specified Group Policy settings in the category ''Security + Options - Microsoft Network Server'' for disabling SMB v1 server. This policy + requires that the Guest Configuration prerequisites have been deployed to + the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsMicrosoftNetworkServer","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkServer","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/caf2d518-f029-4f6b-833b-d7081702f253","type":"Microsoft.Authorization/policyDefinitions","name":"caf2d518-f029-4f6b-833b-d7081702f253"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Microsoft Network Client''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Microsoft Network Client''. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"MicrosoftNetworkClientDigitallySignCommunicationsAlways":{"type":"String","metadata":{"displayName":"[Deprecated]: + Microsoft network client: Digitally sign communications (always)","description":"Specifies + whether packet signing is required by the SMB client component."},"defaultValue":"1"},"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers":{"type":"String","metadata":{"displayName":"[Deprecated]: + Microsoft network client: Send unencrypted password to third-party SMB servers","description":"Specifies + whether the SMB redirector will send plaintext passwords during authentication + to third-party SMB servers that do not support password encryption. It is + recommended that you disable this policy setting unless there is a strong + business case to enable it."},"defaultValue":"0"},"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession":{"type":"String","metadata":{"displayName":"[Deprecated]: + Microsoft network server: Amount of idle time required before suspending session","description":"Specifies + the amount of continuous idle time that must pass in an SMB session before + the session is suspended because of inactivity. The format of the value is + two integers separated by a comma, denoting an inclusive range."},"defaultValue":"1,15"},"MicrosoftNetworkServerDigitallySignCommunicationsAlways":{"type":"String","metadata":{"displayName":"[Deprecated]: + Microsoft network server: Digitally sign communications (always)","description":"Specifies + whether packet signing is required by the SMB server component."},"defaultValue":"1"},"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire":{"type":"String","metadata":{"displayName":"[Deprecated]: + Microsoft network server: Disconnect clients when logon hours expire","description":"Specifies + whether to disconnect users who are connected to the local computer outside + their user account''s valid logon hours. This setting affects the Server Message + Block (SMB) component. If you enable this policy setting you should also enable + ''Network security: Force logoff when logon hours expire''"},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkClient","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Microsoft + network client: Digitally sign communications (always);ExpectedValue'', ''='', + parameters(''MicrosoftNetworkClientDigitallySignCommunicationsAlways''), '','', + ''Microsoft network client: Send unencrypted password to third-party SMB servers;ExpectedValue'', + ''='', parameters(''MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers''), + '','', ''Microsoft network server: Amount of idle time required before suspending + session;ExpectedValue'', ''='', parameters(''MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession''), + '','', ''Microsoft network server: Digitally sign communications (always);ExpectedValue'', + ''='', parameters(''MicrosoftNetworkServerDigitallySignCommunicationsAlways''), + '','', ''Microsoft network server: Disconnect clients when logon hours expire;ExpectedValue'', + ''='', parameters(''MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsMicrosoftNetworkClient"},"MicrosoftNetworkClientDigitallySignCommunicationsAlways":{"value":"[parameters(''MicrosoftNetworkClientDigitallySignCommunicationsAlways'')]"},"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers":{"value":"[parameters(''MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers'')]"},"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession":{"value":"[parameters(''MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession'')]"},"MicrosoftNetworkServerDigitallySignCommunicationsAlways":{"value":"[parameters(''MicrosoftNetworkServerDigitallySignCommunicationsAlways'')]"},"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire":{"value":"[parameters(''MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"MicrosoftNetworkClientDigitallySignCommunicationsAlways":{"type":"string"},"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers":{"type":"string"},"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession":{"type":"string"},"MicrosoftNetworkServerDigitallySignCommunicationsAlways":{"type":"string"},"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Microsoft + network client: Digitally sign communications (always);ExpectedValue","value":"[parameters(''MicrosoftNetworkClientDigitallySignCommunicationsAlways'')]"},{"name":"Microsoft + network client: Send unencrypted password to third-party SMB servers;ExpectedValue","value":"[parameters(''MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers'')]"},{"name":"Microsoft + network server: Amount of idle time required before suspending session;ExpectedValue","value":"[parameters(''MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession'')]"},{"name":"Microsoft + network server: Digitally sign communications (always);ExpectedValue","value":"[parameters(''MicrosoftNetworkServerDigitallySignCommunicationsAlways'')]"},{"name":"Microsoft + network server: Disconnect clients when logon hours expire;ExpectedValue","value":"[parameters(''MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Microsoft + network client: Digitally sign communications (always);ExpectedValue","value":"[parameters(''MicrosoftNetworkClientDigitallySignCommunicationsAlways'')]"},{"name":"Microsoft + network client: Send unencrypted password to third-party SMB servers;ExpectedValue","value":"[parameters(''MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers'')]"},{"name":"Microsoft + network server: Amount of idle time required before suspending session;ExpectedValue","value":"[parameters(''MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession'')]"},{"name":"Microsoft + network server: Digitally sign communications (always);ExpectedValue","value":"[parameters(''MicrosoftNetworkServerDigitallySignCommunicationsAlways'')]"},{"name":"Microsoft + network server: Disconnect clients when logon hours expire;ExpectedValue","value":"[parameters(''MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bbcdd8fa-b600-4ee3-85b8-d184e3339652","type":"Microsoft.Authorization/policyDefinitions","name":"bbcdd8fa-b600-4ee3-85b8-d184e3339652"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Microsoft Network Server''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Microsoft Network Server''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkServer","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6fe4ef56-7576-4dc4-8e9c-26bad4b087ce","type":"Microsoft.Authorization/policyDefinitions","name":"6fe4ef56-7576-4dc4-8e9c-26bad4b087ce"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Network Access''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Network Access'' for including access for anonymous users, local + accounts, and remote access to the registry. This policy requires that the + Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsNetworkAccess","version":"1.*","configurationParameter":{"NetworkAccessRemotelyAccessibleRegistryPaths":"Network + access: Remotely accessible registry paths;ExpectedValue","NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths":"Network + access: Remotely accessible registry paths and sub-paths;ExpectedValue","NetworkAccessSharesThatCanBeAccessedAnonymously":"Network + access: Shares that can be accessed anonymously;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"NetworkAccessRemotelyAccessibleRegistryPaths":{"type":"String","metadata":{"displayName":"Network + access: Remotely accessible registry paths","description":"Specifies which + registry paths will be accessible over the network, regardless of the users + or groups listed in the access control list (ACL) of the `winreg` registry + key."},"defaultValue":"System\\CurrentControlSet\\Control\\ProductOptions|#|System\\CurrentControlSet\\Control\\Server + Applications|#|Software\\Microsoft\\Windows NT\\CurrentVersion"},"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths":{"type":"String","metadata":{"displayName":"Network + access: Remotely accessible registry paths and sub-paths","description":"Specifies + which registry paths and sub-paths will be accessible over the network, regardless + of the users or groups listed in the access control list (ACL) of the `winreg` + registry key."},"defaultValue":"System\\CurrentControlSet\\Control\\Print\\Printers|#|System\\CurrentControlSet\\Services\\Eventlog|#|Software\\Microsoft\\OLAP + Server|#|Software\\Microsoft\\Windows NT\\CurrentVersion\\Print|#|Software\\Microsoft\\Windows + NT\\CurrentVersion\\Windows|#|System\\CurrentControlSet\\Control\\ContentIndex|#|System\\CurrentControlSet\\Control\\Terminal + Server|#|System\\CurrentControlSet\\Control\\Terminal Server\\UserConfig|#|System\\CurrentControlSet\\Control\\Terminal + Server\\DefaultUserConfiguration|#|Software\\Microsoft\\Windows NT\\CurrentVersion\\Perflib|#|System\\CurrentControlSet\\Services\\SysmonLog"},"NetworkAccessSharesThatCanBeAccessedAnonymously":{"type":"String","metadata":{"displayName":"Network + access: Shares that can be accessed anonymously","description":"Specifies + which network shares can be accessed by anonymous users. The default configuration + for this policy setting has little effect because all users have to be authenticated + before they can access shared resources on the server."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkAccess","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Network + access: Remotely accessible registry paths;ExpectedValue'', ''='', parameters(''NetworkAccessRemotelyAccessibleRegistryPaths''), + '','', ''Network access: Remotely accessible registry paths and sub-paths;ExpectedValue'', + ''='', parameters(''NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths''), + '','', ''Network access: Shares that can be accessed anonymously;ExpectedValue'', + ''='', parameters(''NetworkAccessSharesThatCanBeAccessedAnonymously'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3ff60f98-7fa4-410a-9f7f-0b00f5afdbdd","type":"Microsoft.Authorization/policyDefinitions","name":"3ff60f98-7fa4-410a-9f7f-0b00f5afdbdd"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Network Access''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Network Access''. For more information on Guest + Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkAccess","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/30040dab-4e75-4456-8273-14b8f75d91d9","type":"Microsoft.Authorization/policyDefinitions","name":"30040dab-4e75-4456-8273-14b8f75d91d9"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Microsoft Network Server''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Microsoft Network Server''. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsMicrosoftNetworkServer","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsMicrosoftNetworkServer"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86880e5c-df35-43c5-95ad-7e120635775e","type":"Microsoft.Authorization/policyDefinitions","name":"86880e5c-df35-43c5-95ad-7e120635775e"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Network Security''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Network Security''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkSecurity","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5c028d2a-1889-45f6-b821-31f42711ced8","type":"Microsoft.Authorization/policyDefinitions","name":"5c028d2a-1889-45f6-b821-31f42711ced8"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Network Access''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Network Access''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"NetworkAccessRemotelyAccessibleRegistryPaths":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network access: Remotely accessible registry paths","description":"Specifies + which registry paths will be accessible over the network, regardless of the + users or groups listed in the access control list (ACL) of the `winreg` registry + key."},"defaultValue":"System\\CurrentControlSet\\Control\\ProductOptions|#|System\\CurrentControlSet\\Control\\Server + Applications|#|Software\\Microsoft\\Windows NT\\CurrentVersion"},"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network access: Remotely accessible registry paths and sub-paths","description":"Specifies + which registry paths and sub-paths will be accessible over the network, regardless + of the users or groups listed in the access control list (ACL) of the `winreg` + registry key."},"defaultValue":"System\\CurrentControlSet\\Control\\Print\\Printers|#|System\\CurrentControlSet\\Services\\Eventlog|#|Software\\Microsoft\\OLAP + Server|#|Software\\Microsoft\\Windows NT\\CurrentVersion\\Print|#|Software\\Microsoft\\Windows + NT\\CurrentVersion\\Windows|#|System\\CurrentControlSet\\Control\\ContentIndex|#|System\\CurrentControlSet\\Control\\Terminal + Server|#|System\\CurrentControlSet\\Control\\Terminal Server\\UserConfig|#|System\\CurrentControlSet\\Control\\Terminal + Server\\DefaultUserConfiguration|#|Software\\Microsoft\\Windows NT\\CurrentVersion\\Perflib|#|System\\CurrentControlSet\\Services\\SysmonLog"},"NetworkAccessSharesThatCanBeAccessedAnonymously":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network access: Shares that can be accessed anonymously","description":"Specifies + which network shares can be accessed by anonymous users. The default configuration + for this policy setting has little effect because all users have to be authenticated + before they can access shared resources on the server."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkAccess","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Network + access: Remotely accessible registry paths;ExpectedValue'', ''='', parameters(''NetworkAccessRemotelyAccessibleRegistryPaths''), + '','', ''Network access: Remotely accessible registry paths and sub-paths;ExpectedValue'', + ''='', parameters(''NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths''), + '','', ''Network access: Shares that can be accessed anonymously;ExpectedValue'', + ''='', parameters(''NetworkAccessSharesThatCanBeAccessedAnonymously'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsNetworkAccess"},"NetworkAccessRemotelyAccessibleRegistryPaths":{"value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPaths'')]"},"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths":{"value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths'')]"},"NetworkAccessSharesThatCanBeAccessedAnonymously":{"value":"[parameters(''NetworkAccessSharesThatCanBeAccessedAnonymously'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"NetworkAccessRemotelyAccessibleRegistryPaths":{"type":"string"},"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths":{"type":"string"},"NetworkAccessSharesThatCanBeAccessedAnonymously":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Network + access: Remotely accessible registry paths;ExpectedValue","value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPaths'')]"},{"name":"Network + access: Remotely accessible registry paths and sub-paths;ExpectedValue","value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths'')]"},{"name":"Network + access: Shares that can be accessed anonymously;ExpectedValue","value":"[parameters(''NetworkAccessSharesThatCanBeAccessedAnonymously'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Network + access: Remotely accessible registry paths;ExpectedValue","value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPaths'')]"},{"name":"Network + access: Remotely accessible registry paths and sub-paths;ExpectedValue","value":"[parameters(''NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths'')]"},{"name":"Network + access: Shares that can be accessed anonymously;ExpectedValue","value":"[parameters(''NetworkAccessSharesThatCanBeAccessedAnonymously'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f56a3ab2-89d1-44de-ac0d-2ada5962e22a","type":"Microsoft.Authorization/policyDefinitions","name":"f56a3ab2-89d1-44de-ac0d-2ada5962e22a"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Network Security''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Network Security''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network Security: Configure encryption types allowed for Kerberos","description":"Specifies + the encryption types that Kerberos is allowed to use."},"defaultValue":"2147483644"},"NetworkSecurityLANManagerAuthenticationLevel":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network security: LAN Manager authentication level","description":"Specify + which challenge-response authentication protocol is used for network logons. + This choice affects the level of authentication protocol used by clients, + the level of session security negotiated, and the level of authentication + accepted by servers."},"defaultValue":"5"},"NetworkSecurityLDAPClientSigningRequirements":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network security: LDAP client signing requirements","description":"Specify + the level of data signing that is requested on behalf of clients that issue + LDAP BIND requests."},"defaultValue":"1"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network security: Minimum session security for NTLM SSP based (including secure + RPC) clients","description":"Specifies which behaviors are allowed by clients + for applications using the NTLM Security Support Provider (SSP). The SSP Interface + (SSPI) is used by applications that need authentication services. See https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/network-security-minimum-session-security-for-ntlm-ssp-based-including-secure-rpc-servers + for more information."},"defaultValue":"537395200"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers":{"type":"String","metadata":{"displayName":"[Deprecated]: + Network security: Minimum session security for NTLM SSP based (including secure + RPC) servers","description":"Specifies which behaviors are allowed by servers + for applications using the NTLM Security Support Provider (SSP). The SSP Interface + (SSPI) is used by applications that need authentication services."},"defaultValue":"537395200"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkSecurity","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Network + Security: Configure encryption types allowed for Kerberos;ExpectedValue'', + ''='', parameters(''NetworkSecurityConfigureEncryptionTypesAllowedForKerberos''), + '','', ''Network security: LAN Manager authentication level;ExpectedValue'', + ''='', parameters(''NetworkSecurityLANManagerAuthenticationLevel''), '','', + ''Network security: LDAP client signing requirements;ExpectedValue'', ''='', + parameters(''NetworkSecurityLDAPClientSigningRequirements''), '','', ''Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients;ExpectedValue'', ''='', parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients''), + '','', ''Network security: Minimum session security for NTLM SSP based (including + secure RPC) servers;ExpectedValue'', ''='', parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsNetworkSecurity"},"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos":{"value":"[parameters(''NetworkSecurityConfigureEncryptionTypesAllowedForKerberos'')]"},"NetworkSecurityLANManagerAuthenticationLevel":{"value":"[parameters(''NetworkSecurityLANManagerAuthenticationLevel'')]"},"NetworkSecurityLDAPClientSigningRequirements":{"value":"[parameters(''NetworkSecurityLDAPClientSigningRequirements'')]"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients":{"value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients'')]"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers":{"value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos":{"type":"string"},"NetworkSecurityLANManagerAuthenticationLevel":{"type":"string"},"NetworkSecurityLDAPClientSigningRequirements":{"type":"string"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients":{"type":"string"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Network + Security: Configure encryption types allowed for Kerberos;ExpectedValue","value":"[parameters(''NetworkSecurityConfigureEncryptionTypesAllowedForKerberos'')]"},{"name":"Network + security: LAN Manager authentication level;ExpectedValue","value":"[parameters(''NetworkSecurityLANManagerAuthenticationLevel'')]"},{"name":"Network + security: LDAP client signing requirements;ExpectedValue","value":"[parameters(''NetworkSecurityLDAPClientSigningRequirements'')]"},{"name":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients;ExpectedValue","value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients'')]"},{"name":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + servers;ExpectedValue","value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Network + Security: Configure encryption types allowed for Kerberos;ExpectedValue","value":"[parameters(''NetworkSecurityConfigureEncryptionTypesAllowedForKerberos'')]"},{"name":"Network + security: LAN Manager authentication level;ExpectedValue","value":"[parameters(''NetworkSecurityLANManagerAuthenticationLevel'')]"},{"name":"Network + security: LDAP client signing requirements;ExpectedValue","value":"[parameters(''NetworkSecurityLDAPClientSigningRequirements'')]"},{"name":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients;ExpectedValue","value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients'')]"},{"name":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + servers;ExpectedValue","value":"[parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/36e17963-7202-494a-80c3-f508211c826b","type":"Microsoft.Authorization/policyDefinitions","name":"36e17963-7202-494a-80c3-f508211c826b"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Network Security''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Network Security'' for including Local System behavior, PKU2U, LAN + Manager, LDAP client, and NTLM SSP. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsNetworkSecurity","version":"1.*","configurationParameter":{"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos":"Network + Security: Configure encryption types allowed for Kerberos;ExpectedValue","NetworkSecurityLANManagerAuthenticationLevel":"Network + security: LAN Manager authentication level;ExpectedValue","NetworkSecurityLDAPClientSigningRequirements":"Network + security: LDAP client signing requirements;ExpectedValue","NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients;ExpectedValue","NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + servers;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos":{"type":"String","metadata":{"displayName":"Network + Security: Configure encryption types allowed for Kerberos","description":"Specifies + the encryption types that Kerberos is allowed to use."},"defaultValue":"2147483644"},"NetworkSecurityLANManagerAuthenticationLevel":{"type":"String","metadata":{"displayName":"Network + security: LAN Manager authentication level","description":"Specify which challenge-response + authentication protocol is used for network logons. This choice affects the + level of authentication protocol used by clients, the level of session security + negotiated, and the level of authentication accepted by servers."},"defaultValue":"5"},"NetworkSecurityLDAPClientSigningRequirements":{"type":"String","metadata":{"displayName":"Network + security: LDAP client signing requirements","description":"Specify the level + of data signing that is requested on behalf of clients that issue LDAP BIND + requests."},"defaultValue":"1"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients":{"type":"String","metadata":{"displayName":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients","description":"Specifies which behaviors are allowed by clients for + applications using the NTLM Security Support Provider (SSP). The SSP Interface + (SSPI) is used by applications that need authentication services. See https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/network-security-minimum-session-security-for-ntlm-ssp-based-including-secure-rpc-servers + for more information."},"defaultValue":"537395200"},"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers":{"type":"String","metadata":{"displayName":"Network + security: Minimum session security for NTLM SSP based (including secure RPC) + servers","description":"Specifies which behaviors are allowed by servers for + applications using the NTLM Security Support Provider (SSP). The SSP Interface + (SSPI) is used by applications that need authentication services."},"defaultValue":"537395200"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsNetworkSecurity","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Network + Security: Configure encryption types allowed for Kerberos;ExpectedValue'', + ''='', parameters(''NetworkSecurityConfigureEncryptionTypesAllowedForKerberos''), + '','', ''Network security: LAN Manager authentication level;ExpectedValue'', + ''='', parameters(''NetworkSecurityLANManagerAuthenticationLevel''), '','', + ''Network security: LDAP client signing requirements;ExpectedValue'', ''='', + parameters(''NetworkSecurityLDAPClientSigningRequirements''), '','', ''Network + security: Minimum session security for NTLM SSP based (including secure RPC) + clients;ExpectedValue'', ''='', parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients''), + '','', ''Network security: Minimum session security for NTLM SSP based (including + secure RPC) servers;ExpectedValue'', ''='', parameters(''NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1221c620-d201-468c-81e7-2817e6107e84","type":"Microsoft.Authorization/policyDefinitions","name":"1221c620-d201-468c-81e7-2817e6107e84"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Recovery console''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Recovery console'' for allowing floppy copy and access to all drives + and folders. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsRecoveryconsole","version":"1.*","configurationParameter":{"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders":"Recovery + console: Allow floppy copy and access to all drives and all folders;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders":{"type":"String","metadata":{"displayName":"Recovery + console: Allow floppy copy and access to all drives and all folders","description":"Specifies + whether to make the Recovery Console SET command available, which allows setting + of recovery console environment variables."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsRecoveryconsole","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Recovery + console: Allow floppy copy and access to all drives and all folders;ExpectedValue'', + ''='', parameters(''RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f71be03e-e25b-4d0f-b8bc-9b3e309b66c0","type":"Microsoft.Authorization/policyDefinitions","name":"f71be03e-e25b-4d0f-b8bc-9b3e309b66c0"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Recovery console''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - Recovery console''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsRecoveryconsole","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ba12366f-f9a6-42b8-9d98-157d0b1a837b","type":"Microsoft.Authorization/policyDefinitions","name":"ba12366f-f9a6-42b8-9d98-157d0b1a837b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Recovery console''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Recovery console''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders":{"type":"String","metadata":{"displayName":"[Deprecated]: + Recovery console: Allow floppy copy and access to all drives and all folders","description":"Specifies + whether to make the Recovery Console SET command available, which allows setting + of recovery console environment variables."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsRecoveryconsole","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Recovery + console: Allow floppy copy and access to all drives and all folders;ExpectedValue'', + ''='', parameters(''RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsRecoveryconsole"},"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders":{"value":"[parameters(''RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Recovery + console: Allow floppy copy and access to all drives and all folders;ExpectedValue","value":"[parameters(''RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Recovery + console: Allow floppy copy and access to all drives and all folders;ExpectedValue","value":"[parameters(''RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ddc0a4d5-5e08-43d5-9fd9-b586d8d7116b","type":"Microsoft.Authorization/policyDefinitions","name":"ddc0a4d5-5e08-43d5-9fd9-b586d8d7116b"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - Shutdown''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - Shutdown'' for allowing shutdown without logon and clearing the + virtual memory pagefile. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsShutdown","version":"1.*","configurationParameter":{"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn":"Shutdown: + Allow system to be shut down without having to log on;ExpectedValue","ShutdownClearVirtualMemoryPagefile":"Shutdown: + Clear virtual memory pagefile;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn":{"type":"String","metadata":{"displayName":"Shutdown: + Allow system to be shut down without having to log on","description":"Specifies + whether a computer can be shut down when a user is not logged on. If this + policy setting is enabled, the shutdown command is available on the Windows + logon screen."},"defaultValue":"0"},"ShutdownClearVirtualMemoryPagefile":{"type":"String","metadata":{"displayName":"Shutdown: + Clear virtual memory pagefile","description":"Specifies whether the virtual + memory pagefile is cleared when the system is shut down. When this policy + setting is enabled, the system pagefile is cleared each time that the system + shuts down properly. For systems with large amounts of RAM, this could result + in substantial time needed to complete the shutdown."},"defaultValue":"0"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsShutdown","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Shutdown: + Allow system to be shut down without having to log on;ExpectedValue'', ''='', + parameters(''ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn''), '','', + ''Shutdown: Clear virtual memory pagefile;ExpectedValue'', ''='', parameters(''ShutdownClearVirtualMemoryPagefile'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b4a4d1eb-0263-441b-84cb-a44073d8372d","type":"Microsoft.Authorization/policyDefinitions","name":"b4a4d1eb-0263-441b-84cb-a44073d8372d"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - Shutdown''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + Shutdown''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn":{"type":"String","metadata":{"displayName":"[Deprecated]: + Shutdown: Allow system to be shut down without having to log on","description":"Specifies + whether a computer can be shut down when a user is not logged on. If this + policy setting is enabled, the shutdown command is available on the Windows + logon screen."},"defaultValue":"0"},"ShutdownClearVirtualMemoryPagefile":{"type":"String","metadata":{"displayName":"[Deprecated]: + Shutdown: Clear virtual memory pagefile","description":"Specifies whether + the virtual memory pagefile is cleared when the system is shut down. When + this policy setting is enabled, the system pagefile is cleared each time that + the system shuts down properly. For systems with large amounts of RAM, this + could result in substantial time needed to complete the shutdown."},"defaultValue":"0"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsShutdown","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Shutdown: + Allow system to be shut down without having to log on;ExpectedValue'', ''='', + parameters(''ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn''), '','', + ''Shutdown: Clear virtual memory pagefile;ExpectedValue'', ''='', parameters(''ShutdownClearVirtualMemoryPagefile'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsShutdown"},"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn":{"value":"[parameters(''ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn'')]"},"ShutdownClearVirtualMemoryPagefile":{"value":"[parameters(''ShutdownClearVirtualMemoryPagefile'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn":{"type":"string"},"ShutdownClearVirtualMemoryPagefile":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Shutdown: + Allow system to be shut down without having to log on;ExpectedValue","value":"[parameters(''ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn'')]"},{"name":"Shutdown: + Clear virtual memory pagefile;ExpectedValue","value":"[parameters(''ShutdownClearVirtualMemoryPagefile'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Shutdown: + Allow system to be shut down without having to log on;ExpectedValue","value":"[parameters(''ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn'')]"},{"name":"Shutdown: + Clear virtual memory pagefile;ExpectedValue","value":"[parameters(''ShutdownClearVirtualMemoryPagefile'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1f8c20ce-3414-4496-8b26-0e902a1541da","type":"Microsoft.Authorization/policyDefinitions","name":"1f8c20ce-3414-4496-8b26-0e902a1541da"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + Shutdown''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''Security + Options - Shutdown''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsShutdown","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e3a77a94-cf41-4ee8-b45c-98be28841c03","type":"Microsoft.Authorization/policyDefinitions","name":"e3a77a94-cf41-4ee8-b45c-98be28841c03"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - System objects''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - System objects'' for case insensitivity for non-Windows subsystems + and permissions of internal system objects. This policy requires that the + Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsSystemobjects","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemobjects","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2f262ace-812a-4fd0-b731-b38ba9e9708d","type":"Microsoft.Authorization/policyDefinitions","name":"2f262ace-812a-4fd0-b731-b38ba9e9708d"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + System objects''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - System objects''. For more information on Guest + Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemobjects","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/620e58b5-ac75-49b4-993f-a9d4f0459636","type":"Microsoft.Authorization/policyDefinitions","name":"620e58b5-ac75-49b4-993f-a9d4f0459636"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - System settings''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - System settings'' for certificate rules on executables for SRP and + optional subsystems. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsSystemsettings","version":"1.*","configurationParameter":{"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies":"System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies":{"type":"String","metadata":{"displayName":"System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies","description":"Specifies whether digital certificates are processed + when software restriction policies are enabled and a user or process attempts + to run software with an .exe file name extension. It enables or disables certificate + rules (a type of software restriction policies rule). For certificate rules + to take effect in software restriction policies, you must enable this policy + setting."},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemsettings","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies;ExpectedValue'', ''='', parameters(''SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/12017595-5a75-4bb1-9d97-4c2c939ea3c3","type":"Microsoft.Authorization/policyDefinitions","name":"12017595-5a75-4bb1-9d97-4c2c939ea3c3"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - System objects''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + System objects''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemobjects","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsSystemobjects"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/12ae2d24-3805-4b37-9fa9-465968bfbcfa","type":"Microsoft.Authorization/policyDefinitions","name":"12ae2d24-3805-4b37-9fa9-465968bfbcfa"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + System settings''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - System settings''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemsettings","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8a39d1f1-5513-4628-b261-f469a5a3341b","type":"Microsoft.Authorization/policyDefinitions","name":"8a39d1f1-5513-4628-b261-f469a5a3341b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - System settings''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + System settings''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies":{"type":"String","metadata":{"displayName":"[Deprecated]: + System settings: Use Certificate Rules on Windows Executables for Software + Restriction Policies","description":"Specifies whether digital certificates + are processed when software restriction policies are enabled and a user or + process attempts to run software with an .exe file name extension. It enables + or disables certificate rules (a type of software restriction policies rule). + For certificate rules to take effect in software restriction policies, you + must enable this policy setting."},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsSystemsettings","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies;ExpectedValue'', ''='', parameters(''SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsSystemsettings"},"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies":{"value":"[parameters(''SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies;ExpectedValue","value":"[parameters(''SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"System + settings: Use Certificate Rules on Windows Executables for Software Restriction + Policies;ExpectedValue","value":"[parameters(''SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/437a1f8f-8552-47a8-8b12-a2fee3269dd5","type":"Microsoft.Authorization/policyDefinitions","name":"437a1f8f-8552-47a8-8b12-a2fee3269dd5"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Options - User Account Control''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Options - User Account Control'' for mode for admins, behavior of elevation + prompt, and virtualizing file and registry write failures. This policy requires + that the Guest Configuration prerequisites have been deployed to the policy + assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecurityOptionsUserAccountControl","version":"1.*","configurationParameter":{"UACAdminApprovalModeForTheBuiltinAdministratorAccount":"User + Account Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue","UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode":"User + Account Control: Behavior of the elevation prompt for administrators in Admin + Approval Mode;ExpectedValue","UACDetectApplicationInstallationsAndPromptForElevation":"User + Account Control: Detect application installations and prompt for elevation;ExpectedValue","UACRunAllAdministratorsInAdminApprovalMode":"User + Account Control: Run all administrators in Admin Approval Mode;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"UACAdminApprovalModeForTheBuiltinAdministratorAccount":{"type":"String","metadata":{"displayName":"UAC: + Admin Approval Mode for the Built-in Administrator account","description":"Specifies + the behavior of Admin Approval Mode for the built-in Administrator account."},"defaultValue":"1"},"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode":{"type":"String","metadata":{"displayName":"UAC: + Behavior of the elevation prompt for administrators in Admin Approval Mode","description":"Specifies + the behavior of the elevation prompt for administrators."},"defaultValue":"2"},"UACDetectApplicationInstallationsAndPromptForElevation":{"type":"String","metadata":{"displayName":"UAC: + Detect application installations and prompt for elevation","description":"Specifies + the behavior of application installation detection for the computer."},"defaultValue":"1"},"UACRunAllAdministratorsInAdminApprovalMode":{"type":"String","metadata":{"displayName":"UAC: + Run all administrators in Admin Approval Mode","description":"Specifies the + behavior of all User Account Control (UAC) policy settings for the computer."},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsUserAccountControl","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''User + Account Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue'', + ''='', parameters(''UACAdminApprovalModeForTheBuiltinAdministratorAccount''), + '','', ''User Account Control: Behavior of the elevation prompt for administrators + in Admin Approval Mode;ExpectedValue'', ''='', parameters(''UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode''), + '','', ''User Account Control: Detect application installations and prompt + for elevation;ExpectedValue'', ''='', parameters(''UACDetectApplicationInstallationsAndPromptForElevation''), + '','', ''User Account Control: Run all administrators in Admin Approval Mode;ExpectedValue'', + ''='', parameters(''UACRunAllAdministratorsInAdminApprovalMode'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/492a29ed-d143-4f03-b6a4-705ce081b463","type":"Microsoft.Authorization/policyDefinitions","name":"492a29ed-d143-4f03-b6a4-705ce081b463"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Options - + User Account Control''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Options - User Account Control''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsUserAccountControl","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/29829ec2-489d-4925-81b7-bda06b1718e0","type":"Microsoft.Authorization/policyDefinitions","name":"29829ec2-489d-4925-81b7-bda06b1718e0"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Security Settings - Account Policies''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Security + Settings - Account Policies'' for password history, age, length, complexity, + and storing passwords using reversible encryption. This policy requires that + the Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SecuritySettingsAccountPolicies","version":"1.*","configurationParameter":{"EnforcePasswordHistory":"Enforce + password history;ExpectedValue","MaximumPasswordAge":"Maximum password age;ExpectedValue","MinimumPasswordAge":"Minimum + password age;ExpectedValue","MinimumPasswordLength":"Minimum password length;ExpectedValue","PasswordMustMeetComplexityRequirements":"Password + must meet complexity requirements;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"EnforcePasswordHistory":{"type":"String","metadata":{"displayName":"Enforce + password history","description":"Specifies limits on password reuse - how + many times a new password must be created for a user account before the password + can be repeated."},"defaultValue":"24"},"MaximumPasswordAge":{"type":"String","metadata":{"displayName":"Maximum + password age","description":"Specifies the maximum number of days that may + elapse before a user account password must be changed. The format of the value + is two integers separated by a comma, denoting an inclusive range."},"defaultValue":"1,70"},"MinimumPasswordAge":{"type":"String","metadata":{"displayName":"Minimum + password age","description":"Specifies the minimum number of days that must + elapse before a user account password can be changed."},"defaultValue":"1"},"MinimumPasswordLength":{"type":"String","metadata":{"displayName":"Minimum + password length","description":"Specifies the minimum number of characters + that a user account password may contain."},"defaultValue":"14"},"PasswordMustMeetComplexityRequirements":{"type":"String","metadata":{"displayName":"Password + must meet complexity requirements","description":"Specifies whether a user + account password must be complex. If required, a complex password must not + contain part of user''s account name or full name; be at least 6 characters + long; contain a mix of uppercase, lowercase, number, and non-alphabetic characters."},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecuritySettingsAccountPolicies","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Enforce + password history;ExpectedValue'', ''='', parameters(''EnforcePasswordHistory''), + '','', ''Maximum password age;ExpectedValue'', ''='', parameters(''MaximumPasswordAge''), + '','', ''Minimum password age;ExpectedValue'', ''='', parameters(''MinimumPasswordAge''), + '','', ''Minimum password length;ExpectedValue'', ''='', parameters(''MinimumPasswordLength''), + '','', ''Password must meet complexity requirements;ExpectedValue'', ''='', + parameters(''PasswordMustMeetComplexityRequirements'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f2143251-70de-4e81-87a8-36cee5a2f29d","type":"Microsoft.Authorization/policyDefinitions","name":"f2143251-70de-4e81-87a8-36cee5a2f29d"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Options + - User Account Control''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Options - + User Account Control''. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"UACAdminApprovalModeForTheBuiltinAdministratorAccount":{"type":"String","metadata":{"displayName":"[Deprecated]: + UAC: Admin Approval Mode for the Built-in Administrator account","description":"Specifies + the behavior of Admin Approval Mode for the built-in Administrator account."},"defaultValue":"1"},"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode":{"type":"String","metadata":{"displayName":"[Deprecated]: + UAC: Behavior of the elevation prompt for administrators in Admin Approval + Mode","description":"Specifies the behavior of the elevation prompt for administrators."},"defaultValue":"2"},"UACDetectApplicationInstallationsAndPromptForElevation":{"type":"String","metadata":{"displayName":"[Deprecated]: + UAC: Detect application installations and prompt for elevation","description":"Specifies + the behavior of application installation detection for the computer."},"defaultValue":"1"},"UACRunAllAdministratorsInAdminApprovalMode":{"type":"String","metadata":{"displayName":"[Deprecated]: + UAC: Run all administrators in Admin Approval Mode","description":"Specifies + the behavior of all User Account Control (UAC) policy settings for the computer."},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecurityOptionsUserAccountControl","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''User + Account Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue'', + ''='', parameters(''UACAdminApprovalModeForTheBuiltinAdministratorAccount''), + '','', ''User Account Control: Behavior of the elevation prompt for administrators + in Admin Approval Mode;ExpectedValue'', ''='', parameters(''UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode''), + '','', ''User Account Control: Detect application installations and prompt + for elevation;ExpectedValue'', ''='', parameters(''UACDetectApplicationInstallationsAndPromptForElevation''), + '','', ''User Account Control: Run all administrators in Admin Approval Mode;ExpectedValue'', + ''='', parameters(''UACRunAllAdministratorsInAdminApprovalMode'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecurityOptionsUserAccountControl"},"UACAdminApprovalModeForTheBuiltinAdministratorAccount":{"value":"[parameters(''UACAdminApprovalModeForTheBuiltinAdministratorAccount'')]"},"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode":{"value":"[parameters(''UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode'')]"},"UACDetectApplicationInstallationsAndPromptForElevation":{"value":"[parameters(''UACDetectApplicationInstallationsAndPromptForElevation'')]"},"UACRunAllAdministratorsInAdminApprovalMode":{"value":"[parameters(''UACRunAllAdministratorsInAdminApprovalMode'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"UACAdminApprovalModeForTheBuiltinAdministratorAccount":{"type":"string"},"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode":{"type":"string"},"UACDetectApplicationInstallationsAndPromptForElevation":{"type":"string"},"UACRunAllAdministratorsInAdminApprovalMode":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"User + Account Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue","value":"[parameters(''UACAdminApprovalModeForTheBuiltinAdministratorAccount'')]"},{"name":"User + Account Control: Behavior of the elevation prompt for administrators in Admin + Approval Mode;ExpectedValue","value":"[parameters(''UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode'')]"},{"name":"User + Account Control: Detect application installations and prompt for elevation;ExpectedValue","value":"[parameters(''UACDetectApplicationInstallationsAndPromptForElevation'')]"},{"name":"User + Account Control: Run all administrators in Admin Approval Mode;ExpectedValue","value":"[parameters(''UACRunAllAdministratorsInAdminApprovalMode'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"User + Account Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue","value":"[parameters(''UACAdminApprovalModeForTheBuiltinAdministratorAccount'')]"},{"name":"User + Account Control: Behavior of the elevation prompt for administrators in Admin + Approval Mode;ExpectedValue","value":"[parameters(''UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode'')]"},{"name":"User + Account Control: Detect application installations and prompt for elevation;ExpectedValue","value":"[parameters(''UACDetectApplicationInstallationsAndPromptForElevation'')]"},{"name":"User + Account Control: Run all administrators in Admin Approval Mode;ExpectedValue","value":"[parameters(''UACRunAllAdministratorsInAdminApprovalMode'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e425e402-a050-45e5-b010-bd3f934589fc","type":"Microsoft.Authorization/policyDefinitions","name":"e425e402-a050-45e5-b010-bd3f934589fc"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Security Settings + - Account Policies''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Security Settings - Account Policies''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecuritySettingsAccountPolicies","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ddb53c61-9db4-41d4-a953-2abff5b66c12","type":"Microsoft.Authorization/policyDefinitions","name":"ddb53c61-9db4-41d4-a953-2abff5b66c12"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Security Settings + - Account Policies''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Security Settings + - Account Policies''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"EnforcePasswordHistory":{"type":"String","metadata":{"displayName":"[Deprecated]: + Enforce password history","description":"Specifies limits on password reuse + - how many times a new password must be created for a user account before + the password can be repeated."},"defaultValue":"24"},"MaximumPasswordAge":{"type":"String","metadata":{"displayName":"[Deprecated]: + Maximum password age","description":"Specifies the maximum number of days + that may elapse before a user account password must be changed. The format + of the value is two integers separated by a comma, denoting an inclusive range."},"defaultValue":"1,70"},"MinimumPasswordAge":{"type":"String","metadata":{"displayName":"[Deprecated]: + Minimum password age","description":"Specifies the minimum number of days + that must elapse before a user account password can be changed."},"defaultValue":"1"},"MinimumPasswordLength":{"type":"String","metadata":{"displayName":"[Deprecated]: + Minimum password length","description":"Specifies the minimum number of characters + that a user account password may contain."},"defaultValue":"14"},"PasswordMustMeetComplexityRequirements":{"type":"String","metadata":{"displayName":"[Deprecated]: + Password must meet complexity requirements","description":"Specifies whether + a user account password must be complex. If required, a complex password must + not contain part of user''s account name or full name; be at least 6 characters + long; contain a mix of uppercase, lowercase, number, and non-alphabetic characters."},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SecuritySettingsAccountPolicies","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Enforce + password history;ExpectedValue'', ''='', parameters(''EnforcePasswordHistory''), + '','', ''Maximum password age;ExpectedValue'', ''='', parameters(''MaximumPasswordAge''), + '','', ''Minimum password age;ExpectedValue'', ''='', parameters(''MinimumPasswordAge''), + '','', ''Minimum password length;ExpectedValue'', ''='', parameters(''MinimumPasswordLength''), + '','', ''Password must meet complexity requirements;ExpectedValue'', ''='', + parameters(''PasswordMustMeetComplexityRequirements'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SecuritySettingsAccountPolicies"},"EnforcePasswordHistory":{"value":"[parameters(''EnforcePasswordHistory'')]"},"MaximumPasswordAge":{"value":"[parameters(''MaximumPasswordAge'')]"},"MinimumPasswordAge":{"value":"[parameters(''MinimumPasswordAge'')]"},"MinimumPasswordLength":{"value":"[parameters(''MinimumPasswordLength'')]"},"PasswordMustMeetComplexityRequirements":{"value":"[parameters(''PasswordMustMeetComplexityRequirements'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"EnforcePasswordHistory":{"type":"string"},"MaximumPasswordAge":{"type":"string"},"MinimumPasswordAge":{"type":"string"},"MinimumPasswordLength":{"type":"string"},"PasswordMustMeetComplexityRequirements":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Enforce + password history;ExpectedValue","value":"[parameters(''EnforcePasswordHistory'')]"},{"name":"Maximum + password age;ExpectedValue","value":"[parameters(''MaximumPasswordAge'')]"},{"name":"Minimum + password age;ExpectedValue","value":"[parameters(''MinimumPasswordAge'')]"},{"name":"Minimum + password length;ExpectedValue","value":"[parameters(''MinimumPasswordLength'')]"},{"name":"Password + must meet complexity requirements;ExpectedValue","value":"[parameters(''PasswordMustMeetComplexityRequirements'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Enforce + password history;ExpectedValue","value":"[parameters(''EnforcePasswordHistory'')]"},{"name":"Maximum + password age;ExpectedValue","value":"[parameters(''MaximumPasswordAge'')]"},{"name":"Minimum + password age;ExpectedValue","value":"[parameters(''MinimumPasswordAge'')]"},{"name":"Minimum + password length;ExpectedValue","value":"[parameters(''MinimumPasswordLength'')]"},{"name":"Password + must meet complexity requirements;ExpectedValue","value":"[parameters(''PasswordMustMeetComplexityRequirements'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e3d95ab7-f47a-49d8-a347-784177b6c94c","type":"Microsoft.Authorization/policyDefinitions","name":"e3d95ab7-f47a-49d8-a347-784177b6c94c"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Account Logon''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Account Logon'' for auditing credential validation and other + account logon events. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesAccountLogon","version":"1.*","configurationParameter":{"AuditCredentialValidation":"Audit + Credential Validation;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditCredentialValidation":{"type":"String","metadata":{"displayName":"Audit + Credential Validation","description":"Specifies whether audit events are generated + when credentials are submitted for a user account logon request. This setting + is especially useful for monitoring unsuccessful attempts, to find brute-force + attacks, account enumeration, and potential account compromise events on domain + controllers."},"allowedValues":["No Auditing","Success","Failure","Success + and Failure"],"defaultValue":"Success and Failure"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountLogon","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Credential Validation;ExpectedValue'', ''='', parameters(''AuditCredentialValidation'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/43bb60fe-1d7e-4b82-9e93-496bfc99e7d5","type":"Microsoft.Authorization/policyDefinitions","name":"43bb60fe-1d7e-4b82-9e93-496bfc99e7d5"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Account Logon''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Account Logon''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountLogon","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bc87d811-4a9b-47cc-ae54-0a41abda7768","type":"Microsoft.Authorization/policyDefinitions","name":"bc87d811-4a9b-47cc-ae54-0a41abda7768"},{"properties":{"displayName":"Configure + time zone on Windows machines.","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to set specified time zone + on Windows virtual machines.","metadata":{"version":"1.1.0","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"]},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"TimeZone":{"type":"String","metadata":{"displayName":"Time + zone","description":"The expected time zone"},"allowedValues":["(UTC-12:00) + International Date Line West","(UTC-11:00) Coordinated Universal Time-11","(UTC-10:00) + Aleutian Islands","(UTC-10:00) Hawaii","(UTC-09:30) Marquesas Islands","(UTC-09:00) + Alaska","(UTC-09:00) Coordinated Universal Time-09","(UTC-08:00) Baja California","(UTC-08:00) + Coordinated Universal Time-08","(UTC-08:00) Pacific Time (US & Canada)","(UTC-07:00) + Arizona","(UTC-07:00) Chihuahua, La Paz, Mazatlan","(UTC-07:00) Mountain Time + (US & Canada)","(UTC-06:00) Central America","(UTC-06:00) Central Time (US + & Canada)","(UTC-06:00) Easter Island","(UTC-06:00) Guadalajara, Mexico City, + Monterrey","(UTC-06:00) Saskatchewan","(UTC-05:00) Bogota, Lima, Quito, Rio + Branco","(UTC-05:00) Chetumal","(UTC-05:00) Eastern Time (US & Canada)","(UTC-05:00) + Haiti","(UTC-05:00) Havana","(UTC-05:00) Indiana (East)","(UTC-05:00) Turks + and Caicos","(UTC-04:00) Asuncion","(UTC-04:00) Atlantic Time (Canada)","(UTC-04:00) + Caracas","(UTC-04:00) Cuiaba","(UTC-04:00) Georgetown, La Paz, Manaus, San + Juan","(UTC-04:00) Santiago","(UTC-03:30) Newfoundland","(UTC-03:00) Araguaina","(UTC-03:00) + Brasilia","(UTC-03:00) Cayenne, Fortaleza","(UTC-03:00) City of Buenos Aires","(UTC-03:00) + Greenland","(UTC-03:00) Montevideo","(UTC-03:00) Punta Arenas","(UTC-03:00) + Saint Pierre and Miquelon","(UTC-03:00) Salvador","(UTC-02:00) Coordinated + Universal Time-02","(UTC-02:00) Mid-Atlantic - Old","(UTC-01:00) Azores","(UTC-01:00) + Cabo Verde Is.","(UTC) Coordinated Universal Time","(UTC+00:00) Dublin, Edinburgh, + Lisbon, London","(UTC+00:00) Monrovia, Reykjavik","(UTC+00:00) Sao Tome","(UTC+01:00) + Casablanca","(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna","(UTC+01:00) + Belgrade, Bratislava, Budapest, Ljubljana, Prague","(UTC+01:00) Brussels, + Copenhagen, Madrid, Paris","(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb","(UTC+01:00) + West Central Africa","(UTC+02:00) Amman","(UTC+02:00) Athens, Bucharest","(UTC+02:00) + Beirut","(UTC+02:00) Cairo","(UTC+02:00) Chisinau","(UTC+02:00) Damascus","(UTC+02:00) + Gaza, Hebron","(UTC+02:00) Harare, Pretoria","(UTC+02:00) Helsinki, Kyiv, + Riga, Sofia, Tallinn, Vilnius","(UTC+02:00) Jerusalem","(UTC+02:00) Kaliningrad","(UTC+02:00) + Khartoum","(UTC+02:00) Tripoli","(UTC+02:00) Windhoek","(UTC+03:00) Baghdad","(UTC+03:00) + Istanbul","(UTC+03:00) Kuwait, Riyadh","(UTC+03:00) Minsk","(UTC+03:00) Moscow, + St. Petersburg","(UTC+03:00) Nairobi","(UTC+03:30) Tehran","(UTC+04:00) Abu + Dhabi, Muscat","(UTC+04:00) Astrakhan, Ulyanovsk","(UTC+04:00) Baku","(UTC+04:00) + Izhevsk, Samara","(UTC+04:00) Port Louis","(UTC+04:00) Saratov","(UTC+04:00) + Tbilisi","(UTC+04:00) Volgograd","(UTC+04:00) Yerevan","(UTC+04:30) Kabul","(UTC+05:00) + Ashgabat, Tashkent","(UTC+05:00) Ekaterinburg","(UTC+05:00) Islamabad, Karachi","(UTC+05:00) + Qyzylorda","(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi","(UTC+05:30) + Sri Jayawardenepura","(UTC+05:45) Kathmandu","(UTC+06:00) Astana","(UTC+06:00) + Dhaka","(UTC+06:00) Omsk","(UTC+06:30) Yangon (Rangoon)","(UTC+07:00) Bangkok, + Hanoi, Jakarta","(UTC+07:00) Barnaul, Gorno-Altaysk","(UTC+07:00) Hovd","(UTC+07:00) + Krasnoyarsk","(UTC+07:00) Novosibirsk","(UTC+07:00) Tomsk","(UTC+08:00) Beijing, + Chongqing, Hong Kong, Urumqi","(UTC+08:00) Irkutsk","(UTC+08:00) Kuala Lumpur, + Singapore","(UTC+08:00) Perth","(UTC+08:00) Taipei","(UTC+08:00) Ulaanbaatar","(UTC+08:45) + Eucla","(UTC+09:00) Chita","(UTC+09:00) Osaka, Sapporo, Tokyo","(UTC+09:00) + Pyongyang","(UTC+09:00) Seoul","(UTC+09:00) Yakutsk","(UTC+09:30) Adelaide","(UTC+09:30) + Darwin","(UTC+10:00) Brisbane","(UTC+10:00) Canberra, Melbourne, Sydney","(UTC+10:00) + Guam, Port Moresby","(UTC+10:00) Hobart","(UTC+10:00) Vladivostok","(UTC+10:30) + Lord Howe Island","(UTC+11:00) Bougainville Island","(UTC+11:00) Chokurdakh","(UTC+11:00) + Magadan","(UTC+11:00) Norfolk Island","(UTC+11:00) Sakhalin","(UTC+11:00) + Solomon Is., New Caledonia","(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky","(UTC+12:00) + Auckland, Wellington","(UTC+12:00) Coordinated Universal Time+12","(UTC+12:00) + Fiji","(UTC+12:00) Petropavlovsk-Kamchatsky - Old","(UTC+12:45) Chatham Islands","(UTC+13:00) + Coordinated Universal Time+13","(UTC+13:00) Nuku''alofa","(UTC+13:00) Samoa","(UTC+14:00) + Kiritimati Island"]}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"SetWindowsTimeZone","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsTimeZone]WindowsTimeZone1;TimeZone'', + ''='', parameters(''TimeZone'')))]"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"SetWindowsTimeZone"},"TimeZone":{"value":"[parameters(''TimeZone'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"TimeZone":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","assignmentType":"DeployAndAutoCorrect","configurationParameter":[{"name":"[WindowsTimeZone]WindowsTimeZone1;TimeZone","value":"[parameters(''TimeZone'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","assignmentType":"DeployAndAutoCorrect","configurationParameter":[{"name":"[WindowsTimeZone]WindowsTimeZone1;TimeZone","value":"[parameters(''TimeZone'')]"}]}}}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6141c932-9384-44c6-a395-59e4c057d7c9","type":"Microsoft.Authorization/policyDefinitions","name":"6141c932-9384-44c6-a395-59e4c057d7c9"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Account Logon''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Account Logon''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditCredentialValidation":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Credential Validation","description":"Specifies whether audit events + are generated when credentials are submitted for a user account logon request. This + setting is especially useful for monitoring unsuccessful attempts, to find + brute-force attacks, account enumeration, and potential account compromise + events on domain controllers."},"allowedValues":["No Auditing","Success","Failure","Success + and Failure"],"defaultValue":"Success and Failure"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountLogon","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Credential Validation;ExpectedValue'', ''='', parameters(''AuditCredentialValidation'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesAccountLogon"},"AuditCredentialValidation":{"value":"[parameters(''AuditCredentialValidation'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditCredentialValidation":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Credential Validation;ExpectedValue","value":"[parameters(''AuditCredentialValidation'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Credential Validation;ExpectedValue","value":"[parameters(''AuditCredentialValidation'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c1e289c0-ffad-475d-a924-adc058765d65","type":"Microsoft.Authorization/policyDefinitions","name":"c1e289c0-ffad-475d-a924-adc058765d65"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Account Management''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Account Management'' for auditing application, security, + and user group management, and other management events. This policy requires + that the Guest Configuration prerequisites have been deployed to the policy + assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesAccountManagement","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountManagement","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/94d9aca8-3757-46df-aa51-f218c5f11954","type":"Microsoft.Authorization/policyDefinitions","name":"94d9aca8-3757-46df-aa51-f218c5f11954"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Account Management''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Account Management''. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountManagement","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesAccountManagement"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0a9991e6-21be-49f9-8916-a06d934bcf29","type":"Microsoft.Authorization/policyDefinitions","name":"0a9991e6-21be-49f9-8916-a06d934bcf29"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Account Management''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Account Management''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesAccountManagement","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/225e937e-d32e-4713-ab74-13ce95b3519a","type":"Microsoft.Authorization/policyDefinitions","name":"225e937e-d32e-4713-ab74-13ce95b3519a"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Detailed Tracking''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Detailed Tracking''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesDetailedTracking","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a9a33475-481d-4b81-9116-0bf02ffe67e8","type":"Microsoft.Authorization/policyDefinitions","name":"a9a33475-481d-4b81-9116-0bf02ffe67e8"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Detailed Tracking''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Detailed Tracking''. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditProcessTermination":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Process Termination","description":"Specifies whether audit events are + generated when a process has exited. Recommended for monitoring termination + of critical processes."},"allowedValues":["No Auditing","Success","Failure","Success + and Failure"],"defaultValue":"No Auditing"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesDetailedTracking","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Process Termination;ExpectedValue'', ''='', parameters(''AuditProcessTermination'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesDetailedTracking"},"AuditProcessTermination":{"value":"[parameters(''AuditProcessTermination'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditProcessTermination":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Process Termination;ExpectedValue","value":"[parameters(''AuditProcessTermination'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Process Termination;ExpectedValue","value":"[parameters(''AuditProcessTermination'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/42a07bbf-ffcf-459a-b4b1-30ecd118a505","type":"Microsoft.Authorization/policyDefinitions","name":"42a07bbf-ffcf-459a-b4b1-30ecd118a505"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Detailed Tracking''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Detailed Tracking'' for auditing DPAPI, process creation/termination, + RPC events, and PNP activity. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesDetailedTracking","version":"1.*","configurationParameter":{"AuditProcessTermination":"Audit + Process Termination;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditProcessTermination":{"type":"String","metadata":{"displayName":"Audit + Process Termination","description":"Specifies whether audit events are generated + when a process has exited. Recommended for monitoring termination of critical + processes."},"allowedValues":["No Auditing","Success","Failure","Success and + Failure"],"defaultValue":"No Auditing"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesDetailedTracking","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Process Termination;ExpectedValue'', ''='', parameters(''AuditProcessTermination'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/58383b73-94a9-4414-b382-4146eb02611b","type":"Microsoft.Authorization/policyDefinitions","name":"58383b73-94a9-4414-b382-4146eb02611b"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Logon-Logoff''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Logon-Logoff''. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesLogonLogoff","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b3802d79-dd88-4bce-b81d-780218e48280","type":"Microsoft.Authorization/policyDefinitions","name":"b3802d79-dd88-4bce-b81d-780218e48280"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Logon-Logoff''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Logon-Logoff'' for auditing IPSec, network policy, claims, + account lockout, group membership, and logon/logoff events. This policy requires + that the Guest Configuration prerequisites have been deployed to the policy + assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesLogonLogoff","version":"1.*","configurationParameter":{"AuditGroupMembership":"Audit + Group Membership;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditGroupMembership":{"type":"String","metadata":{"displayName":"Audit + Group Membership","description":"Specifies whether audit events are generated + when group memberships are enumerated on the client computer."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"Success"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesLogonLogoff","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Group Membership;ExpectedValue'', ''='', parameters(''AuditGroupMembership'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/19be9779-c776-4dfa-8a15-a2fd5dc843d6","type":"Microsoft.Authorization/policyDefinitions","name":"19be9779-c776-4dfa-8a15-a2fd5dc843d6"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Object Access''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Object Access'' for auditing file, registry, SAM, storage, + filtering, kernel, and other system types. This policy requires that the Guest + Configuration prerequisites have been deployed to the policy assignment scope. + For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesObjectAccess","version":"1.*","configurationParameter":{"AuditDetailedFileShare":"Audit + Detailed File Share;ExpectedValue","AuditFileShare":"Audit File Share;ExpectedValue","AuditFileSystem":"Audit + File System;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditDetailedFileShare":{"type":"String","metadata":{"displayName":"Audit + Detailed File Share","description":"If this policy setting is enabled, access + to all shared files and folders on the system is audited. Auditing for Success + can lead to very high volumes of events."},"allowedValues":["No Auditing","Success","Failure","Success + and Failure"],"defaultValue":"No Auditing"},"AuditFileShare":{"type":"String","metadata":{"displayName":"Audit + File Share","description":"Specifies whether to audit events related to file + shares: creation, deletion, modification, and access attempts. Also, it shows + failed SMB SPN checks. Event volumes can be high on DCs and File Servers."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"},"AuditFileSystem":{"type":"String","metadata":{"displayName":"Audit + File System","description":"Specifies whether audit events are generated when + users attempt to access file system objects. Audit events are generated only + for objects that have configured system access control lists (SACLs)."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesObjectAccess","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Detailed File Share;ExpectedValue'', ''='', parameters(''AuditDetailedFileShare''), + '','', ''Audit File Share;ExpectedValue'', ''='', parameters(''AuditFileShare''), + '','', ''Audit File System;ExpectedValue'', ''='', parameters(''AuditFileSystem'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/35781875-8026-4628-b19b-f6efb4d88a1d","type":"Microsoft.Authorization/policyDefinitions","name":"35781875-8026-4628-b19b-f6efb4d88a1d"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Logon-Logoff''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Logon-Logoff''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditGroupMembership":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Group Membership","description":"Specifies whether audit events are + generated when group memberships are enumerated on the client computer."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"Success"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesLogonLogoff","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Group Membership;ExpectedValue'', ''='', parameters(''AuditGroupMembership'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesLogonLogoff"},"AuditGroupMembership":{"value":"[parameters(''AuditGroupMembership'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditGroupMembership":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Group Membership;ExpectedValue","value":"[parameters(''AuditGroupMembership'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Group Membership;ExpectedValue","value":"[parameters(''AuditGroupMembership'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c04255ee-1b9f-42c1-abaa-bf1553f79930","type":"Microsoft.Authorization/policyDefinitions","name":"c04255ee-1b9f-42c1-abaa-bf1553f79930"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Object Access''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Object Access''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesObjectAccess","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/60aeaf73-a074-417a-905f-7ce9df0ff77b","type":"Microsoft.Authorization/policyDefinitions","name":"60aeaf73-a074-417a-905f-7ce9df0ff77b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Object Access''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Object Access''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditDetailedFileShare":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Detailed File Share","description":"If this policy setting is enabled, + access to all shared files and folders on the system is audited. Auditing + for Success can lead to very high volumes of events."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"},"AuditFileShare":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit File Share","description":"Specifies whether to audit events related + to file shares: creation, deletion, modification, and access attempts. Also, + it shows failed SMB SPN checks. Event volumes can be high on DCs and File + Servers."},"allowedValues":["No Auditing","Success","Failure","Success and + Failure"],"defaultValue":"No Auditing"},"AuditFileSystem":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit File System","description":"Specifies whether audit events are generated + when users attempt to access file system objects. Audit events are generated + only for objects that have configured system access control lists (SACLs)."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesObjectAccess","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Detailed File Share;ExpectedValue'', ''='', parameters(''AuditDetailedFileShare''), + '','', ''Audit File Share;ExpectedValue'', ''='', parameters(''AuditFileShare''), + '','', ''Audit File System;ExpectedValue'', ''='', parameters(''AuditFileSystem'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesObjectAccess"},"AuditDetailedFileShare":{"value":"[parameters(''AuditDetailedFileShare'')]"},"AuditFileShare":{"value":"[parameters(''AuditFileShare'')]"},"AuditFileSystem":{"value":"[parameters(''AuditFileSystem'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditDetailedFileShare":{"type":"string"},"AuditFileShare":{"type":"string"},"AuditFileSystem":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Detailed File Share;ExpectedValue","value":"[parameters(''AuditDetailedFileShare'')]"},{"name":"Audit + File Share;ExpectedValue","value":"[parameters(''AuditFileShare'')]"},{"name":"Audit + File System;ExpectedValue","value":"[parameters(''AuditFileSystem'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Detailed File Share;ExpectedValue","value":"[parameters(''AuditDetailedFileShare'')]"},{"name":"Audit + File Share;ExpectedValue","value":"[parameters(''AuditFileShare'')]"},{"name":"Audit + File System;ExpectedValue","value":"[parameters(''AuditFileSystem'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8e170edb-e0f5-497a-bb36-48b3280cec6a","type":"Microsoft.Authorization/policyDefinitions","name":"8e170edb-e0f5-497a-bb36-48b3280cec6a"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Policy Change''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - Policy Change'' for auditing changes to system audit policies. + This policy requires that the Guest Configuration prerequisites have been + deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesPolicyChange","version":"1.*","configurationParameter":{"AuditAuthenticationPolicyChange":"Audit + Authentication Policy Change;ExpectedValue","AuditAuthorizationPolicyChange":"Audit + Authorization Policy Change;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditAuthenticationPolicyChange":{"type":"String","metadata":{"displayName":"Audit + Authentication Policy Change","description":"Specifies whether audit events + are generated when changes are made to authentication policy. This setting + is useful for tracking changes in domain-level and forest-level trust and + privileges that are granted to user accounts or groups."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"Success"},"AuditAuthorizationPolicyChange":{"type":"String","metadata":{"displayName":"Audit + Authorization Policy Change","description":"Specifies whether audit events + are generated for assignment and removal of user rights in user right policies, + changes in security token object permission, resource attributes changes and + Central Access Policy changes for file system objects."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPolicyChange","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Authentication Policy Change;ExpectedValue'', ''='', parameters(''AuditAuthenticationPolicyChange''), + '','', ''Audit Authorization Policy Change;ExpectedValue'', ''='', parameters(''AuditAuthorizationPolicyChange'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2a7a701e-dff3-4da9-9ec5-42cb98594c0b","type":"Microsoft.Authorization/policyDefinitions","name":"2a7a701e-dff3-4da9-9ec5-42cb98594c0b"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - Policy Change''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Policy Change''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPolicyChange","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dd4680ed-0559-4a6a-ad10-081d14cbb484","type":"Microsoft.Authorization/policyDefinitions","name":"dd4680ed-0559-4a6a-ad10-081d14cbb484"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Policy Change''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Policy Change''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditAuthenticationPolicyChange":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Authentication Policy Change","description":"Specifies whether audit + events are generated when changes are made to authentication policy. This + setting is useful for tracking changes in domain-level and forest-level trust + and privileges that are granted to user accounts or groups."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"Success"},"AuditAuthorizationPolicyChange":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Authorization Policy Change","description":"Specifies whether audit + events are generated for assignment and removal of user rights in user right + policies, changes in security token object permission, resource attributes + changes and Central Access Policy changes for file system objects."},"allowedValues":["No + Auditing","Success","Failure","Success and Failure"],"defaultValue":"No Auditing"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPolicyChange","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Authentication Policy Change;ExpectedValue'', ''='', parameters(''AuditAuthenticationPolicyChange''), + '','', ''Audit Authorization Policy Change;ExpectedValue'', ''='', parameters(''AuditAuthorizationPolicyChange'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesPolicyChange"},"AuditAuthenticationPolicyChange":{"value":"[parameters(''AuditAuthenticationPolicyChange'')]"},"AuditAuthorizationPolicyChange":{"value":"[parameters(''AuditAuthorizationPolicyChange'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditAuthenticationPolicyChange":{"type":"string"},"AuditAuthorizationPolicyChange":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Authentication Policy Change;ExpectedValue","value":"[parameters(''AuditAuthenticationPolicyChange'')]"},{"name":"Audit + Authorization Policy Change;ExpectedValue","value":"[parameters(''AuditAuthorizationPolicyChange'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Authentication Policy Change;ExpectedValue","value":"[parameters(''AuditAuthenticationPolicyChange'')]"},{"name":"Audit + Authorization Policy Change;ExpectedValue","value":"[parameters(''AuditAuthorizationPolicyChange'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/97b595c8-fd10-400e-8543-28e2b9138b13","type":"Microsoft.Authorization/policyDefinitions","name":"97b595c8-fd10-400e-8543-28e2b9138b13"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - Privilege Use''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - Privilege Use''. It also creates a system-assigned managed identity and + deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPrivilegeUse","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesPrivilegeUse"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ce2370f6-0ac5-4d85-8ab4-10721cc640b0","type":"Microsoft.Authorization/policyDefinitions","name":"ce2370f6-0ac5-4d85-8ab4-10721cc640b0"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - Privilege + Use''","policyType":"BuiltIn","mode":"Indexed","description":"Windows machines + should have the specified Group Policy settings in the category ''System Audit + Policies - Privilege Use'' for auditing nonsensitive and other privilege use. + This policy requires that the Guest Configuration prerequisites have been + deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesPrivilegeUse","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPrivilegeUse","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/87845465-c458-45f3-af66-dcd62176f397","type":"Microsoft.Authorization/policyDefinitions","name":"87845465-c458-45f3-af66-dcd62176f397"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''System Audit Policies + - System''","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines with non-compliant settings in Group Policy category: ''System + Audit Policies - System''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesSystem","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7066131b-61a6-4917-a7e4-72e8983f0aa6","type":"Microsoft.Authorization/policyDefinitions","name":"7066131b-61a6-4917-a7e4-72e8983f0aa6"}],"nextLink":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVCdWlsdEluRGVmaW5pdGlvbiIsIm5leHRNYXJrZXIiOiIrUklEOn5HTnBpQUlwd25SaDBoaDRBQUFBQUFBPT0jUlQ6MSNUUkM6NTAwI0lTVjoyI0lFTzo2NTU1MSNRQ0Y6MyNGUEM6QWdoNkFBQUFBQUFBQUVvRUFBQUFJQUFBZWdBQUFBQUFBQUFJQUhFRzhQOHhRLzgvZWdBQUFBQWdBQUFJQUlNRS92Ly9mLzBmU2dRQUFBQWdBQUFFQUlFby9nQT0ifQ%253D%253D"}' + headers: + cache-control: + - no-cache + content-length: + - '1360711' + content-type: + - application/json; charset=utf-8 + date: + - Fri, 26 Feb 2021 07:40:15 GMT + expires: + - '-1' + pragma: + - no-cache + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding,Accept-Encoding + x-content-type-options: + - nosniff + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVCdWlsdEluRGVmaW5pdGlvbiIsIm5leHRNYXJrZXIiOiIrUklEOn5HTnBpQUlwd25SaDBoaDRBQUFBQUFBPT0jUlQ6MSNUUkM6NTAwI0lTVjoyI0lFTzo2NTU1MSNRQ0Y6MyNGUEM6QWdoNkFBQUFBQUFBQUVvRUFBQUFJQUFBZWdBQUFBQUFBQUFJQUhFRzhQOHhRLzgvZWdBQUFBQWdBQUFJQUlNRS92Ly9mLzBmU2dRQUFBQWdBQUFFQUlFby9nQT0ifQ%253D%253D + response: + body: + string: '{"value":[{"properties":{"displayName":"[Deprecated]: Show audit results + from Windows VMs configurations in ''System Audit Policies - Privilege Use''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''System Audit Policies - Privilege Use''. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesPrivilegeUse","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7f4e96d1-e4f3-4dbb-b767-33ca4df8df7c","type":"Microsoft.Authorization/policyDefinitions","name":"7f4e96d1-e4f3-4dbb-b767-33ca4df8df7c"},{"properties":{"displayName":"Windows + machines should meet requirements for ''System Audit Policies - System''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''System + Audit Policies - System'' for auditing IPsec driver, system integrity, system + extension, state change, and other system events. This policy requires that + the Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_SystemAuditPoliciesSystem","version":"1.*","configurationParameter":{"AuditOtherSystemEvents":"Audit + Other System Events;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"AuditOtherSystemEvents":{"type":"String","metadata":{"displayName":"Audit + Other System Events","description":"Specifies whether audit events are generated + for Windows Firewall Service and Windows Firewall driver start and stop events, + failure events for these services and Windows Firewall Service policy processing + failures."},"allowedValues":["No Auditing","Success","Failure","Success and + Failure"],"defaultValue":"No Auditing"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesSystem","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Other System Events;ExpectedValue'', ''='', parameters(''AuditOtherSystemEvents'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8316fa92-d69c-4810-8124-62414f560dcf","type":"Microsoft.Authorization/policyDefinitions","name":"8316fa92-d69c-4810-8124-62414f560dcf"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''System Audit + Policies - System''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''System Audit Policies + - System''. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"AuditOtherSystemEvents":{"type":"String","metadata":{"displayName":"[Deprecated]: + Audit Other System Events","description":"Specifies whether audit events are + generated for Windows Firewall Service and Windows Firewall driver start and + stop events, failure events for these services and Windows Firewall Service + policy processing failures."},"allowedValues":["No Auditing","Success","Failure","Success + and Failure"],"defaultValue":"No Auditing"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_SystemAuditPoliciesSystem","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Audit + Other System Events;ExpectedValue'', ''='', parameters(''AuditOtherSystemEvents'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_SystemAuditPoliciesSystem"},"AuditOtherSystemEvents":{"value":"[parameters(''AuditOtherSystemEvents'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"AuditOtherSystemEvents":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Other System Events;ExpectedValue","value":"[parameters(''AuditOtherSystemEvents'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Audit + Other System Events;ExpectedValue","value":"[parameters(''AuditOtherSystemEvents'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f8b0158d-4766-490f-bea0-259e52dba473","type":"Microsoft.Authorization/policyDefinitions","name":"f8b0158d-4766-490f-bea0-259e52dba473"},{"properties":{"displayName":"Windows + machines should meet requirements for ''User Rights Assignment''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''User + Rights Assignment'' for allowing log on locally, RDP, access from the network, + and many other user activities. This policy requires that the Guest Configuration + prerequisites have been deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol.","metadata":{"category":"Guest Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_UserRightsAssignment","version":"1.*","configurationParameter":{"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork":"Access + this computer from the network;ExpectedValue","UsersOrGroupsThatMayLogOnLocally":"Allow + log on locally;ExpectedValue","UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices":"Allow + log on through Remote Desktop Services;ExpectedValue","UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork":"Deny + access to this computer from the network;ExpectedValue","UsersOrGroupsThatMayManageAuditingAndSecurityLog":"Manage + auditing and security log;ExpectedValue","UsersOrGroupsThatMayBackUpFilesAndDirectories":"Back + up files and directories;ExpectedValue","UsersOrGroupsThatMayChangeTheSystemTime":"Change + the system time;ExpectedValue","UsersOrGroupsThatMayChangeTheTimeZone":"Change + the time zone;ExpectedValue","UsersOrGroupsThatMayCreateATokenObject":"Create + a token object;ExpectedValue","UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob":"Deny + log on as a batch job;ExpectedValue","UsersAndGroupsThatAreDeniedLoggingOnAsAService":"Deny + log on as a service;ExpectedValue","UsersAndGroupsThatAreDeniedLocalLogon":"Deny + log on locally;ExpectedValue","UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices":"Deny + log on through Remote Desktop Services;ExpectedValue","UserAndGroupsThatMayForceShutdownFromARemoteSystem":"Force + shutdown from a remote system;ExpectedValue","UsersAndGroupsThatMayRestoreFilesAndDirectories":"Restore + files and directories;ExpectedValue","UsersAndGroupsThatMayShutDownTheSystem":"Shut + down the system;ExpectedValue","UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects":"Take + ownership of files or other objects;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork":{"type":"String","metadata":{"displayName":"Users + or groups that may access this computer from the network","description":"Specifies + which remote users on the network are permitted to connect to the computer. + This does not include Remote Desktop Connection."},"defaultValue":"Administrators, + Authenticated Users"},"UsersOrGroupsThatMayLogOnLocally":{"type":"String","metadata":{"displayName":"Users + or groups that may log on locally","description":"Specifies which users or + groups can interactively log on to the computer. Users who attempt to log + on via Remote Desktop Connection or IIS also require this user right."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices":{"type":"String","metadata":{"displayName":"Users + or groups that may log on through Remote Desktop Services","description":"Specifies + which users or groups are permitted to log on as a Terminal Services client, + Remote Desktop, or for Remote Assistance."},"defaultValue":"Administrators, + Remote Desktop Users"},"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork":{"type":"String","metadata":{"displayName":"Users + and groups that are denied access to this computer from the network","description":"Specifies + which users or groups are explicitly prohibited from connecting to the computer + across the network."},"defaultValue":"Guests"},"UsersOrGroupsThatMayManageAuditingAndSecurityLog":{"type":"String","metadata":{"displayName":"Users + or groups that may manage auditing and security log","description":"Specifies + users and groups permitted to change the auditing options for files and directories + and clear the Security log."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayBackUpFilesAndDirectories":{"type":"String","metadata":{"displayName":"Users + or groups that may back up files and directories","description":"Specifies + users and groups allowed to circumvent file and directory permissions to back + up the system."},"defaultValue":"Administrators, Backup Operators"},"UsersOrGroupsThatMayChangeTheSystemTime":{"type":"String","metadata":{"displayName":"Users + or groups that may change the system time","description":"Specifies which + users and groups are permitted to change the time and date on the internal + clock of the computer."},"defaultValue":"Administrators, LOCAL SERVICE"},"UsersOrGroupsThatMayChangeTheTimeZone":{"type":"String","metadata":{"displayName":"Users + or groups that may change the time zone","description":"Specifies which users + and groups are permitted to change the time zone of the computer."},"defaultValue":"Administrators, + LOCAL SERVICE"},"UsersOrGroupsThatMayCreateATokenObject":{"type":"String","metadata":{"displayName":"Users + or groups that may create a token object","description":"Specifies which users + and groups are permitted to create an access token, which may provide elevated + rights to access sensitive data."},"defaultValue":"No One"},"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob":{"type":"String","metadata":{"displayName":"Users + and groups that are denied logging on as a batch job","description":"Specifies + which users and groups are explicitly not permitted to log on to the computer + as a batch job (i.e. scheduled task)."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLoggingOnAsAService":{"type":"String","metadata":{"displayName":"Users + and groups that are denied logging on as a service","description":"Specifies + which service accounts are explicitly not permitted to register a process + as a service."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLocalLogon":{"type":"String","metadata":{"displayName":"Users + and groups that are denied local logon","description":"Specifies which users + and groups are explicitly not permitted to log on to the computer."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices":{"type":"String","metadata":{"displayName":"Users + and groups that are denied log on through Remote Desktop Services","description":"Specifies + which users and groups are explicitly not permitted to log on to the computer + via Terminal Services/Remote Desktop Client."},"defaultValue":"Guests"},"UserAndGroupsThatMayForceShutdownFromARemoteSystem":{"type":"String","metadata":{"displayName":"User + and groups that may force shutdown from a remote system","description":"Specifies + which users and groups are permitted to shut down the computer from a remote + location on the network."},"defaultValue":"Administrators"},"UsersAndGroupsThatMayRestoreFilesAndDirectories":{"type":"String","metadata":{"displayName":"Users + and groups that may restore files and directories","description":"Specifies + which users and groups are permitted to bypass file, directory, registry, + and other persistent object permissions when restoring backed up files and + directories."},"defaultValue":"Administrators, Backup Operators"},"UsersAndGroupsThatMayShutDownTheSystem":{"type":"String","metadata":{"displayName":"Users + and groups that may shut down the system","description":"Specifies which users + and groups who are logged on locally to the computers in your environment + are permitted to shut down the operating system with the Shut Down command."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects":{"type":"String","metadata":{"displayName":"Users + or groups that may take ownership of files or other objects","description":"Specifies + which users and groups are permitted to take ownership of files, folders, + registry keys, processes, or threads. This user right bypasses any permissions + that are in place to protect objects to give ownership to the specified user."},"defaultValue":"Administrators"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_UserRightsAssignment","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Access + this computer from the network;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayAccessThisComputerFromTheNetwork''), + '','', ''Allow log on locally;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayLogOnLocally''), + '','', ''Allow log on through Remote Desktop Services;ExpectedValue'', ''='', + parameters(''UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices''), '','', + ''Deny access to this computer from the network;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork''), + '','', ''Manage auditing and security log;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayManageAuditingAndSecurityLog''), + '','', ''Back up files and directories;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayBackUpFilesAndDirectories''), + '','', ''Change the system time;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayChangeTheSystemTime''), + '','', ''Change the time zone;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayChangeTheTimeZone''), + '','', ''Create a token object;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayCreateATokenObject''), + '','', ''Deny log on as a batch job;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob''), + '','', ''Deny log on as a service;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsAService''), + '','', ''Deny log on locally;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLocalLogon''), + '','', ''Deny log on through Remote Desktop Services;ExpectedValue'', ''='', + parameters(''UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices''), + '','', ''Force shutdown from a remote system;ExpectedValue'', ''='', parameters(''UserAndGroupsThatMayForceShutdownFromARemoteSystem''), + '','', ''Restore files and directories;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatMayRestoreFilesAndDirectories''), + '','', ''Shut down the system;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatMayShutDownTheSystem''), + '','', ''Take ownership of files or other objects;ExpectedValue'', ''='', + parameters(''UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e068b215-0026-4354-b347-8fb2766f73a2","type":"Microsoft.Authorization/policyDefinitions","name":"e068b215-0026-4354-b347-8fb2766f73a2"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''User Rights Assignment''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''User Rights Assignment''. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_UserRightsAssignment","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c961dac9-5916-42e8-8fb1-703148323994","type":"Microsoft.Authorization/policyDefinitions","name":"c961dac9-5916-42e8-8fb1-703148323994"},{"properties":{"displayName":"Audit + Windows machines that do not contain the specified certificates in Trusted + Root","policyType":"BuiltIn","mode":"Indexed","description":"Requires that + prerequisites are deployed to the policy assignment scope. For details, visit + https://aka.ms/gcpol. Machines are non-compliant if the machine Trusted Root + certificate store (Cert:\\LocalMachine\\Root) does not contain one or more + of the certificates listed by the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.1","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsCertificateInTrustedRoot","version":"1.*","configurationParameter":{"CertificateThumbprints":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"CertificateThumbprints":{"type":"String","metadata":{"displayName":"Certificate + thumbprints","description":"A semicolon-separated list of certificate thumbprints + that should exist under the Trusted Root certificate store (Cert:\\LocalMachine\\Root). + e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsCertificateInTrustedRoot","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude'', + ''='', parameters(''CertificateThumbprints'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/934345e1-4dfb-4c70-90d7-41990dc9608b","type":"Microsoft.Authorization/policyDefinitions","name":"934345e1-4dfb-4c70-90d7-41990dc9608b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''User Rights + Assignment''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''User Rights Assignment''. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may access this computer from the network","description":"Specifies + which remote users on the network are permitted to connect to the computer. + This does not include Remote Desktop Connection."},"defaultValue":"Administrators, + Authenticated Users"},"UsersOrGroupsThatMayLogOnLocally":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may log on locally","description":"Specifies which users + or groups can interactively log on to the computer. Users who attempt to log + on via Remote Desktop Connection or IIS also require this user right."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may log on through Remote Desktop Services","description":"Specifies + which users or groups are permitted to log on as a Terminal Services client, + Remote Desktop, or for Remote Assistance."},"defaultValue":"Administrators, + Remote Desktop Users"},"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that are denied access to this computer from the network","description":"Specifies + which users or groups are explicitly prohibited from connecting to the computer + across the network."},"defaultValue":"Guests"},"UsersOrGroupsThatMayManageAuditingAndSecurityLog":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may manage auditing and security log","description":"Specifies + users and groups permitted to change the auditing options for files and directories + and clear the Security log."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayBackUpFilesAndDirectories":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may back up files and directories","description":"Specifies + users and groups allowed to circumvent file and directory permissions to back + up the system."},"defaultValue":"Administrators, Backup Operators"},"UsersOrGroupsThatMayChangeTheSystemTime":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may change the system time","description":"Specifies + which users and groups are permitted to change the time and date on the internal + clock of the computer."},"defaultValue":"Administrators, LOCAL SERVICE"},"UsersOrGroupsThatMayChangeTheTimeZone":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may change the time zone","description":"Specifies which + users and groups are permitted to change the time zone of the computer."},"defaultValue":"Administrators, + LOCAL SERVICE"},"UsersOrGroupsThatMayCreateATokenObject":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may create a token object","description":"Specifies which + users and groups are permitted to create an access token, which may provide + elevated rights to access sensitive data."},"defaultValue":"No One"},"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that are denied logging on as a batch job","description":"Specifies + which users and groups are explicitly not permitted to log on to the computer + as a batch job (i.e. scheduled task)."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLoggingOnAsAService":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that are denied logging on as a service","description":"Specifies + which service accounts are explicitly not permitted to register a process + as a service."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLocalLogon":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that are denied local logon","description":"Specifies which + users and groups are explicitly not permitted to log on to the computer."},"defaultValue":"Guests"},"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that are denied log on through Remote Desktop Services","description":"Specifies + which users and groups are explicitly not permitted to log on to the computer + via Terminal Services/Remote Desktop Client."},"defaultValue":"Guests"},"UserAndGroupsThatMayForceShutdownFromARemoteSystem":{"type":"String","metadata":{"displayName":"[Deprecated]: + User and groups that may force shutdown from a remote system","description":"Specifies + which users and groups are permitted to shut down the computer from a remote + location on the network."},"defaultValue":"Administrators"},"UsersAndGroupsThatMayRestoreFilesAndDirectories":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that may restore files and directories","description":"Specifies + which users and groups are permitted to bypass file, directory, registry, + and other persistent object permissions when restoring backed up files and + directories."},"defaultValue":"Administrators, Backup Operators"},"UsersAndGroupsThatMayShutDownTheSystem":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users and groups that may shut down the system","description":"Specifies which + users and groups who are logged on locally to the computers in your environment + are permitted to shut down the operating system with the Shut Down command."},"defaultValue":"Administrators"},"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects":{"type":"String","metadata":{"displayName":"[Deprecated]: + Users or groups that may take ownership of files or other objects","description":"Specifies + which users and groups are permitted to take ownership of files, folders, + registry keys, processes, or threads. This user right bypasses any permissions + that are in place to protect objects to give ownership to the specified user."},"defaultValue":"Administrators"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_UserRightsAssignment","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Access + this computer from the network;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayAccessThisComputerFromTheNetwork''), + '','', ''Allow log on locally;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayLogOnLocally''), + '','', ''Allow log on through Remote Desktop Services;ExpectedValue'', ''='', + parameters(''UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices''), '','', + ''Deny access to this computer from the network;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork''), + '','', ''Manage auditing and security log;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayManageAuditingAndSecurityLog''), + '','', ''Back up files and directories;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayBackUpFilesAndDirectories''), + '','', ''Change the system time;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayChangeTheSystemTime''), + '','', ''Change the time zone;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayChangeTheTimeZone''), + '','', ''Create a token object;ExpectedValue'', ''='', parameters(''UsersOrGroupsThatMayCreateATokenObject''), + '','', ''Deny log on as a batch job;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob''), + '','', ''Deny log on as a service;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsAService''), + '','', ''Deny log on locally;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatAreDeniedLocalLogon''), + '','', ''Deny log on through Remote Desktop Services;ExpectedValue'', ''='', + parameters(''UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices''), + '','', ''Force shutdown from a remote system;ExpectedValue'', ''='', parameters(''UserAndGroupsThatMayForceShutdownFromARemoteSystem''), + '','', ''Restore files and directories;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatMayRestoreFilesAndDirectories''), + '','', ''Shut down the system;ExpectedValue'', ''='', parameters(''UsersAndGroupsThatMayShutDownTheSystem''), + '','', ''Take ownership of files or other objects;ExpectedValue'', ''='', + parameters(''UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_UserRightsAssignment"},"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork":{"value":"[parameters(''UsersOrGroupsThatMayAccessThisComputerFromTheNetwork'')]"},"UsersOrGroupsThatMayLogOnLocally":{"value":"[parameters(''UsersOrGroupsThatMayLogOnLocally'')]"},"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices":{"value":"[parameters(''UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices'')]"},"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork":{"value":"[parameters(''UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork'')]"},"UsersOrGroupsThatMayManageAuditingAndSecurityLog":{"value":"[parameters(''UsersOrGroupsThatMayManageAuditingAndSecurityLog'')]"},"UsersOrGroupsThatMayBackUpFilesAndDirectories":{"value":"[parameters(''UsersOrGroupsThatMayBackUpFilesAndDirectories'')]"},"UsersOrGroupsThatMayChangeTheSystemTime":{"value":"[parameters(''UsersOrGroupsThatMayChangeTheSystemTime'')]"},"UsersOrGroupsThatMayChangeTheTimeZone":{"value":"[parameters(''UsersOrGroupsThatMayChangeTheTimeZone'')]"},"UsersOrGroupsThatMayCreateATokenObject":{"value":"[parameters(''UsersOrGroupsThatMayCreateATokenObject'')]"},"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob":{"value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob'')]"},"UsersAndGroupsThatAreDeniedLoggingOnAsAService":{"value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsAService'')]"},"UsersAndGroupsThatAreDeniedLocalLogon":{"value":"[parameters(''UsersAndGroupsThatAreDeniedLocalLogon'')]"},"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices":{"value":"[parameters(''UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices'')]"},"UserAndGroupsThatMayForceShutdownFromARemoteSystem":{"value":"[parameters(''UserAndGroupsThatMayForceShutdownFromARemoteSystem'')]"},"UsersAndGroupsThatMayRestoreFilesAndDirectories":{"value":"[parameters(''UsersAndGroupsThatMayRestoreFilesAndDirectories'')]"},"UsersAndGroupsThatMayShutDownTheSystem":{"value":"[parameters(''UsersAndGroupsThatMayShutDownTheSystem'')]"},"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects":{"value":"[parameters(''UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork":{"type":"string"},"UsersOrGroupsThatMayLogOnLocally":{"type":"string"},"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices":{"type":"string"},"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork":{"type":"string"},"UsersOrGroupsThatMayManageAuditingAndSecurityLog":{"type":"string"},"UsersOrGroupsThatMayBackUpFilesAndDirectories":{"type":"string"},"UsersOrGroupsThatMayChangeTheSystemTime":{"type":"string"},"UsersOrGroupsThatMayChangeTheTimeZone":{"type":"string"},"UsersOrGroupsThatMayCreateATokenObject":{"type":"string"},"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob":{"type":"string"},"UsersAndGroupsThatAreDeniedLoggingOnAsAService":{"type":"string"},"UsersAndGroupsThatAreDeniedLocalLogon":{"type":"string"},"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices":{"type":"string"},"UserAndGroupsThatMayForceShutdownFromARemoteSystem":{"type":"string"},"UsersAndGroupsThatMayRestoreFilesAndDirectories":{"type":"string"},"UsersAndGroupsThatMayShutDownTheSystem":{"type":"string"},"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Access + this computer from the network;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayAccessThisComputerFromTheNetwork'')]"},{"name":"Allow + log on locally;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayLogOnLocally'')]"},{"name":"Allow + log on through Remote Desktop Services;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices'')]"},{"name":"Deny + access to this computer from the network;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork'')]"},{"name":"Manage + auditing and security log;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayManageAuditingAndSecurityLog'')]"},{"name":"Back + up files and directories;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayBackUpFilesAndDirectories'')]"},{"name":"Change + the system time;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayChangeTheSystemTime'')]"},{"name":"Change + the time zone;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayChangeTheTimeZone'')]"},{"name":"Create + a token object;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayCreateATokenObject'')]"},{"name":"Deny + log on as a batch job;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob'')]"},{"name":"Deny + log on as a service;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsAService'')]"},{"name":"Deny + log on locally;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLocalLogon'')]"},{"name":"Deny + log on through Remote Desktop Services;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices'')]"},{"name":"Force + shutdown from a remote system;ExpectedValue","value":"[parameters(''UserAndGroupsThatMayForceShutdownFromARemoteSystem'')]"},{"name":"Restore + files and directories;ExpectedValue","value":"[parameters(''UsersAndGroupsThatMayRestoreFilesAndDirectories'')]"},{"name":"Shut + down the system;ExpectedValue","value":"[parameters(''UsersAndGroupsThatMayShutDownTheSystem'')]"},{"name":"Take + ownership of files or other objects;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Access + this computer from the network;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayAccessThisComputerFromTheNetwork'')]"},{"name":"Allow + log on locally;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayLogOnLocally'')]"},{"name":"Allow + log on through Remote Desktop Services;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices'')]"},{"name":"Deny + access to this computer from the network;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork'')]"},{"name":"Manage + auditing and security log;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayManageAuditingAndSecurityLog'')]"},{"name":"Back + up files and directories;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayBackUpFilesAndDirectories'')]"},{"name":"Change + the system time;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayChangeTheSystemTime'')]"},{"name":"Change + the time zone;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayChangeTheTimeZone'')]"},{"name":"Create + a token object;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayCreateATokenObject'')]"},{"name":"Deny + log on as a batch job;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob'')]"},{"name":"Deny + log on as a service;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLoggingOnAsAService'')]"},{"name":"Deny + log on locally;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLocalLogon'')]"},{"name":"Deny + log on through Remote Desktop Services;ExpectedValue","value":"[parameters(''UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices'')]"},{"name":"Force + shutdown from a remote system;ExpectedValue","value":"[parameters(''UserAndGroupsThatMayForceShutdownFromARemoteSystem'')]"},{"name":"Restore + files and directories;ExpectedValue","value":"[parameters(''UsersAndGroupsThatMayRestoreFilesAndDirectories'')]"},{"name":"Shut + down the system;ExpectedValue","value":"[parameters(''UsersAndGroupsThatMayShutDownTheSystem'')]"},{"name":"Take + ownership of files or other objects;ExpectedValue","value":"[parameters(''UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/815dcc9f-6662-43f2-9a03-1b83e9876f24","type":"Microsoft.Authorization/policyDefinitions","name":"815dcc9f-6662-43f2-9a03-1b83e9876f24"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not contain the specified certificates + in Trusted Root","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + VMs that do not contain the specified certificates in the Trusted Root Certification + Authorities certificate store (Cert:\\LocalMachine\\Root). For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsCertificateInTrustedRoot","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f3b9ad83-000d-4dc1-bff0-6d54533dd03f","type":"Microsoft.Authorization/policyDefinitions","name":"f3b9ad83-000d-4dc1-bff0-6d54533dd03f"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Windows Components''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Windows + Components'' for basic authentication, unencrypted traffic, Microsoft accounts, + telemetry, Cortana, and other Windows behaviors. This policy requires that + the Guest Configuration prerequisites have been deployed to the policy assignment + scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_WindowsComponents","version":"1.*","configurationParameter":{"SendFileSamplesWhenFurtherAnalysisIsRequired":"Send + file samples when further analysis is required;ExpectedValue","AllowIndexingOfEncryptedFiles":"Allow + indexing of encrypted files;ExpectedValue","AllowTelemetry":"Allow Telemetry;ExpectedValue","AllowUnencryptedTraffic":"Allow + unencrypted traffic;ExpectedValue","AlwaysInstallWithElevatedPrivileges":"Always + install with elevated privileges;ExpectedValue","AlwaysPromptForPasswordUponConnection":"Always + prompt for password upon connection;ExpectedValue","ApplicationSpecifyTheMaximumLogFileSizeKB":"Application: + Specify the maximum log file size (KB);ExpectedValue","AutomaticallySendMemoryDumpsForOSgeneratedErrorReports":"Automatically + send memory dumps for OS-generated error reports;ExpectedValue","ConfigureDefaultConsent":"Configure + Default consent;ExpectedValue","ConfigureWindowsSmartScreen":"Configure Windows + SmartScreen;ExpectedValue","DisallowDigestAuthentication":"Disallow Digest + authentication;ExpectedValue","DisallowWinRMFromStoringRunAsCredentials":"Disallow + WinRM from storing RunAs credentials;ExpectedValue","DoNotAllowPasswordsToBeSaved":"Do + not allow passwords to be saved;ExpectedValue","SecuritySpecifyTheMaximumLogFileSizeKB":"Security: + Specify the maximum log file size (KB);ExpectedValue","SetClientConnectionEncryptionLevel":"Set + client connection encryption level;ExpectedValue","SetTheDefaultBehaviorForAutoRun":"Set + the default behavior for AutoRun;ExpectedValue","SetupSpecifyTheMaximumLogFileSizeKB":"Setup: + Specify the maximum log file size (KB);ExpectedValue","SystemSpecifyTheMaximumLogFileSizeKB":"System: + Specify the maximum log file size (KB);ExpectedValue","TurnOffDataExecutionPreventionForExplorer":"Turn + off Data Execution Prevention for Explorer;ExpectedValue","SpecifyTheIntervalToCheckForDefinitionUpdates":"Specify + the interval to check for definition updates;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"SendFileSamplesWhenFurtherAnalysisIsRequired":{"type":"String","metadata":{"displayName":"Send + file samples when further analysis is required","description":"Specifies whether + and how Windows Defender will submit samples of suspected malware to Microsoft + for further analysis when opt-in for MAPS telemetry is set."},"defaultValue":"1"},"AllowIndexingOfEncryptedFiles":{"type":"String","metadata":{"displayName":"Allow + indexing of encrypted files","description":"Specifies whether encrypted items + are allowed to be indexed."},"defaultValue":"0"},"AllowTelemetry":{"type":"String","metadata":{"displayName":"Allow + Telemetry","description":"Specifies configuration of the amount of diagnostic + and usage data reported to Microsoft. The data is transmitted securely and + sensitive data is not sent."},"defaultValue":"2"},"AllowUnencryptedTraffic":{"type":"String","metadata":{"displayName":"Allow + unencrypted traffic","description":"Specifies whether the Windows Remote Management + (WinRM) service sends and receives unencrypted messages over the network."},"defaultValue":"0"},"AlwaysInstallWithElevatedPrivileges":{"type":"String","metadata":{"displayName":"Always + install with elevated privileges","description":"Specifies whether Windows + Installer should use system permissions when it installs any program on the + system."},"defaultValue":"0"},"AlwaysPromptForPasswordUponConnection":{"type":"String","metadata":{"displayName":"Always + prompt for password upon connection","description":"Specifies whether Terminal + Services/Remote Desktop Connection always prompts the client computer for + a password upon connection."},"defaultValue":"1"},"ApplicationSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"Application: + Specify the maximum log file size (KB)","description":"Specifies the maximum + size for the Application event log in kilobytes."},"defaultValue":"32768"},"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports":{"type":"String","metadata":{"displayName":"Automatically + send memory dumps for OS-generated error reports","description":"Specifies + if memory dumps in support of OS-generated error reports can be sent to Microsoft + automatically."},"defaultValue":"1"},"ConfigureDefaultConsent":{"type":"String","metadata":{"displayName":"Configure + Default consent","description":"Specifies setting of the default consent handling + for error reports sent to Microsoft."},"defaultValue":"4"},"ConfigureWindowsSmartScreen":{"type":"String","metadata":{"displayName":"Configure + Windows SmartScreen","description":"Specifies how to manage the behavior of + Windows SmartScreen. Windows SmartScreen helps keep PCs safer by warning users + before running unrecognized programs downloaded from the Internet. Some information + is sent to Microsoft about files and programs run on PCs with this feature + enabled."},"defaultValue":"1"},"DisallowDigestAuthentication":{"type":"String","metadata":{"displayName":"Disallow + Digest authentication","description":"Specifies whether the Windows Remote + Management (WinRM) client will not use Digest authentication."},"defaultValue":"0"},"DisallowWinRMFromStoringRunAsCredentials":{"type":"String","metadata":{"displayName":"Disallow + WinRM from storing RunAs credentials","description":"Specifies whether the + Windows Remote Management (WinRM) service will not allow RunAs credentials + to be stored for any plug-ins."},"defaultValue":"1"},"DoNotAllowPasswordsToBeSaved":{"type":"String","metadata":{"displayName":"Do + not allow passwords to be saved","description":"Specifies whether to prevent + Remote Desktop Services - Terminal Services clients from saving passwords + on a computer."},"defaultValue":"1"},"SecuritySpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"Security: + Specify the maximum log file size (KB)","description":"Specifies the maximum + size for the Security event log in kilobytes."},"defaultValue":"196608"},"SetClientConnectionEncryptionLevel":{"type":"String","metadata":{"displayName":"Set + client connection encryption level","description":"Specifies whether to require + the use of a specific encryption level to secure communications between client + computers and RD Session Host servers during Remote Desktop Protocol (RDP) + connections. This policy only applies when you are using native RDP encryption."},"defaultValue":"3"},"SetTheDefaultBehaviorForAutoRun":{"type":"String","metadata":{"displayName":"Set + the default behavior for AutoRun","description":"Specifies the default behavior + for Autorun commands. Autorun commands are generally stored in autorun.inf + files. They often launch the installation program or other routines."},"defaultValue":"1"},"SetupSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"Setup: + Specify the maximum log file size (KB)","description":"Specifies the maximum + size for the Setup event log in kilobytes."},"defaultValue":"32768"},"SystemSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"System: + Specify the maximum log file size (KB)","description":"Specifies the maximum + size for the System event log in kilobytes."},"defaultValue":"32768"},"TurnOffDataExecutionPreventionForExplorer":{"type":"String","metadata":{"displayName":"Turn + off Data Execution Prevention for Explorer","description":"Specifies whether + to turn off Data Execution Prevention for Windows File Explorer. Disabling + data execution prevention can allow certain legacy plug-in applications to + function without terminating Explorer."},"defaultValue":"0"},"SpecifyTheIntervalToCheckForDefinitionUpdates":{"type":"String","metadata":{"displayName":"Specify + the interval to check for definition updates","description":"Specifies an + interval at which to check for Windows Defender definition updates. The time + value is represented as the number of hours between update checks."},"defaultValue":"8"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsComponents","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Send + file samples when further analysis is required;ExpectedValue'', ''='', parameters(''SendFileSamplesWhenFurtherAnalysisIsRequired''), + '','', ''Allow indexing of encrypted files;ExpectedValue'', ''='', parameters(''AllowIndexingOfEncryptedFiles''), + '','', ''Allow Telemetry;ExpectedValue'', ''='', parameters(''AllowTelemetry''), + '','', ''Allow unencrypted traffic;ExpectedValue'', ''='', parameters(''AllowUnencryptedTraffic''), + '','', ''Always install with elevated privileges;ExpectedValue'', ''='', parameters(''AlwaysInstallWithElevatedPrivileges''), + '','', ''Always prompt for password upon connection;ExpectedValue'', ''='', + parameters(''AlwaysPromptForPasswordUponConnection''), '','', ''Application: + Specify the maximum log file size (KB);ExpectedValue'', ''='', parameters(''ApplicationSpecifyTheMaximumLogFileSizeKB''), + '','', ''Automatically send memory dumps for OS-generated error reports;ExpectedValue'', + ''='', parameters(''AutomaticallySendMemoryDumpsForOSgeneratedErrorReports''), + '','', ''Configure Default consent;ExpectedValue'', ''='', parameters(''ConfigureDefaultConsent''), + '','', ''Configure Windows SmartScreen;ExpectedValue'', ''='', parameters(''ConfigureWindowsSmartScreen''), + '','', ''Disallow Digest authentication;ExpectedValue'', ''='', parameters(''DisallowDigestAuthentication''), + '','', ''Disallow WinRM from storing RunAs credentials;ExpectedValue'', ''='', + parameters(''DisallowWinRMFromStoringRunAsCredentials''), '','', ''Do not + allow passwords to be saved;ExpectedValue'', ''='', parameters(''DoNotAllowPasswordsToBeSaved''), + '','', ''Security: Specify the maximum log file size (KB);ExpectedValue'', + ''='', parameters(''SecuritySpecifyTheMaximumLogFileSizeKB''), '','', ''Set + client connection encryption level;ExpectedValue'', ''='', parameters(''SetClientConnectionEncryptionLevel''), + '','', ''Set the default behavior for AutoRun;ExpectedValue'', ''='', parameters(''SetTheDefaultBehaviorForAutoRun''), + '','', ''Setup: Specify the maximum log file size (KB);ExpectedValue'', ''='', + parameters(''SetupSpecifyTheMaximumLogFileSizeKB''), '','', ''System: Specify + the maximum log file size (KB);ExpectedValue'', ''='', parameters(''SystemSpecifyTheMaximumLogFileSizeKB''), + '','', ''Turn off Data Execution Prevention for Explorer;ExpectedValue'', + ''='', parameters(''TurnOffDataExecutionPreventionForExplorer''), '','', ''Specify + the interval to check for definition updates;ExpectedValue'', ''='', parameters(''SpecifyTheIntervalToCheckForDefinitionUpdates'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8537fe96-8cbe-43de-b0ef-131bc72bc22a","type":"Microsoft.Authorization/policyDefinitions","name":"8537fe96-8cbe-43de-b0ef-131bc72bc22a"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Windows Components''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Windows Components''. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsComponents","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9178b430-2295-406e-bb28-f6a7a2a2f897","type":"Microsoft.Authorization/policyDefinitions","name":"9178b430-2295-406e-bb28-f6a7a2a2f897"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Windows Components''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Windows Components''. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"SendFileSamplesWhenFurtherAnalysisIsRequired":{"type":"String","metadata":{"displayName":"[Deprecated]: + Send file samples when further analysis is required","description":"Specifies + whether and how Windows Defender will submit samples of suspected malware to + Microsoft for further analysis when opt-in for MAPS telemetry is set."},"defaultValue":"1"},"AllowIndexingOfEncryptedFiles":{"type":"String","metadata":{"displayName":"[Deprecated]: + Allow indexing of encrypted files","description":"Specifies whether encrypted + items are allowed to be indexed."},"defaultValue":"0"},"AllowTelemetry":{"type":"String","metadata":{"displayName":"[Deprecated]: + Allow Telemetry","description":"Specifies configuration of the amount of diagnostic + and usage data reported to Microsoft. The data is transmitted securely and + sensitive data is not sent."},"defaultValue":"2"},"AllowUnencryptedTraffic":{"type":"String","metadata":{"displayName":"[Deprecated]: + Allow unencrypted traffic","description":"Specifies whether the Windows Remote + Management (WinRM) service sends and receives unencrypted messages over the + network."},"defaultValue":"0"},"AlwaysInstallWithElevatedPrivileges":{"type":"String","metadata":{"displayName":"[Deprecated]: + Always install with elevated privileges","description":"Specifies whether + Windows Installer should use system permissions when it installs any program + on the system."},"defaultValue":"0"},"AlwaysPromptForPasswordUponConnection":{"type":"String","metadata":{"displayName":"[Deprecated]: + Always prompt for password upon connection","description":"Specifies whether + Terminal Services/Remote Desktop Connection always prompts the client computer + for a password upon connection."},"defaultValue":"1"},"ApplicationSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"[Deprecated]: + Application: Specify the maximum log file size (KB)","description":"Specifies + the maximum size for the Application event log in kilobytes."},"defaultValue":"32768"},"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports":{"type":"String","metadata":{"displayName":"[Deprecated]: + Automatically send memory dumps for OS-generated error reports","description":"Specifies + if memory dumps in support of OS-generated error reports can be sent to Microsoft + automatically."},"defaultValue":"1"},"ConfigureDefaultConsent":{"type":"String","metadata":{"displayName":"[Deprecated]: + Configure Default consent","description":"Specifies setting of the default + consent handling for error reports sent to Microsoft."},"defaultValue":"4"},"ConfigureWindowsSmartScreen":{"type":"String","metadata":{"displayName":"[Deprecated]: + Configure Windows SmartScreen","description":"Specifies how to manage the + behavior of Windows SmartScreen. Windows SmartScreen helps keep PCs safer + by warning users before running unrecognized programs downloaded from the + Internet. Some information is sent to Microsoft about files and programs run + on PCs with this feature enabled."},"defaultValue":"1"},"DisallowDigestAuthentication":{"type":"String","metadata":{"displayName":"[Deprecated]: + Disallow Digest authentication","description":"Specifies whether the Windows + Remote Management (WinRM) client will not use Digest authentication."},"defaultValue":"0"},"DisallowWinRMFromStoringRunAsCredentials":{"type":"String","metadata":{"displayName":"[Deprecated]: + Disallow WinRM from storing RunAs credentials","description":"Specifies whether + the Windows Remote Management (WinRM) service will not allow RunAs credentials + to be stored for any plug-ins."},"defaultValue":"1"},"DoNotAllowPasswordsToBeSaved":{"type":"String","metadata":{"displayName":"[Deprecated]: + Do not allow passwords to be saved","description":"Specifies whether to prevent + Remote Desktop Services - Terminal Services clients from saving passwords + on a computer."},"defaultValue":"1"},"SecuritySpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"[Deprecated]: + Security: Specify the maximum log file size (KB)","description":"Specifies + the maximum size for the Security event log in kilobytes."},"defaultValue":"196608"},"SetClientConnectionEncryptionLevel":{"type":"String","metadata":{"displayName":"[Deprecated]: + Set client connection encryption level","description":"Specifies whether to + require the use of a specific encryption level to secure communications between + client computers and RD Session Host servers during Remote Desktop Protocol + (RDP) connections. This policy only applies when you are using native RDP + encryption."},"defaultValue":"3"},"SetTheDefaultBehaviorForAutoRun":{"type":"String","metadata":{"displayName":"[Deprecated]: + Set the default behavior for AutoRun","description":"Specifies the default + behavior for Autorun commands. Autorun commands are generally stored in autorun.inf + files. They often launch the installation program or other routines."},"defaultValue":"1"},"SetupSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"[Deprecated]: + Setup: Specify the maximum log file size (KB)","description":"Specifies the + maximum size for the Setup event log in kilobytes."},"defaultValue":"32768"},"SystemSpecifyTheMaximumLogFileSizeKB":{"type":"String","metadata":{"displayName":"[Deprecated]: + System: Specify the maximum log file size (KB)","description":"Specifies the + maximum size for the System event log in kilobytes."},"defaultValue":"32768"},"TurnOffDataExecutionPreventionForExplorer":{"type":"String","metadata":{"displayName":"[Deprecated]: + Turn off Data Execution Prevention for Explorer","description":"Specifies + whether to turn off Data Execution Prevention for Windows File Explorer. Disabling + data execution prevention can allow certain legacy plug-in applications to + function without terminating Explorer."},"defaultValue":"0"},"SpecifyTheIntervalToCheckForDefinitionUpdates":{"type":"String","metadata":{"displayName":"[Deprecated]: + Specify the interval to check for definition updates","description":"Specifies + an interval at which to check for Windows Defender definition updates. The + time value is represented as the number of hours between update checks."},"defaultValue":"8"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsComponents","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Send + file samples when further analysis is required;ExpectedValue'', ''='', parameters(''SendFileSamplesWhenFurtherAnalysisIsRequired''), + '','', ''Allow indexing of encrypted files;ExpectedValue'', ''='', parameters(''AllowIndexingOfEncryptedFiles''), + '','', ''Allow Telemetry;ExpectedValue'', ''='', parameters(''AllowTelemetry''), + '','', ''Allow unencrypted traffic;ExpectedValue'', ''='', parameters(''AllowUnencryptedTraffic''), + '','', ''Always install with elevated privileges;ExpectedValue'', ''='', parameters(''AlwaysInstallWithElevatedPrivileges''), + '','', ''Always prompt for password upon connection;ExpectedValue'', ''='', + parameters(''AlwaysPromptForPasswordUponConnection''), '','', ''Application: + Specify the maximum log file size (KB);ExpectedValue'', ''='', parameters(''ApplicationSpecifyTheMaximumLogFileSizeKB''), + '','', ''Automatically send memory dumps for OS-generated error reports;ExpectedValue'', + ''='', parameters(''AutomaticallySendMemoryDumpsForOSgeneratedErrorReports''), + '','', ''Configure Default consent;ExpectedValue'', ''='', parameters(''ConfigureDefaultConsent''), + '','', ''Configure Windows SmartScreen;ExpectedValue'', ''='', parameters(''ConfigureWindowsSmartScreen''), + '','', ''Disallow Digest authentication;ExpectedValue'', ''='', parameters(''DisallowDigestAuthentication''), + '','', ''Disallow WinRM from storing RunAs credentials;ExpectedValue'', ''='', + parameters(''DisallowWinRMFromStoringRunAsCredentials''), '','', ''Do not + allow passwords to be saved;ExpectedValue'', ''='', parameters(''DoNotAllowPasswordsToBeSaved''), + '','', ''Security: Specify the maximum log file size (KB);ExpectedValue'', + ''='', parameters(''SecuritySpecifyTheMaximumLogFileSizeKB''), '','', ''Set + client connection encryption level;ExpectedValue'', ''='', parameters(''SetClientConnectionEncryptionLevel''), + '','', ''Set the default behavior for AutoRun;ExpectedValue'', ''='', parameters(''SetTheDefaultBehaviorForAutoRun''), + '','', ''Setup: Specify the maximum log file size (KB);ExpectedValue'', ''='', + parameters(''SetupSpecifyTheMaximumLogFileSizeKB''), '','', ''System: Specify + the maximum log file size (KB);ExpectedValue'', ''='', parameters(''SystemSpecifyTheMaximumLogFileSizeKB''), + '','', ''Turn off Data Execution Prevention for Explorer;ExpectedValue'', + ''='', parameters(''TurnOffDataExecutionPreventionForExplorer''), '','', ''Specify + the interval to check for definition updates;ExpectedValue'', ''='', parameters(''SpecifyTheIntervalToCheckForDefinitionUpdates'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_WindowsComponents"},"SendFileSamplesWhenFurtherAnalysisIsRequired":{"value":"[parameters(''SendFileSamplesWhenFurtherAnalysisIsRequired'')]"},"AllowIndexingOfEncryptedFiles":{"value":"[parameters(''AllowIndexingOfEncryptedFiles'')]"},"AllowTelemetry":{"value":"[parameters(''AllowTelemetry'')]"},"AllowUnencryptedTraffic":{"value":"[parameters(''AllowUnencryptedTraffic'')]"},"AlwaysInstallWithElevatedPrivileges":{"value":"[parameters(''AlwaysInstallWithElevatedPrivileges'')]"},"AlwaysPromptForPasswordUponConnection":{"value":"[parameters(''AlwaysPromptForPasswordUponConnection'')]"},"ApplicationSpecifyTheMaximumLogFileSizeKB":{"value":"[parameters(''ApplicationSpecifyTheMaximumLogFileSizeKB'')]"},"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports":{"value":"[parameters(''AutomaticallySendMemoryDumpsForOSgeneratedErrorReports'')]"},"ConfigureDefaultConsent":{"value":"[parameters(''ConfigureDefaultConsent'')]"},"ConfigureWindowsSmartScreen":{"value":"[parameters(''ConfigureWindowsSmartScreen'')]"},"DisallowDigestAuthentication":{"value":"[parameters(''DisallowDigestAuthentication'')]"},"DisallowWinRMFromStoringRunAsCredentials":{"value":"[parameters(''DisallowWinRMFromStoringRunAsCredentials'')]"},"DoNotAllowPasswordsToBeSaved":{"value":"[parameters(''DoNotAllowPasswordsToBeSaved'')]"},"SecuritySpecifyTheMaximumLogFileSizeKB":{"value":"[parameters(''SecuritySpecifyTheMaximumLogFileSizeKB'')]"},"SetClientConnectionEncryptionLevel":{"value":"[parameters(''SetClientConnectionEncryptionLevel'')]"},"SetTheDefaultBehaviorForAutoRun":{"value":"[parameters(''SetTheDefaultBehaviorForAutoRun'')]"},"SetupSpecifyTheMaximumLogFileSizeKB":{"value":"[parameters(''SetupSpecifyTheMaximumLogFileSizeKB'')]"},"SystemSpecifyTheMaximumLogFileSizeKB":{"value":"[parameters(''SystemSpecifyTheMaximumLogFileSizeKB'')]"},"TurnOffDataExecutionPreventionForExplorer":{"value":"[parameters(''TurnOffDataExecutionPreventionForExplorer'')]"},"SpecifyTheIntervalToCheckForDefinitionUpdates":{"value":"[parameters(''SpecifyTheIntervalToCheckForDefinitionUpdates'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"SendFileSamplesWhenFurtherAnalysisIsRequired":{"type":"string"},"AllowIndexingOfEncryptedFiles":{"type":"string"},"AllowTelemetry":{"type":"string"},"AllowUnencryptedTraffic":{"type":"string"},"AlwaysInstallWithElevatedPrivileges":{"type":"string"},"AlwaysPromptForPasswordUponConnection":{"type":"string"},"ApplicationSpecifyTheMaximumLogFileSizeKB":{"type":"string"},"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports":{"type":"string"},"ConfigureDefaultConsent":{"type":"string"},"ConfigureWindowsSmartScreen":{"type":"string"},"DisallowDigestAuthentication":{"type":"string"},"DisallowWinRMFromStoringRunAsCredentials":{"type":"string"},"DoNotAllowPasswordsToBeSaved":{"type":"string"},"SecuritySpecifyTheMaximumLogFileSizeKB":{"type":"string"},"SetClientConnectionEncryptionLevel":{"type":"string"},"SetTheDefaultBehaviorForAutoRun":{"type":"string"},"SetupSpecifyTheMaximumLogFileSizeKB":{"type":"string"},"SystemSpecifyTheMaximumLogFileSizeKB":{"type":"string"},"TurnOffDataExecutionPreventionForExplorer":{"type":"string"},"SpecifyTheIntervalToCheckForDefinitionUpdates":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Send + file samples when further analysis is required;ExpectedValue","value":"[parameters(''SendFileSamplesWhenFurtherAnalysisIsRequired'')]"},{"name":"Allow + indexing of encrypted files;ExpectedValue","value":"[parameters(''AllowIndexingOfEncryptedFiles'')]"},{"name":"Allow + Telemetry;ExpectedValue","value":"[parameters(''AllowTelemetry'')]"},{"name":"Allow + unencrypted traffic;ExpectedValue","value":"[parameters(''AllowUnencryptedTraffic'')]"},{"name":"Always + install with elevated privileges;ExpectedValue","value":"[parameters(''AlwaysInstallWithElevatedPrivileges'')]"},{"name":"Always + prompt for password upon connection;ExpectedValue","value":"[parameters(''AlwaysPromptForPasswordUponConnection'')]"},{"name":"Application: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''ApplicationSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Automatically + send memory dumps for OS-generated error reports;ExpectedValue","value":"[parameters(''AutomaticallySendMemoryDumpsForOSgeneratedErrorReports'')]"},{"name":"Configure + Default consent;ExpectedValue","value":"[parameters(''ConfigureDefaultConsent'')]"},{"name":"Configure + Windows SmartScreen;ExpectedValue","value":"[parameters(''ConfigureWindowsSmartScreen'')]"},{"name":"Disallow + Digest authentication;ExpectedValue","value":"[parameters(''DisallowDigestAuthentication'')]"},{"name":"Disallow + WinRM from storing RunAs credentials;ExpectedValue","value":"[parameters(''DisallowWinRMFromStoringRunAsCredentials'')]"},{"name":"Do + not allow passwords to be saved;ExpectedValue","value":"[parameters(''DoNotAllowPasswordsToBeSaved'')]"},{"name":"Security: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SecuritySpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Set + client connection encryption level;ExpectedValue","value":"[parameters(''SetClientConnectionEncryptionLevel'')]"},{"name":"Set + the default behavior for AutoRun;ExpectedValue","value":"[parameters(''SetTheDefaultBehaviorForAutoRun'')]"},{"name":"Setup: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SetupSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"System: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SystemSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Turn + off Data Execution Prevention for Explorer;ExpectedValue","value":"[parameters(''TurnOffDataExecutionPreventionForExplorer'')]"},{"name":"Specify + the interval to check for definition updates;ExpectedValue","value":"[parameters(''SpecifyTheIntervalToCheckForDefinitionUpdates'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Send + file samples when further analysis is required;ExpectedValue","value":"[parameters(''SendFileSamplesWhenFurtherAnalysisIsRequired'')]"},{"name":"Allow + indexing of encrypted files;ExpectedValue","value":"[parameters(''AllowIndexingOfEncryptedFiles'')]"},{"name":"Allow + Telemetry;ExpectedValue","value":"[parameters(''AllowTelemetry'')]"},{"name":"Allow + unencrypted traffic;ExpectedValue","value":"[parameters(''AllowUnencryptedTraffic'')]"},{"name":"Always + install with elevated privileges;ExpectedValue","value":"[parameters(''AlwaysInstallWithElevatedPrivileges'')]"},{"name":"Always + prompt for password upon connection;ExpectedValue","value":"[parameters(''AlwaysPromptForPasswordUponConnection'')]"},{"name":"Application: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''ApplicationSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Automatically + send memory dumps for OS-generated error reports;ExpectedValue","value":"[parameters(''AutomaticallySendMemoryDumpsForOSgeneratedErrorReports'')]"},{"name":"Configure + Default consent;ExpectedValue","value":"[parameters(''ConfigureDefaultConsent'')]"},{"name":"Configure + Windows SmartScreen;ExpectedValue","value":"[parameters(''ConfigureWindowsSmartScreen'')]"},{"name":"Disallow + Digest authentication;ExpectedValue","value":"[parameters(''DisallowDigestAuthentication'')]"},{"name":"Disallow + WinRM from storing RunAs credentials;ExpectedValue","value":"[parameters(''DisallowWinRMFromStoringRunAsCredentials'')]"},{"name":"Do + not allow passwords to be saved;ExpectedValue","value":"[parameters(''DoNotAllowPasswordsToBeSaved'')]"},{"name":"Security: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SecuritySpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Set + client connection encryption level;ExpectedValue","value":"[parameters(''SetClientConnectionEncryptionLevel'')]"},{"name":"Set + the default behavior for AutoRun;ExpectedValue","value":"[parameters(''SetTheDefaultBehaviorForAutoRun'')]"},{"name":"Setup: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SetupSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"System: + Specify the maximum log file size (KB);ExpectedValue","value":"[parameters(''SystemSpecifyTheMaximumLogFileSizeKB'')]"},{"name":"Turn + off Data Execution Prevention for Explorer;ExpectedValue","value":"[parameters(''TurnOffDataExecutionPreventionForExplorer'')]"},{"name":"Specify + the interval to check for definition updates;ExpectedValue","value":"[parameters(''SpecifyTheIntervalToCheckForDefinitionUpdates'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7040a231-fb65-4412-8c0a-b365f4866c24","type":"Microsoft.Authorization/policyDefinitions","name":"7040a231-fb65-4412-8c0a-b365f4866c24"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not contain the specified + certificates in Trusted Root","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows VMs that + do not contain the specified certificates in the Trusted Root Certification + Authorities certificate store (Cert:\\LocalMachine\\Root). It also creates + a system-assigned managed identity and deploys the VM extension for Guest + Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"CertificateThumbprints":{"type":"String","metadata":{"displayName":"[Deprecated]: + Certificate thumbprints","description":"A semicolon-separated list of certificate + thumbprints that should exist under the Trusted Root certificate store (Cert:\\LocalMachine\\Root). + e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsCertificateInTrustedRoot","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude'', + ''='', parameters(''CertificateThumbprints'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsCertificateInTrustedRoot"},"CertificateThumbprints":{"value":"[parameters(''CertificateThumbprints'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"CertificateThumbprints":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude","value":"[parameters(''CertificateThumbprints'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude","value":"[parameters(''CertificateThumbprints'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/106ccbe4-a791-4f33-a44a-06796944b8d5","type":"Microsoft.Authorization/policyDefinitions","name":"106ccbe4-a791-4f33-a44a-06796944b8d5"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs on which Windows Defender Exploit Guard + is not enabled","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines on which Windows Defender Exploit Guard is not enabled. For + more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDefenderExploitGuard","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0d9b45ff-9ddd-43fc-bf59-fbd1c8423053","type":"Microsoft.Authorization/policyDefinitions","name":"0d9b45ff-9ddd-43fc-bf59-fbd1c8423053"},{"properties":{"displayName":"Windows + Defender Exploit Guard should be enabled on your machines","policyType":"BuiltIn","mode":"Indexed","description":"Windows + Defender Exploit Guard uses the Azure Policy Guest Configuration agent. Exploit + Guard has four components that are designed to lock down devices against a + wide variety of attack vectors and block behaviors commonly used in malware + attacks while enabling enterprises to balance their security risk and productivity + requirements (Windows only).","metadata":{"category":"Guest Configuration","version":"1.1.1","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsDefenderExploitGuard","version":"1.*","configurationParameter":{"NotAvailableMachineState":"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"NotAvailableMachineState":{"type":"String","metadata":{"displayName":"Status + if Windows Defender is not available on machine","description":"Windows Defender + Exploit Guard is only available starting with Windows 10/Windows Server with + update 1709. Setting this value to ''Non-Compliant'' shows machines with older + versions on which Windows Defender Exploit Guard is not available (such as + Windows Server 2012 R2) as non-compliant. Setting this value to ''Compliant'' + shows these machines as compliant."},"allowedValues":["Compliant","Non-Compliant"],"defaultValue":"Compliant"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDefenderExploitGuard","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState'', + ''='', parameters(''NotAvailableMachineState'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bed48b13-6647-468e-aa2f-1af1d3f4dd40","type":"Microsoft.Authorization/policyDefinitions","name":"bed48b13-6647-468e-aa2f-1af1d3f4dd40"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs on which Windows Defender Exploit + Guard is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + on which Windows Defender Exploit Guard is not enabled. It also creates a + system-assigned managed identity and deploys the VM extension for Guest Configuration. + This policy should only be used along with its corresponding audit policy + in an initiative. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"1.1.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"NotAvailableMachineState":{"type":"String","metadata":{"displayName":"[Deprecated]: + State in which to show VMs on which Windows Defender Exploit Guard is not + available","description":"Windows Defender Exploit Guard is only available + starting with Windows 10/Windows Server with update 1709. Setting this value + to ''Non-Compliant'' will make machines with older versions on which Windows + Defender Exploit Guard is not available (such as Windows Server 2012 R2) non-compliant. + Setting this value to ''Compliant'' will make these machines compliant."},"allowedValues":["Compliant","Non-Compliant"],"defaultValue":"Non-Compliant"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDefenderExploitGuard","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState'', + ''='', parameters(''NotAvailableMachineState'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsDefenderExploitGuard"},"NotAvailableMachineState":{"value":"[parameters(''NotAvailableMachineState'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"NotAvailableMachineState":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState","value":"[parameters(''NotAvailableMachineState'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState","value":"[parameters(''NotAvailableMachineState'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2015-05-01-preview","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6a7a2bcf-f9be-4e35-9734-4f9657a70f1d","type":"Microsoft.Authorization/policyDefinitions","name":"6a7a2bcf-f9be-4e35-9734-4f9657a70f1d"},{"properties":{"displayName":"Audit + Windows machines that are not joined to the specified domain","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the value of the + Domain property in WMI class win32_computersystem does not match the value + in the policy parameter.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsDomainMembership","version":"1.*","configurationParameter":{"DomainName":"[DomainMembership]WindowsDomainMembership;DomainName"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"DomainName":{"type":"String","metadata":{"displayName":"Domain + Name (FQDN)","description":"The fully qualified domain name (FQDN) that the + Windows machines should be joined to"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDomainMembership","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[DomainMembership]WindowsDomainMembership;DomainName'', + ''='', parameters(''DomainName'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/84662df4-0e37-44a6-9ce1-c9d2150db18c","type":"Microsoft.Authorization/policyDefinitions","name":"84662df4-0e37-44a6-9ce1-c9d2150db18c"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that are not joined to the specified domain","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that are not joined to the specified domain. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDomainMembership","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a29ee95c-0395-4515-9851-cc04ffe82a91","type":"Microsoft.Authorization/policyDefinitions","name":"a29ee95c-0395-4515-9851-cc04ffe82a91"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that are not joined to the specified + domain","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + that are not joined to the specified domain. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"DomainName":{"type":"String","metadata":{"displayName":"[Deprecated]: + Domain Name (FQDN)","description":"The fully qualified domain name (FQDN) + that the Windows VMs should be joined to"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDomainMembership","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[DomainMembership]WindowsDomainMembership;DomainName'', + ''='', parameters(''DomainName'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsDomainMembership"},"DomainName":{"value":"[parameters(''DomainName'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"DomainName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[DomainMembership]WindowsDomainMembership;DomainName","value":"[parameters(''DomainName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[DomainMembership]WindowsDomainMembership;DomainName","value":"[parameters(''DomainName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/315c850a-272d-4502-8935-b79010405970","type":"Microsoft.Authorization/policyDefinitions","name":"315c850a-272d-4502-8935-b79010405970"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs on which the DSC configuration is + not compliant","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows VMs on which + the Desired State Configuration (DSC) configuration is not compliant. This + policy is only applicable to machines with WMF 4 and above. It also creates + a system-assigned managed identity and deploys the VM extension for Guest + Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDscConfiguration","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsDscConfiguration"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d38b4c26-9d2e-47d7-aefe-18d859a8706a","type":"Microsoft.Authorization/policyDefinitions","name":"d38b4c26-9d2e-47d7-aefe-18d859a8706a"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs on which the DSC configuration is not + compliant","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + VMs on which the Desired State Configuration (DSC) configuration is not compliant. + This policy is only applicable to machines with WMF 4 and above. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDscConfiguration","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7227ebe5-9ff7-47ab-b823-171cd02fb90f","type":"Microsoft.Authorization/policyDefinitions","name":"7227ebe5-9ff7-47ab-b823-171cd02fb90f"},{"properties":{"displayName":"Audit + Windows machines on which the DSC configuration is not compliant","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the Windows PowerShell + command Get-DSCConfigurationStatus returns that the DSC configuration for + the machine is not compliant.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsDscConfiguration","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsDscConfiguration","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/08a2f2d2-94b2-4a7b-aa3b-bb3f523ee6fd","type":"Microsoft.Authorization/policyDefinitions","name":"08a2f2d2-94b2-4a7b-aa3b-bb3f523ee6fd"},{"properties":{"displayName":"Windows + machines should meet requirements for ''Windows Firewall Properties''","policyType":"BuiltIn","mode":"Indexed","description":"Windows + machines should have the specified Group Policy settings in the category ''Windows + Firewall Properties'' for firewall state, connections, rule management, and + notifications. This policy requires that the Guest Configuration prerequisites + have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.","metadata":{"category":"Guest + Configuration","version":"2.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"AzureBaseline_WindowsFirewallProperties","version":"1.*","configurationParameter":{"WindowsFirewallDomainUseProfileSettings":"Windows + Firewall: Domain: Firewall state;ExpectedValue","WindowsFirewallDomainBehaviorForOutboundConnections":"Windows + Firewall: Domain: Outbound connections;ExpectedValue","WindowsFirewallDomainApplyLocalConnectionSecurityRules":"Windows + Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue","WindowsFirewallDomainApplyLocalFirewallRules":"Windows + Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue","WindowsFirewallDomainDisplayNotifications":"Windows + Firewall: Domain: Settings: Display a notification;ExpectedValue","WindowsFirewallPrivateUseProfileSettings":"Windows + Firewall: Private: Firewall state;ExpectedValue","WindowsFirewallPrivateBehaviorForOutboundConnections":"Windows + Firewall: Private: Outbound connections;ExpectedValue","WindowsFirewallPrivateApplyLocalConnectionSecurityRules":"Windows + Firewall: Private: Settings: Apply local connection security rules;ExpectedValue","WindowsFirewallPrivateApplyLocalFirewallRules":"Windows + Firewall: Private: Settings: Apply local firewall rules;ExpectedValue","WindowsFirewallPrivateDisplayNotifications":"Windows + Firewall: Private: Settings: Display a notification;ExpectedValue","WindowsFirewallPublicUseProfileSettings":"Windows + Firewall: Public: Firewall state;ExpectedValue","WindowsFirewallPublicBehaviorForOutboundConnections":"Windows + Firewall: Public: Outbound connections;ExpectedValue","WindowsFirewallPublicApplyLocalConnectionSecurityRules":"Windows + Firewall: Public: Settings: Apply local connection security rules;ExpectedValue","WindowsFirewallPublicApplyLocalFirewallRules":"Windows + Firewall: Public: Settings: Apply local firewall rules;ExpectedValue","WindowsFirewallPublicDisplayNotifications":"Windows + Firewall: Public: Settings: Display a notification;ExpectedValue","WindowsFirewallDomainAllowUnicastResponse":"Windows + Firewall: Domain: Allow unicast response;ExpectedValue","WindowsFirewallPrivateAllowUnicastResponse":"Windows + Firewall: Private: Allow unicast response;ExpectedValue","WindowsFirewallPublicAllowUnicastResponse":"Windows + Firewall: Public: Allow unicast response;ExpectedValue"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"WindowsFirewallDomainUseProfileSettings":{"type":"String","metadata":{"displayName":"Windows + Firewall (Domain): Use profile settings","description":"Specifies whether + Windows Firewall with Advanced Security uses the settings for the Domain profile + to filter network traffic. If you select Off, Windows Firewall with Advanced + Security will not use any of the firewall rules or connection security rules + for this profile."},"defaultValue":"1"},"WindowsFirewallDomainBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"Windows + Firewall (Domain): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Domain profile that do not match + an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallDomainApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Domain): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Domain profile."},"defaultValue":"1"},"WindowsFirewallDomainApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Domain): Apply local firewall rules","description":"Specifies whether + local administrators are allowed to create local firewall rules that apply + together with firewall rules configured by Group Policy for the Domain profile."},"defaultValue":"1"},"WindowsFirewallDomainDisplayNotifications":{"type":"String","metadata":{"displayName":"Windows + Firewall (Domain): Display notifications","description":"Specifies whether + Windows Firewall with Advanced Security displays notifications to the user + when a program is blocked from receiving inbound connections, for the Domain + profile."},"defaultValue":"1"},"WindowsFirewallPrivateUseProfileSettings":{"type":"String","metadata":{"displayName":"Windows + Firewall (Private): Use profile settings","description":"Specifies whether + Windows Firewall with Advanced Security uses the settings for the Private + profile to filter network traffic. If you select Off, Windows Firewall with + Advanced Security will not use any of the firewall rules or connection security + rules for this profile."},"defaultValue":"1"},"WindowsFirewallPrivateBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"Windows + Firewall (Private): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Private profile that do not + match an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallPrivateApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Private): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Private profile."},"defaultValue":"1"},"WindowsFirewallPrivateApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Private): Apply local firewall rules","description":"Specifies whether + local administrators are allowed to create local firewall rules that apply + together with firewall rules configured by Group Policy for the Private profile."},"defaultValue":"1"},"WindowsFirewallPrivateDisplayNotifications":{"type":"String","metadata":{"displayName":"Windows + Firewall (Private): Display notifications","description":"Specifies whether + Windows Firewall with Advanced Security displays notifications to the user + when a program is blocked from receiving inbound connections, for the Private + profile."},"defaultValue":"1"},"WindowsFirewallPublicUseProfileSettings":{"type":"String","metadata":{"displayName":"Windows + Firewall (Public): Use profile settings","description":"Specifies whether + Windows Firewall with Advanced Security uses the settings for the Public profile + to filter network traffic. If you select Off, Windows Firewall with Advanced + Security will not use any of the firewall rules or connection security rules + for this profile."},"defaultValue":"1"},"WindowsFirewallPublicBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"Windows + Firewall (Public): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Public profile that do not match + an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallPublicApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Public): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Public profile."},"defaultValue":"1"},"WindowsFirewallPublicApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"Windows + Firewall (Public): Apply local firewall rules","description":"Specifies whether + local administrators are allowed to create local firewall rules that apply + together with firewall rules configured by Group Policy for the Public profile."},"defaultValue":"1"},"WindowsFirewallPublicDisplayNotifications":{"type":"String","metadata":{"displayName":"Windows + Firewall (Public): Display notifications","description":"Specifies whether + Windows Firewall with Advanced Security displays notifications to the user + when a program is blocked from receiving inbound connections, for the Public + profile."},"defaultValue":"1"},"WindowsFirewallDomainAllowUnicastResponse":{"type":"String","metadata":{"displayName":"Windows + Firewall: Domain: Allow unicast response","description":"Specifies whether + Windows Firewall with Advanced Security permits the local computer to receive + unicast responses to its outgoing multicast or broadcast messages; for the + Domain profile."},"defaultValue":"0"},"WindowsFirewallPrivateAllowUnicastResponse":{"type":"String","metadata":{"displayName":"Windows + Firewall: Private: Allow unicast response","description":"Specifies whether + Windows Firewall with Advanced Security permits the local computer to receive + unicast responses to its outgoing multicast or broadcast messages; for the + Private profile."},"defaultValue":"0"},"WindowsFirewallPublicAllowUnicastResponse":{"type":"String","metadata":{"displayName":"Windows + Firewall: Public: Allow unicast response","description":"Specifies whether + Windows Firewall with Advanced Security permits the local computer to receive + unicast responses to its outgoing multicast or broadcast messages; for the + Public profile."},"defaultValue":"1"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsFirewallProperties","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Windows + Firewall: Domain: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallDomainUseProfileSettings''), + '','', ''Windows Firewall: Domain: Outbound connections;ExpectedValue'', ''='', + parameters(''WindowsFirewallDomainBehaviorForOutboundConnections''), '','', + ''Windows Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainApplyLocalFirewallRules''), '','', + ''Windows Firewall: Domain: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainDisplayNotifications''), '','', ''Windows + Firewall: Private: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallPrivateUseProfileSettings''), + '','', ''Windows Firewall: Private: Outbound connections;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateBehaviorForOutboundConnections''), + '','', ''Windows Firewall: Private: Settings: Apply local connection security + rules;ExpectedValue'', ''='', parameters(''WindowsFirewallPrivateApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateApplyLocalFirewallRules''), '','', + ''Windows Firewall: Private: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateDisplayNotifications''), '','', + ''Windows Firewall: Public: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallPublicUseProfileSettings''), + '','', ''Windows Firewall: Public: Outbound connections;ExpectedValue'', ''='', + parameters(''WindowsFirewallPublicBehaviorForOutboundConnections''), '','', + ''Windows Firewall: Public: Settings: Apply local connection security rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicApplyLocalFirewallRules''), '','', + ''Windows Firewall: Public: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicDisplayNotifications''), '','', ''Windows + Firewall: Domain: Allow unicast response;ExpectedValue'', ''='', parameters(''WindowsFirewallDomainAllowUnicastResponse''), + '','', ''Windows Firewall: Private: Allow unicast response;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateAllowUnicastResponse''), '','', + ''Windows Firewall: Public: Allow unicast response;ExpectedValue'', ''='', + parameters(''WindowsFirewallPublicAllowUnicastResponse'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/35d9882c-993d-44e6-87d2-db66ce21b636","type":"Microsoft.Authorization/policyDefinitions","name":"35d9882c-993d-44e6-87d2-db66ce21b636"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs configurations in ''Windows Firewall Properties''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with non-compliant settings in Group Policy + category: ''Windows Firewall Properties''. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsFirewallProperties","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8bbd627e-4d25-4906-9a6e-3789780af3ec","type":"Microsoft.Authorization/policyDefinitions","name":"8bbd627e-4d25-4906-9a6e-3789780af3ec"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs configurations in ''Windows Firewall + Properties''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with non-compliant settings in Group Policy category: ''Windows Firewall Properties''. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"WindowsFirewallDomainUseProfileSettings":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Domain): Use profile settings","description":"Specifies + whether Windows Firewall with Advanced Security uses the settings for the + Domain profile to filter network traffic. If you select Off, Windows Firewall + with Advanced Security will not use any of the firewall rules or connection + security rules for this profile."},"defaultValue":"1"},"WindowsFirewallDomainBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Domain): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Domain profile that do not match + an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallDomainApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Domain): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Domain profile."},"defaultValue":"1"},"WindowsFirewallDomainApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Domain): Apply local firewall rules","description":"Specifies + whether local administrators are allowed to create local firewall rules that + apply together with firewall rules configured by Group Policy for the Domain + profile."},"defaultValue":"1"},"WindowsFirewallDomainDisplayNotifications":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Domain): Display notifications","description":"Specifies + whether Windows Firewall with Advanced Security displays notifications to + the user when a program is blocked from receiving inbound connections, for + the Domain profile."},"defaultValue":"1"},"WindowsFirewallPrivateUseProfileSettings":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Private): Use profile settings","description":"Specifies + whether Windows Firewall with Advanced Security uses the settings for the + Private profile to filter network traffic. If you select Off, Windows Firewall + with Advanced Security will not use any of the firewall rules or connection + security rules for this profile."},"defaultValue":"1"},"WindowsFirewallPrivateBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Private): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Private profile that do not + match an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallPrivateApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Private): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Private profile."},"defaultValue":"1"},"WindowsFirewallPrivateApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Private): Apply local firewall rules","description":"Specifies + whether local administrators are allowed to create local firewall rules that + apply together with firewall rules configured by Group Policy for the Private + profile."},"defaultValue":"1"},"WindowsFirewallPrivateDisplayNotifications":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Private): Display notifications","description":"Specifies + whether Windows Firewall with Advanced Security displays notifications to + the user when a program is blocked from receiving inbound connections, for + the Private profile."},"defaultValue":"1"},"WindowsFirewallPublicUseProfileSettings":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Public): Use profile settings","description":"Specifies + whether Windows Firewall with Advanced Security uses the settings for the + Public profile to filter network traffic. If you select Off, Windows Firewall + with Advanced Security will not use any of the firewall rules or connection + security rules for this profile."},"defaultValue":"1"},"WindowsFirewallPublicBehaviorForOutboundConnections":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Public): Behavior for outbound connections","description":"Specifies + the behavior for outbound connections for the Public profile that do not match + an outbound firewall rule. The default value of 0 means to allow connections, + and a value of 1 means to block connections."},"defaultValue":"0"},"WindowsFirewallPublicApplyLocalConnectionSecurityRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Public): Apply local connection security rules","description":"Specifies + whether local administrators are allowed to create connection security rules + that apply together with connection security rules configured by Group Policy + for the Public profile."},"defaultValue":"1"},"WindowsFirewallPublicApplyLocalFirewallRules":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Public): Apply local firewall rules","description":"Specifies + whether local administrators are allowed to create local firewall rules that + apply together with firewall rules configured by Group Policy for the Public + profile."},"defaultValue":"1"},"WindowsFirewallPublicDisplayNotifications":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall (Public): Display notifications","description":"Specifies + whether Windows Firewall with Advanced Security displays notifications to + the user when a program is blocked from receiving inbound connections, for + the Public profile."},"defaultValue":"1"},"WindowsFirewallDomainAllowUnicastResponse":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall: Domain: Allow unicast response","description":"Specifies + whether Windows Firewall with Advanced Security permits the local computer + to receive unicast responses to its outgoing multicast or broadcast messages; + for the Domain profile."},"defaultValue":"0"},"WindowsFirewallPrivateAllowUnicastResponse":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall: Private: Allow unicast response","description":"Specifies + whether Windows Firewall with Advanced Security permits the local computer + to receive unicast responses to its outgoing multicast or broadcast messages; + for the Private profile."},"defaultValue":"0"},"WindowsFirewallPublicAllowUnicastResponse":{"type":"String","metadata":{"displayName":"[Deprecated]: + Windows Firewall: Public: Allow unicast response","description":"Specifies + whether Windows Firewall with Advanced Security permits the local computer + to receive unicast responses to its outgoing multicast or broadcast messages; + for the Public profile."},"defaultValue":"1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AzureBaseline_WindowsFirewallProperties","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''Windows + Firewall: Domain: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallDomainUseProfileSettings''), + '','', ''Windows Firewall: Domain: Outbound connections;ExpectedValue'', ''='', + parameters(''WindowsFirewallDomainBehaviorForOutboundConnections''), '','', + ''Windows Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainApplyLocalFirewallRules''), '','', + ''Windows Firewall: Domain: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallDomainDisplayNotifications''), '','', ''Windows + Firewall: Private: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallPrivateUseProfileSettings''), + '','', ''Windows Firewall: Private: Outbound connections;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateBehaviorForOutboundConnections''), + '','', ''Windows Firewall: Private: Settings: Apply local connection security + rules;ExpectedValue'', ''='', parameters(''WindowsFirewallPrivateApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateApplyLocalFirewallRules''), '','', + ''Windows Firewall: Private: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateDisplayNotifications''), '','', + ''Windows Firewall: Public: Firewall state;ExpectedValue'', ''='', parameters(''WindowsFirewallPublicUseProfileSettings''), + '','', ''Windows Firewall: Public: Outbound connections;ExpectedValue'', ''='', + parameters(''WindowsFirewallPublicBehaviorForOutboundConnections''), '','', + ''Windows Firewall: Public: Settings: Apply local connection security rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicApplyLocalConnectionSecurityRules''), + '','', ''Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicApplyLocalFirewallRules''), '','', + ''Windows Firewall: Public: Settings: Display a notification;ExpectedValue'', + ''='', parameters(''WindowsFirewallPublicDisplayNotifications''), '','', ''Windows + Firewall: Domain: Allow unicast response;ExpectedValue'', ''='', parameters(''WindowsFirewallDomainAllowUnicastResponse''), + '','', ''Windows Firewall: Private: Allow unicast response;ExpectedValue'', + ''='', parameters(''WindowsFirewallPrivateAllowUnicastResponse''), '','', + ''Windows Firewall: Public: Allow unicast response;ExpectedValue'', ''='', + parameters(''WindowsFirewallPublicAllowUnicastResponse'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AzureBaseline_WindowsFirewallProperties"},"WindowsFirewallDomainUseProfileSettings":{"value":"[parameters(''WindowsFirewallDomainUseProfileSettings'')]"},"WindowsFirewallDomainBehaviorForOutboundConnections":{"value":"[parameters(''WindowsFirewallDomainBehaviorForOutboundConnections'')]"},"WindowsFirewallDomainApplyLocalConnectionSecurityRules":{"value":"[parameters(''WindowsFirewallDomainApplyLocalConnectionSecurityRules'')]"},"WindowsFirewallDomainApplyLocalFirewallRules":{"value":"[parameters(''WindowsFirewallDomainApplyLocalFirewallRules'')]"},"WindowsFirewallDomainDisplayNotifications":{"value":"[parameters(''WindowsFirewallDomainDisplayNotifications'')]"},"WindowsFirewallPrivateUseProfileSettings":{"value":"[parameters(''WindowsFirewallPrivateUseProfileSettings'')]"},"WindowsFirewallPrivateBehaviorForOutboundConnections":{"value":"[parameters(''WindowsFirewallPrivateBehaviorForOutboundConnections'')]"},"WindowsFirewallPrivateApplyLocalConnectionSecurityRules":{"value":"[parameters(''WindowsFirewallPrivateApplyLocalConnectionSecurityRules'')]"},"WindowsFirewallPrivateApplyLocalFirewallRules":{"value":"[parameters(''WindowsFirewallPrivateApplyLocalFirewallRules'')]"},"WindowsFirewallPrivateDisplayNotifications":{"value":"[parameters(''WindowsFirewallPrivateDisplayNotifications'')]"},"WindowsFirewallPublicUseProfileSettings":{"value":"[parameters(''WindowsFirewallPublicUseProfileSettings'')]"},"WindowsFirewallPublicBehaviorForOutboundConnections":{"value":"[parameters(''WindowsFirewallPublicBehaviorForOutboundConnections'')]"},"WindowsFirewallPublicApplyLocalConnectionSecurityRules":{"value":"[parameters(''WindowsFirewallPublicApplyLocalConnectionSecurityRules'')]"},"WindowsFirewallPublicApplyLocalFirewallRules":{"value":"[parameters(''WindowsFirewallPublicApplyLocalFirewallRules'')]"},"WindowsFirewallPublicDisplayNotifications":{"value":"[parameters(''WindowsFirewallPublicDisplayNotifications'')]"},"WindowsFirewallDomainAllowUnicastResponse":{"value":"[parameters(''WindowsFirewallDomainAllowUnicastResponse'')]"},"WindowsFirewallPrivateAllowUnicastResponse":{"value":"[parameters(''WindowsFirewallPrivateAllowUnicastResponse'')]"},"WindowsFirewallPublicAllowUnicastResponse":{"value":"[parameters(''WindowsFirewallPublicAllowUnicastResponse'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"WindowsFirewallDomainUseProfileSettings":{"type":"string"},"WindowsFirewallDomainBehaviorForOutboundConnections":{"type":"string"},"WindowsFirewallDomainApplyLocalConnectionSecurityRules":{"type":"string"},"WindowsFirewallDomainApplyLocalFirewallRules":{"type":"string"},"WindowsFirewallDomainDisplayNotifications":{"type":"string"},"WindowsFirewallPrivateUseProfileSettings":{"type":"string"},"WindowsFirewallPrivateBehaviorForOutboundConnections":{"type":"string"},"WindowsFirewallPrivateApplyLocalConnectionSecurityRules":{"type":"string"},"WindowsFirewallPrivateApplyLocalFirewallRules":{"type":"string"},"WindowsFirewallPrivateDisplayNotifications":{"type":"string"},"WindowsFirewallPublicUseProfileSettings":{"type":"string"},"WindowsFirewallPublicBehaviorForOutboundConnections":{"type":"string"},"WindowsFirewallPublicApplyLocalConnectionSecurityRules":{"type":"string"},"WindowsFirewallPublicApplyLocalFirewallRules":{"type":"string"},"WindowsFirewallPublicDisplayNotifications":{"type":"string"},"WindowsFirewallDomainAllowUnicastResponse":{"type":"string"},"WindowsFirewallPrivateAllowUnicastResponse":{"type":"string"},"WindowsFirewallPublicAllowUnicastResponse":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Windows + Firewall: Domain: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallDomainUseProfileSettings'')]"},{"name":"Windows + Firewall: Domain: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallDomainBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallDomainApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallDomainApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Domain: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallDomainDisplayNotifications'')]"},{"name":"Windows + Firewall: Private: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateUseProfileSettings'')]"},{"name":"Windows + Firewall: Private: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Private: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Private: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Private: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateDisplayNotifications'')]"},{"name":"Windows + Firewall: Public: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallPublicUseProfileSettings'')]"},{"name":"Windows + Firewall: Public: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallPublicBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Public: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallPublicApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Public: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallPublicApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Public: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallPublicDisplayNotifications'')]"},{"name":"Windows + Firewall: Domain: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallDomainAllowUnicastResponse'')]"},{"name":"Windows + Firewall: Private: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateAllowUnicastResponse'')]"},{"name":"Windows + Firewall: Public: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallPublicAllowUnicastResponse'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"Windows + Firewall: Domain: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallDomainUseProfileSettings'')]"},{"name":"Windows + Firewall: Domain: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallDomainBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallDomainApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallDomainApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Domain: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallDomainDisplayNotifications'')]"},{"name":"Windows + Firewall: Private: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateUseProfileSettings'')]"},{"name":"Windows + Firewall: Private: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Private: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Private: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Private: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateDisplayNotifications'')]"},{"name":"Windows + Firewall: Public: Firewall state;ExpectedValue","value":"[parameters(''WindowsFirewallPublicUseProfileSettings'')]"},{"name":"Windows + Firewall: Public: Outbound connections;ExpectedValue","value":"[parameters(''WindowsFirewallPublicBehaviorForOutboundConnections'')]"},{"name":"Windows + Firewall: Public: Settings: Apply local connection security rules;ExpectedValue","value":"[parameters(''WindowsFirewallPublicApplyLocalConnectionSecurityRules'')]"},{"name":"Windows + Firewall: Public: Settings: Apply local firewall rules;ExpectedValue","value":"[parameters(''WindowsFirewallPublicApplyLocalFirewallRules'')]"},{"name":"Windows + Firewall: Public: Settings: Display a notification;ExpectedValue","value":"[parameters(''WindowsFirewallPublicDisplayNotifications'')]"},{"name":"Windows + Firewall: Domain: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallDomainAllowUnicastResponse'')]"},{"name":"Windows + Firewall: Private: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallPrivateAllowUnicastResponse'')]"},{"name":"Windows + Firewall: Public: Allow unicast response;ExpectedValue","value":"[parameters(''WindowsFirewallPublicAllowUnicastResponse'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/909c958d-1b99-4c74-b88f-46a5c5bc34f9","type":"Microsoft.Authorization/policyDefinitions","name":"909c958d-1b99-4c74-b88f-46a5c5bc34f9"},{"properties":{"displayName":"Audit + Windows machines on which the Log Analytics agent is not connected as expected","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the agent is not + installed, or if it is installed but the COM object AgentConfigManager.MgmtSvcCfg + returns that it is registered to a workspace other than the ID specified in + the policy parameter.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsLogAnalyticsAgentConnection","version":"1.*","configurationParameter":{"WorkspaceId":"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"WorkspaceId":{"type":"String","metadata":{"displayName":"Connected + workspace IDs","description":"A semicolon-separated list of the workspace + IDs that the Log Analytics agent should be connected to"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsLogAnalyticsAgentConnection","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId'', + ''='', parameters(''WorkspaceId'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6265018c-d7e2-432f-a75d-094d5f6f4465","type":"Microsoft.Authorization/policyDefinitions","name":"6265018c-d7e2-432f-a75d-094d5f6f4465"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs on which the Log Analytics agent is not + connected as expected","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines on which the Log Analytics agent is not + connected to the specified workspaces. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsLogAnalyticsAgentConnection","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a030a57e-4639-4e8f-ade9-a92f33afe7ee","type":"Microsoft.Authorization/policyDefinitions","name":"a030a57e-4639-4e8f-ade9-a92f33afe7ee"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs on which the Log Analytics agent + is not connected as expected","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + on which the Log Analytics agent is not connected to the specified workspaces. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"WorkspaceId":{"type":"String","metadata":{"displayName":"[Deprecated]: + Connected workspace IDs","description":"A semicolon-separated list of the + workspace IDs that the Log Analytics agent should be connected to"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsLogAnalyticsAgentConnection","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId'', + ''='', parameters(''WorkspaceId'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsLogAnalyticsAgentConnection"},"WorkspaceId":{"value":"[parameters(''WorkspaceId'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"WorkspaceId":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId","value":"[parameters(''WorkspaceId'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId","value":"[parameters(''WorkspaceId'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/68511db2-bd02-41c4-ae6b-1900a012968a","type":"Microsoft.Authorization/policyDefinitions","name":"68511db2-bd02-41c4-ae6b-1900a012968a"},{"properties":{"displayName":"Audit + Windows machines that do not have a maximum password age of 70 days","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that do not have a maximum password age of 70 days","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"MaximumPasswordAge","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MaximumPasswordAge","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4ceb8dc2-559c-478b-a15b-733fbf1e3738","type":"Microsoft.Authorization/policyDefinitions","name":"4ceb8dc2-559c-478b-a15b-733fbf1e3738"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have a maximum password age + of 70 days","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that do not have a maximum password age of 70 days. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MaximumPasswordAge","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/24dde96d-f0b1-425e-884f-4a1421e2dcdc","type":"Microsoft.Authorization/policyDefinitions","name":"24dde96d-f0b1-425e-884f-4a1421e2dcdc"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have a maximum password + age of 70 days","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not have a maximum password age of 70 days. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MaximumPasswordAge","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"MaximumPasswordAge"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/356a906e-05e5-4625-8729-90771e0ee934","type":"Microsoft.Authorization/policyDefinitions","name":"356a906e-05e5-4625-8729-90771e0ee934"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have a minimum password age + of 1 day","policyType":"BuiltIn","mode":"All","description":"This policy should + only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that do not have a minimum password age of 1 day. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordAge","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5aa11bbc-5c76-4302-80e5-aba46a4282e7","type":"Microsoft.Authorization/policyDefinitions","name":"5aa11bbc-5c76-4302-80e5-aba46a4282e7"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have a minimum password + age of 1 day","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not have a minimum password age of 1 day. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordAge","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"MinimumPasswordAge"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/16390df4-2f73-4b42-af13-c801066763df","type":"Microsoft.Authorization/policyDefinitions","name":"16390df4-2f73-4b42-af13-c801066763df"},{"properties":{"displayName":"Audit + Windows machines that do not have the password complexity setting enabled","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that do not have the password complexity setting enabled","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"PasswordMustMeetComplexityRequirements","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordMustMeetComplexityRequirements","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bf16e0bb-31e1-4646-8202-60a235cc7e74","type":"Microsoft.Authorization/policyDefinitions","name":"bf16e0bb-31e1-4646-8202-60a235cc7e74"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have the password complexity + setting enabled","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that do not have the password complexity setting enabled. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordMustMeetComplexityRequirements","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f48b2913-1dc5-4834-8c72-ccc1dfd819bb","type":"Microsoft.Authorization/policyDefinitions","name":"f48b2913-1dc5-4834-8c72-ccc1dfd819bb"},{"properties":{"displayName":"Audit + Windows machines that do not have a minimum password age of 1 day","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that do not have a minimum password age of 1 day","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"MinimumPasswordAge","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordAge","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/237b38db-ca4d-4259-9e47-7882441ca2c0","type":"Microsoft.Authorization/policyDefinitions","name":"237b38db-ca4d-4259-9e47-7882441ca2c0"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have the password complexity + setting enabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not have the password complexity setting enabled. It also creates + a system-assigned managed identity and deploys the VM extension for Guest + Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"PasswordMustMeetComplexityRequirements","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"PasswordMustMeetComplexityRequirements"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7ed40801-8a0f-4ceb-85c0-9fd25c1d61a8","type":"Microsoft.Authorization/policyDefinitions","name":"7ed40801-8a0f-4ceb-85c0-9fd25c1d61a8"},{"properties":{"displayName":"Audit + Windows machines that do not store passwords using reversible encryption","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that do not store passwords using reversible encryption","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"StorePasswordsUsingReversibleEncryption","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"StorePasswordsUsingReversibleEncryption","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/da0f98fe-a24b-4ad5-af69-bd0400233661","type":"Microsoft.Authorization/policyDefinitions","name":"da0f98fe-a24b-4ad5-af69-bd0400233661"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not store passwords using + reversible encryption","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not store passwords using reversible encryption. It also creates a + system-assigned managed identity and deploys the VM extension for Guest Configuration. + This policy should only be used along with its corresponding audit policy + in an initiative. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"StorePasswordsUsingReversibleEncryption","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"StorePasswordsUsingReversibleEncryption"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8ff0b18b-262e-4512-857a-48ad0aeb9a78","type":"Microsoft.Authorization/policyDefinitions","name":"8ff0b18b-262e-4512-857a-48ad0aeb9a78"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not store passwords using reversible + encryption","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that do not store passwords using reversible encryption. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"StorePasswordsUsingReversibleEncryption","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2d60d3b7-aa10-454c-88a8-de39d99d17c6","type":"Microsoft.Authorization/policyDefinitions","name":"2d60d3b7-aa10-454c-88a8-de39d99d17c6"},{"properties":{"displayName":"Audit + Windows machines that allow re-use of the previous 24 passwords","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that allow re-use of the previous 24 passwords","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"EnforcePasswordHistory","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"EnforcePasswordHistory","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b054a0d-39e2-4d53-bea3-9734cad2c69b","type":"Microsoft.Authorization/policyDefinitions","name":"5b054a0d-39e2-4d53-bea3-9734cad2c69b"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that allow re-use of the previous + 24 passwords","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that allow re-use of the previous 24 passwords. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"EnforcePasswordHistory","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"EnforcePasswordHistory"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/726671ac-c4de-4908-8c7d-6043ae62e3b6","type":"Microsoft.Authorization/policyDefinitions","name":"726671ac-c4de-4908-8c7d-6043ae62e3b6"},{"properties":{"displayName":"Audit + Windows machines that do not restrict the minimum password length to 14 characters","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if Windows machines + that do not restrict the minimum password length to 14 characters","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"MinimumPasswordLength","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordLength","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a2d0e922-65d0-40c4-8f87-ea6da2d307a2","type":"Microsoft.Authorization/policyDefinitions","name":"a2d0e922-65d0-40c4-8f87-ea6da2d307a2"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that allow re-use of the previous 24 passwords","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that allow re-use of the previous 24 passwords. + For more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"EnforcePasswordHistory","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cdbf72d9-ac9c-4026-8a3a-491a5ac59293","type":"Microsoft.Authorization/policyDefinitions","name":"cdbf72d9-ac9c-4026-8a3a-491a5ac59293"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not restrict the minimum password + length to 14 characters","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that do not restrict the minimum password + length to 14 characters. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordLength","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5aebc8d1-020d-4037-89a0-02043a7524ec","type":"Microsoft.Authorization/policyDefinitions","name":"5aebc8d1-020d-4037-89a0-02043a7524ec"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not restrict the minimum + password length to 14 characters","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not restrict the minimum password length to 14 characters. It also + creates a system-assigned managed identity and deploys the VM extension for + Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"2.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"MinimumPasswordLength","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"MinimumPasswordLength"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/23020aa6-1135-4be2-bae2-149982b06eca","type":"Microsoft.Authorization/policyDefinitions","name":"23020aa6-1135-4be2-bae2-149982b06eca"},{"properties":{"displayName":"Audit + Windows VMs with a pending reboot","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the machine is pending + reboot for any of the following reasons: component based servicing, Windows + Update, pending file rename, pending computer rename, configuration manager + pending reboot. Each detection has a unique registry path.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsPendingReboot","version":"1.*"}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPendingReboot","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4221adbc-5c0f-474f-88b7-037a99e6114c","type":"Microsoft.Authorization/policyDefinitions","name":"4221adbc-5c0f-474f-88b7-037a99e6114c"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs with a pending reboot","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines with a pending reboot. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPendingReboot","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8b0de57a-f511-4d45-a277-17cb79cb163b","type":"Microsoft.Authorization/policyDefinitions","name":"8b0de57a-f511-4d45-a277-17cb79cb163b"},{"properties":{"displayName":"Audit + Windows machines that do not have the specified Windows PowerShell modules + installed","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if a module isn''t + available in a location specified by the environment variable PSModulePath.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsPowerShellModules","version":"1.*","configurationParameter":{"Modules":"[PowerShellModules]PowerShellModules1;Modules"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"Modules":{"type":"String","metadata":{"displayName":"PowerShell + Modules","description":"A semicolon-separated list of the names of the PowerShell + modules that should be installed. You may also specify a specific version + of a module that should be installed by including a comma after the module + name, followed by the desired version. Example: PSDscResources; SqlServerDsc, + 12.0.0.0; ComputerManagementDsc, 6.1.0.0"}},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellModules","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[PowerShellModules]PowerShellModules1;Modules'', + ''='', parameters(''Modules'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3e4e2bd5-15a2-4628-b3e1-58977e9793f3","type":"Microsoft.Authorization/policyDefinitions","name":"3e4e2bd5-15a2-4628-b3e1-58977e9793f3"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have the specified Windows + PowerShell execution policy","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + where Windows PowerShell is not configured to use the specified PowerShell + execution policy. It also creates a system-assigned managed identity and deploys + the VM extension for Guest Configuration. This policy should only be used + along with its corresponding audit policy in an initiative. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ExecutionPolicy":{"type":"String","metadata":{"displayName":"[Deprecated]: + PowerShell Execution Policy","description":"The expected PowerShell execution + policy."},"allowedValues":["AllSigned","Bypass","Default","RemoteSigned","Restricted","Undefined","Unrestricted"]}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellExecutionPolicy","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy'', + ''='', parameters(''ExecutionPolicy'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsPowerShellExecutionPolicy"},"ExecutionPolicy":{"value":"[parameters(''ExecutionPolicy'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ExecutionPolicy":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy","value":"[parameters(''ExecutionPolicy'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy","value":"[parameters(''ExecutionPolicy'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e0efc13a-122a-47c5-b817-2ccfe5d12615","type":"Microsoft.Authorization/policyDefinitions","name":"e0efc13a-122a-47c5-b817-2ccfe5d12615"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs with a pending reboot","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + with a pending reboot. It also creates a system-assigned managed identity + and deploys the VM extension for Guest Configuration. This policy should only + be used along with its corresponding audit policy in an initiative. For more + information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPendingReboot","deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsPendingReboot"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*"}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c96f3246-4382-4264-bf6b-af0b35e23c3c","type":"Microsoft.Authorization/policyDefinitions","name":"c96f3246-4382-4264-bf6b-af0b35e23c3c"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have the specified Windows + PowerShell execution policy","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines where Windows PowerShell is not configured + to use the specified PowerShell execution policy. For more information on + Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellExecutionPolicy","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f8036bd0-c10b-4931-86bb-94a878add855","type":"Microsoft.Authorization/policyDefinitions","name":"f8036bd0-c10b-4931-86bb-94a878add855"},{"properties":{"displayName":"Audit + Windows machines that do not have the specified Windows PowerShell execution + policy","policyType":"BuiltIn","mode":"Indexed","description":"Requires that + prerequisites are deployed to the policy assignment scope. For details, visit + https://aka.ms/gcpol. Machines are non-compliant if the Windows PowerShell + command Get-ExecutionPolicy returns a value other than what was selected in + the policy parameter.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsPowerShellExecutionPolicy","version":"1.*","configurationParameter":{"ExecutionPolicy":"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ExecutionPolicy":{"type":"String","metadata":{"displayName":"PowerShell + Execution Policy","description":"The expected PowerShell execution policy."},"allowedValues":["AllSigned","Bypass","Default","RemoteSigned","Restricted","Undefined","Unrestricted"]},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of this policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellExecutionPolicy","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy'', + ''='', parameters(''ExecutionPolicy'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c648fbbb-591c-4acd-b465-ce9b176ca173","type":"Microsoft.Authorization/policyDefinitions","name":"c648fbbb-591c-4acd-b465-ce9b176ca173"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that do not have the specified Windows + PowerShell modules installed","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines that do not have the specified Windows PowerShell + modules installed. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellModules","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/16f9b37c-4408-4c30-bc17-254958f2e2d6","type":"Microsoft.Authorization/policyDefinitions","name":"16f9b37c-4408-4c30-bc17-254958f2e2d6"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that do not have the specified Windows + PowerShell modules installed","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + that do not have the specified Windows PowerShell modules installed. It also + creates a system-assigned managed identity and deploys the VM extension for + Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"Modules":{"type":"String","metadata":{"displayName":"[Deprecated]: + PowerShell Modules","description":"A semicolon-separated list of the names + of the PowerShell modules that should be installed. You may also specify a + specific version of a module that should be installed by including a comma + after the module name, followed by the desired version. e.g. PSDscResources; + SqlServerDsc, 12.0.0.0; ComputerManagementDsc, 6.1.0.0"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsPowerShellModules","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[PowerShellModules]PowerShellModules1;Modules'', + ''='', parameters(''Modules'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsPowerShellModules"},"Modules":{"value":"[parameters(''Modules'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"Modules":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[PowerShellModules]PowerShellModules1;Modules","value":"[parameters(''Modules'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[PowerShellModules]PowerShellModules1;Modules","value":"[parameters(''Modules'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/90ba2ee7-4ca8-4673-84d1-c851c50d3baf","type":"Microsoft.Authorization/policyDefinitions","name":"90ba2ee7-4ca8-4673-84d1-c851c50d3baf"},{"properties":{"displayName":"Audit + Windows machines network connectivity","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if a network connection + status to an IP and TCP port does not match the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsRemoteConnection","version":"1.*","configurationParameter":{"host":"[WindowsRemoteConnection]WindowsRemoteConnection1;host","port":"[WindowsRemoteConnection]WindowsRemoteConnection1;port","shouldConnect":"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"host":{"type":"String","metadata":{"displayName":"Remote + Host Name","description":"Specifies the Domain Name System (DNS) name or IP + address of the remote host machine."}},"port":{"type":"String","metadata":{"displayName":"Port","description":"The + TCP port number on the remote host name."}},"shouldConnect":{"type":"String","metadata":{"displayName":"Should + connect to remote host","description":"The machine will be non-compliant if + it can''t establish a connection."},"allowedValues":["True","False"],"defaultValue":"False"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsRemoteConnection","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsRemoteConnection]WindowsRemoteConnection1;host'', + ''='', parameters(''host''), '','', ''[WindowsRemoteConnection]WindowsRemoteConnection1;port'', + ''='', parameters(''port''), '','', ''[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect'', + ''='', parameters(''shouldConnect'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/630ac30f-a234-4533-ac2d-e0df77acda51","type":"Microsoft.Authorization/policyDefinitions","name":"630ac30f-a234-4533-ac2d-e0df77acda51"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs on which the remote connection status + does not match the specified one","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines on which the remote host connection status + does not match the specified one. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsRemoteConnection","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/02a84be7-c304-421f-9bb7-5d2c26af54ad","type":"Microsoft.Authorization/policyDefinitions","name":"02a84be7-c304-421f-9bb7-5d2c26af54ad"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs on which the remote connection status + does not match the specified one","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + on which the remote host connection status does not match the specified one. + It also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"host":{"type":"String","metadata":{"displayName":"[Deprecated]: + Remote Host Name","description":"Specifies the Domain Name System (DNS) name + or IP address of the remote host machine."}},"port":{"type":"String","metadata":{"displayName":"[Deprecated]: + Port","description":"The TCP port number on the remote host name."}},"shouldConnect":{"type":"String","metadata":{"displayName":"[Deprecated]: + Should connect to remote host","description":"Must be ''True'' or ''False''. + ''True'' indicates that the virtual machine should be able to establish a + connection with the remote host specified, so the machine will be non-compliant + if it cannot establish a connection. ''False'' indicates that the virtual + machine should not be able to establish a connection with the remote host + specified, so the machine will be non-compliant if it can establish a connection."},"allowedValues":["True","False"],"defaultValue":"False"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsRemoteConnection","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsRemoteConnection]WindowsRemoteConnection1;host'', + ''='', parameters(''host''), '','', ''[WindowsRemoteConnection]WindowsRemoteConnection1;port'', + ''='', parameters(''port''), '','', ''[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect'', + ''='', parameters(''shouldConnect'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsRemoteConnection"},"host":{"value":"[parameters(''host'')]"},"port":{"value":"[parameters(''port'')]"},"shouldConnect":{"value":"[parameters(''shouldConnect'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"host":{"type":"string"},"port":{"type":"string"},"shouldConnect":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;host","value":"[parameters(''host'')]"},{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;port","value":"[parameters(''port'')]"},{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect","value":"[parameters(''shouldConnect'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;host","value":"[parameters(''host'')]"},{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;port","value":"[parameters(''port'')]"},{"name":"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect","value":"[parameters(''shouldConnect'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5bb36dda-8a78-4df9-affd-4f05a8612a8a","type":"Microsoft.Authorization/policyDefinitions","name":"5bb36dda-8a78-4df9-affd-4f05a8612a8a"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows Server VMs on which Windows Serial Console + is not enabled","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + Server virtual machines on which Windows Serial Console is not enabled. For + more information on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsSerialConsole","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d7ccd0ca-8d78-42af-a43d-6b7f928accbc","type":"Microsoft.Authorization/policyDefinitions","name":"d7ccd0ca-8d78-42af-a43d-6b7f928accbc"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs on which the specified services are not + installed and ''Running''","policyType":"BuiltIn","mode":"All","description":"This + policy should only be used along with its corresponding deploy policy in an + initiative. This definition allows Azure Policy to process the results of + auditing Windows virtual machines on which the specified services are not + installed and ''Running''. For more information on Guest Configuration policies, + please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsServiceStatus","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c2dd2a9a-8a20-4a9c-b8d6-f17ccc26939a","type":"Microsoft.Authorization/policyDefinitions","name":"c2dd2a9a-8a20-4a9c-b8d6-f17ccc26939a"},{"properties":{"displayName":"Audit + Windows machines on which Windows Serial Console is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the machine does + not have the Serial Console software installed or if the EMS port number or + baud rate are not configured with the same values as the policy parameters.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsSerialConsole","version":"1.*","configurationParameter":{"EMSPortNumber":"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber","EMSBaudRate":"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"EMSPortNumber":{"type":"String","metadata":{"displayName":"EMS + Port Number","description":"An integer indicating the COM port to be used + for the Emergency Management Services (EMS) console redirection. For more + information on EMS settings, please visit https://aka.ms/gcpolwsc"},"allowedValues":["1","2","3","4"],"defaultValue":"1"},"EMSBaudRate":{"type":"String","metadata":{"displayName":"EMS + Baud Rate","description":"An integer indicating the baud rate to be used for + the Emergency Management Services (EMS) console redirection. For more information + on EMS settings, please visit https://aka.ms/gcpolwsc"},"allowedValues":["9600","19200","38400","57600","115200"],"defaultValue":"115200"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsSerialConsole","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber'', + ''='', parameters(''EMSPortNumber''), '','', ''[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate'', + ''='', parameters(''EMSBaudRate'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/58c460e9-7573-4bb2-9676-339c2f2486bb","type":"Microsoft.Authorization/policyDefinitions","name":"58c460e9-7573-4bb2-9676-339c2f2486bb"},{"properties":{"displayName":"Audit + Windows machines on which the specified services are not installed and ''Running''","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if result of the Windows + PowerShell command Get-Service do not include the service name with matching + status as specified by the policy parameter.","metadata":{"category":"Guest + Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsServiceStatus","version":"1.*","configurationParameter":{"ServiceName":"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"ServiceName":{"type":"String","metadata":{"displayName":"Service + names (supports wildcards)","description":"A semicolon-separated list of the + names of the services that should be installed and ''Running''. e.g. ''WinRm;Wi*''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsServiceStatus","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsServiceStatus]WindowsServiceStatus1;ServiceName'', + ''='', parameters(''ServiceName'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e6ebf138-3d71-4935-a13b-9c7fdddd94df","type":"Microsoft.Authorization/policyDefinitions","name":"e6ebf138-3d71-4935-a13b-9c7fdddd94df"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs on which the specified services + are not installed and ''Running''","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows virtual machines + on which the specified services are not installed and ''Running''. It also + creates a system-assigned managed identity and deploys the VM extension for + Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"ServiceName":{"type":"String","metadata":{"displayName":"[Deprecated]: + Service names (supports wildcards)","description":"A semicolon-separated list + of the names of the services that should be installed and ''Running''. e.g. + ''WinRm;Wi*''"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsServiceStatus","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsServiceStatus]WindowsServiceStatus1;ServiceName'', + ''='', parameters(''ServiceName'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsServiceStatus"},"ServiceName":{"value":"[parameters(''ServiceName'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"ServiceName":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName","value":"[parameters(''ServiceName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName","value":"[parameters(''ServiceName'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/32b1e4d4-6cd5-47b4-a935-169da8a5c262","type":"Microsoft.Authorization/policyDefinitions","name":"32b1e4d4-6cd5-47b4-a935-169da8a5c262"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows Server VMs on which Windows Serial Console + is not enabled","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows Server virtual + machines on which Windows Serial Console is not enabled. It also creates a + system-assigned managed identity and deploys the VM extension for Guest Configuration. + This policy should only be used along with its corresponding audit policy + in an initiative. For more information on Guest Configuration policies, please + visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"EMSPortNumber":{"type":"String","metadata":{"displayName":"[Deprecated]: + EMS Port Number","description":"An integer indicating the COM port to be used + for the Emergency Management Services (EMS) console redirection. For more + information on EMS settings, please visit https://aka.ms/gcpolwsc"},"allowedValues":["1","2","3","4"],"defaultValue":"1"},"EMSBaudRate":{"type":"String","metadata":{"displayName":"[Deprecated]: + EMS Baud Rate","description":"An integer indicating the baud rate to be used + for the Emergency Management Services (EMS) console redirection. For more + information on EMS settings, please visit https://aka.ms/gcpolwsc"},"allowedValues":["9600","19200","38400","57600","115200"],"defaultValue":"115200"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsSerialConsole","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber'', + ''='', parameters(''EMSPortNumber''), '','', ''[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate'', + ''='', parameters(''EMSBaudRate'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsSerialConsole"},"EMSPortNumber":{"value":"[parameters(''EMSPortNumber'')]"},"EMSBaudRate":{"value":"[parameters(''EMSBaudRate'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"EMSPortNumber":{"type":"string"},"EMSBaudRate":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber","value":"[parameters(''EMSPortNumber'')]"},{"name":"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate","value":"[parameters(''EMSBaudRate'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber","value":"[parameters(''EMSPortNumber'')]"},{"name":"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate","value":"[parameters(''EMSBaudRate'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7a031c68-d6ab-406e-a506-697a19c634b0","type":"Microsoft.Authorization/policyDefinitions","name":"7a031c68-d6ab-406e-a506-697a19c634b0"},{"properties":{"displayName":"Audit + Windows machines that are not set to the specified time zone","policyType":"BuiltIn","mode":"Indexed","description":"Requires + that prerequisites are deployed to the policy assignment scope. For details, + visit https://aka.ms/gcpol. Machines are non-compliant if the value of the + property StandardName in WMI class Win32_TimeZone does not match the selected + time zone for the policy parameter.","metadata":{"category":"Guest Configuration","version":"1.0.0","requiredProviders":["Microsoft.GuestConfiguration"],"guestConfiguration":{"name":"WindowsTimeZone","version":"1.*","configurationParameter":{"TimeZone":"[WindowsTimeZone]WindowsTimeZone1;TimeZone"}}},"parameters":{"IncludeArcMachines":{"type":"String","metadata":{"displayName":"Include + Arc connected servers","description":"By selecting this option, you agree + to be charged monthly per Arc connected machine."},"allowedValues":["true","false"],"defaultValue":"false"},"TimeZone":{"type":"String","metadata":{"displayName":"Time + zone","description":"The expected time zone"},"allowedValues":["(UTC-12:00) + International Date Line West","(UTC-11:00) Coordinated Universal Time-11","(UTC-10:00) + Aleutian Islands","(UTC-10:00) Hawaii","(UTC-09:30) Marquesas Islands","(UTC-09:00) + Alaska","(UTC-09:00) Coordinated Universal Time-09","(UTC-08:00) Baja California","(UTC-08:00) + Coordinated Universal Time-08","(UTC-08:00) Pacific Time (US & Canada)","(UTC-07:00) + Arizona","(UTC-07:00) Chihuahua, La Paz, Mazatlan","(UTC-07:00) Mountain Time + (US & Canada)","(UTC-06:00) Central America","(UTC-06:00) Central Time (US + & Canada)","(UTC-06:00) Easter Island","(UTC-06:00) Guadalajara, Mexico City, + Monterrey","(UTC-06:00) Saskatchewan","(UTC-05:00) Bogota, Lima, Quito, Rio + Branco","(UTC-05:00) Chetumal","(UTC-05:00) Eastern Time (US & Canada)","(UTC-05:00) + Haiti","(UTC-05:00) Havana","(UTC-05:00) Indiana (East)","(UTC-05:00) Turks + and Caicos","(UTC-04:00) Asuncion","(UTC-04:00) Atlantic Time (Canada)","(UTC-04:00) + Caracas","(UTC-04:00) Cuiaba","(UTC-04:00) Georgetown, La Paz, Manaus, San + Juan","(UTC-04:00) Santiago","(UTC-03:30) Newfoundland","(UTC-03:00) Araguaina","(UTC-03:00) + Brasilia","(UTC-03:00) Cayenne, Fortaleza","(UTC-03:00) City of Buenos Aires","(UTC-03:00) + Greenland","(UTC-03:00) Montevideo","(UTC-03:00) Punta Arenas","(UTC-03:00) + Saint Pierre and Miquelon","(UTC-03:00) Salvador","(UTC-02:00) Coordinated + Universal Time-02","(UTC-02:00) Mid-Atlantic - Old","(UTC-01:00) Azores","(UTC-01:00) + Cabo Verde Is.","(UTC) Coordinated Universal Time","(UTC+00:00) Dublin, Edinburgh, + Lisbon, London","(UTC+00:00) Monrovia, Reykjavik","(UTC+00:00) Sao Tome","(UTC+01:00) + Casablanca","(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna","(UTC+01:00) + Belgrade, Bratislava, Budapest, Ljubljana, Prague","(UTC+01:00) Brussels, + Copenhagen, Madrid, Paris","(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb","(UTC+01:00) + West Central Africa","(UTC+02:00) Amman","(UTC+02:00) Athens, Bucharest","(UTC+02:00) + Beirut","(UTC+02:00) Cairo","(UTC+02:00) Chisinau","(UTC+02:00) Damascus","(UTC+02:00) + Gaza, Hebron","(UTC+02:00) Harare, Pretoria","(UTC+02:00) Helsinki, Kyiv, + Riga, Sofia, Tallinn, Vilnius","(UTC+02:00) Jerusalem","(UTC+02:00) Kaliningrad","(UTC+02:00) + Khartoum","(UTC+02:00) Tripoli","(UTC+02:00) Windhoek","(UTC+03:00) Baghdad","(UTC+03:00) + Istanbul","(UTC+03:00) Kuwait, Riyadh","(UTC+03:00) Minsk","(UTC+03:00) Moscow, + St. Petersburg","(UTC+03:00) Nairobi","(UTC+03:30) Tehran","(UTC+04:00) Abu + Dhabi, Muscat","(UTC+04:00) Astrakhan, Ulyanovsk","(UTC+04:00) Baku","(UTC+04:00) + Izhevsk, Samara","(UTC+04:00) Port Louis","(UTC+04:00) Saratov","(UTC+04:00) + Tbilisi","(UTC+04:00) Volgograd","(UTC+04:00) Yerevan","(UTC+04:30) Kabul","(UTC+05:00) + Ashgabat, Tashkent","(UTC+05:00) Ekaterinburg","(UTC+05:00) Islamabad, Karachi","(UTC+05:00) + Qyzylorda","(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi","(UTC+05:30) + Sri Jayawardenepura","(UTC+05:45) Kathmandu","(UTC+06:00) Astana","(UTC+06:00) + Dhaka","(UTC+06:00) Omsk","(UTC+06:30) Yangon (Rangoon)","(UTC+07:00) Bangkok, + Hanoi, Jakarta","(UTC+07:00) Barnaul, Gorno-Altaysk","(UTC+07:00) Hovd","(UTC+07:00) + Krasnoyarsk","(UTC+07:00) Novosibirsk","(UTC+07:00) Tomsk","(UTC+08:00) Beijing, + Chongqing, Hong Kong, Urumqi","(UTC+08:00) Irkutsk","(UTC+08:00) Kuala Lumpur, + Singapore","(UTC+08:00) Perth","(UTC+08:00) Taipei","(UTC+08:00) Ulaanbaatar","(UTC+08:45) + Eucla","(UTC+09:00) Chita","(UTC+09:00) Osaka, Sapporo, Tokyo","(UTC+09:00) + Pyongyang","(UTC+09:00) Seoul","(UTC+09:00) Yakutsk","(UTC+09:30) Adelaide","(UTC+09:30) + Darwin","(UTC+10:00) Brisbane","(UTC+10:00) Canberra, Melbourne, Sydney","(UTC+10:00) + Guam, Port Moresby","(UTC+10:00) Hobart","(UTC+10:00) Vladivostok","(UTC+10:30) + Lord Howe Island","(UTC+11:00) Bougainville Island","(UTC+11:00) Chokurdakh","(UTC+11:00) + Magadan","(UTC+11:00) Norfolk Island","(UTC+11:00) Sakhalin","(UTC+11:00) + Solomon Is., New Caledonia","(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky","(UTC+12:00) + Auckland, Wellington","(UTC+12:00) Coordinated Universal Time+12","(UTC+12:00) + Fiji","(UTC+12:00) Petropavlovsk-Kamchatsky - Old","(UTC+12:45) Chatham Islands","(UTC+13:00) + Coordinated Universal Time+13","(UTC+13:00) Nuku''alofa","(UTC+13:00) Samoa","(UTC+14:00) + Kiritimati Island"]}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"value":"[parameters(''IncludeArcMachines'')]","equals":"true"},{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsTimeZone","existenceCondition":{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"},{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsTimeZone]WindowsTimeZone1;TimeZone'', + ''='', parameters(''TimeZone'')))]"}]}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c633f6a2-7f8b-4d9e-9456-02f0f04f5505","type":"Microsoft.Authorization/policyDefinitions","name":"c633f6a2-7f8b-4d9e-9456-02f0f04f5505"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows VMs that are not set to the specified time + zone","policyType":"BuiltIn","mode":"All","description":"This policy should + only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + virtual machines that are not set to the specified time zone. For more information + on Guest Configuration policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsTimeZone","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9f658460-46b7-43af-8565-94fc0662be38","type":"Microsoft.Authorization/policyDefinitions","name":"9f658460-46b7-43af-8565-94fc0662be38"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows VMs that are not set to the specified + time zone","policyType":"BuiltIn","mode":"Indexed","description":"This policy + creates a Guest Configuration assignment to audit Windows virtual machines + that are not set to the specified time zone. It also creates a system-assigned + managed identity and deploys the VM extension for Guest Configuration. This + policy should only be used along with its corresponding audit policy in an + initiative. For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"TimeZone":{"type":"String","metadata":{"displayName":"[Deprecated]: + Time zone","description":"The expected time zone"},"allowedValues":["(UTC-12:00) + International Date Line West","(UTC-11:00) Coordinated Universal Time-11","(UTC-10:00) + Aleutian Islands","(UTC-10:00) Hawaii","(UTC-09:30) Marquesas Islands","(UTC-09:00) + Alaska","(UTC-09:00) Coordinated Universal Time-09","(UTC-08:00) Baja California","(UTC-08:00) + Coordinated Universal Time-08","(UTC-08:00) Pacific Time (US & Canada)","(UTC-07:00) + Arizona","(UTC-07:00) Chihuahua, La Paz, Mazatlan","(UTC-07:00) Mountain Time + (US & Canada)","(UTC-06:00) Central America","(UTC-06:00) Central Time (US + & Canada)","(UTC-06:00) Easter Island","(UTC-06:00) Guadalajara, Mexico City, + Monterrey","(UTC-06:00) Saskatchewan","(UTC-05:00) Bogota, Lima, Quito, Rio + Branco","(UTC-05:00) Chetumal","(UTC-05:00) Eastern Time (US & Canada)","(UTC-05:00) + Haiti","(UTC-05:00) Havana","(UTC-05:00) Indiana (East)","(UTC-05:00) Turks + and Caicos","(UTC-04:00) Asuncion","(UTC-04:00) Atlantic Time (Canada)","(UTC-04:00) + Caracas","(UTC-04:00) Cuiaba","(UTC-04:00) Georgetown, La Paz, Manaus, San + Juan","(UTC-04:00) Santiago","(UTC-03:30) Newfoundland","(UTC-03:00) Araguaina","(UTC-03:00) + Brasilia","(UTC-03:00) Cayenne, Fortaleza","(UTC-03:00) City of Buenos Aires","(UTC-03:00) + Greenland","(UTC-03:00) Montevideo","(UTC-03:00) Punta Arenas","(UTC-03:00) + Saint Pierre and Miquelon","(UTC-03:00) Salvador","(UTC-02:00) Coordinated + Universal Time-02","(UTC-02:00) Mid-Atlantic - Old","(UTC-01:00) Azores","(UTC-01:00) + Cabo Verde Is.","(UTC) Coordinated Universal Time","(UTC+00:00) Dublin, Edinburgh, + Lisbon, London","(UTC+00:00) Monrovia, Reykjavik","(UTC+00:00) Sao Tome","(UTC+01:00) + Casablanca","(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna","(UTC+01:00) + Belgrade, Bratislava, Budapest, Ljubljana, Prague","(UTC+01:00) Brussels, + Copenhagen, Madrid, Paris","(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb","(UTC+01:00) + West Central Africa","(UTC+02:00) Amman","(UTC+02:00) Athens, Bucharest","(UTC+02:00) + Beirut","(UTC+02:00) Cairo","(UTC+02:00) Chisinau","(UTC+02:00) Damascus","(UTC+02:00) + Gaza, Hebron","(UTC+02:00) Harare, Pretoria","(UTC+02:00) Helsinki, Kyiv, + Riga, Sofia, Tallinn, Vilnius","(UTC+02:00) Jerusalem","(UTC+02:00) Kaliningrad","(UTC+02:00) + Khartoum","(UTC+02:00) Tripoli","(UTC+02:00) Windhoek","(UTC+03:00) Baghdad","(UTC+03:00) + Istanbul","(UTC+03:00) Kuwait, Riyadh","(UTC+03:00) Minsk","(UTC+03:00) Moscow, + St. Petersburg","(UTC+03:00) Nairobi","(UTC+03:30) Tehran","(UTC+04:00) Abu + Dhabi, Muscat","(UTC+04:00) Astrakhan, Ulyanovsk","(UTC+04:00) Baku","(UTC+04:00) + Izhevsk, Samara","(UTC+04:00) Port Louis","(UTC+04:00) Saratov","(UTC+04:00) + Tbilisi","(UTC+04:00) Volgograd","(UTC+04:00) Yerevan","(UTC+04:30) Kabul","(UTC+05:00) + Ashgabat, Tashkent","(UTC+05:00) Ekaterinburg","(UTC+05:00) Islamabad, Karachi","(UTC+05:00) + Qyzylorda","(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi","(UTC+05:30) + Sri Jayawardenepura","(UTC+05:45) Kathmandu","(UTC+06:00) Astana","(UTC+06:00) + Dhaka","(UTC+06:00) Omsk","(UTC+06:30) Yangon (Rangoon)","(UTC+07:00) Bangkok, + Hanoi, Jakarta","(UTC+07:00) Barnaul, Gorno-Altaysk","(UTC+07:00) Hovd","(UTC+07:00) + Krasnoyarsk","(UTC+07:00) Novosibirsk","(UTC+07:00) Tomsk","(UTC+08:00) Beijing, + Chongqing, Hong Kong, Urumqi","(UTC+08:00) Irkutsk","(UTC+08:00) Kuala Lumpur, + Singapore","(UTC+08:00) Perth","(UTC+08:00) Taipei","(UTC+08:00) Ulaanbaatar","(UTC+08:45) + Eucla","(UTC+09:00) Chita","(UTC+09:00) Osaka, Sapporo, Tokyo","(UTC+09:00) + Pyongyang","(UTC+09:00) Seoul","(UTC+09:00) Yakutsk","(UTC+09:30) Adelaide","(UTC+09:30) + Darwin","(UTC+10:00) Brisbane","(UTC+10:00) Canberra, Melbourne, Sydney","(UTC+10:00) + Guam, Port Moresby","(UTC+10:00) Hobart","(UTC+10:00) Vladivostok","(UTC+10:30) + Lord Howe Island","(UTC+11:00) Bougainville Island","(UTC+11:00) Chokurdakh","(UTC+11:00) + Magadan","(UTC+11:00) Norfolk Island","(UTC+11:00) Sakhalin","(UTC+11:00) + Solomon Is., New Caledonia","(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky","(UTC+12:00) + Auckland, Wellington","(UTC+12:00) Coordinated Universal Time+12","(UTC+12:00) + Fiji","(UTC+12:00) Petropavlovsk-Kamchatsky - Old","(UTC+12:45) Chatham Islands","(UTC+13:00) + Coordinated Universal Time+13","(UTC+13:00) Nuku''alofa","(UTC+13:00) Samoa","(UTC+14:00) + Kiritimati Island"]}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"WindowsTimeZone","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[WindowsTimeZone]WindowsTimeZone1;TimeZone'', + ''='', parameters(''TimeZone'')))]"},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"WindowsTimeZone"},"TimeZone":{"value":"[parameters(''TimeZone'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"TimeZone":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsTimeZone]WindowsTimeZone1;TimeZone","value":"[parameters(''TimeZone'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[WindowsTimeZone]WindowsTimeZone1;TimeZone","value":"[parameters(''TimeZone'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c21f7060-c148-41cf-a68b-0ab3e14c764c","type":"Microsoft.Authorization/policyDefinitions","name":"c21f7060-c148-41cf-a68b-0ab3e14c764c"},{"properties":{"displayName":"[Deprecated]: + Show audit results from Windows web servers that are not using secure communication + protocols","policyType":"BuiltIn","mode":"All","description":"This policy + should only be used along with its corresponding deploy policy in an initiative. + This definition allows Azure Policy to process the results of auditing Windows + web servers that are not using secure communication protocols (TLS 1.1 or + TLS 1.2). For more information on Guest Configuration policies, please visit + https://aka.ms/gcpol","metadata":{"version":"1.0.0-deprecated","category":"Guest + Configuration","deprecated":true},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"auditIfNotExists","details":{"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AuditSecureProtocol","existenceCondition":{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus","equals":"Compliant"}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/60ffe3e2-4604-4460-8f22-0f1da058266c","type":"Microsoft.Authorization/policyDefinitions","name":"60ffe3e2-4604-4460-8f22-0f1da058266c"},{"properties":{"displayName":"[Deprecated]: + Deploy prerequisites to audit Windows web servers that are not using secure + communication protocols","policyType":"BuiltIn","mode":"Indexed","description":"This + policy creates a Guest Configuration assignment to audit Windows web servers + that are not using secure communication protocols (TLS 1.1 or TLS 1.2). It + also creates a system-assigned managed identity and deploys the VM extension + for Guest Configuration. This policy should only be used along with its corresponding + audit policy in an initiative. For more information on Guest Configuration + policies, please visit https://aka.ms/gcpol","metadata":{"version":"1.2.0-deprecated","category":"Guest + Configuration","requiredProviders":["Microsoft.GuestConfiguration"],"deprecated":true},"parameters":{"MinimumTLSVersion":{"type":"String","metadata":{"displayName":"[Deprecated]: + Minimum TLS version","description":"The minimum TLS protocol version that + should be enabled. Windows web servers with lower TLS versions will be marked + as non-compliant."},"allowedValues":["1.1","1.2"],"defaultValue":"1.1"}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyOf":[{"field":"Microsoft.Compute/imagePublisher","in":["esri","incredibuild","MicrosoftDynamicsAX","MicrosoftSharepoint","MicrosoftVisualStudio","MicrosoftWindowsDesktop","MicrosoftWindowsServerHPCPack"]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"},{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","equals":"dsvm-windows"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["standard-data-science-vm","windows-data-science-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","equals":"rendering-windows2016"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","like":"cis-windows-server-201*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","like":"bosh-windows-server*"}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","like":"ad*"}]},{"allOf":[{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType","like":"Windows*"}]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","exists":"false"},{"allOf":[{"field":"Microsoft.Compute/imageSKU","notLike":"2008*"},{"field":"Microsoft.Compute/imageOffer","notLike":"SQL2008*"}]}]}]}]}]},{"allOf":[{"field":"type","equals":"Microsoft.HybridCompute/machines"},{"field":"Microsoft.HybridCompute/imageOffer","like":"windows*"}]}]},"then":{"effect":"deployIfNotExists","details":{"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"type":"Microsoft.GuestConfiguration/guestConfigurationAssignments","name":"AuditSecureProtocol","existenceCondition":{"anyOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":"[base64(concat(''[SecureWebServer]s1;MinimumTLSVersion'', + ''='', parameters(''MinimumTLSVersion'')))]"},{"allOf":[{"field":"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash","equals":""},{"value":"[parameters(''MinimumTLSVersion'')]","equals":"1.1"}]}]},"deployment":{"properties":{"mode":"incremental","parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"},"type":{"value":"[field(''type'')]"},"configurationName":{"value":"AuditSecureProtocol"},"MinimumTLSVersion":{"value":"[parameters(''MinimumTLSVersion'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"},"type":{"type":"string"},"configurationName":{"type":"string"},"MinimumTLSVersion":{"type":"string"}},"resources":[{"condition":"[equals(toLower(parameters(''type'')), + toLower(''microsoft.hybridcompute/machines''))]","apiVersion":"2018-11-20","type":"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[SecureWebServer]s1;MinimumTLSVersion","value":"[parameters(''MinimumTLSVersion'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2018-11-20","type":"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments","name":"[concat(parameters(''vmName''), + ''/Microsoft.GuestConfiguration/'', parameters(''configurationName''))]","location":"[parameters(''location'')]","properties":{"guestConfiguration":{"name":"[parameters(''configurationName'')]","version":"1.*","configurationParameter":[{"name":"[SecureWebServer]s1;MinimumTLSVersion","value":"[parameters(''MinimumTLSVersion'')]"}]}}},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","identity":{"type":"SystemAssigned"},"name":"[parameters(''vmName'')]","location":"[parameters(''location'')]"},{"condition":"[equals(toLower(parameters(''type'')), + toLower(''Microsoft.Compute/virtualMachines''))]","apiVersion":"2019-07-01","name":"[concat(parameters(''vmName''), + ''/AzurePolicyforWindows'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.GuestConfiguration","type":"ConfigurationforWindows","typeHandlerVersion":"1.1","autoUpgradeMinorVersion":true,"settings":{},"protectedSettings":{}},"dependsOn":["[concat(''Microsoft.Compute/virtualMachines/'',parameters(''vmName''),''/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/'',parameters(''configurationName''))]"]}]}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b2fc8f91-866d-4434-9089-5ebfe38d6fd8","type":"Microsoft.Authorization/policyDefinitions","name":"b2fc8f91-866d-4434-9089-5ebfe38d6fd8"},{"properties":{"displayName":"[Preview]: + Deploy GitOps to Kubernetes cluster","policyType":"BuiltIn","mode":"All","description":"This + policy deploys a ''sourceControlConfiguration'' to Kubernetes clusters to + assure that the clusters get their source of truth from the defined git repo. + For instructions on using this policy, visit https://aka.ms/K8sGitOpsPolicy.","metadata":{"preview":true,"version":"1.0.0-preview","category":"Kubernetes"},"parameters":{"configurationResourceName":{"type":"String","metadata":{"displayName":"[Preview]: + Configuration resource name","description":"The name for the sourceControlConfiguration. Learn + more about setting up GitOps configuration: https://aka.ms/AzureArcK8sUsingGitOps."}},"operatorInstanceName":{"type":"String","metadata":{"displayName":"[Preview]: + Operator instance name","description":"The name of the operator associated + with this configuration. The instance name can contain up to 353 lower-case + alphanumeric characters, hyphen, or period. If enableHelmOperator is true, + then operatorInstanceName + operatorNamespace strings cannot exceed 47 characters + combined."}},"operatorNamespace":{"type":"String","metadata":{"displayName":"[Preview]: + Operator namespace","description":"The namespace to use for the configuration + operator. The namespace can contain up to 353 lower-case alphanumeric characters, + hyphen, or period. If enableHelmOperator is true, then operatorInstanceName + + operatorNamespace strings cannot exceed 47 characters combined."}},"operatorScope":{"type":"String","metadata":{"displayName":"[Preview]: + Operator scope","description":"The permission scope for the operator. Possible + values are ''cluster'' (full access) or ''namespace'' (restricted access)."},"allowedValues":["cluster","namespace"],"defaultValue":"namespace"},"operatorType":{"type":"String","metadata":{"displayName":"[Preview]: + Operator type","description":"The type of operator to install. Currently, + ''Flux'' is supported."},"allowedValues":["Flux"],"defaultValue":"Flux"},"operatorParams":{"type":"String","metadata":{"displayName":"[Preview]: + Operator parameters","description":"Parameters to set on the Flux operator, + separated by spaces. For example, --git-readonly --git-path=namespaces,workloads. Learn + more: http://aka.ms/AzureArcK8sFluxOperatorParams."},"defaultValue":""},"repositoryUrl":{"type":"String","metadata":{"displayName":"[Preview]: + Repository Url","description":"The URL for the source control repository. + Private repo: git@github.com:Contoso/cluster-config"}},"enableHelmOperator":{"type":"String","metadata":{"displayName":"[Preview]: + Enable Helm","description":"Indicate whether to enable Helm for this instance + of Flux. Learn more: http://aka.ms/AzureArcK8sGitOpsWithHelm."},"allowedValues":["true","false"],"defaultValue":"true"},"chartVersion":{"type":"String","metadata":{"displayName":"[Preview]: + Helm chart version for installing Flux Helm","description":"The version of + the Helm chart for installing Flux Helm. For example, 0.6.0"},"defaultValue":"0.6.0"},"chartValues":{"type":"String","metadata":{"displayName":"[Preview]: + Helm chart parameters for installing Flux Helm","description":"Parameters + for the Helm chart for installing Flux Helm, separated by spaces."},"defaultValue":""}},"policyRule":{"if":{"field":"type","in":["Microsoft.Kubernetes/connectedClusters","Microsoft.ContainerService/managedClusters"]},"then":{"effect":"DeployIfNotExists","details":{"type":"Microsoft.KubernetesConfiguration/sourceControlConfigurations","name":"[parameters(''configurationResourceName'')]","roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c"],"deploymentScope":"ResourceGroup","existenceCondition":{"allOf":[{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/operatorParams","in":["--git-readonly","[parameters(''operatorParams'')]","[concat(''--git-readonly + '',parameters(''operatorParams''))]"]},{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/repositoryUrl","equals":"[parameters(''repositoryUrl'')]"},{"anyOf":[{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/enableHelmOperator","equals":"false"},{"allOf":[{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/enableHelmOperator","equals":"true"},{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/helmOperatorProperties.chartVersion","equals":"[parameters(''chartVersion'')]"},{"field":"Microsoft.KubernetesConfiguration/sourceControlConfigurations/helmOperatorProperties.chartValues","equals":"[parameters(''chartValues'')]"}]}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"configurationResourceName":{"type":"string"},"clusterLocation":{"type":"string"},"clusterName":{"type":"string"},"operatorInstanceName":{"type":"string"},"operatorNamespace":{"type":"string"},"operatorScope":{"type":"string"},"operatorType":{"type":"string"},"operatorParams":{"type":"string"},"repositoryUrl":{"type":"string"},"enableHelmOperator":{"type":"string"},"chartVersion":{"type":"string"},"chartValues":{"type":"string"},"clusterResourceType":{"type":"string"}},"resources":[{"condition":"[contains(parameters(''clusterResourceType''), + ''connectedclusters'')]","type":"Microsoft.Kubernetes/connectedClusters/providers/sourceControlConfigurations","name":"[concat(parameters(''clusterName''), + ''/Microsoft.KubernetesConfiguration/'', parameters(''configurationResourceName''))]","apiVersion":"2019-11-01-preview","properties":{"operatorInstanceName":"[parameters(''operatorInstanceName'')]","operatorNamespace":"[parameters(''operatorNamespace'')]","operatorScope":"[parameters(''operatorScope'')]","operatorType":"[parameters(''operatorType'')]","operatorParams":"[parameters(''operatorParams'')]","repositoryUrl":"[parameters(''repositoryUrl'')]","enableHelmOperator":"[parameters(''enableHelmOperator'')]","helmOperatorProperties":{"chartVersion":"[parameters(''chartVersion'')]","chartValues":"[parameters(''chartValues'')]"}}},{"condition":"[contains(parameters(''clusterResourceType''), + ''managedclusters'')]","type":"Microsoft.ContainerService/managedClusters/providers/sourceControlConfigurations","name":"[concat(parameters(''clusterName''), + ''/Microsoft.KubernetesConfiguration/'', parameters(''configurationResourceName''))]","apiVersion":"2019-11-01-preview","properties":{"operatorInstanceName":"[parameters(''operatorInstanceName'')]","operatorNamespace":"[parameters(''operatorNamespace'')]","operatorScope":"[parameters(''operatorScope'')]","operatorType":"[parameters(''operatorType'')]","operatorParams":"[parameters(''operatorParams'')]","repositoryUrl":"[parameters(''repositoryUrl'')]","enableHelmOperator":"[parameters(''enableHelmOperator'')]","helmOperatorProperties":{"chartVersion":"[parameters(''chartVersion'')]","chartValues":"[parameters(''chartValues'')]"}}}]},"parameters":{"clusterLocation":{"value":"[field(''location'')]"},"clusterName":{"value":"[field(''name'')]"},"configurationResourceName":{"value":"[parameters(''configurationResourceName'')]"},"operatorInstanceName":{"value":"[parameters(''operatorInstanceName'')]"},"operatorNamespace":{"value":"[parameters(''operatorNamespace'')]"},"operatorScope":{"value":"[parameters(''operatorScope'')]"},"operatorType":{"value":"[parameters(''operatorType'')]"},"operatorParams":{"value":"[parameters(''operatorParams'')]"},"repositoryUrl":{"value":"[parameters(''repositoryUrl'')]"},"enableHelmOperator":{"value":"[parameters(''enableHelmOperator'')]"},"chartVersion":{"value":"[parameters(''chartVersion'')]"},"chartValues":{"value":"[parameters(''chartValues'')]"},"clusterResourceType":{"value":"[field(''type'')]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1d61c4d2-aef2-432b-87fc-7f96b019b7e1","type":"Microsoft.Authorization/policyDefinitions","name":"1d61c4d2-aef2-432b-87fc-7f96b019b7e1"},{"properties":{"displayName":"Azure + Policy Add-on for Kubernetes service (AKS) should be installed and enabled + on your clusters","policyType":"BuiltIn","mode":"Indexed","description":"Azure + Policy Add-on for Kubernetes service (AKS) extends Gatekeeper v3, an admission + controller webhook for Open Policy Agent (OPA), to apply at-scale enforcements + and safeguards on your clusters in a centralized, consistent manner.","metadata":{"version":"1.0.2","category":"Kubernetes"},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Disabled"],"defaultValue":"Audit"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"anyOf":[{"field":"Microsoft.ContainerService/managedClusters/addonProfiles.azurePolicy.enabled","exists":"false"},{"field":"Microsoft.ContainerService/managedClusters/addonProfiles.azurePolicy.enabled","equals":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0a15ec92-a229-4763-bb14-0ea34a568f8d","type":"Microsoft.Authorization/policyDefinitions","name":"0a15ec92-a229-4763-bb14-0ea34a568f8d"},{"properties":{"displayName":"Deploy + Azure Policy Add-on to Azure Kubernetes Service clusters","policyType":"BuiltIn","mode":"Indexed","description":"Use + Azure Policy Add-on to manage and report on the compliance state of your Azure + Kubernetes Service (AKS) clusters. For more information, see https://aka.ms/akspolicydoc.","metadata":{"version":"1.0.0","category":"Kubernetes"},"parameters":{},"policyRule":{"if":{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.ContainerService/managedClusters","name":"[field(''name'')]","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/ed7f3fbd-7b88-4dd4-9017-9adb7ce333f8"],"existenceCondition":{"field":"Microsoft.ContainerService/managedClusters/addonProfiles.azurePolicy.enabled","equals":"true"},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"clusterName":{"type":"string"},"clusterResourceGroupName":{"type":"string"}},"variables":{"clusterGetDeploymentName":"[concat(''PolicyDeployment-Get-'', + parameters(''clusterName''))]","clusterUpdateDeploymentName":"[concat(''PolicyDeployment-Update-'', + parameters(''clusterName''))]"},"resources":[{"apiVersion":"2020-06-01","type":"Microsoft.Resources/deployments","name":"[variables(''clusterGetDeploymentName'')]","properties":{"mode":"Incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","resources":[],"outputs":{"aksCluster":{"type":"object","value":"[reference(resourceId(parameters(''clusterResourceGroupName''), + ''Microsoft.ContainerService/managedClusters'', parameters(''clusterName'')), + ''2020-04-01'', ''Full'')]"}}}}},{"apiVersion":"2020-06-01","type":"Microsoft.Resources/deployments","name":"[variables(''clusterUpdateDeploymentName'')]","properties":{"mode":"Incremental","expressionEvaluationOptions":{"scope":"inner"},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"aksClusterName":{"type":"string"},"aksClusterContent":{"type":"object"}},"resources":[{"apiVersion":"2020-04-01","type":"Microsoft.ContainerService/managedClusters","name":"[parameters(''aksClusterName'')]","location":"[parameters(''aksClusterContent'').location]","sku":"[parameters(''aksClusterContent'').sku]","tags":"[if(contains(parameters(''aksClusterContent''), + ''tags''), parameters(''aksClusterContent'').tags, json(''null''))]","identity":"[if(contains(parameters(''aksClusterContent''), + ''identity''), parameters(''aksClusterContent'').identity, json(''null''))]","properties":{"kubernetesVersion":"[parameters(''aksClusterContent'').properties.kubernetesVersion]","dnsPrefix":"[parameters(''aksClusterContent'').properties.dnsPrefix]","agentPoolProfiles":"[if(contains(parameters(''aksClusterContent'').properties, + ''agentPoolProfiles''), parameters(''aksClusterContent'').properties.agentPoolProfiles, + json(''null''))]","linuxProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''linuxProfile''), parameters(''aksClusterContent'').properties.linuxProfile, + json(''null''))]","windowsProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''windowsProfile''), parameters(''aksClusterContent'').properties.windowsProfile, + json(''null''))]","servicePrincipalProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''servicePrincipalProfile''), parameters(''aksClusterContent'').properties.servicePrincipalProfile, + json(''null''))]","addonProfiles":{"azurepolicy":{"enabled":true}},"nodeResourceGroup":"[parameters(''aksClusterContent'').properties.nodeResourceGroup]","enableRBAC":"[if(contains(parameters(''aksClusterContent'').properties, + ''enableRBAC''), parameters(''aksClusterContent'').properties.enableRBAC, + json(''null''))]","enablePodSecurityPolicy":"[if(contains(parameters(''aksClusterContent'').properties, + ''enablePodSecurityPolicy''), parameters(''aksClusterContent'').properties.enablePodSecurityPolicy, + json(''null''))]","networkProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''networkProfile''), parameters(''aksClusterContent'').properties.networkProfile, + json(''null''))]","aadProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''aadProfile''), parameters(''aksClusterContent'').properties.aadProfile, + json(''null''))]","autoScalerProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''autoScalerProfile''), parameters(''aksClusterContent'').properties.autoScalerProfile, + json(''null''))]","apiServerAccessProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''apiServerAccessProfile''), parameters(''aksClusterContent'').properties.apiServerAccessProfile, + json(''null''))]","diskEncryptionSetID":"[if(contains(parameters(''aksClusterContent'').properties, + ''diskEncryptionSetID''), parameters(''aksClusterContent'').properties.diskEncryptionSetID, + json(''null''))]","identityProfile":"[if(contains(parameters(''aksClusterContent'').properties, + ''identityProfile''), parameters(''aksClusterContent'').properties.identityProfile, + json(''null''))]"}}],"outputs":{}},"parameters":{"aksClusterName":{"value":"[parameters(''clusterName'')]"},"aksClusterContent":{"value":"[reference(variables(''clusterGetDeploymentName'')).outputs.aksCluster.value]"}}}}]},"parameters":{"clusterName":{"value":"[field(''name'')]"},"clusterResourceGroupName":{"value":"[resourceGroup().name]"}}}}}}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a8eff44f-8c92-45c3-a3fb-9880802d67a7","type":"Microsoft.Authorization/policyDefinitions","name":"a8eff44f-8c92-45c3-a3fb-9880802d67a7"},{"properties":{"displayName":"Microsoft + Managed Control 1000 - Access Control Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1000"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2ef3cc79-733e-48ed-ab6f-7bf439e9b406","type":"Microsoft.Authorization/policyDefinitions","name":"2ef3cc79-733e-48ed-ab6f-7bf439e9b406"},{"properties":{"displayName":"Microsoft + Managed Control 1002 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1002"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/632024c2-8079-439d-a7f6-90af1d78cc65","type":"Microsoft.Authorization/policyDefinitions","name":"632024c2-8079-439d-a7f6-90af1d78cc65"},{"properties":{"displayName":"Microsoft + Managed Control 1001 - Access Control Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1001"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e26f8c3-4bf3-4191-b8fc-d888805101b7","type":"Microsoft.Authorization/policyDefinitions","name":"4e26f8c3-4bf3-4191-b8fc-d888805101b7"},{"properties":{"displayName":"Microsoft + Managed Control 1003 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1003"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3b68b179-3704-4ff7-b51d-7d65374d165d","type":"Microsoft.Authorization/policyDefinitions","name":"3b68b179-3704-4ff7-b51d-7d65374d165d"},{"properties":{"displayName":"Microsoft + Managed Control 1005 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1005"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b626abc-26d4-4e22-9de8-3831818526b1","type":"Microsoft.Authorization/policyDefinitions","name":"5b626abc-26d4-4e22-9de8-3831818526b1"},{"properties":{"displayName":"Microsoft + Managed Control 1004 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1004"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c17822dc-736f-4eb4-a97d-e6be662ff835","type":"Microsoft.Authorization/policyDefinitions","name":"c17822dc-736f-4eb4-a97d-e6be662ff835"},{"properties":{"displayName":"Microsoft + Managed Control 1006 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1006"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/aae8d54c-4bce-4c04-b3aa-5b65b67caac8","type":"Microsoft.Authorization/policyDefinitions","name":"aae8d54c-4bce-4c04-b3aa-5b65b67caac8"},{"properties":{"displayName":"Microsoft + Managed Control 1012 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1012"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/efd7b9ae-1db6-4eb6-b0fe-87e6565f9738","type":"Microsoft.Authorization/policyDefinitions","name":"efd7b9ae-1db6-4eb6-b0fe-87e6565f9738"},{"properties":{"displayName":"Microsoft + Managed Control 1009 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1009"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b26f8610-e615-47c2-abd6-c00b2b0b503a","type":"Microsoft.Authorization/policyDefinitions","name":"b26f8610-e615-47c2-abd6-c00b2b0b503a"},{"properties":{"displayName":"Microsoft + Managed Control 1011 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1011"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7e6a54f3-883f-43d5-87c4-172dfd64a1f5","type":"Microsoft.Authorization/policyDefinitions","name":"7e6a54f3-883f-43d5-87c4-172dfd64a1f5"},{"properties":{"displayName":"Microsoft + Managed Control 1010 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1010"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/784663a8-1eb0-418a-a98c-24d19bc1bb62","type":"Microsoft.Authorization/policyDefinitions","name":"784663a8-1eb0-418a-a98c-24d19bc1bb62"},{"properties":{"displayName":"Microsoft + Managed Control 1007 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1007"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/17200329-bf6c-46d8-ac6d-abf4641c2add","type":"Microsoft.Authorization/policyDefinitions","name":"17200329-bf6c-46d8-ac6d-abf4641c2add"},{"properties":{"displayName":"Microsoft + Managed Control 1013 - Account Management | Automated System Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1013"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8fd7b917-d83b-4379-af60-51e14e316c61","type":"Microsoft.Authorization/policyDefinitions","name":"8fd7b917-d83b-4379-af60-51e14e316c61"},{"properties":{"displayName":"Microsoft + Managed Control 1008 - Account Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1008"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8356cfc6-507a-4d20-b818-08038011cd07","type":"Microsoft.Authorization/policyDefinitions","name":"8356cfc6-507a-4d20-b818-08038011cd07"},{"properties":{"displayName":"Microsoft + Managed Control 1016 - Account Management | Automated Audit Actions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1016"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d8b43277-512e-40c3-ab00-14b3b6e72238","type":"Microsoft.Authorization/policyDefinitions","name":"d8b43277-512e-40c3-ab00-14b3b6e72238"},{"properties":{"displayName":"Microsoft + Managed Control 1014 - Account Management | Removal Of Temporary / Emergency + Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1014"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5dee936c-8037-4df1-ab35-6635733da48c","type":"Microsoft.Authorization/policyDefinitions","name":"5dee936c-8037-4df1-ab35-6635733da48c"},{"properties":{"displayName":"Microsoft + Managed Control 1015 - Account Management | Disable Inactive Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1015"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/544a208a-9c3f-40bc-b1d1-d7e144495c14","type":"Microsoft.Authorization/policyDefinitions","name":"544a208a-9c3f-40bc-b1d1-d7e144495c14"},{"properties":{"displayName":"Microsoft + Managed Control 1018 - Account Management | Role-Based Schemes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1018"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c9121abf-e698-4ee9-b1cf-71ee528ff07f","type":"Microsoft.Authorization/policyDefinitions","name":"c9121abf-e698-4ee9-b1cf-71ee528ff07f"},{"properties":{"displayName":"Microsoft + Managed Control 1019 - Account Management | Role-Based Schemes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1019"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6a3ee9b2-3977-459c-b8ce-2db583abd9f7","type":"Microsoft.Authorization/policyDefinitions","name":"6a3ee9b2-3977-459c-b8ce-2db583abd9f7"},{"properties":{"displayName":"Microsoft + Managed Control 1021 - Account Management | Restrictions On Use Of Shared + / Group Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1021"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9a3eb0a3-428d-4669-baff-20a14eb4b551","type":"Microsoft.Authorization/policyDefinitions","name":"9a3eb0a3-428d-4669-baff-20a14eb4b551"},{"properties":{"displayName":"Microsoft + Managed Control 1022 - Account Management | Shared / Group Account Credential + Termination","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1022"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/411f7e2d-9a0b-4627-a0b9-1700432db47d","type":"Microsoft.Authorization/policyDefinitions","name":"411f7e2d-9a0b-4627-a0b9-1700432db47d"},{"properties":{"displayName":"Microsoft + Managed Control 1020 - Account Management | Role-Based Schemes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1020"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b291ee8-3140-4cad-beb7-568c077c78ce","type":"Microsoft.Authorization/policyDefinitions","name":"0b291ee8-3140-4cad-beb7-568c077c78ce"},{"properties":{"displayName":"Microsoft + Managed Control 1017 - Account Management | Inactivity Logout","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1017"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0fc3db37-e59a-48c1-84e9-1780cedb409e","type":"Microsoft.Authorization/policyDefinitions","name":"0fc3db37-e59a-48c1-84e9-1780cedb409e"},{"properties":{"displayName":"Microsoft + Managed Control 1023 - Account Management | Usage Conditions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1023"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e55698b6-3dea-4aa9-99b9-d8218c6ab6e5","type":"Microsoft.Authorization/policyDefinitions","name":"e55698b6-3dea-4aa9-99b9-d8218c6ab6e5"},{"properties":{"displayName":"Microsoft + Managed Control 1024 - Account Management | Account Monitoring / Atypical + Usage","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1024"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/84914fb4-12da-4c53-a341-a9fd463bed10","type":"Microsoft.Authorization/policyDefinitions","name":"84914fb4-12da-4c53-a341-a9fd463bed10"},{"properties":{"displayName":"Microsoft + Managed Control 1026 - Account Management | Disable Accounts For High-Risk + Individuals","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1026"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/55419419-c597-4cd4-b51e-009fd2266783","type":"Microsoft.Authorization/policyDefinitions","name":"55419419-c597-4cd4-b51e-009fd2266783"},{"properties":{"displayName":"Microsoft + Managed Control 1025 - Account Management | Account Monitoring / Atypical + Usage","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1025"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/adfe020d-0a97-45f4-a39c-696ef99f3a95","type":"Microsoft.Authorization/policyDefinitions","name":"adfe020d-0a97-45f4-a39c-696ef99f3a95"},{"properties":{"displayName":"Microsoft + Managed Control 1027 - Access Enforcement","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1027"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a76ca9b0-3f4a-4192-9a38-b25e4f8ae48c","type":"Microsoft.Authorization/policyDefinitions","name":"a76ca9b0-3f4a-4192-9a38-b25e4f8ae48c"},{"properties":{"displayName":"Microsoft + Managed Control 1028 - Information Flow Enforcement","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1028"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f171df5c-921b-41e9-b12b-50801c315475","type":"Microsoft.Authorization/policyDefinitions","name":"f171df5c-921b-41e9-b12b-50801c315475"},{"properties":{"displayName":"Microsoft + Managed Control 1029 - Information Flow Enforcement | Security Policy Filters","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1029"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/53ac8f8e-c2b5-4d44-8a2d-058e9ced9b69","type":"Microsoft.Authorization/policyDefinitions","name":"53ac8f8e-c2b5-4d44-8a2d-058e9ced9b69"},{"properties":{"displayName":"Microsoft + Managed Control 1031 - Separation Of Duties","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1031"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6b93a801-fe25-4574-a60d-cb22acffae00","type":"Microsoft.Authorization/policyDefinitions","name":"6b93a801-fe25-4574-a60d-cb22acffae00"},{"properties":{"displayName":"Microsoft + Managed Control 1032 - Separation Of Duties","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1032"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5aa85661-d618-46b8-a20f-ca40a86f0751","type":"Microsoft.Authorization/policyDefinitions","name":"5aa85661-d618-46b8-a20f-ca40a86f0751"},{"properties":{"displayName":"Microsoft + Managed Control 1033 - Separation Of Duties","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1033"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/48540f01-fc11-411a-b160-42807c68896e","type":"Microsoft.Authorization/policyDefinitions","name":"48540f01-fc11-411a-b160-42807c68896e"},{"properties":{"displayName":"Microsoft + Managed Control 1030 - Information Flow Enforcement | Physical / Logical Separation + Of Information Flows","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1030"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d3531453-b869-4606-9122-29c1cd6e7ed1","type":"Microsoft.Authorization/policyDefinitions","name":"d3531453-b869-4606-9122-29c1cd6e7ed1"},{"properties":{"displayName":"Microsoft + Managed Control 1035 - Least Privilege | Authorize Access To Security Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1035"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ca94b046-45e2-444f-a862-dc8ce262a516","type":"Microsoft.Authorization/policyDefinitions","name":"ca94b046-45e2-444f-a862-dc8ce262a516"},{"properties":{"displayName":"Microsoft + Managed Control 1034 - Least Privilege","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1034"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/02a5ed00-6d2e-4e97-9a98-46c32c057329","type":"Microsoft.Authorization/policyDefinitions","name":"02a5ed00-6d2e-4e97-9a98-46c32c057329"},{"properties":{"displayName":"Microsoft + Managed Control 1036 - Least Privilege | Non-Privileged Access For Nonsecurity + Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1036"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9a16d673-8cf0-4dcf-b1d5-9b3e114fef71","type":"Microsoft.Authorization/policyDefinitions","name":"9a16d673-8cf0-4dcf-b1d5-9b3e114fef71"},{"properties":{"displayName":"Microsoft + Managed Control 1040 - Least Privilege | Review Of User Privileges","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1040"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/54205576-cec9-463f-ba44-b4b3f5d0a84c","type":"Microsoft.Authorization/policyDefinitions","name":"54205576-cec9-463f-ba44-b4b3f5d0a84c"},{"properties":{"displayName":"Microsoft + Managed Control 1038 - Least Privilege | Privileged Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1038"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/26692e88-71b7-4a5f-a8ac-9f31dd05bd8e","type":"Microsoft.Authorization/policyDefinitions","name":"26692e88-71b7-4a5f-a8ac-9f31dd05bd8e"},{"properties":{"displayName":"Microsoft + Managed Control 1037 - Least Privilege | Network Access To Privileged Commands","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1037"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fa4c2a3d-1294-41a3-9ada-0e540471e9fb","type":"Microsoft.Authorization/policyDefinitions","name":"fa4c2a3d-1294-41a3-9ada-0e540471e9fb"},{"properties":{"displayName":"Microsoft + Managed Control 1042 - Least Privilege | Auditing Use Of Privileged Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1042"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/319dc4f0-0fed-4ac9-8fc3-7aeddee82c07","type":"Microsoft.Authorization/policyDefinitions","name":"319dc4f0-0fed-4ac9-8fc3-7aeddee82c07"},{"properties":{"displayName":"Microsoft + Managed Control 1039 - Least Privilege | Review Of User Privileges","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1039"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3a7b9de4-a8a2-4672-914d-c5f6752aa7f9","type":"Microsoft.Authorization/policyDefinitions","name":"3a7b9de4-a8a2-4672-914d-c5f6752aa7f9"},{"properties":{"displayName":"Microsoft + Managed Control 1041 - Least Privilege | Privilege Levels For Code Execution","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1041"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b3d8d15b-627a-4219-8c96-4d16f788888b","type":"Microsoft.Authorization/policyDefinitions","name":"b3d8d15b-627a-4219-8c96-4d16f788888b"},{"properties":{"displayName":"Microsoft + Managed Control 1043 - Least Privilege | Prohibit Non-Privileged Users From + Executing Privileged Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1043"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/361a77f6-0f9c-4748-8eec-bc13aaaa2455","type":"Microsoft.Authorization/policyDefinitions","name":"361a77f6-0f9c-4748-8eec-bc13aaaa2455"},{"properties":{"displayName":"Microsoft + Managed Control 1044 - Unsuccessful Logon Attempts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1044"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0abbac52-57cf-450d-8408-1208d0dd9e90","type":"Microsoft.Authorization/policyDefinitions","name":"0abbac52-57cf-450d-8408-1208d0dd9e90"},{"properties":{"displayName":"Microsoft + Managed Control 1045 - Unsuccessful Logon Attempts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1045"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/554d2dd6-f3a8-4ad5-b66f-5ce23bd18892","type":"Microsoft.Authorization/policyDefinitions","name":"554d2dd6-f3a8-4ad5-b66f-5ce23bd18892"},{"properties":{"displayName":"Microsoft + Managed Control 1046 - Automatic Account Lock | Purge / Wipe Mobile Device","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1046"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b1aa965-7502-41f9-92be-3e2fe7cc392a","type":"Microsoft.Authorization/policyDefinitions","name":"0b1aa965-7502-41f9-92be-3e2fe7cc392a"},{"properties":{"displayName":"Microsoft + Managed Control 1049 - System Use Notification","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1049"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9adf7ba7-900a-4f35-8d57-9f34aafc405c","type":"Microsoft.Authorization/policyDefinitions","name":"9adf7ba7-900a-4f35-8d57-9f34aafc405c"},{"properties":{"displayName":"Microsoft + Managed Control 1048 - System Use Notification","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1048"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/483e7ca9-82b3-45a2-be97-b93163a0deb7","type":"Microsoft.Authorization/policyDefinitions","name":"483e7ca9-82b3-45a2-be97-b93163a0deb7"},{"properties":{"displayName":"Microsoft + Managed Control 1047 - System Use Notification","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1047"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e1ff6d62-a55c-41ab-90ba-90bb5b7b6f62","type":"Microsoft.Authorization/policyDefinitions","name":"e1ff6d62-a55c-41ab-90ba-90bb5b7b6f62"},{"properties":{"displayName":"Microsoft + Managed Control 1051 - Session Lock","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1051"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7cac6ee9-b58b-40c8-a5ce-f0efc3d9b339","type":"Microsoft.Authorization/policyDefinitions","name":"7cac6ee9-b58b-40c8-a5ce-f0efc3d9b339"},{"properties":{"displayName":"Microsoft + Managed Control 1050 - Concurrent Session Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1050"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bd20184c-b4ec-4ce5-8db6-6e86352d183f","type":"Microsoft.Authorization/policyDefinitions","name":"bd20184c-b4ec-4ce5-8db6-6e86352d183f"},{"properties":{"displayName":"Microsoft + Managed Control 1052 - Session Lock","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1052"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/027cae1c-ec3e-4492-9036-4168d540c42a","type":"Microsoft.Authorization/policyDefinitions","name":"027cae1c-ec3e-4492-9036-4168d540c42a"},{"properties":{"displayName":"Microsoft + Managed Control 1053 - Session Lock | Pattern-Hiding Displays","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1053"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7582b19c-9dba-438e-aed8-ede59ac35ba3","type":"Microsoft.Authorization/policyDefinitions","name":"7582b19c-9dba-438e-aed8-ede59ac35ba3"},{"properties":{"displayName":"Microsoft + Managed Control 1055 - Session Termination| User-Initiated Logouts / Message + Displays","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1055"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/769efd9b-3587-4e22-90ce-65ddcd5bd969","type":"Microsoft.Authorization/policyDefinitions","name":"769efd9b-3587-4e22-90ce-65ddcd5bd969"},{"properties":{"displayName":"Microsoft + Managed Control 1054 - Session Termination","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1054"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5807e1b4-ba5e-4718-8689-a0ca05a191b2","type":"Microsoft.Authorization/policyDefinitions","name":"5807e1b4-ba5e-4718-8689-a0ca05a191b2"},{"properties":{"displayName":"Microsoft + Managed Control 1056 - Session Termination | User-Initiated Logouts / Message + Displays","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1056"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ac43352f-df83-4694-8738-cfce549fd08d","type":"Microsoft.Authorization/policyDefinitions","name":"ac43352f-df83-4694-8738-cfce549fd08d"},{"properties":{"displayName":"Microsoft + Managed Control 1057 - Permitted Actions Without Identification Or Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1057"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/78255758-6d45-4bf0-a005-7016bc03b13c","type":"Microsoft.Authorization/policyDefinitions","name":"78255758-6d45-4bf0-a005-7016bc03b13c"},{"properties":{"displayName":"Microsoft + Managed Control 1059 - Remote Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1059"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a29b5d9f-4953-4afe-b560-203a6410b6b4","type":"Microsoft.Authorization/policyDefinitions","name":"a29b5d9f-4953-4afe-b560-203a6410b6b4"},{"properties":{"displayName":"Microsoft + Managed Control 1060 - Remote Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1060"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/34a987fd-2003-45de-a120-014956581f2b","type":"Microsoft.Authorization/policyDefinitions","name":"34a987fd-2003-45de-a120-014956581f2b"},{"properties":{"displayName":"Microsoft + Managed Control 1058 - Permitted Actions Without Identification Or Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1058"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/76e85d08-8fbb-4112-a1c1-93521e6a9254","type":"Microsoft.Authorization/policyDefinitions","name":"76e85d08-8fbb-4112-a1c1-93521e6a9254"},{"properties":{"displayName":"Microsoft + Managed Control 1062 - Remote Access | Protection Of Confidentiality / Integrity + Using Encryption","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1062"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4708723f-e099-4af1-bbf9-b6df7642e444","type":"Microsoft.Authorization/policyDefinitions","name":"4708723f-e099-4af1-bbf9-b6df7642e444"},{"properties":{"displayName":"Microsoft + Managed Control 1061 - Remote Access | Automated Monitoring / Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1061"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7ac22808-a2e8-41c4-9d46-429b50738914","type":"Microsoft.Authorization/policyDefinitions","name":"7ac22808-a2e8-41c4-9d46-429b50738914"},{"properties":{"displayName":"Microsoft + Managed Control 1063 - Remote Access | Managed Access Control Points","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1063"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/593ce201-54b2-4dd0-b34f-c308005d7780","type":"Microsoft.Authorization/policyDefinitions","name":"593ce201-54b2-4dd0-b34f-c308005d7780"},{"properties":{"displayName":"Microsoft + Managed Control 1064 - Remote Access | Privileged Commands / Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1064"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb4d9508-cbf0-4a3c-bb5c-6c95b159f3fb","type":"Microsoft.Authorization/policyDefinitions","name":"eb4d9508-cbf0-4a3c-bb5c-6c95b159f3fb"},{"properties":{"displayName":"Microsoft + Managed Control 1065 - Remote Access | Privileged Commands / Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1065"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f87b8085-dca9-4cf1-8f7b-9822b997797c","type":"Microsoft.Authorization/policyDefinitions","name":"f87b8085-dca9-4cf1-8f7b-9822b997797c"},{"properties":{"displayName":"Microsoft + Managed Control 1066 - Remote Access | Disconnect / Disable Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1066"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4455c2e8-c65d-4acf-895e-304916f90b36","type":"Microsoft.Authorization/policyDefinitions","name":"4455c2e8-c65d-4acf-895e-304916f90b36"},{"properties":{"displayName":"Microsoft + Managed Control 1068 - Wireless Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1068"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2d045bca-a0fd-452e-9f41-4ec33769717c","type":"Microsoft.Authorization/policyDefinitions","name":"2d045bca-a0fd-452e-9f41-4ec33769717c"},{"properties":{"displayName":"Microsoft + Managed Control 1067 - Wireless Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1067"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5c5e54f6-0127-44d0-8b61-f31dc8dd6190","type":"Microsoft.Authorization/policyDefinitions","name":"5c5e54f6-0127-44d0-8b61-f31dc8dd6190"},{"properties":{"displayName":"Microsoft + Managed Control 1071 - Wireless Access | Restrict Configurations By Users","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1071"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1a437f5b-9ad6-4f28-8861-de404d511ae4","type":"Microsoft.Authorization/policyDefinitions","name":"1a437f5b-9ad6-4f28-8861-de404d511ae4"},{"properties":{"displayName":"Microsoft + Managed Control 1069 - Wireless Access | Authentication And Encryption","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1069"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/91c97b44-791e-46e9-bad7-ab7c4949edbb","type":"Microsoft.Authorization/policyDefinitions","name":"91c97b44-791e-46e9-bad7-ab7c4949edbb"},{"properties":{"displayName":"Microsoft + Managed Control 1072 - Wireless Access | Antennas / Transmission Power Levels","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1072"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1ca29e41-34ec-4e70-aba9-6248aca18c31","type":"Microsoft.Authorization/policyDefinitions","name":"1ca29e41-34ec-4e70-aba9-6248aca18c31"},{"properties":{"displayName":"Microsoft + Managed Control 1070 - Wireless Access | Disable Wireless Networking","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1070"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/68f837d0-8942-4b1e-9b31-be78b247bda8","type":"Microsoft.Authorization/policyDefinitions","name":"68f837d0-8942-4b1e-9b31-be78b247bda8"},{"properties":{"displayName":"Microsoft + Managed Control 1074 - Access Control For Mobile Devices","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1074"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/27a69937-af92-4198-9b86-08d355c7e59a","type":"Microsoft.Authorization/policyDefinitions","name":"27a69937-af92-4198-9b86-08d355c7e59a"},{"properties":{"displayName":"Microsoft + Managed Control 1073 - Access Control For Mobile Devices","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1073"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ab55cdb0-c7dd-4bd8-ae22-a7cea7594e9c","type":"Microsoft.Authorization/policyDefinitions","name":"ab55cdb0-c7dd-4bd8-ae22-a7cea7594e9c"},{"properties":{"displayName":"Microsoft + Managed Control 1075 - Access Control For Mobile Devices | Full Device / Container-Based Encryption","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1075"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fc933d22-04df-48ed-8f87-22a3773d4309","type":"Microsoft.Authorization/policyDefinitions","name":"fc933d22-04df-48ed-8f87-22a3773d4309"},{"properties":{"displayName":"Microsoft + Managed Control 1076 - Use Of External Information Systems","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1076"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/98a4bd5f-6436-46d4-ad00-930b5b1dfed4","type":"Microsoft.Authorization/policyDefinitions","name":"98a4bd5f-6436-46d4-ad00-930b5b1dfed4"},{"properties":{"displayName":"Microsoft + Managed Control 1077 - Use Of External Information Systems","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1077"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2dad3668-797a-412e-a798-07d3849a7a79","type":"Microsoft.Authorization/policyDefinitions","name":"2dad3668-797a-412e-a798-07d3849a7a79"},{"properties":{"displayName":"Microsoft + Managed Control 1078 - Use Of External Information Systems | Limits On Authorized + Use","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1078"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b25faf85-8a16-4f28-8e15-d05c0072d64d","type":"Microsoft.Authorization/policyDefinitions","name":"b25faf85-8a16-4f28-8e15-d05c0072d64d"},{"properties":{"displayName":"Microsoft + Managed Control 1081 - Information Sharing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1081"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3867f2a9-23bb-4729-851f-c3ad98580caf","type":"Microsoft.Authorization/policyDefinitions","name":"3867f2a9-23bb-4729-851f-c3ad98580caf"},{"properties":{"displayName":"Microsoft + Managed Control 1079 - Use Of External Information Systems | Limits On Authorized + Use","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1079"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/85c32733-7d23-4948-88da-058e2c56b60f","type":"Microsoft.Authorization/policyDefinitions","name":"85c32733-7d23-4948-88da-058e2c56b60f"},{"properties":{"displayName":"Microsoft + Managed Control 1080 - Use Of External Information Systems | Portable Storage + Devices","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1080"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/852981b4-a380-4704-aa1e-2e52d63445e5","type":"Microsoft.Authorization/policyDefinitions","name":"852981b4-a380-4704-aa1e-2e52d63445e5"},{"properties":{"displayName":"Microsoft + Managed Control 1084 - Publicly Accessible Content","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1084"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d0eb15db-dd1c-4d1d-b200-b12dd6cd060c","type":"Microsoft.Authorization/policyDefinitions","name":"d0eb15db-dd1c-4d1d-b200-b12dd6cd060c"},{"properties":{"displayName":"Microsoft + Managed Control 1083 - Publicly Accessible Content","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1083"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e319cb6-2ca3-4a58-ad75-e67f484e50ec","type":"Microsoft.Authorization/policyDefinitions","name":"4e319cb6-2ca3-4a58-ad75-e67f484e50ec"},{"properties":{"displayName":"Microsoft + Managed Control 1085 - Publicly Accessible Content","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1085"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/13d117e0-38b0-4bbb-aaab-563be5dd10ba","type":"Microsoft.Authorization/policyDefinitions","name":"13d117e0-38b0-4bbb-aaab-563be5dd10ba"},{"properties":{"displayName":"Microsoft + Managed Control 1082 - Information Sharing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1082"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/24d480ef-11a0-4b1b-8e70-4e023bf2be23","type":"Microsoft.Authorization/policyDefinitions","name":"24d480ef-11a0-4b1b-8e70-4e023bf2be23"},{"properties":{"displayName":"Microsoft + Managed Control 1086 - Publicly Accessible Content","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Access Control control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1086"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fb321e6f-16a0-4be3-878f-500956e309c5","type":"Microsoft.Authorization/policyDefinitions","name":"fb321e6f-16a0-4be3-878f-500956e309c5"},{"properties":{"displayName":"Microsoft + Managed Control 1087 - Security Awareness And Training Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1087"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/100c82ba-42e9-4d44-a2ba-94b209248583","type":"Microsoft.Authorization/policyDefinitions","name":"100c82ba-42e9-4d44-a2ba-94b209248583"},{"properties":{"displayName":"Microsoft + Managed Control 1089 - Security Awareness Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1089"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef080e67-0d1a-4f76-a0c5-fb9b0358485e","type":"Microsoft.Authorization/policyDefinitions","name":"ef080e67-0d1a-4f76-a0c5-fb9b0358485e"},{"properties":{"displayName":"Microsoft + Managed Control 1088 - Security Awareness And Training Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1088"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1d50f99d-1356-49c0-934a-45f742ba7783","type":"Microsoft.Authorization/policyDefinitions","name":"1d50f99d-1356-49c0-934a-45f742ba7783"},{"properties":{"displayName":"Microsoft + Managed Control 1090 - Security Awareness Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1090"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2fb740e5-cbc7-4d10-8686-d1bf826652b1","type":"Microsoft.Authorization/policyDefinitions","name":"2fb740e5-cbc7-4d10-8686-d1bf826652b1"},{"properties":{"displayName":"Microsoft + Managed Control 1091 - Security Awareness Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1091"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b23bd715-5d1c-4e5c-9759-9cbdf79ded9d","type":"Microsoft.Authorization/policyDefinitions","name":"b23bd715-5d1c-4e5c-9759-9cbdf79ded9d"},{"properties":{"displayName":"Microsoft + Managed Control 1092 - Security Awareness Training | Insider Threat","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1092"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8a29d47b-8604-4667-84ef-90d203fcb305","type":"Microsoft.Authorization/policyDefinitions","name":"8a29d47b-8604-4667-84ef-90d203fcb305"},{"properties":{"displayName":"Microsoft + Managed Control 1093 - Role-Based Security Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1093"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7a0bdeeb-15f4-47e8-a1da-9f769f845fdf","type":"Microsoft.Authorization/policyDefinitions","name":"7a0bdeeb-15f4-47e8-a1da-9f769f845fdf"},{"properties":{"displayName":"Microsoft + Managed Control 1095 - Role-Based Security Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1095"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bc3f6f7a-057b-433e-9834-e8c97b0194f6","type":"Microsoft.Authorization/policyDefinitions","name":"bc3f6f7a-057b-433e-9834-e8c97b0194f6"},{"properties":{"displayName":"Microsoft + Managed Control 1094 - Role-Based Security Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1094"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4b1853e0-8973-446b-b567-09d901d31a09","type":"Microsoft.Authorization/policyDefinitions","name":"4b1853e0-8973-446b-b567-09d901d31a09"},{"properties":{"displayName":"Microsoft + Managed Control 1096 - Role-Based Security Training | Practical Exercises","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1096"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/420c1477-aa43-49d0-bd7e-c4abdd9addff","type":"Microsoft.Authorization/policyDefinitions","name":"420c1477-aa43-49d0-bd7e-c4abdd9addff"},{"properties":{"displayName":"Microsoft + Managed Control 1097 - Role-Based Security Training | Suspicious Communications + And Anomalous System Behavior","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1097"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cf3e4836-f19e-47eb-a8cd-c3ca150452c0","type":"Microsoft.Authorization/policyDefinitions","name":"cf3e4836-f19e-47eb-a8cd-c3ca150452c0"},{"properties":{"displayName":"Microsoft + Managed Control 1099 - Security Training Records","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1099"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/01910bab-8639-4bd0-84ef-cc53b24d79ba","type":"Microsoft.Authorization/policyDefinitions","name":"01910bab-8639-4bd0-84ef-cc53b24d79ba"},{"properties":{"displayName":"Microsoft + Managed Control 1100 - Audit And Accountability Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1100"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4057863c-ca7d-47eb-b1e0-503580cba8a4","type":"Microsoft.Authorization/policyDefinitions","name":"4057863c-ca7d-47eb-b1e0-503580cba8a4"},{"properties":{"displayName":"Microsoft + Managed Control 1102 - Audit Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1102"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9943c16a-c54c-4b4a-ad28-bfd938cdbf57","type":"Microsoft.Authorization/policyDefinitions","name":"9943c16a-c54c-4b4a-ad28-bfd938cdbf57"},{"properties":{"displayName":"Microsoft + Managed Control 1098 - Security Training Records","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Awareness and Training control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1098"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/84363adb-dde3-411a-9fc1-36b56737f822","type":"Microsoft.Authorization/policyDefinitions","name":"84363adb-dde3-411a-9fc1-36b56737f822"},{"properties":{"displayName":"Microsoft + Managed Control 1101 - Audit And Accountability Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1101"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7327b708-f0e0-457d-9d2a-527fcc9c9a65","type":"Microsoft.Authorization/policyDefinitions","name":"7327b708-f0e0-457d-9d2a-527fcc9c9a65"},{"properties":{"displayName":"Microsoft + Managed Control 1105 - Audit Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1105"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b73f57b-587d-4470-a344-0b0ae805f459","type":"Microsoft.Authorization/policyDefinitions","name":"5b73f57b-587d-4470-a344-0b0ae805f459"},{"properties":{"displayName":"Microsoft + Managed Control 1104 - Audit Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1104"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cdd8d244-18b2-4306-a1d1-df175ae0935f","type":"Microsoft.Authorization/policyDefinitions","name":"cdd8d244-18b2-4306-a1d1-df175ae0935f"},{"properties":{"displayName":"Microsoft + Managed Control 1103 - Audit Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1103"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/16feeb31-6377-437e-bbab-d7f73911896d","type":"Microsoft.Authorization/policyDefinitions","name":"16feeb31-6377-437e-bbab-d7f73911896d"},{"properties":{"displayName":"Microsoft + Managed Control 1106 - Audit Events | Reviews And Updates","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1106"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d2b4feae-61ab-423f-a4c5-0e38ac4464d8","type":"Microsoft.Authorization/policyDefinitions","name":"d2b4feae-61ab-423f-a4c5-0e38ac4464d8"},{"properties":{"displayName":"Microsoft + Managed Control 1107 - Content Of Audit Records","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1107"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b29ed931-8e21-4779-8458-27916122a904","type":"Microsoft.Authorization/policyDefinitions","name":"b29ed931-8e21-4779-8458-27916122a904"},{"properties":{"displayName":"Microsoft + Managed Control 1108 - Content Of Audit Records | Additional Audit Information","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1108"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f9ad559e-c12d-415e-9a78-e50fdd7da7ba","type":"Microsoft.Authorization/policyDefinitions","name":"f9ad559e-c12d-415e-9a78-e50fdd7da7ba"},{"properties":{"displayName":"Microsoft + Managed Control 1109 - Content Of Audit Records | Centralized Management Of + Planned Audit Record Content","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1109"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7d9ffa23-ad92-4d0d-b1f4-7db274cc2aec","type":"Microsoft.Authorization/policyDefinitions","name":"7d9ffa23-ad92-4d0d-b1f4-7db274cc2aec"},{"properties":{"displayName":"Microsoft + Managed Control 1110 - Audit Storage Capacity","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1110"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6182bfa7-0f2a-43f5-834a-a2ddf31c13c7","type":"Microsoft.Authorization/policyDefinitions","name":"6182bfa7-0f2a-43f5-834a-a2ddf31c13c7"},{"properties":{"displayName":"Microsoft + Managed Control 1113 - Response To Audit Processing Failures | Audit Storage + Capacity","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1113"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/562afd61-56be-4313-8fe4-b9564aa4ba7d","type":"Microsoft.Authorization/policyDefinitions","name":"562afd61-56be-4313-8fe4-b9564aa4ba7d"},{"properties":{"displayName":"Microsoft + Managed Control 1112 - Response To Audit Processing Failures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1112"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d530aad8-4ee2-45f4-b234-c061dae683c0","type":"Microsoft.Authorization/policyDefinitions","name":"d530aad8-4ee2-45f4-b234-c061dae683c0"},{"properties":{"displayName":"Microsoft + Managed Control 1111 - Response To Audit Processing Failures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1111"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/21de687c-f15e-4e51-bf8d-f35c8619965b","type":"Microsoft.Authorization/policyDefinitions","name":"21de687c-f15e-4e51-bf8d-f35c8619965b"},{"properties":{"displayName":"Microsoft + Managed Control 1115 - Audit Review, Analysis, And Reporting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1115"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0b653845-2ad9-4e09-a4f3-5a7c1d78353d","type":"Microsoft.Authorization/policyDefinitions","name":"0b653845-2ad9-4e09-a4f3-5a7c1d78353d"},{"properties":{"displayName":"Microsoft + Managed Control 1114 - Response To Audit Processing Failures | Real-Time Alerts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1114"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4c090801-59bc-4454-bb33-e0455133486a","type":"Microsoft.Authorization/policyDefinitions","name":"4c090801-59bc-4454-bb33-e0455133486a"},{"properties":{"displayName":"Microsoft + Managed Control 1117 - Audit Review, Analysis, And Reporting | Process Integration","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1117"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7fbfe680-6dbb-4037-963c-a621c5635902","type":"Microsoft.Authorization/policyDefinitions","name":"7fbfe680-6dbb-4037-963c-a621c5635902"},{"properties":{"displayName":"Microsoft + Managed Control 1116 - Audit Review, Analysis, And Reporting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1116"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5e47bc51-35d1-44b8-92af-e2f2d8b67635","type":"Microsoft.Authorization/policyDefinitions","name":"5e47bc51-35d1-44b8-92af-e2f2d8b67635"},{"properties":{"displayName":"Microsoft + Managed Control 1118 - Audit Review, Analysis, And Reporting | Correlate Audit + Repositories","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1118"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a96f743d-a195-420d-983a-08aa06bc441e","type":"Microsoft.Authorization/policyDefinitions","name":"a96f743d-a195-420d-983a-08aa06bc441e"},{"properties":{"displayName":"Microsoft + Managed Control 1119 - Audit Review, Analysis, And Reporting | Central Review + And Analysis","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1119"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/845f6359-b764-4b40-b579-657aefe23c44","type":"Microsoft.Authorization/policyDefinitions","name":"845f6359-b764-4b40-b579-657aefe23c44"},{"properties":{"displayName":"Microsoft + Managed Control 1120 - Audit Review, Analysis, And Reporting | Integration + / Scanning And Monitoring Capabilities","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1120"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c69b870e-857b-458b-af02-bb234f7a00d3","type":"Microsoft.Authorization/policyDefinitions","name":"c69b870e-857b-458b-af02-bb234f7a00d3"},{"properties":{"displayName":"Microsoft + Managed Control 1121 - Audit Review, Analysis, And Reporting | Correlation + With Physical Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1121"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c72b0eb9-1fc2-44e5-a866-e7cb0532f7c1","type":"Microsoft.Authorization/policyDefinitions","name":"c72b0eb9-1fc2-44e5-a866-e7cb0532f7c1"},{"properties":{"displayName":"Microsoft + Managed Control 1123 - Audit Review, Analysis, And Reporting | Audit Level + Adjustment","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1123"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/03996055-37a4-45a5-8b70-3f1caa45f87d","type":"Microsoft.Authorization/policyDefinitions","name":"03996055-37a4-45a5-8b70-3f1caa45f87d"},{"properties":{"displayName":"Microsoft + Managed Control 1122 - Audit Review, Analysis, And Reporting | Permitted Actions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1122"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/243ec95e-800c-49d4-ba52-1fdd9f6b8b57","type":"Microsoft.Authorization/policyDefinitions","name":"243ec95e-800c-49d4-ba52-1fdd9f6b8b57"},{"properties":{"displayName":"Microsoft + Managed Control 1124 - Audit Reduction And Report Generation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1124"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c10152dd-78f8-4335-ae2d-ad92cc028da4","type":"Microsoft.Authorization/policyDefinitions","name":"c10152dd-78f8-4335-ae2d-ad92cc028da4"},{"properties":{"displayName":"Microsoft + Managed Control 1125 - Audit Reduction And Report Generation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1125"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c6ce745a-670e-47d3-a6c4-3cfe5ef00c10","type":"Microsoft.Authorization/policyDefinitions","name":"c6ce745a-670e-47d3-a6c4-3cfe5ef00c10"},{"properties":{"displayName":"Microsoft + Managed Control 1126 - Audit Reduction And Report Generation | Automatic Processing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1126"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7f37f71b-420f-49bf-9477-9c0196974ecf","type":"Microsoft.Authorization/policyDefinitions","name":"7f37f71b-420f-49bf-9477-9c0196974ecf"},{"properties":{"displayName":"Microsoft + Managed Control 1127 - Time Stamps","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1127"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3ce328db-aef3-48ed-9f81-2ab7cf839c66","type":"Microsoft.Authorization/policyDefinitions","name":"3ce328db-aef3-48ed-9f81-2ab7cf839c66"},{"properties":{"displayName":"Microsoft + Managed Control 1128 - Time Stamps","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1128"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef212163-3bc4-4e86-bcf8-705127086393","type":"Microsoft.Authorization/policyDefinitions","name":"ef212163-3bc4-4e86-bcf8-705127086393"},{"properties":{"displayName":"Microsoft + Managed Control 1130 - Time Stamps | Synchronization With Authoritative Time + Source","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1130"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fd7c4c1d-51ee-4349-9dab-89a7f8c8d102","type":"Microsoft.Authorization/policyDefinitions","name":"fd7c4c1d-51ee-4349-9dab-89a7f8c8d102"},{"properties":{"displayName":"Microsoft + Managed Control 1131 - Protection Of Audit Information","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1131"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b472a17e-c2bc-493f-b50b-42d55a346962","type":"Microsoft.Authorization/policyDefinitions","name":"b472a17e-c2bc-493f-b50b-42d55a346962"},{"properties":{"displayName":"Microsoft + Managed Control 1129 - Time Stamps | Synchronization With Authoritative Time + Source","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1129"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/71bb965d-4047-4623-afd4-b8189a58df5d","type":"Microsoft.Authorization/policyDefinitions","name":"71bb965d-4047-4623-afd4-b8189a58df5d"},{"properties":{"displayName":"Microsoft + Managed Control 1134 - Protection Of Audit Information | Access By Subset + Of Privileged Users","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1134"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e95f70e-181c-4422-9da2-43079710c789","type":"Microsoft.Authorization/policyDefinitions","name":"4e95f70e-181c-4422-9da2-43079710c789"},{"properties":{"displayName":"Microsoft + Managed Control 1132 - Protection Of Audit Information | Audit Backup On Separate + Physical Systems / Components","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1132"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/05938e10-cdbd-4a54-9b2b-1cbcfc141ad0","type":"Microsoft.Authorization/policyDefinitions","name":"05938e10-cdbd-4a54-9b2b-1cbcfc141ad0"},{"properties":{"displayName":"Microsoft + Managed Control 1133 - Protection Of Audit Information | Cryptographic Protection","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1133"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/90b60a09-133d-45bc-86ef-b206a6134bbe","type":"Microsoft.Authorization/policyDefinitions","name":"90b60a09-133d-45bc-86ef-b206a6134bbe"},{"properties":{"displayName":"Microsoft + Managed Control 1135 - Non-Repudiation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1135"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9c308b6b-2429-4b97-86cf-081b8e737b04","type":"Microsoft.Authorization/policyDefinitions","name":"9c308b6b-2429-4b97-86cf-081b8e737b04"},{"properties":{"displayName":"Microsoft + Managed Control 1136 - Audit Record Retention","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1136"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/97ed5bac-a92f-4f6d-a8ed-dc094723597c","type":"Microsoft.Authorization/policyDefinitions","name":"97ed5bac-a92f-4f6d-a8ed-dc094723597c"},{"properties":{"displayName":"Microsoft + Managed Control 1138 - Audit Generation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1138"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9c284fc0-268a-4f29-af44-3c126674edb4","type":"Microsoft.Authorization/policyDefinitions","name":"9c284fc0-268a-4f29-af44-3c126674edb4"},{"properties":{"displayName":"Microsoft + Managed Control 1137 - Audit Generation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1137"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4344df62-88ab-4637-b97b-bcaf2ec97e7c","type":"Microsoft.Authorization/policyDefinitions","name":"4344df62-88ab-4637-b97b-bcaf2ec97e7c"},{"properties":{"displayName":"Microsoft + Managed Control 1139 - Audit Generation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1139"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4ed62522-de00-4dda-9810-5205733d2f34","type":"Microsoft.Authorization/policyDefinitions","name":"4ed62522-de00-4dda-9810-5205733d2f34"},{"properties":{"displayName":"Microsoft + Managed Control 1140 - Audit Generation | System-Wide / Time-Correlated Audit + Trail","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1140"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/90d8b8ad-8ee3-4db7-913f-2a53fcff5316","type":"Microsoft.Authorization/policyDefinitions","name":"90d8b8ad-8ee3-4db7-913f-2a53fcff5316"},{"properties":{"displayName":"Microsoft + Managed Control 1143 - Security Assessment And Authorization Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1143"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7c6de11b-5f51-4f7c-8d83-d2467c8a816e","type":"Microsoft.Authorization/policyDefinitions","name":"7c6de11b-5f51-4f7c-8d83-d2467c8a816e"},{"properties":{"displayName":"Microsoft + Managed Control 1141 - Audit Generation | Changes By Authorized Individuals","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Audit and Accountability control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1141"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6fdefbf4-93e7-4513-bc95-c1858b7093e0","type":"Microsoft.Authorization/policyDefinitions","name":"6fdefbf4-93e7-4513-bc95-c1858b7093e0"},{"properties":{"displayName":"Microsoft + Managed Control 1142 - Security Assessment And Authorization Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1142"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/01524fa8-4555-48ce-ba5f-c3b8dcef5147","type":"Microsoft.Authorization/policyDefinitions","name":"01524fa8-4555-48ce-ba5f-c3b8dcef5147"},{"properties":{"displayName":"Microsoft + Managed Control 1145 - Security Assessments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1145"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a0724970-9c75-4a64-a225-a28002953f28","type":"Microsoft.Authorization/policyDefinitions","name":"a0724970-9c75-4a64-a225-a28002953f28"},{"properties":{"displayName":"Microsoft + Managed Control 1144 - Security Assessments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1144"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2fa15ff1-a693-4ee4-b094-324818dc9a51","type":"Microsoft.Authorization/policyDefinitions","name":"2fa15ff1-a693-4ee4-b094-324818dc9a51"},{"properties":{"displayName":"Microsoft + Managed Control 1147 - Security Assessments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1147"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8fef824a-29a8-4a4c-88fc-420a39c0d541","type":"Microsoft.Authorization/policyDefinitions","name":"8fef824a-29a8-4a4c-88fc-420a39c0d541"},{"properties":{"displayName":"Microsoft + Managed Control 1148 - Security Assessments | Independent Assessors","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1148"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/28e62650-c7c2-4786-bdfa-17edc1673902","type":"Microsoft.Authorization/policyDefinitions","name":"28e62650-c7c2-4786-bdfa-17edc1673902"},{"properties":{"displayName":"Microsoft + Managed Control 1146 - Security Assessments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1146"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dd83410c-ecb6-4547-8f14-748c3cbdc7ac","type":"Microsoft.Authorization/policyDefinitions","name":"dd83410c-ecb6-4547-8f14-748c3cbdc7ac"},{"properties":{"displayName":"Microsoft + Managed Control 1149 - Security Assessments | Specialized Assessments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1149"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2e1b855b-a013-481a-aeeb-2bcb129fd35d","type":"Microsoft.Authorization/policyDefinitions","name":"2e1b855b-a013-481a-aeeb-2bcb129fd35d"},{"properties":{"displayName":"Microsoft + Managed Control 1150 - Security Assessments | External Organizations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1150"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d630429d-e763-40b1-8fba-d20ba7314afb","type":"Microsoft.Authorization/policyDefinitions","name":"d630429d-e763-40b1-8fba-d20ba7314afb"},{"properties":{"displayName":"Microsoft + Managed Control 1151 - System Interconnections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1151"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/347e3b69-7fb7-47df-a8ef-71a1a7b44bca","type":"Microsoft.Authorization/policyDefinitions","name":"347e3b69-7fb7-47df-a8ef-71a1a7b44bca"},{"properties":{"displayName":"Microsoft + Managed Control 1154 - System Interconnections | Unclassified Non-National + Security System Connections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1154"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e757ceb9-93b3-45fe-a4f4-f43f64f1ac5a","type":"Microsoft.Authorization/policyDefinitions","name":"e757ceb9-93b3-45fe-a4f4-f43f64f1ac5a"},{"properties":{"displayName":"Microsoft + Managed Control 1155 - System Interconnections | Restrictions On External + System Connections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1155"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4d33f9f1-12d0-46ad-9fbd-8f8046694977","type":"Microsoft.Authorization/policyDefinitions","name":"4d33f9f1-12d0-46ad-9fbd-8f8046694977"},{"properties":{"displayName":"Microsoft + Managed Control 1152 - System Interconnections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1152"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/beff0acf-7e67-40b2-b1ca-1a0e8205cf1b","type":"Microsoft.Authorization/policyDefinitions","name":"beff0acf-7e67-40b2-b1ca-1a0e8205cf1b"},{"properties":{"displayName":"Microsoft + Managed Control 1153 - System Interconnections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1153"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/61cf3125-142c-4754-8a16-41ab4d529635","type":"Microsoft.Authorization/policyDefinitions","name":"61cf3125-142c-4754-8a16-41ab4d529635"},{"properties":{"displayName":"Microsoft + Managed Control 1157 - Plan Of Action And Milestones","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1157"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/15495367-cf68-464c-bbc3-f53ca5227b7a","type":"Microsoft.Authorization/policyDefinitions","name":"15495367-cf68-464c-bbc3-f53ca5227b7a"},{"properties":{"displayName":"Microsoft + Managed Control 1158 - Security Authorization","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1158"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fff50cf2-28eb-45b4-b378-c99412688907","type":"Microsoft.Authorization/policyDefinitions","name":"fff50cf2-28eb-45b4-b378-c99412688907"},{"properties":{"displayName":"Microsoft + Managed Control 1156 - Plan Of Action And Milestones","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1156"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4d52e864-9a3b-41ee-8f03-520815fe5378","type":"Microsoft.Authorization/policyDefinitions","name":"4d52e864-9a3b-41ee-8f03-520815fe5378"},{"properties":{"displayName":"Microsoft + Managed Control 1160 - Security Authorization","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1160"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3e797ca6-2aa8-4333-b335-7036f1110c05","type":"Microsoft.Authorization/policyDefinitions","name":"3e797ca6-2aa8-4333-b335-7036f1110c05"},{"properties":{"displayName":"Microsoft + Managed Control 1159 - Security Authorization","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1159"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0925f098-7877-450b-8ba4-d1e55f2d8795","type":"Microsoft.Authorization/policyDefinitions","name":"0925f098-7877-450b-8ba4-d1e55f2d8795"},{"properties":{"displayName":"Microsoft + Managed Control 1161 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1161"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e2f8f6c6-dde4-436b-a79d-bc50e129eb3a","type":"Microsoft.Authorization/policyDefinitions","name":"e2f8f6c6-dde4-436b-a79d-bc50e129eb3a"},{"properties":{"displayName":"Microsoft + Managed Control 1164 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1164"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0fb8d3ce-9e96-481c-9c68-88d4e3019310","type":"Microsoft.Authorization/policyDefinitions","name":"0fb8d3ce-9e96-481c-9c68-88d4e3019310"},{"properties":{"displayName":"Microsoft + Managed Control 1166 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1166"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bb02733d-3cc5-4bb0-a6cd-695ba2c2272e","type":"Microsoft.Authorization/policyDefinitions","name":"bb02733d-3cc5-4bb0-a6cd-695ba2c2272e"},{"properties":{"displayName":"Microsoft + Managed Control 1163 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1163"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/961663a1-8a91-4e59-b6f5-1eee57c0f49c","type":"Microsoft.Authorization/policyDefinitions","name":"961663a1-8a91-4e59-b6f5-1eee57c0f49c"},{"properties":{"displayName":"Microsoft + Managed Control 1162 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1162"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5770f3d6-8c2b-4f6f-bf0e-c8c8fc36d592","type":"Microsoft.Authorization/policyDefinitions","name":"5770f3d6-8c2b-4f6f-bf0e-c8c8fc36d592"},{"properties":{"displayName":"Microsoft + Managed Control 1165 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1165"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/47e10916-6c9e-446b-b0bd-ff5fd439d79d","type":"Microsoft.Authorization/policyDefinitions","name":"47e10916-6c9e-446b-b0bd-ff5fd439d79d"},{"properties":{"displayName":"Microsoft + Managed Control 1167 - Continuous Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1167"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cbb2be76-4891-430b-95a7-ca0b0a3d1300","type":"Microsoft.Authorization/policyDefinitions","name":"cbb2be76-4891-430b-95a7-ca0b0a3d1300"},{"properties":{"displayName":"Microsoft + Managed Control 1168 - Continuous Monitoring | Independent Assessment","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1168"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/82409f9e-1f32-4775-bf07-b99d53a91b06","type":"Microsoft.Authorization/policyDefinitions","name":"82409f9e-1f32-4775-bf07-b99d53a91b06"},{"properties":{"displayName":"Microsoft + Managed Control 1170 - Penetration Testing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1170"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8b78b9b3-ee3c-48e0-a243-ed6dba5b7a12","type":"Microsoft.Authorization/policyDefinitions","name":"8b78b9b3-ee3c-48e0-a243-ed6dba5b7a12"},{"properties":{"displayName":"Microsoft + Managed Control 1169 - Continuous Monitoring | Trend Analyses","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1169"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e7ba2cb3-5675-4468-8b50-8486bdd998a5","type":"Microsoft.Authorization/policyDefinitions","name":"e7ba2cb3-5675-4468-8b50-8486bdd998a5"},{"properties":{"displayName":"Microsoft + Managed Control 1171 - Penetration Testing | Independent Penetration Agent + Or Team","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1171"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6d4820bc-8b61-4982-9501-2123cb776c00","type":"Microsoft.Authorization/policyDefinitions","name":"6d4820bc-8b61-4982-9501-2123cb776c00"},{"properties":{"displayName":"Microsoft + Managed Control 1173 - Internal System Connections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1173"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c4aff9e7-2e60-46fa-86be-506b79033fc5","type":"Microsoft.Authorization/policyDefinitions","name":"c4aff9e7-2e60-46fa-86be-506b79033fc5"},{"properties":{"displayName":"Microsoft + Managed Control 1174 - Configuration Management Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1174"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/42a9a714-8fbb-43ac-b115-ea12d2bd652f","type":"Microsoft.Authorization/policyDefinitions","name":"42a9a714-8fbb-43ac-b115-ea12d2bd652f"},{"properties":{"displayName":"Microsoft + Managed Control 1175 - Configuration Management Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1175"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6dab4254-c30d-4bb7-ae99-1d21586c063c","type":"Microsoft.Authorization/policyDefinitions","name":"6dab4254-c30d-4bb7-ae99-1d21586c063c"},{"properties":{"displayName":"Microsoft + Managed Control 1177 - Baseline Configuration | Reviews And Updates","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1177"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/63dbc7a8-e20b-4d38-b857-a7f6c0cd94bc","type":"Microsoft.Authorization/policyDefinitions","name":"63dbc7a8-e20b-4d38-b857-a7f6c0cd94bc"},{"properties":{"displayName":"Microsoft + Managed Control 1172 - Internal System Connections","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Security Assessment and Authorization control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1172"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b43e946e-a4c8-4b92-8201-4a39331db43c","type":"Microsoft.Authorization/policyDefinitions","name":"b43e946e-a4c8-4b92-8201-4a39331db43c"},{"properties":{"displayName":"Microsoft + Managed Control 1176 - Baseline Configuration","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1176"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c30690a5-7bf3-467f-b0cd-ef5c7c7449cd","type":"Microsoft.Authorization/policyDefinitions","name":"c30690a5-7bf3-467f-b0cd-ef5c7c7449cd"},{"properties":{"displayName":"Microsoft + Managed Control 1178 - Baseline Configuration | Reviews And Updates","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1178"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7818b8f4-47c6-441a-90ae-12ce04e99893","type":"Microsoft.Authorization/policyDefinitions","name":"7818b8f4-47c6-441a-90ae-12ce04e99893"},{"properties":{"displayName":"Microsoft + Managed Control 1179 - Baseline Configuration | Reviews And Updates","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1179"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3f9ce557-c8ab-4e6c-bb2c-9b8ed002c46c","type":"Microsoft.Authorization/policyDefinitions","name":"3f9ce557-c8ab-4e6c-bb2c-9b8ed002c46c"},{"properties":{"displayName":"Microsoft + Managed Control 1180 - Baseline Configuration | Automation Support For Accuracy + / Currency","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1180"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/874e7880-a067-42a7-bcbe-1a340f54c8cc","type":"Microsoft.Authorization/policyDefinitions","name":"874e7880-a067-42a7-bcbe-1a340f54c8cc"},{"properties":{"displayName":"Microsoft + Managed Control 1181 - Baseline Configuration | Retention Of Previous Configurations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1181"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/21839937-d241-4fa5-95c6-b669253d9ab9","type":"Microsoft.Authorization/policyDefinitions","name":"21839937-d241-4fa5-95c6-b669253d9ab9"},{"properties":{"displayName":"Microsoft + Managed Control 1183 - Baseline Configuration | Configure Systems, Components, + Or Devices For High-Risk Areas","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1183"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5352e3e0-e63a-452e-9e5f-9c1d181cff9c","type":"Microsoft.Authorization/policyDefinitions","name":"5352e3e0-e63a-452e-9e5f-9c1d181cff9c"},{"properties":{"displayName":"Microsoft + Managed Control 1185 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1185"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6420cd73-b939-43b7-9d99-e8688fea053c","type":"Microsoft.Authorization/policyDefinitions","name":"6420cd73-b939-43b7-9d99-e8688fea053c"},{"properties":{"displayName":"Microsoft + Managed Control 1182 - Baseline Configuration | Configure Systems, Components, + Or Devices For High-Risk Areas","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1182"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4f34f554-da4b-4786-8d66-7915c90893da","type":"Microsoft.Authorization/policyDefinitions","name":"4f34f554-da4b-4786-8d66-7915c90893da"},{"properties":{"displayName":"Microsoft + Managed Control 1187 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1187"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9f2b2f9e-4ba6-46c3-907f-66db138b6f85","type":"Microsoft.Authorization/policyDefinitions","name":"9f2b2f9e-4ba6-46c3-907f-66db138b6f85"},{"properties":{"displayName":"Microsoft + Managed Control 1184 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1184"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/13579d0e-0ab0-4b26-b0fb-d586f6d7ed20","type":"Microsoft.Authorization/policyDefinitions","name":"13579d0e-0ab0-4b26-b0fb-d586f6d7ed20"},{"properties":{"displayName":"Microsoft + Managed Control 1186 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1186"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b95ba3bd-4ded-49ea-9d10-c6f4b680813d","type":"Microsoft.Authorization/policyDefinitions","name":"b95ba3bd-4ded-49ea-9d10-c6f4b680813d"},{"properties":{"displayName":"Microsoft + Managed Control 1188 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1188"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bb20548a-c926-4e4d-855c-bcddc6faf95e","type":"Microsoft.Authorization/policyDefinitions","name":"bb20548a-c926-4e4d-855c-bcddc6faf95e"},{"properties":{"displayName":"Microsoft + Managed Control 1190 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1190"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c66a3d1e-465b-4f28-9da5-aef701b59892","type":"Microsoft.Authorization/policyDefinitions","name":"c66a3d1e-465b-4f28-9da5-aef701b59892"},{"properties":{"displayName":"Microsoft + Managed Control 1189 - Configuration Change Control","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1189"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ee45e02a-4140-416c-82c4-fecfea660b9d","type":"Microsoft.Authorization/policyDefinitions","name":"ee45e02a-4140-416c-82c4-fecfea660b9d"},{"properties":{"displayName":"Microsoft + Managed Control 1191 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1191"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7f26a61b-a74d-467c-99cf-63644db144f7","type":"Microsoft.Authorization/policyDefinitions","name":"7f26a61b-a74d-467c-99cf-63644db144f7"},{"properties":{"displayName":"Microsoft + Managed Control 1192 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1192"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4ebd97f7-b105-4f50-8daf-c51465991240","type":"Microsoft.Authorization/policyDefinitions","name":"4ebd97f7-b105-4f50-8daf-c51465991240"},{"properties":{"displayName":"Microsoft + Managed Control 1193 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1193"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f5fd629f-3075-4cae-ab53-bad65495a4ac","type":"Microsoft.Authorization/policyDefinitions","name":"f5fd629f-3075-4cae-ab53-bad65495a4ac"},{"properties":{"displayName":"Microsoft + Managed Control 1195 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1195"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d1e1d65c-1013-4484-bd54-991332e6a0d2","type":"Microsoft.Authorization/policyDefinitions","name":"d1e1d65c-1013-4484-bd54-991332e6a0d2"},{"properties":{"displayName":"Microsoft + Managed Control 1194 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1194"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bc34667f-397e-4a65-9b72-d0358f0b6b09","type":"Microsoft.Authorization/policyDefinitions","name":"bc34667f-397e-4a65-9b72-d0358f0b6b09"},{"properties":{"displayName":"Microsoft + Managed Control 1196 - Configuration Change Control | Automated Document / + Notification / Prohibition Of Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1196"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e7f4ea4-dd62-44f6-8886-ac6137cf52b0","type":"Microsoft.Authorization/policyDefinitions","name":"4e7f4ea4-dd62-44f6-8886-ac6137cf52b0"},{"properties":{"displayName":"Microsoft + Managed Control 1198 - Configuration Change Control | Security Representative","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1198"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f56be5c3-660b-4c61-9078-f67cf072c356","type":"Microsoft.Authorization/policyDefinitions","name":"f56be5c3-660b-4c61-9078-f67cf072c356"},{"properties":{"displayName":"Microsoft + Managed Control 1199 - Configuration Change Control | Cryptography Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1199"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a9a08d1c-09b1-48f1-90ea-029bbdf7111e","type":"Microsoft.Authorization/policyDefinitions","name":"a9a08d1c-09b1-48f1-90ea-029bbdf7111e"},{"properties":{"displayName":"Microsoft + Managed Control 1201 - Security Impact Analysis | Separate Test Environments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1201"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7daef997-fdd3-461b-8807-a608a6dd70f1","type":"Microsoft.Authorization/policyDefinitions","name":"7daef997-fdd3-461b-8807-a608a6dd70f1"},{"properties":{"displayName":"Microsoft + Managed Control 1200 - Security Impact Analysis","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1200"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e98fe9d7-2ed3-44f8-93b7-24dca69783ff","type":"Microsoft.Authorization/policyDefinitions","name":"e98fe9d7-2ed3-44f8-93b7-24dca69783ff"},{"properties":{"displayName":"Microsoft + Managed Control 1203 - Access Restrictions For Change | Automated Access Enforcement + / Auditing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1203"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f9012d14-e3e6-4d7b-b926-9f37b5537066","type":"Microsoft.Authorization/policyDefinitions","name":"f9012d14-e3e6-4d7b-b926-9f37b5537066"},{"properties":{"displayName":"Microsoft + Managed Control 1202 - Access Restrictions For Change","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1202"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/40a2a83b-74f2-4c02-ae65-f460a5d2792a","type":"Microsoft.Authorization/policyDefinitions","name":"40a2a83b-74f2-4c02-ae65-f460a5d2792a"},{"properties":{"displayName":"Microsoft + Managed Control 1197 - Configuration Change Control | Test / Validate / Document + Changes","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1197"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a20d2eaa-88e2-4907-96a2-8f3a05797e5c","type":"Microsoft.Authorization/policyDefinitions","name":"a20d2eaa-88e2-4907-96a2-8f3a05797e5c"},{"properties":{"displayName":"Microsoft + Managed Control 1205 - Access Restrictions For Change | Signed Components","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1205"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5b070cab-0fb8-4e48-ad29-fc90b4c2797c","type":"Microsoft.Authorization/policyDefinitions","name":"5b070cab-0fb8-4e48-ad29-fc90b4c2797c"},{"properties":{"displayName":"Microsoft + Managed Control 1206 - Access Restrictions For Change | Limit Production / + Operational Privileges","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1206"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e0de232d-02a0-4652-872d-88afb4ae5e91","type":"Microsoft.Authorization/policyDefinitions","name":"e0de232d-02a0-4652-872d-88afb4ae5e91"},{"properties":{"displayName":"Microsoft + Managed Control 1207 - Access Restrictions For Change | Limit Production / + Operational Privileges","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1207"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8713a0ed-0d1e-4d10-be82-83dffb39830e","type":"Microsoft.Authorization/policyDefinitions","name":"8713a0ed-0d1e-4d10-be82-83dffb39830e"},{"properties":{"displayName":"Microsoft + Managed Control 1204 - Access Restrictions For Change | Review System Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1204"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0f4f6750-d1ab-4a4c-8dfd-af3237682665","type":"Microsoft.Authorization/policyDefinitions","name":"0f4f6750-d1ab-4a4c-8dfd-af3237682665"},{"properties":{"displayName":"Microsoft + Managed Control 1208 - Configuration Settings","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1208"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5ea87673-d06b-456f-a324-8abcee5c159f","type":"Microsoft.Authorization/policyDefinitions","name":"5ea87673-d06b-456f-a324-8abcee5c159f"},{"properties":{"displayName":"Microsoft + Managed Control 1209 - Configuration Settings","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1209"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ce669c31-9103-4552-ae9c-cdef4e03580d","type":"Microsoft.Authorization/policyDefinitions","name":"ce669c31-9103-4552-ae9c-cdef4e03580d"},{"properties":{"displayName":"Microsoft + Managed Control 1210 - Configuration Settings","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1210"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3502c968-c490-4570-8167-1476f955e9b8","type":"Microsoft.Authorization/policyDefinitions","name":"3502c968-c490-4570-8167-1476f955e9b8"},{"properties":{"displayName":"Microsoft + Managed Control 1211 - Configuration Settings","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1211"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6a8b9dc8-6b00-4701-aa96-bba3277ebf50","type":"Microsoft.Authorization/policyDefinitions","name":"6a8b9dc8-6b00-4701-aa96-bba3277ebf50"},{"properties":{"displayName":"Microsoft + Managed Control 1212 - Configuration Settings | Automated Central Management + / Application / Verification","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1212"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/56d970ee-4efc-49c8-8a4e-5916940d784c","type":"Microsoft.Authorization/policyDefinitions","name":"56d970ee-4efc-49c8-8a4e-5916940d784c"},{"properties":{"displayName":"Microsoft + Managed Control 1215 - Least Functionality","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1215"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/88fc93e8-4745-4785-b5a5-b44bb92c44ff","type":"Microsoft.Authorization/policyDefinitions","name":"88fc93e8-4745-4785-b5a5-b44bb92c44ff"},{"properties":{"displayName":"Microsoft + Managed Control 1214 - Least Functionality","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1214"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f714a4e2-b580-47b6-ae8c-f2812d3750f3","type":"Microsoft.Authorization/policyDefinitions","name":"f714a4e2-b580-47b6-ae8c-f2812d3750f3"},{"properties":{"displayName":"Microsoft + Managed Control 1216 - Least Functionality | Periodic Review","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1216"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7894fe6a-f5cb-44c8-ba90-c3f254ff9484","type":"Microsoft.Authorization/policyDefinitions","name":"7894fe6a-f5cb-44c8-ba90-c3f254ff9484"},{"properties":{"displayName":"Microsoft + Managed Control 1213 - Configuration Settings | Respond To Unauthorized Changes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1213"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/81f11e32-a293-4a58-82cd-134af52e2318","type":"Microsoft.Authorization/policyDefinitions","name":"81f11e32-a293-4a58-82cd-134af52e2318"},{"properties":{"displayName":"Microsoft + Managed Control 1217 - Least Functionality | Periodic Review","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1217"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/edea4f20-b02c-4115-be75-86c080e5c0ed","type":"Microsoft.Authorization/policyDefinitions","name":"edea4f20-b02c-4115-be75-86c080e5c0ed"},{"properties":{"displayName":"Microsoft + Managed Control 1218 - Least Functionality | Prevent Program Execution","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1218"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4a1d0394-b9f5-493e-9e83-563fd0ac4df8","type":"Microsoft.Authorization/policyDefinitions","name":"4a1d0394-b9f5-493e-9e83-563fd0ac4df8"},{"properties":{"displayName":"Microsoft + Managed Control 1219 - Least Functionality | Authorized Software / Whitelisting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1219"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2a39ac75-622b-4c88-9a3f-45b7373f7ef7","type":"Microsoft.Authorization/policyDefinitions","name":"2a39ac75-622b-4c88-9a3f-45b7373f7ef7"},{"properties":{"displayName":"Microsoft + Managed Control 1220 - Least Functionality | Authorized Software / Whitelisting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1220"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c40f31a7-81e1-4130-99e5-a02ceea2a1d6","type":"Microsoft.Authorization/policyDefinitions","name":"c40f31a7-81e1-4130-99e5-a02ceea2a1d6"},{"properties":{"displayName":"Microsoft + Managed Control 1222 - Information System Component Inventory","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1222"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fb39e62f-6bda-4558-8088-ec03d5670914","type":"Microsoft.Authorization/policyDefinitions","name":"fb39e62f-6bda-4558-8088-ec03d5670914"},{"properties":{"displayName":"Microsoft + Managed Control 1223 - Information System Component Inventory","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1223"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/05a1bb01-ad5a-49c1-aad3-b0c893b2ec3a","type":"Microsoft.Authorization/policyDefinitions","name":"05a1bb01-ad5a-49c1-aad3-b0c893b2ec3a"},{"properties":{"displayName":"Microsoft + Managed Control 1224 - Information System Component Inventory | Updates During + Installations / Removals","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1224"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/28cfa30b-7f72-47ce-ba3b-eed26c8d2c82","type":"Microsoft.Authorization/policyDefinitions","name":"28cfa30b-7f72-47ce-ba3b-eed26c8d2c82"},{"properties":{"displayName":"Microsoft + Managed Control 1225 - Information System Component Inventory | Automated + Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1225"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8d096fe0-f510-4486-8b4d-d17dc230980b","type":"Microsoft.Authorization/policyDefinitions","name":"8d096fe0-f510-4486-8b4d-d17dc230980b"},{"properties":{"displayName":"Microsoft + Managed Control 1227 - Information System Component Inventory | Automated + Unauthorized Component Detection","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1227"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/03b78f5e-4877-4303-b0f4-eb6583f25768","type":"Microsoft.Authorization/policyDefinitions","name":"03b78f5e-4877-4303-b0f4-eb6583f25768"},{"properties":{"displayName":"Microsoft + Managed Control 1226 - Information System Component Inventory | Automated + Unauthorized Component Detection","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1226"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c158eb1c-ae7e-4081-8057-d527140c4e0c","type":"Microsoft.Authorization/policyDefinitions","name":"c158eb1c-ae7e-4081-8057-d527140c4e0c"},{"properties":{"displayName":"Microsoft + Managed Control 1221 - Least Functionality | Authorized Software / Whitelisting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1221"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/22589a07-0007-486a-86ca-95355081ae2a","type":"Microsoft.Authorization/policyDefinitions","name":"22589a07-0007-486a-86ca-95355081ae2a"},{"properties":{"displayName":"Microsoft + Managed Control 1228 - Information System Component Inventory | Accountability + Information","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1228"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/39c54140-5902-4079-8bb5-ad31936fe764","type":"Microsoft.Authorization/policyDefinitions","name":"39c54140-5902-4079-8bb5-ad31936fe764"},{"properties":{"displayName":"Microsoft + Managed Control 1230 - Configuration Management Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1230"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/11158848-f679-4e9b-aa7b-9fb07d945071","type":"Microsoft.Authorization/policyDefinitions","name":"11158848-f679-4e9b-aa7b-9fb07d945071"},{"properties":{"displayName":"Microsoft + Managed Control 1229 - Information System Component Inventory | No Duplicate + Accounting Of Components","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1229"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/03752212-103c-4ab8-a306-7e813022ca9d","type":"Microsoft.Authorization/policyDefinitions","name":"03752212-103c-4ab8-a306-7e813022ca9d"},{"properties":{"displayName":"Microsoft + Managed Control 1231 - Configuration Management Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1231"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/244e0c05-cc45-4fe7-bf36-42dcf01f457d","type":"Microsoft.Authorization/policyDefinitions","name":"244e0c05-cc45-4fe7-bf36-42dcf01f457d"},{"properties":{"displayName":"Microsoft + Managed Control 1232 - Configuration Management Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1232"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/396ba986-eac1-4d6d-85c4-d3fda6b78272","type":"Microsoft.Authorization/policyDefinitions","name":"396ba986-eac1-4d6d-85c4-d3fda6b78272"},{"properties":{"displayName":"Microsoft + Managed Control 1234 - Software Usage Restrictions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1234"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b293f881-361c-47ed-b997-bc4e2296bc0b","type":"Microsoft.Authorization/policyDefinitions","name":"b293f881-361c-47ed-b997-bc4e2296bc0b"},{"properties":{"displayName":"Microsoft + Managed Control 1233 - Configuration Management Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1233"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9d79001f-95fe-45d0-8736-f217e78c1f57","type":"Microsoft.Authorization/policyDefinitions","name":"9d79001f-95fe-45d0-8736-f217e78c1f57"},{"properties":{"displayName":"Microsoft + Managed Control 1236 - Software Usage Restrictions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1236"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9ba3ed84-c768-4e18-b87c-34ef1aff1b57","type":"Microsoft.Authorization/policyDefinitions","name":"9ba3ed84-c768-4e18-b87c-34ef1aff1b57"},{"properties":{"displayName":"Microsoft + Managed Control 1235 - Software Usage Restrictions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1235"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c49c610b-ece4-44b3-988c-2172b70d6e46","type":"Microsoft.Authorization/policyDefinitions","name":"c49c610b-ece4-44b3-988c-2172b70d6e46"},{"properties":{"displayName":"Microsoft + Managed Control 1237 - Software Usage Restrictions | Open Source Software","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1237"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e80b6812-0bfa-4383-8223-cdd86a46a890","type":"Microsoft.Authorization/policyDefinitions","name":"e80b6812-0bfa-4383-8223-cdd86a46a890"},{"properties":{"displayName":"Microsoft + Managed Control 1238 - User-Installed Software","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1238"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a36cedd4-3ffd-4b1f-8b18-aa71d8d87ce1","type":"Microsoft.Authorization/policyDefinitions","name":"a36cedd4-3ffd-4b1f-8b18-aa71d8d87ce1"},{"properties":{"displayName":"Microsoft + Managed Control 1239 - User-Installed Software","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1239"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0be51298-f643-4556-88af-d7db90794879","type":"Microsoft.Authorization/policyDefinitions","name":"0be51298-f643-4556-88af-d7db90794879"},{"properties":{"displayName":"Microsoft + Managed Control 1240 - User-Installed Software","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1240"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/129eb39f-d79a-4503-84cd-92f036b5e429","type":"Microsoft.Authorization/policyDefinitions","name":"129eb39f-d79a-4503-84cd-92f036b5e429"},{"properties":{"displayName":"Microsoft + Managed Control 1242 - Contingency Planning Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1242"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cf3b3293-667a-445e-a722-fa0b0afc0958","type":"Microsoft.Authorization/policyDefinitions","name":"cf3b3293-667a-445e-a722-fa0b0afc0958"},{"properties":{"displayName":"Microsoft + Managed Control 1241 - User-Installed Software | Alerts For Unauthorized Installations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Configuration Management control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1241"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eca4d7b2-65e2-4e04-95d4-c68606b063c3","type":"Microsoft.Authorization/policyDefinitions","name":"eca4d7b2-65e2-4e04-95d4-c68606b063c3"},{"properties":{"displayName":"Microsoft + Managed Control 1243 - Contingency Planning Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1243"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ca9a4469-d6df-4ab2-a42f-1213c396f0ec","type":"Microsoft.Authorization/policyDefinitions","name":"ca9a4469-d6df-4ab2-a42f-1213c396f0ec"},{"properties":{"displayName":"Microsoft + Managed Control 1244 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1244"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6a13a8f8-c163-4b1b-8554-d63569dab937","type":"Microsoft.Authorization/policyDefinitions","name":"6a13a8f8-c163-4b1b-8554-d63569dab937"},{"properties":{"displayName":"Microsoft + Managed Control 1245 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1245"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a0e45314-57b8-4623-80cd-bbb561f59516","type":"Microsoft.Authorization/policyDefinitions","name":"a0e45314-57b8-4623-80cd-bbb561f59516"},{"properties":{"displayName":"Microsoft + Managed Control 1246 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1246"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/398eb61e-8111-40d5-a0c9-003df28f1753","type":"Microsoft.Authorization/policyDefinitions","name":"398eb61e-8111-40d5-a0c9-003df28f1753"},{"properties":{"displayName":"Microsoft + Managed Control 1247 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1247"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e666db5-b2ef-4b06-aac6-09bfce49151b","type":"Microsoft.Authorization/policyDefinitions","name":"4e666db5-b2ef-4b06-aac6-09bfce49151b"},{"properties":{"displayName":"Microsoft + Managed Control 1249 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1249"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d3bf4251-0818-42db-950b-afd5b25a51c2","type":"Microsoft.Authorization/policyDefinitions","name":"d3bf4251-0818-42db-950b-afd5b25a51c2"},{"properties":{"displayName":"Microsoft + Managed Control 1248 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1248"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/50fc602d-d8e0-444b-a039-ad138ee5deb0","type":"Microsoft.Authorization/policyDefinitions","name":"50fc602d-d8e0-444b-a039-ad138ee5deb0"},{"properties":{"displayName":"Microsoft + Managed Control 1250 - Contingency Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1250"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8de614d8-a8b7-4f70-a62a-6d37089a002c","type":"Microsoft.Authorization/policyDefinitions","name":"8de614d8-a8b7-4f70-a62a-6d37089a002c"},{"properties":{"displayName":"Microsoft + Managed Control 1251 - Contingency Plan | Coordinate With Related Plans","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1251"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5e2b3730-8c14-4081-8893-19dbb5de7348","type":"Microsoft.Authorization/policyDefinitions","name":"5e2b3730-8c14-4081-8893-19dbb5de7348"},{"properties":{"displayName":"Microsoft + Managed Control 1252 - Contingency Plan | Capacity Planning","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1252"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a328fd72-8ff5-4f96-8c9c-b30ed95db4ab","type":"Microsoft.Authorization/policyDefinitions","name":"a328fd72-8ff5-4f96-8c9c-b30ed95db4ab"},{"properties":{"displayName":"Microsoft + Managed Control 1253 - Contingency Plan | Resume Essential Missions / Business + Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1253"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0afce0b3-dd9f-42bb-af28-1e4284ba8311","type":"Microsoft.Authorization/policyDefinitions","name":"0afce0b3-dd9f-42bb-af28-1e4284ba8311"},{"properties":{"displayName":"Microsoft + Managed Control 1254 - Contingency Plan | Resume All Missions / Business Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1254"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/704e136a-4fe0-427c-b829-cd69957f5d2b","type":"Microsoft.Authorization/policyDefinitions","name":"704e136a-4fe0-427c-b829-cd69957f5d2b"},{"properties":{"displayName":"Microsoft + Managed Control 1257 - Contingency Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1257"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b958b241-4245-4bd6-bd2d-b8f0779fb543","type":"Microsoft.Authorization/policyDefinitions","name":"b958b241-4245-4bd6-bd2d-b8f0779fb543"},{"properties":{"displayName":"Microsoft + Managed Control 1256 - Contingency Plan | Identify Critical Assets","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1256"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/232ab24b-810b-4640-9019-74a7d0d6a980","type":"Microsoft.Authorization/policyDefinitions","name":"232ab24b-810b-4640-9019-74a7d0d6a980"},{"properties":{"displayName":"Microsoft + Managed Control 1255 - Contingency Plan | Continue Essential Missions / Business + Functions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1255"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f3793f5e-937f-44f7-bfba-40647ef3efa0","type":"Microsoft.Authorization/policyDefinitions","name":"f3793f5e-937f-44f7-bfba-40647ef3efa0"},{"properties":{"displayName":"Microsoft + Managed Control 1258 - Contingency Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1258"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7814506c-382c-4d33-a142-249dd4a0dbff","type":"Microsoft.Authorization/policyDefinitions","name":"7814506c-382c-4d33-a142-249dd4a0dbff"},{"properties":{"displayName":"Microsoft + Managed Control 1260 - Contingency Training | Simulated Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1260"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/42254fc4-2738-4128-9613-72aaa4f0d9c3","type":"Microsoft.Authorization/policyDefinitions","name":"42254fc4-2738-4128-9613-72aaa4f0d9c3"},{"properties":{"displayName":"Microsoft + Managed Control 1259 - Contingency Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1259"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9d9e18f7-bad9-4d30-8806-a0c9d5e26208","type":"Microsoft.Authorization/policyDefinitions","name":"9d9e18f7-bad9-4d30-8806-a0c9d5e26208"},{"properties":{"displayName":"Microsoft + Managed Control 1264 - Contingency Plan Testing | Coordinate With Related + Plans","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1264"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dd280d4b-50a1-42fb-a479-ece5878acf19","type":"Microsoft.Authorization/policyDefinitions","name":"dd280d4b-50a1-42fb-a479-ece5878acf19"},{"properties":{"displayName":"Microsoft + Managed Control 1266 - Contingency Plan Testing | Alternate Processing Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1266"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3b4a3eb2-c25d-40bf-ad41-5094b6f59cee","type":"Microsoft.Authorization/policyDefinitions","name":"3b4a3eb2-c25d-40bf-ad41-5094b6f59cee"},{"properties":{"displayName":"Microsoft + Managed Control 1263 - Contingency Plan Testing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1263"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/41472613-3b05-49f6-8fe8-525af113ce17","type":"Microsoft.Authorization/policyDefinitions","name":"41472613-3b05-49f6-8fe8-525af113ce17"},{"properties":{"displayName":"Microsoft + Managed Control 1261 - Contingency Plan Testing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1261"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/65aeceb5-a59c-4cb1-8d82-9c474be5d431","type":"Microsoft.Authorization/policyDefinitions","name":"65aeceb5-a59c-4cb1-8d82-9c474be5d431"},{"properties":{"displayName":"Microsoft + Managed Control 1262 - Contingency Plan Testing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1262"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/831e510e-db41-4c72-888e-a0621ab62265","type":"Microsoft.Authorization/policyDefinitions","name":"831e510e-db41-4c72-888e-a0621ab62265"},{"properties":{"displayName":"Microsoft + Managed Control 1265 - Contingency Plan Testing | Alternate Processing Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1265"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a18adb5b-1db6-4a5b-901a-7d3797d12972","type":"Microsoft.Authorization/policyDefinitions","name":"a18adb5b-1db6-4a5b-901a-7d3797d12972"},{"properties":{"displayName":"Microsoft + Managed Control 1267 - Alternate Storage Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1267"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4e97ba1d-be5d-4953-8da4-0cccf28f4805","type":"Microsoft.Authorization/policyDefinitions","name":"4e97ba1d-be5d-4953-8da4-0cccf28f4805"},{"properties":{"displayName":"Microsoft + Managed Control 1268 - Alternate Storage Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1268"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/23f6e984-3053-4dfc-ab48-543b764781f5","type":"Microsoft.Authorization/policyDefinitions","name":"23f6e984-3053-4dfc-ab48-543b764781f5"},{"properties":{"displayName":"Microsoft + Managed Control 1269 - Alternate Storage Site | Separation From Primary Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1269"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/19b9439d-865d-4474-b17d-97d2702fdb66","type":"Microsoft.Authorization/policyDefinitions","name":"19b9439d-865d-4474-b17d-97d2702fdb66"},{"properties":{"displayName":"Microsoft + Managed Control 1270 - Alternate Storage Site | Recovery Time / Point Objectives","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1270"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/53c76a39-2097-408a-b237-b279f7b4614d","type":"Microsoft.Authorization/policyDefinitions","name":"53c76a39-2097-408a-b237-b279f7b4614d"},{"properties":{"displayName":"Microsoft + Managed Control 1271 - Alternate Storage Site | Accessibility","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1271"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/da3bfb53-9c46-4010-b3db-a7ba1296dada","type":"Microsoft.Authorization/policyDefinitions","name":"da3bfb53-9c46-4010-b3db-a7ba1296dada"},{"properties":{"displayName":"Microsoft + Managed Control 1273 - Alternate Processing Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1273"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e77fcbf2-a1e8-44f1-860e-ed6583761e65","type":"Microsoft.Authorization/policyDefinitions","name":"e77fcbf2-a1e8-44f1-860e-ed6583761e65"},{"properties":{"displayName":"Microsoft + Managed Control 1272 - Alternate Processing Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1272"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ae46cf7a-e3fd-427b-9b91-44bc78e2d9d8","type":"Microsoft.Authorization/policyDefinitions","name":"ae46cf7a-e3fd-427b-9b91-44bc78e2d9d8"},{"properties":{"displayName":"Microsoft + Managed Control 1275 - Alternate Processing Site | Separation From Primary + Site","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1275"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a23d9d53-ad2e-45ef-afd5-e6d10900a737","type":"Microsoft.Authorization/policyDefinitions","name":"a23d9d53-ad2e-45ef-afd5-e6d10900a737"},{"properties":{"displayName":"Microsoft + Managed Control 1274 - Alternate Processing Site","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1274"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2aee175f-cd16-4825-939a-a85349d96210","type":"Microsoft.Authorization/policyDefinitions","name":"2aee175f-cd16-4825-939a-a85349d96210"},{"properties":{"displayName":"Microsoft + Managed Control 1276 - Alternate Processing Site | Accessibility","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1276"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e214e563-1206-4a43-a56b-ac5880c9c571","type":"Microsoft.Authorization/policyDefinitions","name":"e214e563-1206-4a43-a56b-ac5880c9c571"},{"properties":{"displayName":"Microsoft + Managed Control 1278 - Alternate Processing Site | Preparation For Use","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1278"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8e5ef485-9e16-4c53-a475-fbb8107eac59","type":"Microsoft.Authorization/policyDefinitions","name":"8e5ef485-9e16-4c53-a475-fbb8107eac59"},{"properties":{"displayName":"Microsoft + Managed Control 1277 - Alternate Processing Site | Priority Of Service","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1277"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dc43e829-3d50-4a0a-aa0f-428d551862aa","type":"Microsoft.Authorization/policyDefinitions","name":"dc43e829-3d50-4a0a-aa0f-428d551862aa"},{"properties":{"displayName":"Microsoft + Managed Control 1279 - Telecommunications Services","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1279"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7d00bcd6-963d-4c02-ad8e-b45fa50bf3b0","type":"Microsoft.Authorization/policyDefinitions","name":"7d00bcd6-963d-4c02-ad8e-b45fa50bf3b0"},{"properties":{"displayName":"Microsoft + Managed Control 1280 - Telecommunications Services | Priority Of Service Provisions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1280"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fa108498-b3a8-4ffb-9e79-1107e76afad3","type":"Microsoft.Authorization/policyDefinitions","name":"fa108498-b3a8-4ffb-9e79-1107e76afad3"},{"properties":{"displayName":"Microsoft + Managed Control 1281 - Telecommunications Services | Priority Of Service Provisions","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1281"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8dc459b3-0e77-45af-8d71-cfd8c9654fe2","type":"Microsoft.Authorization/policyDefinitions","name":"8dc459b3-0e77-45af-8d71-cfd8c9654fe2"},{"properties":{"displayName":"Microsoft + Managed Control 1282 - Telecommunications Services | Single Points Of Failure","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1282"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/34042a97-ec6d-4263-93d2-8c1c46823b2a","type":"Microsoft.Authorization/policyDefinitions","name":"34042a97-ec6d-4263-93d2-8c1c46823b2a"},{"properties":{"displayName":"Microsoft + Managed Control 1283 - Telecommunications Services | Separation Of Primary + / Alternate Providers","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1283"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a9172e76-7f56-46e9-93bf-75d69bdb5491","type":"Microsoft.Authorization/policyDefinitions","name":"a9172e76-7f56-46e9-93bf-75d69bdb5491"},{"properties":{"displayName":"Microsoft + Managed Control 1285 - Telecommunications Services | Provider Contingency + Plan","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1285"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/01f7726b-db54-45c2-bcb5-9bd7a43796ee","type":"Microsoft.Authorization/policyDefinitions","name":"01f7726b-db54-45c2-bcb5-9bd7a43796ee"},{"properties":{"displayName":"Microsoft + Managed Control 1284 - Telecommunications Services | Provider Contingency + Plan","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1284"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/942b3e97-6ae3-410e-a794-c9c999b97c0b","type":"Microsoft.Authorization/policyDefinitions","name":"942b3e97-6ae3-410e-a794-c9c999b97c0b"},{"properties":{"displayName":"Microsoft + Managed Control 1286 - Telecommunications Services | Provider Contingency + Plan","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1286"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b4f9b47a-2116-4e6f-88db-4edbf22753f1","type":"Microsoft.Authorization/policyDefinitions","name":"b4f9b47a-2116-4e6f-88db-4edbf22753f1"},{"properties":{"displayName":"Microsoft + Managed Control 1288 - Information System Backup","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1288"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8d854c3b-a3e6-4ec9-9f0c-c7274dbaeb2f","type":"Microsoft.Authorization/policyDefinitions","name":"8d854c3b-a3e6-4ec9-9f0c-c7274dbaeb2f"},{"properties":{"displayName":"Microsoft + Managed Control 1287 - Information System Backup","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1287"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/819dc6da-289d-476e-8500-7e341ef8677d","type":"Microsoft.Authorization/policyDefinitions","name":"819dc6da-289d-476e-8500-7e341ef8677d"},{"properties":{"displayName":"Microsoft + Managed Control 1289 - Information System Backup","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1289"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7a724864-956a-496c-b778-637cb1d762cf","type":"Microsoft.Authorization/policyDefinitions","name":"7a724864-956a-496c-b778-637cb1d762cf"},{"properties":{"displayName":"Microsoft + Managed Control 1290 - Information System Backup","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1290"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/92f85ce9-17b7-49ea-85ee-ea7271ea6b82","type":"Microsoft.Authorization/policyDefinitions","name":"92f85ce9-17b7-49ea-85ee-ea7271ea6b82"},{"properties":{"displayName":"Microsoft + Managed Control 1291 - Information System Backup | Testing For Reliability + / Integrity","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1291"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6d8fd073-9c85-4ee2-a9d0-2e4ec9eb8912","type":"Microsoft.Authorization/policyDefinitions","name":"6d8fd073-9c85-4ee2-a9d0-2e4ec9eb8912"},{"properties":{"displayName":"Microsoft + Managed Control 1293 - Information System Backup | Separate Storage For Critical + Information","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1293"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/87f7cd82-2e45-4d0f-9e2f-586b0962d142","type":"Microsoft.Authorization/policyDefinitions","name":"87f7cd82-2e45-4d0f-9e2f-586b0962d142"},{"properties":{"displayName":"Microsoft + Managed Control 1292 - Information System Backup | Test Restoration Using + Sampling","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1292"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d03516cf-0293-489f-9b32-a18f2a79f836","type":"Microsoft.Authorization/policyDefinitions","name":"d03516cf-0293-489f-9b32-a18f2a79f836"},{"properties":{"displayName":"Microsoft + Managed Control 1294 - Information System Backup | Transfer To Alternate Storage + Site","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1294"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/49dbe627-2c1e-438c-979e-dd7a39bbf81d","type":"Microsoft.Authorization/policyDefinitions","name":"49dbe627-2c1e-438c-979e-dd7a39bbf81d"},{"properties":{"displayName":"Microsoft + Managed Control 1296 - Information System Recovery And Reconstitution | Transaction + Recovery","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1296"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e57b98a0-a011-4956-a79d-5d17ed8b8e48","type":"Microsoft.Authorization/policyDefinitions","name":"e57b98a0-a011-4956-a79d-5d17ed8b8e48"},{"properties":{"displayName":"Microsoft + Managed Control 1295 - Information System Recovery And Reconstitution","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1295"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a895fbdb-204d-4302-9689-0a59dc42b3d9","type":"Microsoft.Authorization/policyDefinitions","name":"a895fbdb-204d-4302-9689-0a59dc42b3d9"},{"properties":{"displayName":"Microsoft + Managed Control 1298 - Identification And Authentication Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1298"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1dc784b5-4895-4d27-9d40-a06b032bd1ee","type":"Microsoft.Authorization/policyDefinitions","name":"1dc784b5-4895-4d27-9d40-a06b032bd1ee"},{"properties":{"displayName":"Microsoft + Managed Control 1299 - Identification And Authentication Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1299"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fd4e54f7-9ab0-4bae-b6cc-457809948a89","type":"Microsoft.Authorization/policyDefinitions","name":"fd4e54f7-9ab0-4bae-b6cc-457809948a89"},{"properties":{"displayName":"Microsoft + Managed Control 1297 - Information System Recovery And Reconstitution | Restore + Within Time Period","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Contingency Planning control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1297"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/93fd8af1-c161-4bae-9ba9-f62731f76439","type":"Microsoft.Authorization/policyDefinitions","name":"93fd8af1-c161-4bae-9ba9-f62731f76439"},{"properties":{"displayName":"Microsoft + Managed Control 1300 - Identification And Authentication (Organizational Users)","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1300"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/99deec7d-5526-472e-b07c-3645a792026a","type":"Microsoft.Authorization/policyDefinitions","name":"99deec7d-5526-472e-b07c-3645a792026a"},{"properties":{"displayName":"Microsoft + Managed Control 1301 - Identification And Authentication (Org. Users) | Network + Access To Privileged Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1301"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b6a8e0cc-ac23-468b-abe4-a8a1cc6d7a08","type":"Microsoft.Authorization/policyDefinitions","name":"b6a8e0cc-ac23-468b-abe4-a8a1cc6d7a08"},{"properties":{"displayName":"Microsoft + Managed Control 1303 - Identification And Authentication (Org. Users) | Local + Access To Privileged Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1303"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/80ca0a27-918a-4604-af9e-723a27ee51e8","type":"Microsoft.Authorization/policyDefinitions","name":"80ca0a27-918a-4604-af9e-723a27ee51e8"},{"properties":{"displayName":"Microsoft + Managed Control 1302 - Identification And Authentication (Org. Users) | Network + Access To Non-Privileged Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1302"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/09828c65-e323-422b-9774-9d5c646124da","type":"Microsoft.Authorization/policyDefinitions","name":"09828c65-e323-422b-9774-9d5c646124da"},{"properties":{"displayName":"Microsoft + Managed Control 1304 - Identification And Authentication (Org. Users) | Local + Access To Non-Privileged Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1304"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6ca71be3-16cb-4d39-8b50-7f8fd5e2f11b","type":"Microsoft.Authorization/policyDefinitions","name":"6ca71be3-16cb-4d39-8b50-7f8fd5e2f11b"},{"properties":{"displayName":"Microsoft + Managed Control 1305 - Identification And Authentication (Org. Users) | Group + Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1305"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9d9166a8-1722-4b8f-847c-2cf3f2618b3d","type":"Microsoft.Authorization/policyDefinitions","name":"9d9166a8-1722-4b8f-847c-2cf3f2618b3d"},{"properties":{"displayName":"Microsoft + Managed Control 1306 - Identification And Authentication (Org. Users) | Net. + Access To Priv. Accts. - Replay","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1306"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cafc6c3c-5fc5-4c5e-a99b-a0ccb1d34eff","type":"Microsoft.Authorization/policyDefinitions","name":"cafc6c3c-5fc5-4c5e-a99b-a0ccb1d34eff"},{"properties":{"displayName":"Microsoft + Managed Control 1307 - Identification And Authentication (Org. Users) | Net. + Access To Non-Priv. Accts. - Replay","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1307"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/84e622c8-4bed-417c-84c6-b2fb0dd73682","type":"Microsoft.Authorization/policyDefinitions","name":"84e622c8-4bed-417c-84c6-b2fb0dd73682"},{"properties":{"displayName":"Microsoft + Managed Control 1309 - Identification And Authentication (Org. Users) | Acceptance + Of Piv Credentials","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1309"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f355d62b-39a8-4ba3-abf7-90f71cb3b000","type":"Microsoft.Authorization/policyDefinitions","name":"f355d62b-39a8-4ba3-abf7-90f71cb3b000"},{"properties":{"displayName":"Microsoft + Managed Control 1308 - Identification And Authentication (Org. Users) | Remote + Access - Separate Device","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1308"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/81817e1c-5347-48dd-965a-40159d008229","type":"Microsoft.Authorization/policyDefinitions","name":"81817e1c-5347-48dd-965a-40159d008229"},{"properties":{"displayName":"Microsoft + Managed Control 1310 - Device Identification And Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1310"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/450d7ede-823d-4931-a99d-57f6a38807dc","type":"Microsoft.Authorization/policyDefinitions","name":"450d7ede-823d-4931-a99d-57f6a38807dc"},{"properties":{"displayName":"Microsoft + Managed Control 1311 - Identifier Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1311"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e7568697-0c9e-4ea3-9cec-9e567d14f3c6","type":"Microsoft.Authorization/policyDefinitions","name":"e7568697-0c9e-4ea3-9cec-9e567d14f3c6"},{"properties":{"displayName":"Microsoft + Managed Control 1312 - Identifier Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1312"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4d6a5968-9eef-4c18-8534-376790ab7274","type":"Microsoft.Authorization/policyDefinitions","name":"4d6a5968-9eef-4c18-8534-376790ab7274"},{"properties":{"displayName":"Microsoft + Managed Control 1314 - Identifier Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1314"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ef0c8530-efd9-45b8-b753-f03083d06295","type":"Microsoft.Authorization/policyDefinitions","name":"ef0c8530-efd9-45b8-b753-f03083d06295"},{"properties":{"displayName":"Microsoft + Managed Control 1313 - Identifier Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1313"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/36220f5b-79a1-4cdb-8c74-2d2449f9a510","type":"Microsoft.Authorization/policyDefinitions","name":"36220f5b-79a1-4cdb-8c74-2d2449f9a510"},{"properties":{"displayName":"Microsoft + Managed Control 1315 - Identifier Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1315"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3aa87116-f1a1-4edb-bfbf-14e036f8d454","type":"Microsoft.Authorization/policyDefinitions","name":"3aa87116-f1a1-4edb-bfbf-14e036f8d454"},{"properties":{"displayName":"Microsoft + Managed Control 1316 - Identifier Management | Identify User Status","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1316"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8ce14753-66e5-465d-9841-26ef55c09c0d","type":"Microsoft.Authorization/policyDefinitions","name":"8ce14753-66e5-465d-9841-26ef55c09c0d"},{"properties":{"displayName":"Microsoft + Managed Control 1317 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1317"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8877f519-c166-47b7-81b7-8a8eb4ff3775","type":"Microsoft.Authorization/policyDefinitions","name":"8877f519-c166-47b7-81b7-8a8eb4ff3775"},{"properties":{"displayName":"Microsoft + Managed Control 1319 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1319"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/66f7ae57-5560-4fc5-85c9-659f204e7a42","type":"Microsoft.Authorization/policyDefinitions","name":"66f7ae57-5560-4fc5-85c9-659f204e7a42"},{"properties":{"displayName":"Microsoft + Managed Control 1320 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1320"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6f54c732-71d4-4f93-a696-4e373eca3a77","type":"Microsoft.Authorization/policyDefinitions","name":"6f54c732-71d4-4f93-a696-4e373eca3a77"},{"properties":{"displayName":"Microsoft + Managed Control 1318 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1318"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fced5fda-3bdb-4d73-bfea-0e2c80428b66","type":"Microsoft.Authorization/policyDefinitions","name":"fced5fda-3bdb-4d73-bfea-0e2c80428b66"},{"properties":{"displayName":"Microsoft + Managed Control 1321 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1321"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/eb627cc6-3a9d-46b5-96b7-5fca49178a37","type":"Microsoft.Authorization/policyDefinitions","name":"eb627cc6-3a9d-46b5-96b7-5fca49178a37"},{"properties":{"displayName":"Microsoft + Managed Control 1322 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1322"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9d1d971e-467e-4278-9633-c74c3d4fecc4","type":"Microsoft.Authorization/policyDefinitions","name":"9d1d971e-467e-4278-9633-c74c3d4fecc4"},{"properties":{"displayName":"Microsoft + Managed Control 1323 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1323"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/abe8f70b-680f-470c-9b86-a7edfb664ecc","type":"Microsoft.Authorization/policyDefinitions","name":"abe8f70b-680f-470c-9b86-a7edfb664ecc"},{"properties":{"displayName":"Microsoft + Managed Control 1324 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1324"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8cfea2b3-7f77-497e-ac20-0752f2ff6eee","type":"Microsoft.Authorization/policyDefinitions","name":"8cfea2b3-7f77-497e-ac20-0752f2ff6eee"},{"properties":{"displayName":"Microsoft + Managed Control 1325 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1325"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/1845796a-7581-49b2-ae20-443121538e19","type":"Microsoft.Authorization/policyDefinitions","name":"1845796a-7581-49b2-ae20-443121538e19"},{"properties":{"displayName":"Microsoft + Managed Control 1326 - Authenticator Management","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1326"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8605fc00-1bf5-4fb3-984e-c95cec4f231d","type":"Microsoft.Authorization/policyDefinitions","name":"8605fc00-1bf5-4fb3-984e-c95cec4f231d"},{"properties":{"displayName":"Microsoft + Managed Control 1327 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1327"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/03188d8f-1ae5-4fe1-974d-2d7d32ef937d","type":"Microsoft.Authorization/policyDefinitions","name":"03188d8f-1ae5-4fe1-974d-2d7d32ef937d"},{"properties":{"displayName":"Microsoft + Managed Control 1328 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1328"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f5c66fdc-3d02-4034-9db5-ba57802609de","type":"Microsoft.Authorization/policyDefinitions","name":"f5c66fdc-3d02-4034-9db5-ba57802609de"},{"properties":{"displayName":"Microsoft + Managed Control 1329 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1329"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/498f6234-3e20-4b6a-a880-cbd646d973bd","type":"Microsoft.Authorization/policyDefinitions","name":"498f6234-3e20-4b6a-a880-cbd646d973bd"},{"properties":{"displayName":"Microsoft + Managed Control 1330 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1330"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f75cedb2-5def-4b31-973e-b69e8c7bd031","type":"Microsoft.Authorization/policyDefinitions","name":"f75cedb2-5def-4b31-973e-b69e8c7bd031"},{"properties":{"displayName":"Microsoft + Managed Control 1331 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1331"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/05460fe2-301f-4ed1-8174-d62c8bb92ff4","type":"Microsoft.Authorization/policyDefinitions","name":"05460fe2-301f-4ed1-8174-d62c8bb92ff4"},{"properties":{"displayName":"Microsoft + Managed Control 1332 - Authenticator Management | Password-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1332"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/068260be-a5e6-4b0a-a430-cd27071c226a","type":"Microsoft.Authorization/policyDefinitions","name":"068260be-a5e6-4b0a-a430-cd27071c226a"},{"properties":{"displayName":"Microsoft + Managed Control 1334 - Authenticator Management | Pki-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1334"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/44bfdadc-8c2e-4c30-9c99-f005986fabcd","type":"Microsoft.Authorization/policyDefinitions","name":"44bfdadc-8c2e-4c30-9c99-f005986fabcd"},{"properties":{"displayName":"Microsoft + Managed Control 1333 - Authenticator Management | Pki-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1333"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3298d6bf-4bc6-4278-a95d-f7ef3ac6e594","type":"Microsoft.Authorization/policyDefinitions","name":"3298d6bf-4bc6-4278-a95d-f7ef3ac6e594"},{"properties":{"displayName":"Microsoft + Managed Control 1335 - Authenticator Management | Pki-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1335"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/382016f3-d4ba-4e15-9716-55077ec4dc2a","type":"Microsoft.Authorization/policyDefinitions","name":"382016f3-d4ba-4e15-9716-55077ec4dc2a"},{"properties":{"displayName":"Microsoft + Managed Control 1336 - Authenticator Management | Pki-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1336"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/77f56280-e367-432a-a3b9-8ca2aa636a26","type":"Microsoft.Authorization/policyDefinitions","name":"77f56280-e367-432a-a3b9-8ca2aa636a26"},{"properties":{"displayName":"Microsoft + Managed Control 1337 - Authenticator Management | In-Person Or Trusted Third-Party + Registration","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1337"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/463e5220-3f79-4e24-a63f-343e4096cd22","type":"Microsoft.Authorization/policyDefinitions","name":"463e5220-3f79-4e24-a63f-343e4096cd22"},{"properties":{"displayName":"Microsoft + Managed Control 1338 - Authenticator Management | Automated Support For Password + Strength Determination","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1338"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/6c59a207-6aed-41dc-83a2-e1ff66e4a4db","type":"Microsoft.Authorization/policyDefinitions","name":"6c59a207-6aed-41dc-83a2-e1ff66e4a4db"},{"properties":{"displayName":"Microsoft + Managed Control 1340 - Authenticator Management | No Embedded Unencrypted + Static Authenticators","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1340"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e51ff84b-e5ea-408f-b651-2ecc2933e4c6","type":"Microsoft.Authorization/policyDefinitions","name":"e51ff84b-e5ea-408f-b651-2ecc2933e4c6"},{"properties":{"displayName":"Microsoft + Managed Control 1339 - Authenticator Management | Protection Of Authenticators","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1339"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/367ae386-db7f-4167-b672-984ff86277c0","type":"Microsoft.Authorization/policyDefinitions","name":"367ae386-db7f-4167-b672-984ff86277c0"},{"properties":{"displayName":"Microsoft + Managed Control 1341 - Authenticator Management | Multiple Information System + Accounts","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1341"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/34cb7e92-fe4c-4826-b51e-8cd203fa5d35","type":"Microsoft.Authorization/policyDefinitions","name":"34cb7e92-fe4c-4826-b51e-8cd203fa5d35"},{"properties":{"displayName":"Microsoft + Managed Control 1342 - Authenticator Management | Hardware Token-Based Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1342"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/283a4e29-69d5-4c94-b99e-29acf003c899","type":"Microsoft.Authorization/policyDefinitions","name":"283a4e29-69d5-4c94-b99e-29acf003c899"},{"properties":{"displayName":"Microsoft + Managed Control 1343 - Authenticator Management | Expiration Of Cached Authenticators","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1343"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2c251a55-31eb-4e53-99c6-e9c43c393ac2","type":"Microsoft.Authorization/policyDefinitions","name":"2c251a55-31eb-4e53-99c6-e9c43c393ac2"},{"properties":{"displayName":"Microsoft + Managed Control 1345 - Cryptographic Module Authentication","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1345"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/f86aa129-7c07-4aa4-bbf5-792d93ffd9ea","type":"Microsoft.Authorization/policyDefinitions","name":"f86aa129-7c07-4aa4-bbf5-792d93ffd9ea"},{"properties":{"displayName":"Microsoft + Managed Control 1346 - Identification And Authentication (Non-Organizational + Users)","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1346"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/464dc8ce-2200-4720-87a5-dc5952924cc6","type":"Microsoft.Authorization/policyDefinitions","name":"464dc8ce-2200-4720-87a5-dc5952924cc6"},{"properties":{"displayName":"Microsoft + Managed Control 1347 - Identification And Authentication (Non-Org. Users) + | Acceptance Of PIV Creds. From Other Agys.","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1347"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/131a2706-61e9-4916-a164-00e052056462","type":"Microsoft.Authorization/policyDefinitions","name":"131a2706-61e9-4916-a164-00e052056462"},{"properties":{"displayName":"Microsoft + Managed Control 1344 - Authenticator Feedback","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1344"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2c895fe7-2d8e-43a2-838c-3a533a5b355e","type":"Microsoft.Authorization/policyDefinitions","name":"2c895fe7-2d8e-43a2-838c-3a533a5b355e"},{"properties":{"displayName":"Microsoft + Managed Control 1349 - Identification And Authentication (Non-Org. Users) + | Use Of FICAM-Approved Products","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1349"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/17641f70-94cd-4a5d-a613-3d1143e20e34","type":"Microsoft.Authorization/policyDefinitions","name":"17641f70-94cd-4a5d-a613-3d1143e20e34"},{"properties":{"displayName":"Microsoft + Managed Control 1348 - Identification And Authentication (Non-Org. Users) + | Acceptance Of Third-Party Credentials","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1348"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/855ced56-417b-4d74-9d5f-dd1bc81e22d6","type":"Microsoft.Authorization/policyDefinitions","name":"855ced56-417b-4d74-9d5f-dd1bc81e22d6"},{"properties":{"displayName":"Microsoft + Managed Control 1351 - Incident Response Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1351"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bcfb6683-05e5-4ce6-9723-c3fbe9896bdd","type":"Microsoft.Authorization/policyDefinitions","name":"bcfb6683-05e5-4ce6-9723-c3fbe9896bdd"},{"properties":{"displayName":"Microsoft + Managed Control 1350 - Identification And Authentication (Non-Org. Users) + | Use Of FICAM-Issued Profiles","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Identification and Authentication control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1350"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d77fd943-6ba6-4a21-ba07-22b03e347cc4","type":"Microsoft.Authorization/policyDefinitions","name":"d77fd943-6ba6-4a21-ba07-22b03e347cc4"},{"properties":{"displayName":"Microsoft + Managed Control 1353 - Incident Response Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1353"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c785ad59-f78f-44ad-9a7f-d1202318c748","type":"Microsoft.Authorization/policyDefinitions","name":"c785ad59-f78f-44ad-9a7f-d1202318c748"},{"properties":{"displayName":"Microsoft + Managed Control 1352 - Incident Response Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1352"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/518cb545-bfa8-43f8-a108-3b7d5037469a","type":"Microsoft.Authorization/policyDefinitions","name":"518cb545-bfa8-43f8-a108-3b7d5037469a"},{"properties":{"displayName":"Microsoft + Managed Control 1355 - Incident Response Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1355"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/90e01f69-3074-4de8-ade7-0fef3e7d83e0","type":"Microsoft.Authorization/policyDefinitions","name":"90e01f69-3074-4de8-ade7-0fef3e7d83e0"},{"properties":{"displayName":"Microsoft + Managed Control 1356 - Incident Response Training | Simulated Events","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1356"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/8829f8f5-e8be-441e-85c9-85b72a5d0ef3","type":"Microsoft.Authorization/policyDefinitions","name":"8829f8f5-e8be-441e-85c9-85b72a5d0ef3"},{"properties":{"displayName":"Microsoft + Managed Control 1354 - Incident Response Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1354"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9fd92c17-163a-4511-bb96-bbb476449796","type":"Microsoft.Authorization/policyDefinitions","name":"9fd92c17-163a-4511-bb96-bbb476449796"},{"properties":{"displayName":"Microsoft + Managed Control 1357 - Incident Response Training | Automated Training Environments","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1357"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e4213689-05e8-4241-9d4e-8dd1cdafd105","type":"Microsoft.Authorization/policyDefinitions","name":"e4213689-05e8-4241-9d4e-8dd1cdafd105"},{"properties":{"displayName":"Microsoft + Managed Control 1359 - Incident Response Testing | Coordination With Related + Plans","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1359"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/47bc7ea0-7d13-4f7c-a154-b903f7194253","type":"Microsoft.Authorization/policyDefinitions","name":"47bc7ea0-7d13-4f7c-a154-b903f7194253"},{"properties":{"displayName":"Microsoft + Managed Control 1360 - Incident Handling","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1360"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/be5b05e7-0b82-4ebc-9eda-25e447b1a41e","type":"Microsoft.Authorization/policyDefinitions","name":"be5b05e7-0b82-4ebc-9eda-25e447b1a41e"},{"properties":{"displayName":"Microsoft + Managed Control 1358 - Incident Response Testing","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1358"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/effbaeef-5bf4-400d-895e-ef8cbc0e64c7","type":"Microsoft.Authorization/policyDefinitions","name":"effbaeef-5bf4-400d-895e-ef8cbc0e64c7"},{"properties":{"displayName":"Microsoft + Managed Control 1361 - Incident Handling","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1361"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/03ed3be1-7276-4452-9a5d-e4168565ac67","type":"Microsoft.Authorization/policyDefinitions","name":"03ed3be1-7276-4452-9a5d-e4168565ac67"},{"properties":{"displayName":"Microsoft + Managed Control 1362 - Incident Handling","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1362"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5d169442-d6ef-439b-8dca-46c2c3248214","type":"Microsoft.Authorization/policyDefinitions","name":"5d169442-d6ef-439b-8dca-46c2c3248214"},{"properties":{"displayName":"Microsoft + Managed Control 1363 - Incident Handling | Automated Incident Handling Processes","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1363"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ea3e8156-89a1-45b1-8bd6-938abc79fdfd","type":"Microsoft.Authorization/policyDefinitions","name":"ea3e8156-89a1-45b1-8bd6-938abc79fdfd"},{"properties":{"displayName":"Microsoft + Managed Control 1366 - Incident Handling | Information Correlation","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1366"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/06c45c30-ae44-4f0f-82be-41331da911cc","type":"Microsoft.Authorization/policyDefinitions","name":"06c45c30-ae44-4f0f-82be-41331da911cc"},{"properties":{"displayName":"Microsoft + Managed Control 1365 - Incident Handling | Continuity Of Operations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1365"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4116891d-72f7-46ee-911c-8056cc8dcbd5","type":"Microsoft.Authorization/policyDefinitions","name":"4116891d-72f7-46ee-911c-8056cc8dcbd5"},{"properties":{"displayName":"Microsoft + Managed Control 1364 - Incident Handling | Dynamic Reconfiguration","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1364"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4c615c2a-dc83-4dda-8220-abce7b50c9bc","type":"Microsoft.Authorization/policyDefinitions","name":"4c615c2a-dc83-4dda-8220-abce7b50c9bc"},{"properties":{"displayName":"Microsoft + Managed Control 1368 - Incident Handling | Correlation With External Organizations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1368"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/465f32da-0ace-4603-8d1b-7be5a3a702de","type":"Microsoft.Authorization/policyDefinitions","name":"465f32da-0ace-4603-8d1b-7be5a3a702de"},{"properties":{"displayName":"Microsoft + Managed Control 1367 - Incident Handling | Insider Threats - Specific Capabilities","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1367"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/435b2547-6374-4f87-b42d-6e8dbe6ae62a","type":"Microsoft.Authorization/policyDefinitions","name":"435b2547-6374-4f87-b42d-6e8dbe6ae62a"},{"properties":{"displayName":"Microsoft + Managed Control 1369 - Incident Monitoring","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1369"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/18cc35ed-a429-486d-8d59-cb47e87304ed","type":"Microsoft.Authorization/policyDefinitions","name":"18cc35ed-a429-486d-8d59-cb47e87304ed"},{"properties":{"displayName":"Microsoft + Managed Control 1370 - Incident Monitoring | Automated Tracking / Data Collection + / Analysis","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1370"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/924e1b2d-c502-478f-bfdb-a7e09a0d5c01","type":"Microsoft.Authorization/policyDefinitions","name":"924e1b2d-c502-478f-bfdb-a7e09a0d5c01"},{"properties":{"displayName":"Microsoft + Managed Control 1371 - Incident Reporting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1371"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9447f354-2c85-4700-93b3-ecdc6cb6a417","type":"Microsoft.Authorization/policyDefinitions","name":"9447f354-2c85-4700-93b3-ecdc6cb6a417"},{"properties":{"displayName":"Microsoft + Managed Control 1372 - Incident Reporting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1372"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/25b96717-c912-4c00-9143-4e487f411726","type":"Microsoft.Authorization/policyDefinitions","name":"25b96717-c912-4c00-9143-4e487f411726"},{"properties":{"displayName":"Microsoft + Managed Control 1373 - Incident Reporting | Automated Reporting","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1373"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4cca950f-c3b7-492a-8e8f-ea39663c14f9","type":"Microsoft.Authorization/policyDefinitions","name":"4cca950f-c3b7-492a-8e8f-ea39663c14f9"},{"properties":{"displayName":"Microsoft + Managed Control 1374 - Incident Response Assistance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1374"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cc5c8616-52ef-4e5e-8000-491634ed9249","type":"Microsoft.Authorization/policyDefinitions","name":"cc5c8616-52ef-4e5e-8000-491634ed9249"},{"properties":{"displayName":"Microsoft + Managed Control 1375 - Incident Response Assistance | Automation Support For + Availability Of Information / Support","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1375"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/00379355-8932-4b52-b63a-3bc6daf3451a","type":"Microsoft.Authorization/policyDefinitions","name":"00379355-8932-4b52-b63a-3bc6daf3451a"},{"properties":{"displayName":"Microsoft + Managed Control 1377 - Incident Response Assistance | Coordination With External + Providers","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1377"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/68434bd1-e14b-4031-9edb-a4adf5f84a67","type":"Microsoft.Authorization/policyDefinitions","name":"68434bd1-e14b-4031-9edb-a4adf5f84a67"},{"properties":{"displayName":"Microsoft + Managed Control 1378 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1378"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/97fceb70-6983-42d0-9331-18ad8253184d","type":"Microsoft.Authorization/policyDefinitions","name":"97fceb70-6983-42d0-9331-18ad8253184d"},{"properties":{"displayName":"Microsoft + Managed Control 1376 - Incident Response Assistance | Coordination With External + Providers","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1376"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/493a95f3-f2e3-47d0-af02-65e6d6decc2f","type":"Microsoft.Authorization/policyDefinitions","name":"493a95f3-f2e3-47d0-af02-65e6d6decc2f"},{"properties":{"displayName":"Microsoft + Managed Control 1379 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1379"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/9442dd2c-a07f-46cd-b55a-553b66ba47ca","type":"Microsoft.Authorization/policyDefinitions","name":"9442dd2c-a07f-46cd-b55a-553b66ba47ca"},{"properties":{"displayName":"Microsoft + Managed Control 1380 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1380"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b4319b7e-ea8d-42ff-8a67-ccd462972827","type":"Microsoft.Authorization/policyDefinitions","name":"b4319b7e-ea8d-42ff-8a67-ccd462972827"},{"properties":{"displayName":"Microsoft + Managed Control 1381 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1381"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e5368258-9684-4567-8126-269f34e65eab","type":"Microsoft.Authorization/policyDefinitions","name":"e5368258-9684-4567-8126-269f34e65eab"},{"properties":{"displayName":"Microsoft + Managed Control 1383 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1383"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d4558451-e16a-4d2d-a066-fe12a6282bb9","type":"Microsoft.Authorization/policyDefinitions","name":"d4558451-e16a-4d2d-a066-fe12a6282bb9"},{"properties":{"displayName":"Microsoft + Managed Control 1382 - Incident Response Plan","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1382"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/841392b3-40da-4473-b328-4cde49db67b3","type":"Microsoft.Authorization/policyDefinitions","name":"841392b3-40da-4473-b328-4cde49db67b3"},{"properties":{"displayName":"Microsoft + Managed Control 1384 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1384"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/79fbc228-461c-4a45-9004-a865ca0728a7","type":"Microsoft.Authorization/policyDefinitions","name":"79fbc228-461c-4a45-9004-a865ca0728a7"},{"properties":{"displayName":"Microsoft + Managed Control 1386 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1386"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5120193e-91fd-4f9d-bc6d-194f94734065","type":"Microsoft.Authorization/policyDefinitions","name":"5120193e-91fd-4f9d-bc6d-194f94734065"},{"properties":{"displayName":"Microsoft + Managed Control 1388 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1388"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2c7c575a-d4c5-4f6f-bd49-dee97a8cba55","type":"Microsoft.Authorization/policyDefinitions","name":"2c7c575a-d4c5-4f6f-bd49-dee97a8cba55"},{"properties":{"displayName":"Microsoft + Managed Control 1385 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1385"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3e495e65-8663-49ca-9b38-9f45e800bc58","type":"Microsoft.Authorization/policyDefinitions","name":"3e495e65-8663-49ca-9b38-9f45e800bc58"},{"properties":{"displayName":"Microsoft + Managed Control 1389 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1389"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c39e6fda-ae70-4891-a739-be7bba6d1062","type":"Microsoft.Authorization/policyDefinitions","name":"c39e6fda-ae70-4891-a739-be7bba6d1062"},{"properties":{"displayName":"Microsoft + Managed Control 1390 - Information Spillage Response | Responsible Personnel","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1390"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c3b65b63-09ec-4cb5-8028-7dd324d10eb0","type":"Microsoft.Authorization/policyDefinitions","name":"c3b65b63-09ec-4cb5-8028-7dd324d10eb0"},{"properties":{"displayName":"Microsoft + Managed Control 1387 - Information Spillage Response","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1387"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e3007185-3857-43a9-8237-06ca94f1084c","type":"Microsoft.Authorization/policyDefinitions","name":"e3007185-3857-43a9-8237-06ca94f1084c"},{"properties":{"displayName":"Microsoft + Managed Control 1391 - Information Spillage Response | Training","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1391"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/dd6ac1a1-660e-4810-baa8-74e868e2ed47","type":"Microsoft.Authorization/policyDefinitions","name":"dd6ac1a1-660e-4810-baa8-74e868e2ed47"},{"properties":{"displayName":"Microsoft + Managed Control 1392 - Information Spillage Response | Post-Spill Operations","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1392"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/86dc819f-15e1-43f9-a271-41ae58d4cecc","type":"Microsoft.Authorization/policyDefinitions","name":"86dc819f-15e1-43f9-a271-41ae58d4cecc"},{"properties":{"displayName":"Microsoft + Managed Control 1393 - Information Spillage Response | Exposure To Unauthorized + Personnel","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Incident Response control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1393"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/731856d8-1598-4b75-92de-7d46235747c0","type":"Microsoft.Authorization/policyDefinitions","name":"731856d8-1598-4b75-92de-7d46235747c0"},{"properties":{"displayName":"Microsoft + Managed Control 1394 - System Maintenance Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1394"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/4db56f68-3f50-45ab-88f3-ca46f5379a94","type":"Microsoft.Authorization/policyDefinitions","name":"4db56f68-3f50-45ab-88f3-ca46f5379a94"},{"properties":{"displayName":"Microsoft + Managed Control 1397 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1397"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/391af4ab-1117-46b9-b2c7-78bbd5cd995b","type":"Microsoft.Authorization/policyDefinitions","name":"391af4ab-1117-46b9-b2c7-78bbd5cd995b"},{"properties":{"displayName":"Microsoft + Managed Control 1395 - System Maintenance Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1395"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7207a023-a517-41c5-9df2-09d4c6845a05","type":"Microsoft.Authorization/policyDefinitions","name":"7207a023-a517-41c5-9df2-09d4c6845a05"},{"properties":{"displayName":"Microsoft + Managed Control 1396 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1396"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/276af98f-4ff9-4e69-99fb-c9b2452fb85f","type":"Microsoft.Authorization/policyDefinitions","name":"276af98f-4ff9-4e69-99fb-c9b2452fb85f"},{"properties":{"displayName":"Microsoft + Managed Control 1398 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1398"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/443e8f3d-b51a-45d8-95a7-18b0e42f4dc4","type":"Microsoft.Authorization/policyDefinitions","name":"443e8f3d-b51a-45d8-95a7-18b0e42f4dc4"},{"properties":{"displayName":"Microsoft + Managed Control 1401 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1401"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b78ee928-e3c1-4569-ad97-9f8c4b629847","type":"Microsoft.Authorization/policyDefinitions","name":"b78ee928-e3c1-4569-ad97-9f8c4b629847"},{"properties":{"displayName":"Microsoft + Managed Control 1399 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1399"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2256e638-eb23-480f-9e15-6cf1af0a76b3","type":"Microsoft.Authorization/policyDefinitions","name":"2256e638-eb23-480f-9e15-6cf1af0a76b3"},{"properties":{"displayName":"Microsoft + Managed Control 1400 - Controlled Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1400"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a96d5098-a604-4cdf-90b1-ef6449a27424","type":"Microsoft.Authorization/policyDefinitions","name":"a96d5098-a604-4cdf-90b1-ef6449a27424"},{"properties":{"displayName":"Microsoft + Managed Control 1402 - Controlled Maintenance | Automated Maintenance Activities","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1402"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0a560d32-8075-4fec-9615-9f7c853f4ea9","type":"Microsoft.Authorization/policyDefinitions","name":"0a560d32-8075-4fec-9615-9f7c853f4ea9"},{"properties":{"displayName":"Microsoft + Managed Control 1404 - Maintenance Tools","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1404"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/13d8f903-0cd6-449f-a172-50f6579c182b","type":"Microsoft.Authorization/policyDefinitions","name":"13d8f903-0cd6-449f-a172-50f6579c182b"},{"properties":{"displayName":"Microsoft + Managed Control 1406 - Maintenance Tools | Inspect Media","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1406"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a0f5339c-9292-43aa-a0bc-d27c6b8e30aa","type":"Microsoft.Authorization/policyDefinitions","name":"a0f5339c-9292-43aa-a0bc-d27c6b8e30aa"},{"properties":{"displayName":"Microsoft + Managed Control 1403 - Controlled Maintenance | Automated Maintenance Activities","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1403"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/57149289-d52b-4f40-9fe6-5233c1ef80f7","type":"Microsoft.Authorization/policyDefinitions","name":"57149289-d52b-4f40-9fe6-5233c1ef80f7"},{"properties":{"displayName":"Microsoft + Managed Control 1405 - Maintenance Tools | Inspect Tools","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1405"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/fe1a0bf3-409a-4b00-b60d-0b1f917f7e7b","type":"Microsoft.Authorization/policyDefinitions","name":"fe1a0bf3-409a-4b00-b60d-0b1f917f7e7b"},{"properties":{"displayName":"Microsoft + Managed Control 1407 - Maintenance Tools | Prevent Unauthorized Removal","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1407"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ff9fbd83-1d8d-4b41-aac2-94cb44b33976","type":"Microsoft.Authorization/policyDefinitions","name":"ff9fbd83-1d8d-4b41-aac2-94cb44b33976"},{"properties":{"displayName":"Microsoft + Managed Control 1409 - Maintenance Tools | Prevent Unauthorized Removal","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1409"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/d1880188-e51a-4772-b2ab-68f5e8bd27f6","type":"Microsoft.Authorization/policyDefinitions","name":"d1880188-e51a-4772-b2ab-68f5e8bd27f6"},{"properties":{"displayName":"Microsoft + Managed Control 1408 - Maintenance Tools | Prevent Unauthorized Removal","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1408"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/c5f56ac6-4bb2-4086-bc41-ad76344ba2c2","type":"Microsoft.Authorization/policyDefinitions","name":"c5f56ac6-4bb2-4086-bc41-ad76344ba2c2"},{"properties":{"displayName":"Microsoft + Managed Control 1410 - Maintenance Tools | Prevent Unauthorized Removal","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1410"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/a2596a9f-e59f-420d-9625-6e0b536348be","type":"Microsoft.Authorization/policyDefinitions","name":"a2596a9f-e59f-420d-9625-6e0b536348be"},{"properties":{"displayName":"Microsoft + Managed Control 1411 - Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1411"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/898d4fe8-f743-4333-86b7-0c9245d93e7d","type":"Microsoft.Authorization/policyDefinitions","name":"898d4fe8-f743-4333-86b7-0c9245d93e7d"},{"properties":{"displayName":"Microsoft + Managed Control 1412 - Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1412"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/3492d949-0dbb-4589-88b3-7b59601cc764","type":"Microsoft.Authorization/policyDefinitions","name":"3492d949-0dbb-4589-88b3-7b59601cc764"},{"properties":{"displayName":"Microsoft + Managed Control 1413 - Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1413"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/aeedddb6-6bc0-42d5-809b-80048033419d","type":"Microsoft.Authorization/policyDefinitions","name":"aeedddb6-6bc0-42d5-809b-80048033419d"},{"properties":{"displayName":"Microsoft + Managed Control 1415 - Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1415"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/61a1dd98-b259-4840-abd5-fbba7ee0da83","type":"Microsoft.Authorization/policyDefinitions","name":"61a1dd98-b259-4840-abd5-fbba7ee0da83"},{"properties":{"displayName":"Microsoft + Managed Control 1414 - Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1414"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/2ce63a52-e47b-4ae2-adbb-6e40d967f9e6","type":"Microsoft.Authorization/policyDefinitions","name":"2ce63a52-e47b-4ae2-adbb-6e40d967f9e6"},{"properties":{"displayName":"Microsoft + Managed Control 1418 - Nonlocal Maintenance | Comparable Security / Sanitization","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1418"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/28e633fd-284e-4ea7-88b4-02ca157ed713","type":"Microsoft.Authorization/policyDefinitions","name":"28e633fd-284e-4ea7-88b4-02ca157ed713"},{"properties":{"displayName":"Microsoft + Managed Control 1416 - Nonlocal Maintenance | Document Nonlocal Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1416"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/38dfd8a3-5290-4099-88b7-4081f4c4d8ae","type":"Microsoft.Authorization/policyDefinitions","name":"38dfd8a3-5290-4099-88b7-4081f4c4d8ae"},{"properties":{"displayName":"Microsoft + Managed Control 1419 - Nonlocal Maintenance | Cryptographic Protection","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1419"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/b6747bf9-2b97-45b8-b162-3c8becb9937d","type":"Microsoft.Authorization/policyDefinitions","name":"b6747bf9-2b97-45b8-b162-3c8becb9937d"},{"properties":{"displayName":"Microsoft + Managed Control 1417 - Nonlocal Maintenance | Comparable Security / Sanitization","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1417"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7522ed84-70d5-4181-afc0-21e50b1b6d0e","type":"Microsoft.Authorization/policyDefinitions","name":"7522ed84-70d5-4181-afc0-21e50b1b6d0e"},{"properties":{"displayName":"Microsoft + Managed Control 1421 - Maintenance Personnel","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1421"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/e539caaa-da8c-41b8-9e1e-449851e2f7a6","type":"Microsoft.Authorization/policyDefinitions","name":"e539caaa-da8c-41b8-9e1e-449851e2f7a6"},{"properties":{"displayName":"Microsoft + Managed Control 1420 - Maintenance Personnel","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1420"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/05ae08cc-a282-413b-90c7-21a2c60b8404","type":"Microsoft.Authorization/policyDefinitions","name":"05ae08cc-a282-413b-90c7-21a2c60b8404"},{"properties":{"displayName":"Microsoft + Managed Control 1422 - Maintenance Personnel","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1422"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/ea556850-838d-4a37-8ce5-9d7642f95e11","type":"Microsoft.Authorization/policyDefinitions","name":"ea556850-838d-4a37-8ce5-9d7642f95e11"},{"properties":{"displayName":"Microsoft + Managed Control 1423 - Maintenance Personnel | Individuals Without Appropriate + Access","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1423"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/7741669e-d4f6-485a-83cb-e70ce7cbbc20","type":"Microsoft.Authorization/policyDefinitions","name":"7741669e-d4f6-485a-83cb-e70ce7cbbc20"},{"properties":{"displayName":"Microsoft + Managed Control 1425 - Timely Maintenance","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1425"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/5983d99c-f39b-4c32-a3dc-170f19f6941b","type":"Microsoft.Authorization/policyDefinitions","name":"5983d99c-f39b-4c32-a3dc-170f19f6941b"},{"properties":{"displayName":"Microsoft + Managed Control 1424 - Maintenance Personnel | Individuals Without Appropriate + Access","policyType":"Static","mode":"Indexed","description":"Microsoft implements + this Maintenance control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1424"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/cf55fc87-48e1-4676-a2f8-d9a8cf993283","type":"Microsoft.Authorization/policyDefinitions","name":"cf55fc87-48e1-4676-a2f8-d9a8cf993283"},{"properties":{"displayName":"Microsoft + Managed Control 1427 - Media Protection Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Media Protection control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1427"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/bc90e44f-d83f-4bdf-900f-3d5eb4111b31","type":"Microsoft.Authorization/policyDefinitions","name":"bc90e44f-d83f-4bdf-900f-3d5eb4111b31"},{"properties":{"displayName":"Microsoft + Managed Control 1426 - Media Protection Policy And Procedures","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Media Protection control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1426"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/21f639bc-f42b-46b1-8f40-7a2a389c291a","type":"Microsoft.Authorization/policyDefinitions","name":"21f639bc-f42b-46b1-8f40-7a2a389c291a"},{"properties":{"displayName":"Microsoft + Managed Control 1428 - Media Access","policyType":"Static","mode":"Indexed","description":"Microsoft + implements this Media Protection control","metadata":{"version":"1.0.0","category":"Regulatory + Compliance","additionalMetadataId":"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1428"},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Resources/subscriptions","Microsoft.Resources/subscriptions/resourceGroups"]},{"value":"false","equals":"true"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Authorization/policyDefinitions/0a77fcc7-b8d8-451a-ab52-56197913c0c7","type":"Microsoft.Authorization/policyDefinitions","name":"0a77fcc7-b8d8-451a-ab52-56197913c0c7"}],"nextLink":"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVCdWlsdEluRGVmaW5pdGlvbiIsIm5leHRNYXJrZXIiOiIrUklEOn5HTnBpQUlwd25SaG9pQjRBQUFBQUFBPT0jUlQ6MiNUUkM6MTAwMCNJU1Y6MiNJRU86NjU1NTEjUUNGOjMjRlBDOkFnaDZBQUFBQUFBQUFFb0VBQUFBSUFBQWVnQUFBQUFBQUFBSUFHRUlBUDlCUWY4L2VnQUFBQUFnQUFBSUFJTUUvdi8vZi8wZlNnUUFBQUFnQUFBRUFJRW8vZ0E9In0%253D"}' + headers: + cache-control: + - no-cache + content-length: + - '744425' + content-type: + - application/json; charset=utf-8 + date: + - Fri, 26 Feb 2021 07:40:16 GMT + expires: + - '-1' + pragma: + - no-cache + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding,Accept-Encoding + x-content-type-options: + - nosniff + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVCdWlsdEluRGVmaW5pdGlvbiIsIm5leHRNYXJrZXIiOiIrUklEOn5HTnBpQUlwd25SaG9pQjRBQUFBQUFBPT0jUlQ6MiNUUkM6MTAwMCNJU1Y6MiNJRU86NjU1NTEjUUNGOjMjRlBDOkFnaDZBQUFBQUFBQUFFb0VBQUFBSUFBQWVnQUFBQUFBQUFBSUFHRUlBUDlCUWY4L2VnQUFBQUFnQUFBSUFJTUUvdi8vZi8wZlNnUUFBQUFnQUFBRUFJRW8vZ0E9In0%253D response: body: string: "{\"value\":[{\"properties\":{\"displayName\":\"Microsoft Managed Control\ - \ 1599 - Developer Configuration Management | Software / Firmware Integrity\ - \ Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1599\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0004bbf0-5099-4179-869e-e9ffe5fb0945\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0004bbf0-5099-4179-869e-e9ffe5fb0945\"\ - },{\"properties\":{\"displayName\":\"Audit virtual machines without disaster\ - \ recovery configured\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Audit virtual machines which do not have disaster recovery configured.\ - \ To learn more about disaster recovery, visit https://aka.ms/asr-doc.\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Compute\"},\"parameters\"\ - :{},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"auditIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Resources/links\",\"existenceCondition\"\ - :{\"field\":\"name\",\"like\":\"ASR-Protect-*\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0015ea4d-51ff-4ce3-8d8c-f3f8f0179a56\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0015ea4d-51ff-4ce3-8d8c-f3f8f0179a56\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Sockets state\ - \ for a Function App\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"The Web Sockets protocol is vulnerable to different types of security threats.\ - \ Use of Web Sockets within an Function app must be carefully reviewed.\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\"\ - ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\"\ - :[{\"field\":\"kind\",\"equals\":\"functionapp\"},{\"field\":\"kind\",\"equals\"\ - :\"functionapp,linux\"},{\"field\":\"kind\",\"equals\":\"functionapp,linux,container\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Security/complianceResults\",\"name\":\"DisableWebSockets\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/001802d1-4969-4c82-a700-c29c6c6f9bbd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"001802d1-4969-4c82-a700-c29c6c6f9bbd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1375 - Incident\ - \ Response Assistance | Automation Support For Availability Of Information\ - \ / Support\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1375\"},\"policyRule\"\ + \ 1431 - Media Storage\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Media Protection control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1431\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/00379355-8932-4b52-b63a-3bc6daf3451a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"00379355-8932-4b52-b63a-3bc6daf3451a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1605 - Developer\ - \ Security Testing And Evaluation | Static Code Analysis\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1605\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7173c52-2b99-4696-a576-63dd5f970ef4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7173c52-2b99-4696-a576-63dd5f970ef4\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1430 - Media\ + \ Marking\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1430\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0062eb8b-dc75-4718-8ea5-9bb4a9606655\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0062eb8b-dc75-4718-8ea5-9bb4a9606655\"\ - },{\"properties\":{\"displayName\":\"Azure Backup should be enabled for Virtual\ - \ Machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Ensure protection of your Azure Virtual Machines by enabling Azure Backup.\ - \ Azure Backup is a secure and cost effective data protection solution for\ - \ Azure.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Backup\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.RecoveryServices/backupprotecteditems\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/013e242c-8828-4970-87b3-ab247555486d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"013e242c-8828-4970-87b3-ab247555486d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1142 - Security\ - \ Assessment And Authorization Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Security\ - \ Assessment and Authorization control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1142\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f559588-5e53-4b14-a7c4-85d28ebc2234\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f559588-5e53-4b14-a7c4-85d28ebc2234\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1429 - Media\ + \ Marking\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1429\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/01524fa8-4555-48ce-ba5f-c3b8dcef5147\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"01524fa8-4555-48ce-ba5f-c3b8dcef5147\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1099 - Security\ - \ Training Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1099\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b07c9b24-729e-4e85-95fc-f224d2d08a80\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b07c9b24-729e-4e85-95fc-f224d2d08a80\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1432 - Media\ + \ Storage\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1432\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/01910bab-8639-4bd0-84ef-cc53b24d79ba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"01910bab-8639-4bd0-84ef-cc53b24d79ba\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1285 - Telecommunications\ - \ Services | Provider Contingency Plan\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1285\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1140e542-b80d-4048-af45-3f7245be274b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1140e542-b80d-4048-af45-3f7245be274b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1433 - Media\ + \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1433\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/01f7726b-db54-45c2-bcb5-9bd7a43796ee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"01f7726b-db54-45c2-bcb5-9bd7a43796ee\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1709 - Security\ - \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1709\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b879b41-2728-41c5-ad24-9ee2c37cbe65\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b879b41-2728-41c5-ad24-9ee2c37cbe65\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1435 - Media\ + \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1435\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/025992d6-7fee-4137-9bbf-2ffc39c0686c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"025992d6-7fee-4137-9bbf-2ffc39c0686c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1052 - Session\ - \ Lock\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fa8d221b-d130-4637-ba16-501e666628bb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fa8d221b-d130-4637-ba16-501e666628bb\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1434 - Media\ + \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1052\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1434\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/027cae1c-ec3e-4492-9036-4168d540c42a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"027cae1c-ec3e-4492-9036-4168d540c42a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1034 - Least\ - \ Privilege\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c18f06b-a68d-41c3-8863-b8cd3acb5f8f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c18f06b-a68d-41c3-8863-b8cd3acb5f8f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1436 - Media\ + \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1034\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1436\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02a5ed00-6d2e-4e97-9a98-46c32c057329\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02a5ed00-6d2e-4e97-9a98-46c32c057329\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs on which the remote connection status does not match the specified\ - \ one\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This\ - \ policy should only be used along with its corresponding deploy policy in\ - \ an initiative. This definition allows Azure Policy to process the results\ - \ of auditing Windows virtual machines on which the remote host connection\ - \ status does not match the specified one. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsRemoteConnection\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02a84be7-c304-421f-9bb7-5d2c26af54ad\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02a84be7-c304-421f-9bb7-5d2c26af54ad\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1623 - Boundary\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1623\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/28aab8b4-74fd-4b7c-9080-5a7be525d574\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28aab8b4-74fd-4b7c-9080-5a7be525d574\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1437 - Media\ + \ Transport | Cryptographic Protection\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Media Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1437\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02ce1b22-412a-4528-8630-c42146f917ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02ce1b22-412a-4528-8630-c42146f917ed\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1515 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1515\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d1eb6ed-bf13-4046-b993-b9e2aef0f76c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d1eb6ed-bf13-4046-b993-b9e2aef0f76c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1438 - Media\ + \ Sanitization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1438\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02dd141a-a2b2-49a7-bcbd-ca31142f6211\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02dd141a-a2b2-49a7-bcbd-ca31142f6211\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1327 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1327\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40fcc635-52a2-4dbc-9523-80a1f4aa1de6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40fcc635-52a2-4dbc-9523-80a1f4aa1de6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1440 - Media\ + \ Sanitization | Review / Approve / Track / Document / Verify\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Media Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1440\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03188d8f-1ae5-4fe1-974d-2d7d32ef937d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03188d8f-1ae5-4fe1-974d-2d7d32ef937d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1229 - Information\ - \ System Component Inventory | No Duplicate Accounting Of Components\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1229\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/881299bf-2a5b-4686-a1b2-321d33679953\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"881299bf-2a5b-4686-a1b2-321d33679953\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1442 - Media\ + \ Sanitization | Nondestructive Techniques\",\"policyType\":\"Static\",\"\ + mode\":\"Indexed\",\"description\":\"Microsoft implements this Media Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1442\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03752212-103c-4ab8-a306-7e813022ca9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03752212-103c-4ab8-a306-7e813022ca9d\"\ - },{\"properties\":{\"displayName\":\"Cognitive Services accounts should restrict\ - \ network access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Network access to Cognitive Services accounts should be restricted. Configure\ - \ network rules so only applications from allowed networks can access the\ - \ Cognitive Services account. To allow connections from specific internet\ - \ or on-premises clients, access can be granted to traffic from specific Azure\ - \ virtual networks or to public internet IP address ranges.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Cognitive Services\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"The effect determines what happens when the policy rule\ - \ is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"},{\"field\"\ - :\"Microsoft.CognitiveServices/accounts/networkAcls.defaultAction\",\"notEquals\"\ - :\"Deny\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/037eea7a-bd0a-46c5-9a66-03aea78705d3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"037eea7a-bd0a-46c5-9a66-03aea78705d3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1123 - Audit\ - \ Review, Analysis, And Reporting | Audit Level Adjustment\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1123\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4f26049b-2c5a-4841-9ff3-d48a26aae475\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f26049b-2c5a-4841-9ff3-d48a26aae475\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1441 - Media\ + \ Sanitization | Equipment Testing\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1441\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03996055-37a4-45a5-8b70-3f1caa45f87d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03996055-37a4-45a5-8b70-3f1caa45f87d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1474 - Emergency\ - \ Power | Long-Term Alternate Power Supply - Minimal Operational Capability\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Physical and Environmental Protection control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1474\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6519d7f3-e8a2-4ff3-a935-9a9497152ad7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6519d7f3-e8a2-4ff3-a935-9a9497152ad7\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1439 - Media\ + \ Sanitization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1439\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03ad326e-d7a1-44b1-9a76-e17492efc9e4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03ad326e-d7a1-44b1-9a76-e17492efc9e4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1227 - Information\ - \ System Component Inventory | Automated Unauthorized Component Detection\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dce72873-c5f1-47c3-9b4f-6b8207fd5a45\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dce72873-c5f1-47c3-9b4f-6b8207fd5a45\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1443 - Media\ + \ Use\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ + Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1227\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1443\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03b78f5e-4877-4303-b0f4-eb6583f25768\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03b78f5e-4877-4303-b0f4-eb6583f25768\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1361 - Incident\ - \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1361\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd0ec6fa-a2e7-4361-aee4-a8688659a9ed\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd0ec6fa-a2e7-4361-aee4-a8688659a9ed\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1444 - Media\ + \ Use | Prohibit Use Without Owner\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1444\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03ed3be1-7276-4452-9a5d-e4168565ac67\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03ed3be1-7276-4452-9a5d-e4168565ac67\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1594 - Developer\ - \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1594\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/666143df-f5e0-45bd-b554-135f0f93e44e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"666143df-f5e0-45bd-b554-135f0f93e44e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1445 - Physical\ + \ And Environmental Protection Policy And Procedures\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical\ + \ and Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1445\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/042ba2a1-8bb8-45f4-b080-c78cf62b90e9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"042ba2a1-8bb8-45f4-b080-c78cf62b90e9\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that have the specified\ - \ applications installed\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if the Chef InSpec resource indicates that one or more of\ - \ the packages provided by the parameter are installed.\",\"metadata\":{\"\ - category\":\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"not_installed_application_linux\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"ApplicationName\":\"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ApplicationName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Application names\"\ - ,\"description\":\"A semicolon-separated list of the names of the applications\ - \ that should not be installed. e.g. 'python; powershell'\"}}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"not_installed_application_linux\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent',\ - \ '=', concat('packages: [', replace(parameters('ApplicationName'), ';', ','),\ - \ ']')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0447bc18-e2f7-4c0d-aa20-bff034275be1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0447bc18-e2f7-4c0d-aa20-bff034275be1\"\ - },{\"properties\":{\"displayName\":\"Azure Cosmos DB allowed locations\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ enables you to restrict the locations your organization can specify when\ - \ deploying Azure Cosmos DB resources. Use to enforce your geo-compliance\ - \ requirements.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cosmos\ - \ DB\"},\"parameters\":{\"listOfAllowedLocations\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Allowed locations\",\"description\":\"The list\ - \ of locations that can be specified when deploying Azure Cosmos DB resources.\"\ - ,\"strongType\":\"location\"}},\"policyEffect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Policy Effect\",\"description\":\"The desired effect of\ - \ the policy.\"},\"allowedValues\":[\"deny\",\"audit\",\"disabled\"],\"defaultValue\"\ - :\"deny\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DocumentDB/databaseAccounts\"},{\"count\":{\"field\":\"Microsoft.DocumentDB/databaseAccounts/Locations[*]\"\ - ,\"where\":{\"value\":\"[replace(toLower(first(field('Microsoft.DocumentDB/databaseAccounts/Locations[*].locationName'))),\ - \ ' ', '')]\",\"in\":\"[parameters('listOfAllowedLocations')]\"}},\"notEquals\"\ - :\"[length(field('Microsoft.DocumentDB/databaseAccounts/Locations[*]'))]\"\ - }]},\"then\":{\"effect\":\"[parameters('policyEffect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0473574d-2d43-4217-aefe-941fcdf7e684\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0473574d-2d43-4217-aefe-941fcdf7e684\"\ - },{\"properties\":{\"displayName\":\"SQL Managed Instance TDE protector should\ - \ be encrypted with your own key\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Transparent Data Encryption (TDE) with your own\ - \ key support provides increased transparency and control over the TDE Protector,\ - \ increased security with an HSM-backed external service, and promotion of\ - \ separation of duties.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Sql/managedInstances\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/managedInstances/encryptionProtector\"\ - ,\"name\":\"current\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Sql/managedInstances/encryptionProtector/serverKeyType\"\ - ,\"equals\":\"AzureKeyVault\"},{\"field\":\"Microsoft.Sql/managedInstances/encryptionProtector/uri\"\ - ,\"notEquals\":\"\"},{\"field\":\"Microsoft.Sql/managedInstances/encryptionProtector/uri\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/048248b0-55cd-46da-b1ff-39efd52db260\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"048248b0-55cd-46da-b1ff-39efd52db260\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Network traffic data collection\ - \ agent should be installed on Linux virtual machines\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Security Center uses the\ - \ Microsoft Dependency agent to collect network traffic data from your Azure\ - \ virtual machines to enable advanced network protection features such as\ - \ traffic visualization on the network map, network hardening recommendations\ - \ and specific network threats.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ - ,\"category\":\"Monitoring\",\"preview\":\"true\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\"\ - ,\"description\":\"Enable or disable Dependency Agent for Linux VMs monitoring\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"14.04.0-LTS\"\ - ,\"14.04.1-LTS\",\"14.04.5-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"16.04-LTS\",\"16.04.0-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"18.04-LTS\"]}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"in\":[\"12-SP2\",\"12-SP3\",\"12-SP4\"]}]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\",\"Centos-LVM\"\ - ,\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"DependencyAgentLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/04c4380f-3fae-46e8-96c9-30193528f602\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"04c4380f-3fae-46e8-96c9-30193528f602\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Service\ - \ Bus to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Deploys the diagnostic settings for Service Bus\ - \ to stream to a regional Log Analytics workspace when any Service Bus which\ - \ is missing this diagnostic settings is created or updated.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ServiceBus/namespaces\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.ServiceBus/namespaces/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"OperationalLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/04d53d87-841c-4f23-8a5b-21564380b55e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"04d53d87-841c-4f23-8a5b-21564380b55e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1572 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1572\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32d07d59-2716-4972-b37b-214a67ac4a37\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32d07d59-2716-4972-b37b-214a67ac4a37\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1446 - Physical\ + \ And Environmental Protection Policy And Procedures\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical\ + \ and Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1446\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/04f5fb00-80bb-48a9-a75b-4cb4d4c97c36\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"04f5fb00-80bb-48a9-a75b-4cb4d4c97c36\"\ - },{\"properties\":{\"displayName\":\"Deploy Log Analytics agent for Linux\ - \ VMs\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - Deploy Log Analytics agent for Linux VMs if the VM Image (OS) is in the list\ - \ defined and the agent is not installed.\",\"metadata\":{\"version\":\"1.1.0\"\ - ,\"category\":\"Monitoring\"},\"parameters\":{\"logAnalytics\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\",\"description\"\ - :\"Select Log Analytics workspace from dropdown list. If this workspace is\ - \ outside of the scope of the assignment you must manually grant 'Log Analytics\ - \ Contributor' permissions (or similar) to the policy assignment's principal\ - \ ID.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Linux OS to add to scope\",\"description\":\"\ - Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\",\"\ - RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7.*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\"\ - ,\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"variables\":{\"vmExtensionName\":\"OMSAgentForLinux\",\"vmExtensionPublisher\"\ - :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"OmsAgentForLinux\"\ - ,\"vmExtensionTypeHandlerVersion\":\"1.7\"},\"resources\":[{\"name\":\"[concat(parameters('vmName'),\ - \ '/', variables('vmExtensionName'))]\",\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"apiVersion\":\"2018-06-01\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'),\ - \ '2015-03-20').customerId]\",\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\"\ - :{\"workspaceKey\":\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ - }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ - vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/053d3325-282c-4e5c-b944-24faffd30d77\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"053d3325-282c-4e5c-b944-24faffd30d77\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1331 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1331\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf6850fe-abba-468e-9ef4-d09ec7d983cd\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf6850fe-abba-468e-9ef4-d09ec7d983cd\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1447 - Physical\ + \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1447\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05460fe2-301f-4ed1-8174-d62c8bb92ff4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05460fe2-301f-4ed1-8174-d62c8bb92ff4\"\ - },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ - \ be enabled for Azure Front Door Service\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Requires Web Application Firewall (WAF)\ - \ on any Azure Front Door Service. A Web Application Firewall provides greater\ - \ security for your other Azure resources.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Network\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/frontdoors\"},{\"\ - field\":\"Microsoft.Network/frontdoors/frontendEndpoints[*].webApplicationFirewallPolicyLink.id\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/055aa869-bc98-4af8-bafc-23f1ab6ffe2c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"055aa869-bc98-4af8-bafc-23f1ab6ffe2c\"\ - },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ - \ PostgreSQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy audits PostgreSQL servers not configured to use\ - \ a private endpoint. For more details, visit https://aka.ms/pgprivatelink.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforPostgreSQL/servers/privateEndpointConnections\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforPostgreSQL/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0564d078-92f5-4f97-8398-b9f58a51f70b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0564d078-92f5-4f97-8398-b9f58a51f70b\"\ - },{\"properties\":{\"displayName\":\"Vulnerability Assessment settings for\ - \ SQL server should contain an email address to receive scan reports\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Ensure that\ - \ an email address is provided for the 'Send scan reports to' field in the\ - \ Vulnerability Assessment settings. This email address receives scan result\ - \ summary after a periodic scan runs on SQL servers.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/vulnerabilityAssessments\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/vulnerabilityAssessments/default.recurringScans.emails[*]\"\ - ,\"notEquals\":\"\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/057d6cfe-9c4f-4a6d-bc60-14420ea1f1a9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"057d6cfe-9c4f-4a6d-bc60-14420ea1f1a9\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Azure Data Lake Store\ - \ should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Data Lake\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DataLakeStore/accounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/057ef27e-665e-4328-8ea3-04b3122bd9fb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"057ef27e-665e-4328-8ea3-04b3122bd9fb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1132 - Protection\ - \ Of Audit Information | Audit Backup On Separate Physical Systems / Components\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Audit and Accountability control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1132\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9783a99-98fe-4a95-873f-29613309fe9a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9783a99-98fe-4a95-873f-29613309fe9a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1449 - Physical\ + \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1449\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05938e10-cdbd-4a54-9b2b-1cbcfc141ad0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05938e10-cdbd-4a54-9b2b-1cbcfc141ad0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1223 - Information\ - \ System Component Inventory\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Configuration Management control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1223\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f784d3b0-5f2b-49b7-b9f3-00ba8653ced5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f784d3b0-5f2b-49b7-b9f3-00ba8653ced5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1448 - Physical\ + \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1448\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05a1bb01-ad5a-49c1-aad3-b0c893b2ec3a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05a1bb01-ad5a-49c1-aad3-b0c893b2ec3a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1640 - Transmission\ - \ Confidentiality And Integrity\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Communications Protection\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/825d6494-e583-42f2-a3f2-6458e6f0004f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"825d6494-e583-42f2-a3f2-6458e6f0004f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1450 - Physical\ + \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1640\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1450\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05a289ce-6a20-4b75-a0f3-dc8601b6acd0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05a289ce-6a20-4b75-a0f3-dc8601b6acd0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1420 - Maintenance\ - \ Personnel\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1420\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/134d7a13-ba3e-41e2-b236-91bfcfa24e01\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"134d7a13-ba3e-41e2-b236-91bfcfa24e01\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1451 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1451\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05ae08cc-a282-413b-90c7-21a2c60b8404\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05ae08cc-a282-413b-90c7-21a2c60b8404\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1658 - Secure\ - \ Name / Address Resolution Service (Recursive Or Caching Resolver)\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1658\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3f1e5a3-25c1-4476-8cb6-3955031f8e65\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3f1e5a3-25c1-4476-8cb6-3955031f8e65\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1452 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1452\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/063b540e-4bdc-4e7a-a569-3a42ddf22098\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"063b540e-4bdc-4e7a-a569-3a42ddf22098\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1688 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1688\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/82c76455-4d3f-4e09-a654-22e592107e74\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82c76455-4d3f-4e09-a654-22e592107e74\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1453 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1453\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/063c3f09-e0f0-4587-8fd5-f4276fae675f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"063c3f09-e0f0-4587-8fd5-f4276fae675f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1332 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1332\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9693b564-3008-42bc-9d5d-9c7fe198c011\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9693b564-3008-42bc-9d5d-9c7fe198c011\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1454 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1454\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/068260be-a5e6-4b0a-a430-cd27071c226a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"068260be-a5e6-4b0a-a430-cd27071c226a\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ad58985d-ab32-4f99-8bd3-b7e134c90229\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ad58985d-ab32-4f99-8bd3-b7e134c90229\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1455 - Physical\ \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this Physical and Environmental Protection control\"\ @@ -790,1093 +8583,190 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/068a88d4-e520-434e-baf0-9005a8164e6a\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"068a88d4-e520-434e-baf0-9005a8164e6a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit SQL DB Level Audit\ - \ Setting\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - Audit DB level audit setting for SQL databases\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"SQL\",\"deprecated\":true},\"parameters\"\ - :{\"setting\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Audit Setting\"},\"allowedValues\":[\"enabled\",\"disabled\"]}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"\ - },{\"field\":\"name\",\"notEquals\":\"master\"}]},\"then\":{\"effect\":\"\ - AuditIfNotExists\",\"details\":{\"type\":\"Microsoft.Sql/servers/databases/auditingSettings\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Sql/auditingSettings.state\"\ - ,\"equals\":\"[parameters('setting')]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a12\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"06a78e20-9358-41c9-923c-fb736d382a12\"\ - },{\"properties\":{\"displayName\":\"Audit VMs that do not use managed disks\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits VMs that do not use managed disks\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Compute\"},\"parameters\":{},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/osDisk.uri\",\"exists\":\"\ - True\"}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/VirtualMachineScaleSets\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osDisk.vhdContainers\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osdisk.imageUrl\"\ - ,\"exists\":\"True\"}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"06a78e20-9358-41c9-923c-fb736d382a4d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1366 - Incident\ - \ Handling | Information Correlation\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1366\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1456 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1456\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/06c45c30-ae44-4f0f-82be-41331da911cc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"06c45c30-ae44-4f0f-82be-41331da911cc\"\ - },{\"properties\":{\"displayName\":\"Public network access should be disabled\ - \ for Cognitive Services accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy audits any Cognitive Services account\ - \ in your environment with public network access enabled. Public network access\ - \ should be disabled so that only connections from private endpoints are allowed.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cognitive Services\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"The effect determines what happens when the\ - \ policy rule is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\"\ - ,\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"\ - },{\"field\":\"Microsoft.CognitiveServices/accounts/publicNetworkAccess\"\ - ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0725b4dd-7e76-479c-a735-68e7ee23d5ca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0725b4dd-7e76-479c-a735-68e7ee23d5ca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1633 - Boundary\ - \ Protection | Route Traffic To Authenticated Proxy Servers\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1633\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/733ba9e3-9e7c-440a-a7aa-6196a90a2870\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"733ba9e3-9e7c-440a-a7aa-6196a90a2870\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1457 - Physical\ + \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1457\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/07557aa0-e02f-4460-9a81-8ecd2fed601a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"07557aa0-e02f-4460-9a81-8ecd2fed601a\"\ - },{\"properties\":{\"displayName\":\"CORS should not allow every resource\ - \ to access your Function Apps\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Cross-Origin Resource Sharing (CORS) should not allow all\ - \ domains to access your Function app. Allow only required domains to interact\ - \ with your Function app.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"\ - like\":\"functionapp*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]\",\"notEquals\"\ - :\"*\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0820b7b9-23aa-4725-a1ce-ae4558f718e5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0820b7b9-23aa-4725-a1ce-ae4558f718e5\"\ - },{\"properties\":{\"displayName\":\"Deploy Log Analytics agent for Windows\ - \ VMs\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - Deploy Log Analytics agent for Windows VMs if the VM Image (OS) is in the\ - \ list defined and the agent is not installed. The list of OS images will\ - \ be updated over time as support is updated.\",\"metadata\":{\"version\"\ - :\"1.1.0\",\"category\":\"Monitoring\"},\"parameters\":{\"logAnalytics\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\"\ - ,\"description\":\"Select Log Analytics workspace from dropdown list. If this\ - \ workspace is outside of the scope of the assignment you must manually grant\ - \ 'Log Analytics Contributor' permissions (or similar) to the policy assignment's\ - \ principal ID.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"\ - listOfImageIdToInclude\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Optional: List of VM images that have supported Windows OS to add to scope\"\ - ,\"description\":\"Example values: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\"\ - ,\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ - roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"variables\":{\"vmExtensionName\":\"MicrosoftMonitoringAgent\",\"vmExtensionPublisher\"\ - :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"MicrosoftMonitoringAgent\"\ - ,\"vmExtensionTypeHandlerVersion\":\"1.0\"},\"resources\":[{\"name\":\"[concat(parameters('vmName'),\ - \ '/', variables('vmExtensionName'))]\",\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"apiVersion\":\"2018-06-01\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'),\ - \ '2015-03-20').customerId]\",\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\"\ - :{\"workspaceKey\":\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ - }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ - vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/0868462e-646c-4fe3-9ced-a733534b6a2c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0868462e-646c-4fe3-9ced-a733534b6a2c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1583 - Information\ - \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Services Acquisition\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f2d9d3e6-8886-4305-865d-639163e5c305\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f2d9d3e6-8886-4305-865d-639163e5c305\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1460 - Access\ + \ Control For Output Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Physical and Environmental Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1583\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1460\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0882d488-8e80-4466-bc0f-0cd15b6cb66d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0882d488-8e80-4466-bc0f-0cd15b6cb66d\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines on which the DSC\ - \ configuration is not compliant\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Requires that prerequisites are deployed to the\ - \ policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the Windows PowerShell command Get-DSCConfigurationStatus\ - \ returns that the DSC configuration for the machine is not compliant.\",\"\ - metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"WindowsDscConfiguration\",\"version\":\"1.*\"}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"}},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDscConfiguration\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/08a2f2d2-94b2-4a7b-aa3b-bb3f523ee6fd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"08a2f2d2-94b2-4a7b-aa3b-bb3f523ee6fd\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using latest supported PHP Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported PHP version for\ - \ the latest security classes. Using older classes and types can make your\ - \ application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"app\"},{\"field\":\"kind\",\"equals\":\"WebApp\"},{\"field\":\"kind\",\"\ - equals\":\"app,linux\"},{\"field\":\"kind\",\"equals\":\"app,linux,container\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Security/complianceResults\",\"name\":\"UseLatestPHP\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\",\"in\"\ - :[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/08b17839-76c6-4015-90e0-33d9d54d219c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"08b17839-76c6-4015-90e0-33d9d54d219c\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Search\ - \ Services to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Deploys the diagnostic settings for Search\ - \ Services to stream to a regional Log Analytics workspace when any Search\ - \ Services which is missing this diagnostic settings is created or updated.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - },\"profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Search/searchServices\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Search/searchServices/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"OperationLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/08ba64b8-738f-4918-9686-730d2ed79c7d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"08ba64b8-738f-4918-9686-730d2ed79c7d\"\ - },{\"properties\":{\"displayName\":\"Adaptive Network Hardening recommendations\ - \ should be applied on internet facing virtual machines\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Azure Security Center analyzes\ - \ the traffic patterns of Internet facing virtual machines and provides Network\ - \ Security Group rule recommendations that reduce the potential attack surface\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"f9f0eed0-f143-47bf-b856-671ea2eeed62\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/08e6af2d-db70-460a-bfe9-d5bd474ba9d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"08e6af2d-db70-460a-bfe9-d5bd474ba9d6\"\ - },{\"properties\":{\"displayName\":\"There should be more than one owner assigned\ - \ to your subscription\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"It is recommended to designate more than one subscription owner in order\ - \ to have administrator access redundancy.\",\"metadata\":{\"version\":\"\ - 2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"2c79b4af-f830-b61e-92b9-63dfa30f16e4\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/09024ccc-0c5f-475e-9457-b7c0d9ed487b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"09024ccc-0c5f-475e-9457-b7c0d9ed487b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1159 - Security\ - \ Authorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1159\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6f3ce1bb-4f77-4695-8355-70b08d54fdda\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6f3ce1bb-4f77-4695-8355-70b08d54fdda\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1459 - Access\ + \ Control For Transmission Medium\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1459\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0925f098-7877-450b-8ba4-d1e55f2d8795\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0925f098-7877-450b-8ba4-d1e55f2d8795\"\ - },{\"properties\":{\"displayName\":\"Disk encryption should be applied on\ - \ virtual machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Virtual machines without an enabled disk encryption will be monitored by\ - \ Azure Security Center as recommendations.\",\"metadata\":{\"version\":\"\ - 2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"Microsoft.ClassicCompute/virtualMachines\"\ - ,\"Microsoft.Compute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"d57a4221-a804-52ca-3dea-768284f06bb7\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"NotApplicable\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0961003e-5a0a-4549-abde-af6a37f2724d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0961003e-5a0a-4549-abde-af6a37f2724d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1302 - Identification\ - \ And Authentication (Org. Users) | Network Access To Non-Privileged Accounts\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1302\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75cc73c7-5cdb-479d-a06f-7b4d0dbb1da0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75cc73c7-5cdb-479d-a06f-7b4d0dbb1da0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1458 - Physical\ + \ Access Control | Information System Access\",\"policyType\":\"Static\",\"\ + mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ + \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1458\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/09828c65-e323-422b-9774-9d5c646124da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"09828c65-e323-422b-9774-9d5c646124da\"\ - },{\"properties\":{\"displayName\":\"Configure backup on VMs of a location\ - \ to an existing central Vault in the same location\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy configures Azure Backup\ - \ protection on VMs in a given location to an existing central vault in the\ - \ same location. It applies to only those VMs that are not already configured\ - \ for backup. It is recommended that this policy is assigned to not more than\ - \ 200 VMs. If the policy is assigned for more than 200 VMs, it can result\ - \ in the backup getting triggered a few hours beyond the defined schedule.\ - \ This policy will be enhanced to support more VM images.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Backup\"},\"parameters\":{\"vaultLocation\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Location (Specify the\ - \ location of the VMs that you want to protect)\",\"description\":\"Specify\ - \ the location of the VMs that you want to protect. VMs should be backed up\ - \ to a vault in the same location.\\r\\nFor example - southeastasia\",\"strongType\"\ - :\"location\"}},\"backupPolicyId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Backup Policy (of type Azure VM from a vault in the location chosen above)\"\ - ,\"description\":\"Specify the id of the Azure backup policy to configure\ - \ backup of the virtual machines. The selected Azure backup policy should\ - \ be of type Azure virtual machine. This policy needs to be in a vault that\ - \ is present in the location chosen above.\\r\\nFor example - /subscriptions//resourceGroups//providers/Microsoft.RecoveryServices/vaults//backupPolicies/\"\ - ,\"strongType\":\"Microsoft.RecoveryServices/vaults/backupPolicies\"}},\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"deployIfNotExists\",\"auditIfNotExists\",\"disabled\"],\"defaultValue\"\ - :\"deployIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"field\":\"location\"\ - ,\"equals\":\"[parameters('vaultLocation')]\"},{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ - ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ - ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ - ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ - 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ - ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ - ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ - ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7.*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\"\ - ,\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/5e467623-bb1f-42f4-a55d-6e525e11384b\"\ - ],\"type\":\"Microsoft.RecoveryServices/backupprotecteditems\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"backupPolicyId\":{\"type\"\ - :\"String\"},\"fabricName\":{\"type\":\"String\"},\"protectionContainers\"\ - :{\"type\":\"String\"},\"protectedItems\":{\"type\":\"String\"},\"sourceResourceId\"\ - :{\"type\":\"String\"}},\"resources\":[{\"apiVersion\":\"2017-05-10\",\"name\"\ - :\"[concat('DeployProtection-',uniqueString(parameters('protectedItems')))]\"\ - ,\"type\":\"Microsoft.Resources/deployments\",\"resourceGroup\":\"[first(skip(split(parameters('backupPolicyId'),\ - \ '/'), 4))]\",\"subscriptionId\":\"[first(skip(split(parameters('backupPolicyId'),\ - \ '/'), 2))]\",\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"backupPolicyId\":{\"type\"\ - :\"String\"},\"fabricName\":{\"type\":\"String\"},\"protectionContainers\"\ - :{\"type\":\"String\"},\"protectedItems\":{\"type\":\"String\"},\"sourceResourceId\"\ - :{\"type\":\"String\"}},\"resources\":[{\"type\":\"Microsoft.RecoveryServices/vaults/backupFabrics/protectionContainers/protectedItems\"\ - ,\"name\":\"[concat(first(skip(split(parameters('backupPolicyId'), '/'), 8)),\ - \ '/', parameters('fabricName'), '/',parameters('protectionContainers'), '/',\ - \ parameters('protectedItems'))]\",\"apiVersion\":\"2016-06-01\",\"properties\"\ - :{\"protectedItemType\":\"Microsoft.Compute/virtualMachines\",\"policyId\"\ - :\"[parameters('backupPolicyId')]\",\"sourceResourceId\":\"[parameters('sourceResourceId')]\"\ - }}]},\"parameters\":{\"backupPolicyId\":{\"value\":\"[parameters('backupPolicyId')]\"\ - },\"fabricName\":{\"value\":\"[parameters('fabricName')]\"},\"protectionContainers\"\ - :{\"value\":\"[parameters('protectionContainers')]\"},\"protectedItems\":{\"\ - value\":\"[parameters('protectedItems')]\"},\"sourceResourceId\":{\"value\"\ - :\"[parameters('sourceResourceId')]\"}}}}]},\"parameters\":{\"backupPolicyId\"\ - :{\"value\":\"[parameters('backupPolicyId')]\"},\"fabricName\":{\"value\"\ - :\"Azure\"},\"protectionContainers\":{\"value\":\"[concat('iaasvmcontainer;iaasvmcontainerv2;',\ - \ resourceGroup().name, ';' ,field('name'))]\"},\"protectedItems\":{\"value\"\ - :\"[concat('vm;iaasvmcontainerv2;', resourceGroup().name, ';' ,field('name'))]\"\ - },\"sourceResourceId\":{\"value\":\"[concat('/subscriptions/', subscription().subscriptionId,\ - \ '/resourceGroups/', resourceGroup().name, '/providers/Microsoft.Compute/virtualMachines/',field('name'))]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/09ce66bc-1220-4153-8104-e3f51c936913\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"09ce66bc-1220-4153-8104-e3f51c936913\"\ - },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ - \ MariaDB servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits MariaDB servers not configured to use a private endpoint.\ - \ For more details, visit https://aka.ms/mariadbprivatelink.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMariaDB/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforMariaDB/servers/privateEndpointConnections\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforMariaDB/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a1302fb-a631-4106-9753-f3d494733990\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a1302fb-a631-4106-9753-f3d494733990\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Azure Policy Add-on for Kubernetes\ - \ service (AKS) should be installed and enabled on your clusters\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Azure Policy Add-on for\ - \ Kubernetes service (AKS) extends Gatekeeper v3, an admission controller\ - \ webhook for Open Policy Agent (OPA), to apply at-scale enforcements and\ - \ safeguards on your clusters in a centralized, consistent manner.\",\"metadata\"\ - :{\"version\":\"1.0.1-preview\",\"category\":\"Kubernetes\",\"preview\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerService/managedClusters\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.ContainerService/managedClusters/addonProfiles.azurePolicy.enabled\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ContainerService/managedClusters/addonProfiles.azurePolicy.enabled\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a15ec92-a229-4763-bb14-0ea34a568f8d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a15ec92-a229-4763-bb14-0ea34a568f8d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1654 - Voice\ - \ Over Internet Protocol\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1654\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8c19ceb7-56e9-4488-8ddb-b1eb3aa6d203\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8c19ceb7-56e9-4488-8ddb-b1eb3aa6d203\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1463 - Monitoring\ + \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1463\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a2ee16e-ab1f-414a-800b-d1608835862b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a2ee16e-ab1f-414a-800b-d1608835862b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1402 - Controlled\ - \ Maintenance | Automated Maintenance Activities\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1402\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/59721f87-ae25-4db0-a2a4-77cc5b25d495\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"59721f87-ae25-4db0-a2a4-77cc5b25d495\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1462 - Monitoring\ + \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1462\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a560d32-8075-4fec-9615-9f7c853f4ea9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a560d32-8075-4fec-9615-9f7c853f4ea9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1428 - Media\ - \ Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9b1f3a9a-13a1-4b40-8420-36bca6fd8c02\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9b1f3a9a-13a1-4b40-8420-36bca6fd8c02\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1461 - Monitoring\ + \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1461\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aafef03e-fea8-470b-88fa-54bd1fcd7064\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aafef03e-fea8-470b-88fa-54bd1fcd7064\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1464 - Monitoring\ + \ Physical Access | Intrusion Alarms / Surveillance Equipment\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1428\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1464\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a77fcc7-b8d8-451a-ab52-56197913c0c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a77fcc7-b8d8-451a-ab52-56197913c0c7\"\ - },{\"properties\":{\"displayName\":\"Audit resource location matches resource\ - \ group location\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit that the resource location matches its resource group location\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"General\"},\"policyRule\"\ - :{\"if\":{\"field\":\"location\",\"notIn\":[\"[resourcegroup().location]\"\ - ,\"global\"]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a914e76-4921-4c19-b460-a2d36003525a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a914e76-4921-4c19-b460-a2d36003525a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Account Management'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Account Management'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesAccountManagement\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SystemAuditPoliciesAccountManagement\"}},\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a9991e6-21be-49f9-8916-a06d934bcf29\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a9991e6-21be-49f9-8916-a06d934bcf29\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1044 - Unsuccessful\ - \ Logon Attempts\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/41256567-1795-4684-b00b-a1308ce43cac\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"41256567-1795-4684-b00b-a1308ce43cac\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1465 - Monitoring\ + \ Physical Access | Monitoring Physical Access To Information Systems\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this Physical and Environmental Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1044\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1465\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0abbac52-57cf-450d-8408-1208d0dd9e90\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0abbac52-57cf-450d-8408-1208d0dd9e90\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1253 - Contingency\ - \ Plan | Resume Essential Missions / Business Functions\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1253\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e6e41554-86b5-4537-9f7f-4fc41a1d1640\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e6e41554-86b5-4537-9f7f-4fc41a1d1640\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1466 - Visitor\ + \ Access Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1466\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0afce0b3-dd9f-42bb-af28-1e4284ba8311\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0afce0b3-dd9f-42bb-af28-1e4284ba8311\"\ - },{\"properties\":{\"displayName\":\"Email notification to subscription owner\ - \ for high severity alerts should be enabled\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Enable emailing security alerts to the\ - \ subscription owner, in order to have them receive security alert emails\ - \ from Microsoft. This ensures that they are aware of any potential security\ - \ issues and can mitigate the risk in a timely fashion\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/securityContacts\",\"existenceCondition\":{\"field\":\"\ - Microsoft.Security/securityContacts/alertsToAdmins\",\"notEquals\":\"Off\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b15565f-aa9e-48ba-8619-45960f2c314d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b15565f-aa9e-48ba-8619-45960f2c314d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1046 - Automatic\ - \ Account Lock | Purge / Wipe Mobile Device\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1046\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d943a9c-a6f1-401f-a792-740cdb09c451\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d943a9c-a6f1-401f-a792-740cdb09c451\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1467 - Visitor\ + \ Access Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1467\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b1aa965-7502-41f9-92be-3e2fe7cc392a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b1aa965-7502-41f9-92be-3e2fe7cc392a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1020 - Account\ - \ Management | Role-Based Schemes\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5350cbf9-8bdd-4904-b22a-e88be84ca49d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5350cbf9-8bdd-4904-b22a-e88be84ca49d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1468 - Visitor\ + \ Access Records | Automated Records Maintenance / Review\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1468\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75603f96-80a1-4757-991d-5a1221765ddd\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75603f96-80a1-4757-991d-5a1221765ddd\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1471 - Emergency\ + \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1020\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1471\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b291ee8-3140-4cad-beb7-568c077c78ce\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b291ee8-3140-4cad-beb7-568c077c78ce\"\ - },{\"properties\":{\"displayName\":\"Key Vault objects should be recoverable\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ audits if key vault objects are not recoverable. Soft Delete feature helps\ - \ to effectively hold the resources for a given retention period (90 days)\ - \ even after a DELETE operation, while giving the appearance that the object\ - \ is deleted. When 'Purge protection' is on, a vault or an object in deleted\ - \ state cannot be purged until the retention period of 90 days has passed.\ - \ These vaults and objects can still be recovered, assuring customers that\ - \ the retention policy will be followed.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Key Vault\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.KeyVault/vaults/enableSoftDelete\",\"exists\":\"false\"},{\"\ - field\":\"Microsoft.KeyVault/vaults/enablePurgeProtection\",\"exists\":\"\ - false\"},{\"field\":\"Microsoft.KeyVault/vaults/enableSoftDelete\",\"equals\"\ - :\"false\"},{\"field\":\"Microsoft.KeyVault/vaults/enablePurgeProtection\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b60c0b2-2dc2-4e1c-b5c9-abbed971de53\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b60c0b2-2dc2-4e1c-b5c9-abbed971de53\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1115 - Audit\ - \ Review, Analysis, And Reporting\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7dd0e9ce-1772-41fb-a50a-99977071f916\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7dd0e9ce-1772-41fb-a50a-99977071f916\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1469 - Power\ + \ Equipment And Cabling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1115\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1469\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b653845-2ad9-4e09-a4f3-5a7c1d78353d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b653845-2ad9-4e09-a4f3-5a7c1d78353d\"\ - },{\"properties\":{\"displayName\":\"Azure Cosmos DB throughput should be\ - \ limited\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy enables you to restrict the maximum throughput your organization\ - \ can specify when creating Azure Cosmos DB databases and containers through\ - \ the resource provider. It blocks the creation of autoscale resources.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cosmos DB\"},\"parameters\"\ - :{\"throughputMax\":{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"\ - Max RUs\",\"description\":\"The maximum throughput (RU/s) that can be assigned\ - \ to a container via the Resource Provider during create or update.\"}},\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Policy Effect\"\ - ,\"description\":\"The desired effect of the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"anyOf\":[{\"field\":\"type\",\"like\":\"Microsoft.DocumentDB/databaseAccounts/*/throughputSettings\"\ - },{\"field\":\"type\",\"in\":[\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases\"\ - ,\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers\",\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases\"\ - ,\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections\",\"\ - Microsoft.DocumentDB/databaseAccounts/gremlinDatabases\",\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs\"\ - ,\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces\",\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables\"\ - ,\"Microsoft.DocumentDB/databaseAccounts/tables\"]}]},{\"anyOf\":[{\"value\"\ - :\"[requestContext().apiVersion]\",\"less\":\"2019-08-01\"},{\"value\":\"\ - [if(equals(field('Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/sqlDatabases/containers/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/cassandraKeyspaces/tables/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/gremlinDatabases/graphs/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/mongodbDatabases/collections/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"},{\"value\":\"[if(equals(field('Microsoft.DocumentDB/databaseAccounts/tables/options.throughput'),\ - \ ''), 0, int(field('Microsoft.DocumentDB/databaseAccounts/tables/options.throughput')))]\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/tables/options\"\ - ,\"containsKey\":\"ProvisionedThroughputSettings\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/tables/throughputSettings/default.resource.throughput\"\ - ,\"greater\":\"[parameters('throughputMax')]\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/tables/throughputSettings/default.resource.provisionedThroughputSettings\"\ - ,\"exists\":\"true\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0b7ef78e-a035-4f23-b9bd-aff122a1b1cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0b7ef78e-a035-4f23-b9bd-aff122a1b1cf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1239 - User-Installed\ - \ Software\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1239\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0be51298-f643-4556-88af-d7db90794879\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0be51298-f643-4556-88af-d7db90794879\"\ - },{\"properties\":{\"displayName\":\"Ensure API app has 'Client Certificates\ - \ (Incoming client certificates)' set to 'On'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Client certificates allow for the\ - \ app to request a certificate for incoming requests. Only clients that have\ - \ a valid certificate will be able to reach the app.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"*api\"},{\"field\":\"Microsoft.Web/sites/clientCertEnabled\",\"\ - equals\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/0c192fe8-9cbb-4516-85b3-0ade8bd03886\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0c192fe8-9cbb-4516-85b3-0ade8bd03886\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1496 - System\ - \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1496\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ca96127-2f87-46ab-a4fc-0d2a786df1c8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ca96127-2f87-46ab-a4fc-0d2a786df1c8\"\ - },{\"properties\":{\"displayName\":\"SQL server TDE protector should be encrypted\ - \ with your own key\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Transparent Data Encryption (TDE) with your own key support provides increased\ - \ transparency and control over the TDE Protector, increased security with\ - \ an HSM-backed external service, and promotion of separation of duties.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/servers/encryptionProtector\",\"name\":\"current\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.Sql/servers/encryptionProtector/serverKeyType\"\ - ,\"equals\":\"AzureKeyVault\"},{\"field\":\"Microsoft.Sql/servers/encryptionProtector/uri\"\ - ,\"notEquals\":\"\"},{\"field\":\"Microsoft.Sql/servers/encryptionProtector/uri\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d134df8-db83-46fb-ad72-fe0c9428c8dd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d134df8-db83-46fb-ad72-fe0c9428c8dd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1518 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1518\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f509c5b6-0de0-4a4e-9b2e-cd9cbf3a58fd\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f509c5b6-0de0-4a4e-9b2e-cd9cbf3a58fd\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1470 - Emergency\ + \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1470\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d58f734-c052-40e9-8b2f-a1c2bff0b815\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d58f734-c052-40e9-8b2f-a1c2bff0b815\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1713 - Software,\ - \ Firmware, And Information Integrity | Integrity Checks\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1713\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c89ba09f-2e0f-44d0-8095-65b05bd151ef\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c89ba09f-2e0f-44d0-8095-65b05bd151ef\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1473 - Emergency\ + \ Power\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ + Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1473\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d87c70b-5012-48e9-994b-e70dd4b8def0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d87c70b-5012-48e9-994b-e70dd4b8def0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1466 - Visitor\ - \ Access Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d7047705-d719-46a7-8bb0-76ad233eba71\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d7047705-d719-46a7-8bb0-76ad233eba71\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1472 - Emergency\ + \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this Physical and Environmental Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1466\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1472\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d943a9c-a6f1-401f-a792-740cdb09c451\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d943a9c-a6f1-401f-a792-740cdb09c451\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs on which Windows Defender Exploit Guard is not enabled\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines on which Windows Defender Exploit Guard is not enabled.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDefenderExploitGuard\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d9b45ff-9ddd-43fc-bf59-fbd1c8423053\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d9b45ff-9ddd-43fc-bf59-fbd1c8423053\"\ - },{\"properties\":{\"displayName\":\"Managed identity should be used in your\ - \ Function App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use a managed identity for enhanced authentication security\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0da106f2-4ca3-48e8-bc85-c638fe6aea8f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0da106f2-4ca3-48e8-bc85-c638fe6aea8f\"\ - },{\"properties\":{\"displayName\":\"Deploy a flow log resource with target\ - \ network security group\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Configures flow log for specific network security group.\ - \ It will allow to log information about IP traffic flowing through an network\ - \ security group. Flow log helps to identify unknown or undesired traffic,\ - \ verify network isolation and compliance with enterprise access rules, analyze\ - \ network flows from compromised IPs and network interfaces.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{\"nsgRegion\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"NSG Region\",\"description\"\ - :\"This Policy will review NSGs only in the selected region. You can create\ - \ other assignments to include other regions.\",\"strongType\":\"location\"\ - }},\"storageId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Storage\ - \ id\",\"description\":\"A string with the storage id for the flowlogs to\ - \ be sent to. It will be used for deployment purposes only. Make sure this\ - \ storage account is located in the same region as the NSG. The format must\ - \ be: '/subscriptions/{subscription id}/resourceGroups/{resourceGroup name}/providers/Microsoft.Storage/storageAccounts/{storage\ - \ account name}\",\"assignPermissions\":\"true\"}},\"networkWatcherRG\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Network Watchers RG\",\"\ - description\":\"The name of the resource group where the flowLog resources\ - \ will be created. This will be used only if a deployment is required. This\ - \ is the resource group where the Network Watchers are located.\",\"strongType\"\ - :\"existingResourceGroups\"}},\"networkWatcherName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Network Watcher name\",\"description\":\"\ - The name of the network watcher under which the flowLog resources will be\ - \ created. Make sure it belongs to the same region as the NSG.\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"equals\":\"[parameters('nsgRegion')]\"}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkWatchers/flowlogs\"\ - ,\"resourceGroupName\":\"[if(empty(coalesce(field('Microsoft.Network/networkSecurityGroups/flowLogs'))),\ - \ parameters('networkWatcherRG'), split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[4])]\",\"name\":\"[if(empty(coalesce(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id'))),\ - \ 'null/null', concat(split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[8], '/', split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[10]))]\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Network/networkWatchers/flowLogs/enabled\"\ - ,\"equals\":\"true\"},{\"field\":\"Microsoft.Network/networkWatchers/flowLogs/storageId\"\ - ,\"equals\":\"[parameters('storageId')]\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"storageId\":{\"type\":\"\ - String\"},\"networkWatcherRG\":{\"type\":\"String\"},\"networkWatcherName\"\ - :{\"type\":\"String\"},\"flowlogName\":{\"type\":\"String\"},\"location\"\ - :{\"type\":\"String\"},\"targetResource\":{\"type\":\"string\"}},\"resources\"\ - :[{\"type\":\"Microsoft.Resources/deployments\",\"name\":\"[concat('flowlogDeployment-',\ - \ uniqueString(parameters('flowlogName')))]\",\"apiVersion\":\"2019-10-01\"\ - ,\"resourceGroup\":\"[parameters('networkWatcherRG')]\",\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{},\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"resources\":[{\"type\"\ - :\"Microsoft.Network/networkWatchers/flowLogs\",\"name\":\"[concat(parameters('networkWatcherName'),\ - \ '/', parameters('flowlogName'))]\",\"apiVersion\":\"2019-11-01\",\"location\"\ - :\"[parameters('location')]\",\"properties\":{\"targetResourceId\":\"[parameters('targetResource')]\"\ - ,\"storageId\":\"[parameters('storageId')]\",\"enabled\":\"true\",\"retentionPolicy\"\ - :{\"days\":\"0\",\"enabled\":\"false\"}}}]}}}]},\"parameters\":{\"storageId\"\ - :{\"value\":\"[parameters('storageId')]\"},\"networkWatcherRG\":{\"value\"\ - :\"[if(empty(coalesce(field('Microsoft.Network/networkSecurityGroups/flowLogs'))),\ - \ parameters('networkWatcherRG'), split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[4])]\"},\"networkWatcherName\":{\"value\":\"[if(empty(coalesce(field('Microsoft.Network/networkSecurityGroups/flowLogs'))),\ - \ parameters('networkWatcherName'), split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[8])]\"},\"flowlogName\":{\"value\":\"[if(empty(coalesce(field('Microsoft.Network/networkSecurityGroups/flowLogs'))),\ - \ concat(field('name'), '-', resourceGroup().name, '-', 'flowlog'), split(first(field('Microsoft.Network/networkSecurityGroups/flowLogs[*].id')),\ - \ '/')[10])]\"},\"location\":{\"value\":\"[field('location')]\"},\"targetResource\"\ - :{\"value\":\"[concat(resourceGroup().id, '/providers/Microsoft.Network/networkSecurityGroups/',\ - \ field('name'))]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0db34a60-64f4-4bf6-bd44-f95c16cf34b9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0db34a60-64f4-4bf6-bd44-f95c16cf34b9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1718 - Software,\ - \ Firmware, And Information Integrity | Binary Or Machine Executable Code\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef869332-921d-4c28-9402-3be73e6e50c8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef869332-921d-4c28-9402-3be73e6e50c8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1474 - Emergency\ + \ Power | Long-Term Alternate Power Supply - Minimal Operational Capability\"\ ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ + \ implements this Physical and Environmental Protection control\",\"metadata\"\ :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1718\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1474\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0dced7ab-9ce5-4137-93aa-14c13e06ab17\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0dced7ab-9ce5-4137-93aa-14c13e06ab17\"\ - },{\"properties\":{\"displayName\":\"Authorized IP ranges should be defined\ - \ on Kubernetes Services\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Restrict access to the Kubernetes Service Management API by\ - \ granting API access only to IP addresses in specific ranges. It is recommended\ - \ to limit access to authorized IP ranges to ensure that only applications\ - \ from allowed networks can access the cluster.\",\"metadata\":{\"version\"\ - :\"2.0.1\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"field\":\"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.authorizedIPRanges\"\ - ,\"exists\":\"false\"},{\"anyOf\":[{\"field\":\"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.enablePrivateCluster\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ContainerService/managedClusters/apiServerAccessProfile.enablePrivateCluster\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0e246bcf-5f6f-4f87-bc6f-775d4712c7ea\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0e246bcf-5f6f-4f87-bc6f-775d4712c7ea\"\ - },{\"properties\":{\"displayName\":\"Remote debugging should be turned off\ - \ for Function Apps\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Remote debugging requires inbound ports to be opened on function apps.\ - \ Remote debugging should be turned off.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/config/web.remoteDebuggingEnabled\",\"equals\"\ - :\"false\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0e60b895-3786-45da-8377-9c6b4b6ac5f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0e60b895-3786-45da-8377-9c6b4b6ac5f9\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Azure Key Vault vaults\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Advanced threat protection provides an additional\ - \ layer of protection of security intelligence by detecting unusual and potentially\ - \ harmful attempts to access or exploit key vault accounts.\",\"metadata\"\ - :{\"version\":\"1.0.2\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/pricings\",\"name\":\"KeyVaults\",\"existenceScope\":\"\ - subscription\",\"existenceCondition\":{\"field\":\"Microsoft.Security/pricings/pricingTier\"\ - ,\"equals\":\"Standard\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0e6763cc-5078-4e64-889d-ff4d9a839047\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0e6763cc-5078-4e64-889d-ff4d9a839047\"\ - },{\"properties\":{\"displayName\":\"Geo-redundant backup should be enabled\ - \ for Azure Database for MariaDB\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy audits any Azure Database for MariaDB\ - \ with geo-redundant backup not enabled.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.DBforMariaDB/servers\"},{\"field\":\"Microsoft.DBforMariaDB/servers/storageProfile.geoRedundantBackup\"\ - ,\"notEquals\":\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ec47710-77ff-4a3d-9181-6aa50af424d0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ec47710-77ff-4a3d-9181-6aa50af424d0\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ enable Guest Configuration Policy on Windows VMs.\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration on\ - \ Windows VMs. This is a prerequisite for Guest Configuration Policy and must\ - \ be assigned to the scope before using any Guest Configuration policy. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzurePolicyforWindows\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.GuestConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"ConfigurationforWindows\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'),\ - \ '/AzurePolicyforWindows')]\",\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"properties\":{\"publisher\":\"\ - Microsoft.GuestConfiguration\",\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\"\ - :\"1.1\",\"autoUpgradeMinorVersion\":true,\"settings\":{},\"protectedSettings\"\ - :{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ecd903d-91e7-4726-83d3-a229d7f2e293\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ecd903d-91e7-4726-83d3-a229d7f2e293\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1601 - Developer\ - \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1601\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/03ad326e-d7a1-44b1-9a76-e17492efc9e4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"03ad326e-d7a1-44b1-9a76-e17492efc9e4\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1475 - Emergency\ + \ Lighting\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1475\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ee79a0c-addf-4ce9-9b3c-d9576ed5e20e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ee79a0c-addf-4ce9-9b3c-d9576ed5e20e\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Audit Azure Spring Cloud instances\ - \ where distributed tracing is not enabled\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Distributed tracing tools in Azure Spring\ - \ Cloud allow debugging and monitoring the complex interconnections between\ - \ microservices in an application. Distributed tracing tools should be enabled\ - \ and in a healthy state.\",\"metadata\":{\"version\":\"1.0.0-preview\",\"\ - category\":\"App Platform\",\"preview\":true},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.AppPlatform/Spring\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.AppPlatform/Spring/trace.enabled\",\"\ - notEquals\":\"true\"},{\"field\":\"Microsoft.AppPlatform/Spring/trace.state\"\ - ,\"notEquals\":\"Succeeded\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f2d8593-4667-4932-acca-6a9f187af109\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f2d8593-4667-4932-acca-6a9f187af109\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34a63848-30cf-4081-937e-ce1a1c885501\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34a63848-30cf-4081-937e-ce1a1c885501\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1476 - Fire\ \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this Physical and Environmental Protection control\"\ @@ -1886,1577 +8776,556 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f3c4ac2-3e35-4906-a80b-473b12a622d7\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f3c4ac2-3e35-4906-a80b-473b12a622d7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1204 - Access\ - \ Restrictions For Change | Review System Changes\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1204\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1477 - Fire\ + \ Protection | Detection Devices / Systems\",\"policyType\":\"Static\",\"\ + mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ + \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1477\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f4f6750-d1ab-4a4c-8dfd-af3237682665\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f4f6750-d1ab-4a4c-8dfd-af3237682665\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1430 - Media\ - \ Marking\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1430\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f559588-5e53-4b14-a7c4-85d28ebc2234\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f559588-5e53-4b14-a7c4-85d28ebc2234\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1574 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1574\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4862a63c-6c74-4a9d-a221-89af3c374503\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4862a63c-6c74-4a9d-a221-89af3c374503\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1478 - Fire\ + \ Protection | Suppression Devices / Systems\",\"policyType\":\"Static\",\"\ + mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ + \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1478\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f935dab-83d6-47b8-85ef-68b8584161b9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f935dab-83d6-47b8-85ef-68b8584161b9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1164 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1164\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f997df46-cfbb-4cc8-aac8-3fecdaf6a183\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f997df46-cfbb-4cc8-aac8-3fecdaf6a183\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1481 - Temperature\ + \ And Humidity Controls\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1481\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0fb8d3ce-9e96-481c-9c68-88d4e3019310\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0fb8d3ce-9e96-481c-9c68-88d4e3019310\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1017 - Account\ - \ Management | Inactivity Logout\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1017\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0fc3db37-e59a-48c1-84e9-1780cedb409e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0fc3db37-e59a-48c1-84e9-1780cedb409e\"\ - },{\"properties\":{\"displayName\":\"CORS should not allow every domain to\ - \ access your API for FHIR\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Cross-Origin Resource Sharing (CORS) should not allow all\ - \ domains to access your API for FHIR. To protect your API for FHIR, remove\ - \ access for all domains and explicitly define the domains allowed to connect.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"API for FHIR\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"audit\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HealthcareApis/services\"\ - },{\"not\":{\"field\":\"Microsoft.HealthcareApis/services/corsConfiguration.origins[*]\"\ - ,\"notEquals\":\"*\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/0fea8f8a-4169-495d-8307-30ec335f387d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0fea8f8a-4169-495d-8307-30ec335f387d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1087 - Security\ - \ Awareness And Training Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Awareness\ - \ and Training control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1087\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/717a1c78-a267-4f56-ac58-ee6c54dc4339\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"717a1c78-a267-4f56-ac58-ee6c54dc4339\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1482 - Temperature\ + \ And Humidity Controls | Monitoring With Alarms / Notifications\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1482\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9df4277e-8c88-4d5c-9b1a-541d53d15d7b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9df4277e-8c88-4d5c-9b1a-541d53d15d7b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1480 - Temperature\ + \ And Humidity Controls\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Physical and Environmental Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1480\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/100c82ba-42e9-4d44-a2ba-94b209248583\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"100c82ba-42e9-4d44-a2ba-94b209248583\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not contain the specified certificates in Trusted\ - \ Root\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - This policy creates a Guest Configuration assignment to audit Windows VMs\ - \ that do not contain the specified certificates in the Trusted Root Certification\ - \ Authorities certificate store (Cert:\\\\LocalMachine\\\\Root). It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - CertificateThumbprints\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Certificate thumbprints\",\"description\":\"A semicolon-separated\ - \ list of certificate thumbprints that should exist under the Trusted Root\ - \ certificate store (Cert:\\\\LocalMachine\\\\Root). e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsCertificateInTrustedRoot\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude',\ - \ '=', parameters('CertificateThumbprints')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsCertificateInTrustedRoot\"\ - },\"CertificateThumbprints\":{\"value\":\"[parameters('CertificateThumbprints')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"CertificateThumbprints\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"\ - ,\"value\":\"[parameters('CertificateThumbprints')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"\ - ,\"value\":\"[parameters('CertificateThumbprints')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/106ccbe4-a791-4f33-a44a-06796944b8d5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"106ccbe4-a791-4f33-a44a-06796944b8d5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1554 - Vulnerability\ - \ Scanning | Discoverable Information\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/18a767cc-1947-4338-a240-bc058c81164f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"18a767cc-1947-4338-a240-bc058c81164f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1483 - Water\ + \ Damage Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1554\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1483\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/10984b4e-c93e-48d7-bf20-9c03b04e9eca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"10984b4e-c93e-48d7-bf20-9c03b04e9eca\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that '.NET Framework'\ - \ version is the latest, if used as a part of the Function App\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy is not required\ - \ since Azure App Service automatically updates and maintains the .NET Framework\ - \ versions installed on the platform.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.netFrameworkVersion\"\ - ,\"in\":[\"v3.0\",\"v4.0\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/10c1859c-e1a7-4df3-ab97-a487fa8059f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"10c1859c-e1a7-4df3-ab97-a487fa8059f6\"\ - },{\"properties\":{\"displayName\":\"Custom subscription owner roles should\ - \ not exist\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"This policy ensures that no custom subscription owner roles exist.\",\"\ - metadata\":{\"version\":\"2.0.0\",\"category\":\"General\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Authorization/roleDefinitions\"\ - },{\"field\":\"Microsoft.Authorization/roleDefinitions/type\",\"equals\":\"\ - CustomRole\"},{\"anyOf\":[{\"not\":{\"field\":\"Microsoft.Authorization/roleDefinitions/permissions[*].actions[*]\"\ - ,\"notEquals\":\"*\"}},{\"not\":{\"field\":\"Microsoft.Authorization/roleDefinitions/permissions.actions[*]\"\ - ,\"notEquals\":\"*\"}}]},{\"anyOf\":[{\"not\":{\"field\":\"Microsoft.Authorization/roleDefinitions/assignableScopes[*]\"\ - ,\"notIn\":[\"[concat(subscription().id,'/')]\",\"[subscription().id]\",\"\ - /\"]}},{\"not\":{\"field\":\"Microsoft.Authorization/roleDefinitions/assignableScopes[*]\"\ - ,\"notLike\":\"/providers/Microsoft.Management/*\"}}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/10ee2ea2-fb4d-45b8-a7e9-a2e770044cd9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"10ee2ea2-fb4d-45b8-a7e9-a2e770044cd9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1230 - Configuration\ - \ Management Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1230\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5cb81060-3c8a-4968-bcdc-395a1801f6c1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5cb81060-3c8a-4968-bcdc-395a1801f6c1\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1484 - Water\ + \ Damage Protection | Automation Support\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1484\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/11158848-f679-4e9b-aa7b-9fb07d945071\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"11158848-f679-4e9b-aa7b-9fb07d945071\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1432 - Media\ - \ Storage\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1432\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/486b006a-3653-45e8-b41c-a052d3e05456\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"486b006a-3653-45e8-b41c-a052d3e05456\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1479 - Fire\ + \ Protection | Automatic Fire Suppression\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1479\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1140e542-b80d-4048-af45-3f7245be274b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1140e542-b80d-4048-af45-3f7245be274b\"\ - },{\"properties\":{\"displayName\":\"Cognitive Services accounts should use\ - \ customer owned storage or enable data encryption.\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy audits any Cognitive Services\ - \ account not using customer owned storage nor data encryption. For each Cognitive\ - \ Services account with storage, use either customer owned storage or enable\ - \ data encryption.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cognitive\ - \ Services\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"The effect determines what\ - \ happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"\ - },{\"count\":{\"field\":\"Microsoft.CognitiveServices/accounts/userOwnedStorage[*]\"\ - },\"less\":1},{\"field\":\"Microsoft.CognitiveServices/accounts/encryption.keySource\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/11566b39-f7f7-4b82-ab06-68d8700eb0a4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"11566b39-f7f7-4b82-ab06-68d8700eb0a4\"\ - },{\"properties\":{\"displayName\":\"Audit Dependency agent deployment - VM\ - \ Image (OS) unlisted\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Reports VMs as non-compliant if the VM Image (OS) is not in\ - \ the list defined and the agent is not installed. The list of OS images will\ - \ be updated over time as support is updated.\",\"metadata\":{\"version\"\ - :\"1.0.1\",\"category\":\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude_windows\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Windows OS to add to scope\",\"description\"\ - :\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]},\"listOfImageIdToInclude_linux\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"Optional: List of VM images that have supported\ - \ Linux OS to add to scope\",\"description\":\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"not\":{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_windows')]\"\ - },{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_linux')]\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"in\":[\"12-SP2\",\"12-SP3\",\"12-SP4\"]}]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"14.04.0-LTS\"\ - ,\"14.04.1-LTS\",\"14.04.5-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"16.04-LTS\",\"16.04.0-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"18.04-LTS\"]}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"Centos\",\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ - :\"7*\"}]}]}}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\",\"\ - equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/11ac78e3-31bc-4f0c-8434-37ab963cea07\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"11ac78e3-31bc-4f0c-8434-37ab963cea07\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - System settings'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - System settings'\ - \ for certificate rules on executables for SRP and optional subsystems. This\ - \ policy requires that the Guest Configuration prerequisites have been deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsSystemsettings\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies\"\ - :\"System settings: Use Certificate Rules on Windows Executables for Software\ - \ Restriction Policies;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"System settings: Use\ - \ Certificate Rules on Windows Executables for Software Restriction Policies\"\ - ,\"description\":\"Specifies whether digital certificates are processed when\ - \ software restriction policies are enabled and a user or process attempts\ - \ to run software with an .exe file name extension. It enables or disables\ - \ certificate rules (a type of software restriction policies rule). For certificate\ - \ rules to take effect in software restriction policies, you must enable this\ - \ policy setting.\"},\"defaultValue\":\"1\"},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsSystemsettings\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('System settings: Use Certificate Rules on Windows\ - \ Executables for Software Restriction Policies;ExpectedValue', '=', parameters('SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12017595-5a75-4bb1-9d97-4c2c939ea3c3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12017595-5a75-4bb1-9d97-4c2c939ea3c3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1655 - Voice\ - \ Over Internet Protocol\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1655\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e327b072-281d-4f75-9c28-4216e5d72f26\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e327b072-281d-4f75-9c28-4216e5d72f26\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1485 - Delivery\ + \ And Removal\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1485\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/121eab72-390e-4629-a7e2-6d6184f57c6b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"121eab72-390e-4629-a7e2-6d6184f57c6b\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Network Security'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Network Security'\ - \ for including Local System behavior, PKU2U, LAN Manager, LDAP client, and\ - \ NTLM SSP. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsNetworkSecurity\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos\"\ - :\"Network Security: Configure encryption types allowed for Kerberos;ExpectedValue\"\ - ,\"NetworkSecurityLANManagerAuthenticationLevel\":\"Network security: LAN\ - \ Manager authentication level;ExpectedValue\",\"NetworkSecurityLDAPClientSigningRequirements\"\ - :\"Network security: LDAP client signing requirements;ExpectedValue\",\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients\"\ - :\"Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) clients;ExpectedValue\",\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers\"\ - :\"Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) servers;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Network Security: Configure\ - \ encryption types allowed for Kerberos\",\"description\":\"Specifies the\ - \ encryption types that Kerberos is allowed to use.\"},\"defaultValue\":\"\ - 2147483644\"},\"NetworkSecurityLANManagerAuthenticationLevel\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Network security: LAN Manager authentication\ - \ level\",\"description\":\"Specify which challenge-response authentication\ - \ protocol is used for network logons. This choice affects the level of authentication\ - \ protocol used by clients, the level of session security negotiated, and\ - \ the level of authentication accepted by servers.\"},\"defaultValue\":\"\ - 5\"},\"NetworkSecurityLDAPClientSigningRequirements\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Network security: LDAP client signing requirements\"\ - ,\"description\":\"Specify the level of data signing that is requested on\ - \ behalf of clients that issue LDAP BIND requests.\"},\"defaultValue\":\"\ - 1\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Network security: Minimum\ - \ session security for NTLM SSP based (including secure RPC) clients\",\"\ - description\":\"Specifies which behaviors are allowed by clients for applications\ - \ using the NTLM Security Support Provider (SSP). The SSP Interface (SSPI)\ - \ is used by applications that need authentication services. See https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/network-security-minimum-session-security-for-ntlm-ssp-based-including-secure-rpc-servers\ - \ for more information.\"},\"defaultValue\":\"537395200\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Network security: Minimum\ - \ session security for NTLM SSP based (including secure RPC) servers\",\"\ - description\":\"Specifies which behaviors are allowed by servers for applications\ - \ using the NTLM Security Support Provider (SSP). The SSP Interface (SSPI)\ - \ is used by applications that need authentication services.\"},\"defaultValue\"\ - :\"537395200\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of this policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsNetworkSecurity\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Network Security: Configure encryption types\ - \ allowed for Kerberos;ExpectedValue', '=', parameters('NetworkSecurityConfigureEncryptionTypesAllowedForKerberos'),\ - \ ',', 'Network security: LAN Manager authentication level;ExpectedValue',\ - \ '=', parameters('NetworkSecurityLANManagerAuthenticationLevel'), ',', 'Network\ - \ security: LDAP client signing requirements;ExpectedValue', '=', parameters('NetworkSecurityLDAPClientSigningRequirements'),\ - \ ',', 'Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) clients;ExpectedValue', '=', parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients'),\ - \ ',', 'Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) servers;ExpectedValue', '=', parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1221c620-d201-468c-81e7-2817e6107e84\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1221c620-d201-468c-81e7-2817e6107e84\"\ - },{\"properties\":{\"displayName\":\"Allowlist rules in your adaptive application\ - \ control policy should be updated\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - All\",\"description\":\"Monitor for changes in behavior on groups of machines\ - \ configured for auditing by Azure Security Center's adaptive application\ - \ controls. Security Center uses machine learning to analyze the running processes\ - \ on your machines and suggest a list of known-safe applications. These are\ - \ presented as recommended apps to allow in adaptive application control policies.\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"1234abcd-1b53-4fd4-9835-2c2fa3935313\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/123a3936-f020-408a-ba0c-47873faf1534\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"123a3936-f020-408a-ba0c-47873faf1534\"\ - },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ - \ use the specified mode for Application Gateway\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Mandates the use of 'Detection' or\ - \ 'Prevention' mode to be active on all Web Application Firewall policies\ - \ for Application Gateway.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ - defaultValue\":\"Audit\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Mode Requirement\",\"description\":\"Mode required for\ - \ all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"],\"\ - defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies\"\ - },{\"field\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies/policySettings.mode\"\ - ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12430be1-6cc8-4527-a9a8-e3d38f250096\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12430be1-6cc8-4527-a9a8-e3d38f250096\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1681 - Malicious\ - \ Code Protection | Automatic Updates\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1681\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50301354-95d0-4a11-8af5-8039ecf6d38b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50301354-95d0-4a11-8af5-8039ecf6d38b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1486 - Alternate\ + \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1486\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12623e7e-4736-4b2e-b776-c1600f35f93a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12623e7e-4736-4b2e-b776-c1600f35f93a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1240 - User-Installed\ - \ Software\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cb790345-a51f-43de-934e-98dbfaf9dca5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cb790345-a51f-43de-934e-98dbfaf9dca5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1487 - Alternate\ + \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1487\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e9c3371d-c30c-4f58-abd9-30b8a8199571\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e9c3371d-c30c-4f58-abd9-30b8a8199571\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1488 - Alternate\ + \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Physical and Environmental Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1488\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d8ef30eb-a44f-47af-8524-ac19a36d41d2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d8ef30eb-a44f-47af-8524-ac19a36d41d2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1490 - Security\ + \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Planning control\",\"metadata\"\ :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1240\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1490\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/129eb39f-d79a-4503-84cd-92f036b5e429\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"129eb39f-d79a-4503-84cd-92f036b5e429\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - System objects'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - System objects'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsSystemobjects\",\"deployment\":{\"\ - properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\"\ - :\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"},\"\ - type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\":\"\ - AzureBaseline_SecurityOptionsSystemobjects\"}},\"template\":{\"$schema\":\"\ - https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12ae2d24-3805-4b37-9fa9-465968bfbcfa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12ae2d24-3805-4b37-9fa9-465968bfbcfa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1666 - System\ - \ And Information Integrity Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1666\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12e30ee3-61e6-4509-8302-a871e8ebb91e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12e30ee3-61e6-4509-8302-a871e8ebb91e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have the specified applications installed\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ that do not have the specified applications installed. It also creates a\ - \ system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - installedApplication\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Application names (supports wildcards)\",\"description\"\ - :\"A semicolon-separated list of the names of the applications that should\ - \ be installed. e.g. 'Microsoft SQL Server 2014 (64-bit); Microsoft Visual\ - \ Studio Code' or 'Microsoft SQL Server 2014*' (to match any application starting\ - \ with 'Microsoft SQL Server 2014')\"}}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WhitelistedApplication\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[InstalledApplication]bwhitelistedapp;Name',\ - \ '=', parameters('installedApplication')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WhitelistedApplication\"\ - },\"installedApplication\":{\"value\":\"[parameters('installedApplication')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"installedApplication\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[InstalledApplication]bwhitelistedapp;Name\"\ - ,\"value\":\"[parameters('installedApplication')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[InstalledApplication]bwhitelistedapp;Name\"\ - ,\"value\":\"[parameters('installedApplication')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12f7e5d0-42a7-4630-80d8-54fb7cff9bd6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12f7e5d0-42a7-4630-80d8-54fb7cff9bd6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1347 - Identification\ - \ And Authentication (Non-Org. Users) | Acceptance Of PIV Creds. From Other\ - \ Agys.\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Identification and Authentication control\",\"metadata\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e61da80-0957-4892-b70c-609d5eaafb6b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e61da80-0957-4892-b70c-609d5eaafb6b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1491 - Security\ + \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Planning control\",\"metadata\"\ :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1347\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1491\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/131a2706-61e9-4916-a164-00e052056462\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"131a2706-61e9-4916-a164-00e052056462\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1450 - Physical\ - \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1450\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1571dd40-dafc-4ef4-8f55-16eba27efc7b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1571dd40-dafc-4ef4-8f55-16eba27efc7b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1494 - System\ + \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1494\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/134d7a13-ba3e-41e2-b236-91bfcfa24e01\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"134d7a13-ba3e-41e2-b236-91bfcfa24e01\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1184 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1184\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ed09d84-3311-4853-8b67-2b55dfa33d09\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ed09d84-3311-4853-8b67-2b55dfa33d09\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1493 - System\ + \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1493\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/22b469b3-fccf-42da-aa3b-a28e6fb113ce\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"22b469b3-fccf-42da-aa3b-a28e6fb113ce\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1492 - System\ + \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1492\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/13579d0e-0ab0-4b26-b0fb-d586f6d7ed20\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"13579d0e-0ab0-4b26-b0fb-d586f6d7ed20\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1085 - Publicly\ - \ Accessible Content\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ad5f307-e045-46f7-8214-5bdb7e973737\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ad5f307-e045-46f7-8214-5bdb7e973737\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1495 - System\ + \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1085\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1495\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/13d117e0-38b0-4bbb-aaab-563be5dd10ba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"13d117e0-38b0-4bbb-aaab-563be5dd10ba\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1404 - Maintenance\ - \ Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f4978d0e-a596-48e7-9f8c-bbf52554ce8d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4978d0e-a596-48e7-9f8c-bbf52554ce8d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1498 - Rules\ + \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1404\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1498\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/13d8f903-0cd6-449f-a172-50f6579c182b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"13d8f903-0cd6-449f-a172-50f6579c182b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1695 - Information\ - \ System Monitoring | Wireless Intrusion Detection\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1695\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/633988b9-cf2f-4323-8394-f0d2af9cd6e1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"633988b9-cf2f-4323-8394-f0d2af9cd6e1\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1497 - System\ + \ Security Plan | Plan / Coordinate With Other Organizational Entities\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1497\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/13fcf812-ec82-4eda-9b89-498de9efd620\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"13fcf812-ec82-4eda-9b89-498de9efd620\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that contain certificates\ - \ expiring within the specified number of days\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if certificates in the specified store have an\ - \ expiration date out of range for the number of days given as parameter.\ - \ The policy also provides the option to only check for specific certificates\ - \ or exclude specific certificates, and whether to report on expired certificates.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"CertificateExpiration\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"CertificateStorePath\":\"[CertificateStore]CertificateStore1;CertificateStorePath\"\ - ,\"ExpirationLimitInDays\":\"[CertificateStore]CertificateStore1;ExpirationLimitInDays\"\ - ,\"CertificateThumbprintsToInclude\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"\ - ,\"CertificateThumbprintsToExclude\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude\"\ - ,\"IncludeExpiredCertificates\":\"[CertificateStore]CertificateStore1;IncludeExpiredCertificates\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"CertificateStorePath\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Certificate store path\"\ - ,\"description\":\"The path to the certificate store containing the certificates\ - \ to check the expiration dates of. Default value is 'Cert:' which is the\ - \ root certificate store path, so all certificates on the machine will be\ - \ checked. Other example paths: 'Cert:\\\\LocalMachine', 'Cert:\\\\LocalMachine\\\ - \\TrustedPublisher', 'Cert:\\\\CurrentUser'\"},\"defaultValue\":\"Cert:\"\ - },\"ExpirationLimitInDays\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Expiration limit in days\",\"description\":\"An integer indicating the\ - \ number of days within which to check for certificates that are expiring.\ - \ For example, if this value is 30, any certificate expiring within the next\ - \ 30 days will cause this policy to be non-compliant.\"},\"defaultValue\"\ - :\"30\"},\"CertificateThumbprintsToInclude\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Certificate thumbprints to include\",\"description\":\"\ - A semicolon-separated list of certificate thumbprints to check under the specified\ - \ path. If a value is not specified, all certificates under the certificate\ - \ store path will be checked. If a value is specified, no certificates other\ - \ than those with the thumbprints specified will be checked. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"\ - },\"defaultValue\":\"\"},\"CertificateThumbprintsToExclude\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Certificate thumbprints to exclude\"\ - ,\"description\":\"A semicolon-separated list of certificate thumbprints to\ - \ ignore. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"},\"defaultValue\":\"\"\ - },\"IncludeExpiredCertificates\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include expired certificates\",\"description\":\"Must be 'true' or 'false'.\ - \ True indicates that any found certificates that have already expired will\ - \ also make this policy non-compliant. False indicates that certificates that\ - \ have expired will be be ignored.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"CertificateExpiration\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[CertificateStore]CertificateStore1;CertificateStorePath',\ - \ '=', parameters('CertificateStorePath'), ',', '[CertificateStore]CertificateStore1;ExpirationLimitInDays',\ - \ '=', parameters('ExpirationLimitInDays'), ',', '[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude',\ - \ '=', parameters('CertificateThumbprintsToInclude'), ',', '[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude',\ - \ '=', parameters('CertificateThumbprintsToExclude'), ',', '[CertificateStore]CertificateStore1;IncludeExpiredCertificates',\ - \ '=', parameters('IncludeExpiredCertificates')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1417908b-4bff-46ee-a2a6-4acc899320ab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1417908b-4bff-46ee-a2a6-4acc899320ab\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs if the Administrators group contains any of the specified\ - \ members\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines in which the Administrators group contains any of the specified\ - \ members. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"MembersToExclude\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Members to exclude\",\"description\":\"A semicolon-separated\ - \ list of members that should be excluded in the Administrators local group.\ - \ Ex: Administrator; myUser1; myUser2\"}}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToExclude\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;MembersToExclude',\ - \ '=', parameters('MembersToExclude')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AdministratorsGroupMembersToExclude\"\ - },\"MembersToExclude\":{\"value\":\"[parameters('MembersToExclude')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"MembersToExclude\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;MembersToExclude\"\ - ,\"value\":\"[parameters('MembersToExclude')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;MembersToExclude\"\ - ,\"value\":\"[parameters('MembersToExclude')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/144f1397-32f9-4598-8c88-118decc3ccba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"144f1397-32f9-4598-8c88-118decc3ccba\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1157 - Plan\ - \ Of Action And Milestones\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Security Assessment and Authorization\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1157\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2e3c5583-1729-4d36-8771-59c32f090a22\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2e3c5583-1729-4d36-8771-59c32f090a22\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1496 - System\ + \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1496\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ca96127-2f87-46ab-a4fc-0d2a786df1c8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ca96127-2f87-46ab-a4fc-0d2a786df1c8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1499 - Rules\ + \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1499\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e59671ab-9720-4ee2-9c60-170e8c82251e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e59671ab-9720-4ee2-9c60-170e8c82251e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1501 - Rules\ + \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1501\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/88817b58-8472-4f6c-81fa-58ce42b67f51\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88817b58-8472-4f6c-81fa-58ce42b67f51\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1489 - Location\ + \ Of Information System Components\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1489\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/15495367-cf68-464c-bbc3-f53ca5227b7a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"15495367-cf68-464c-bbc3-f53ca5227b7a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1491 - Security\ - \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Planning control\",\"metadata\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d0a794f-1444-4c96-9534-e35fc8c39c91\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d0a794f-1444-4c96-9534-e35fc8c39c91\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1500 - Rules\ + \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1500\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9dd5b241-03cb-47d3-a5cd-4b89f9c53c92\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9dd5b241-03cb-47d3-a5cd-4b89f9c53c92\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1503 - Information\ + \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Planning control\",\"metadata\"\ :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1491\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1503\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1571dd40-dafc-4ef4-8f55-16eba27efc7b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1571dd40-dafc-4ef4-8f55-16eba27efc7b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1564 - System\ - \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1564\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c1fa9c2f-d439-4ab9-8b83-81fb1934f81d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c1fa9c2f-d439-4ab9-8b83-81fb1934f81d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1502 - Rules\ + \ Of Behavior | Social Media And Networking Restrictions\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1502\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/157f0ef9-143f-496d-b8f9-f8c8eeaad801\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"157f0ef9-143f-496d-b8f9-f8c8eeaad801\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have a minimum password age of 1 day\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ that do not have a minimum password age of 1 day. It also creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration. This\ - \ policy should only be used along with its corresponding audit policy in\ - \ an initiative. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"2.2.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MinimumPasswordAge\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"MinimumPasswordAge\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16390df4-2f73-4b42-af13-c801066763df\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16390df4-2f73-4b42-af13-c801066763df\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1662 - Fail\ - \ In Known State\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e901375c-8f01-4ac8-9183-d5312f47fe63\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e901375c-8f01-4ac8-9183-d5312f47fe63\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1504 - Information\ + \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Planning control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1504\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e7c35d0-12d4-4e0c-80a2-8a352537aefd\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e7c35d0-12d4-4e0c-80a2-8a352537aefd\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1507 - Personnel\ + \ Security Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Personnel Security control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1662\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1507\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/165cb91f-7ea8-4ab7-beaf-8636b98c9d15\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"165cb91f-7ea8-4ab7-beaf-8636b98c9d15\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1684 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1684\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86ccd1bf-e7ad-4851-93ce-6ec817469c1e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86ccd1bf-e7ad-4851-93ce-6ec817469c1e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1505 - Information\ + \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this Planning control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1505\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/813a10a7-3943-4fe3-8678-00dc52db5490\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"813a10a7-3943-4fe3-8678-00dc52db5490\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1506 - Personnel\ + \ Security Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Personnel Security control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1506\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16bfdb59-db38-47a5-88a9-2e9371a638cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16bfdb59-db38-47a5-88a9-2e9371a638cf\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have the specified Windows PowerShell modules installed\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines that do not have the specified Windows PowerShell modules\ - \ installed. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPowerShellModules\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16f9b37c-4408-4c30-bc17-254958f2e2d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16f9b37c-4408-4c30-bc17-254958f2e2d6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1103 - Audit\ - \ Events\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1103\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f7d2ff17-d604-4dd9-b607-9ecf63f28ad2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f7d2ff17-d604-4dd9-b607-9ecf63f28ad2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1508 - Position\ + \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1508\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16feeb31-6377-437e-bbab-d7f73911896d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16feeb31-6377-437e-bbab-d7f73911896d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1007 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1007\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/76f500cc-4bca-4583-bda1-6d084dc21086\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"76f500cc-4bca-4583-bda1-6d084dc21086\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1510 - Position\ + \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1510\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17200329-bf6c-46d8-ac6d-abf4641c2add\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17200329-bf6c-46d8-ac6d-abf4641c2add\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1349 - Identification\ - \ And Authentication (Non-Org. Users) | Use Of FICAM-Approved Products\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Identification and Authentication control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1349\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/79da5b09-0e7e-499e-adda-141b069c7998\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"79da5b09-0e7e-499e-adda-141b069c7998\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1509 - Position\ + \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1509\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17641f70-94cd-4a5d-a613-3d1143e20e34\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17641f70-94cd-4a5d-a613-3d1143e20e34\"\ - },{\"properties\":{\"displayName\":\"Deploy associations for a managed application\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys\ - \ an association resource that associates selected resource types to the specified\ - \ managed application. This policy deployment does not support nested resource\ - \ types.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Managed Application\"\ - },\"parameters\":{\"targetManagedApplicationId\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Managed application ID\",\"description\":\"Resource ID\ - \ of the managed application to which resources need to be associated.\"}},\"\ - resourceTypesToAssociate\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Resource types to associate\",\"description\":\"The list of resource types\ - \ to be associated to the managed application.\",\"strongType\":\"resourceTypes\"\ - }},\"associationNamePrefix\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Association name prefix\",\"description\":\"Prefix to be added to the name\ - \ of the association resource being created.\"},\"defaultValue\":\"DeployedByPolicy\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":\"[parameters('resourceTypesToAssociate')]\"\ - },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.CustomProviders/Associations\"\ - ,\"name\":\"[concat(parameters('associationNamePrefix'), '-', uniqueString(parameters('targetManagedApplicationId')))]\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"associatedResourceName\"\ - :{\"type\":\"string\"},\"resourceTypesToAssociate\":{\"type\":\"string\"},\"\ - targetManagedApplicationId\":{\"type\":\"string\"},\"associationNamePrefix\"\ - :{\"type\":\"string\"}},\"variables\":{\"resourceType\":\"[concat(parameters('resourceTypesToAssociate'),\ - \ '/providers/associations')]\",\"resourceName\":\"[concat(parameters('associatedResourceName'),\ - \ '/microsoft.customproviders/', parameters('associationNamePrefix'), '-',\ - \ uniqueString(parameters('targetManagedApplicationId')))]\"},\"resources\"\ - :[{\"type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2017-05-10\"\ - ,\"name\":\"[concat(deployment().Name, '-2')]\",\"properties\":{\"mode\":\"\ - Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"type\":\"[variables('resourceType')]\"\ - ,\"name\":\"[variables('resourceName')]\",\"apiVersion\":\"2018-09-01-preview\"\ - ,\"properties\":{\"targetResourceId\":\"[parameters('targetManagedApplicationId')]\"\ - }}]}}}]},\"parameters\":{\"resourceTypesToAssociate\":{\"value\":\"[field('type')]\"\ - },\"associatedResourceName\":{\"value\":\"[field('name')]\"},\"targetManagedApplicationId\"\ - :{\"value\":\"[parameters('targetManagedApplicationId')]\"},\"associationNamePrefix\"\ - :{\"value\":\"[parameters('associationNamePrefix')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17763ad9-70c0-4794-9397-53d765932634\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17763ad9-70c0-4794-9397-53d765932634\"\ - },{\"properties\":{\"displayName\":\"Transparent Data Encryption on SQL databases\ - \ should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Transparent data encryption should be enabled to protect data-at-rest and\ - \ meet compliance requirements\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"},{\"field\"\ - :\"name\",\"notEquals\":\"master\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/servers/databases/transparentDataEncryption\"\ - ,\"name\":\"current\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Sql/transparentDataEncryption.status\"\ - ,\"equals\":\"enabled\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17k78e20-9358-41c9-923c-fb736d382a12\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17k78e20-9358-41c9-923c-fb736d382a12\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1325 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1325\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/70792197-9bfc-4813-905a-bd33993e327f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"70792197-9bfc-4813-905a-bd33993e327f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1511 - Personnel\ + \ Screening\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1511\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9eae324-d327-4539-9293-b48e122465f8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9eae324-d327-4539-9293-b48e122465f8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1512 - Personnel\ + \ Screening\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1512\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5a8324ad-f599-429b-aaed-f9c6e8c987a8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5a8324ad-f599-429b-aaed-f9c6e8c987a8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1513 - Personnel\ + \ Screening | Information With Special Protection Measures\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Personnel Security control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1513\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1845796a-7581-49b2-ae20-443121538e19\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1845796a-7581-49b2-ae20-443121538e19\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1480 - Temperature\ - \ And Humidity Controls\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1480\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c416970d-b12b-49eb-8af4-fb144cd7c290\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c416970d-b12b-49eb-8af4-fb144cd7c290\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1514 - Personnel\ + \ Screening | Information With Special Protection Measures\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ Personnel Security control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1514\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/18a767cc-1947-4338-a240-bc058c81164f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"18a767cc-1947-4338-a240-bc058c81164f\"\ - },{\"properties\":{\"displayName\":\"Bring your own key data protection should\ - \ be enabled for PostgreSQL servers\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"This policy audits PostgreSQL servers in your\ - \ environment without bring your own key data protection enabled. For more\ - \ details, visit https://aka.ms/postgresqlbyok.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.DBforPostgreSQL/servers/keys\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.DBforPostgreSQL/servers/keys/serverKeyType\"\ - ,\"equals\":\"AzureKeyVault\"},{\"field\":\"Microsoft.DBforPostgreSQL/servers/keys/uri\"\ - ,\"notEquals\":\"\"},{\"field\":\"Microsoft.DBforPostgreSQL/servers/keys/uri\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/18adea5e-f416-4d0f-8aa8-d24321e3e274\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"18adea5e-f416-4d0f-8aa8-d24321e3e274\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1369 - Incident\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ed5ca00-0e43-434e-a018-7aab91461ba7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ed5ca00-0e43-434e-a018-7aab91461ba7\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1515 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1369\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1515\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/18cc35ed-a429-486d-8d59-cb47e87304ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"18cc35ed-a429-486d-8d59-cb47e87304ed\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1269 - Alternate\ - \ Storage Site | Separation From Primary Site\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1269\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02dd141a-a2b2-49a7-bcbd-ca31142f6211\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02dd141a-a2b2-49a7-bcbd-ca31142f6211\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1516 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1516\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/19b9439d-865d-4474-b17d-97d2702fdb66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"19b9439d-865d-4474-b17d-97d2702fdb66\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Logon-Logoff'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Logon-Logoff'\ - \ for auditing IPSec, network policy, claims, account lockout, group membership,\ - \ and logon/logoff events. This policy requires that the Guest Configuration\ - \ prerequisites have been deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SystemAuditPoliciesLogonLogoff\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"AuditGroupMembership\"\ - :\"Audit Group Membership;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"AuditGroupMembership\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Audit Group Membership\",\"description\"\ - :\"Specifies whether audit events are generated when group memberships are\ - \ enumerated on the client computer.\"},\"allowedValues\":[\"No Auditing\"\ - ,\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\":\"Success\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesLogonLogoff\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Group Membership;ExpectedValue', '=',\ - \ parameters('AuditGroupMembership')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/19be9779-c776-4dfa-8a15-a2fd5dc843d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"19be9779-c776-4dfa-8a15-a2fd5dc843d6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1071 - Wireless\ - \ Access | Restrict Configurations By Users\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1071\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/da3cd269-156f-435b-b472-c3af34c032ed\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"da3cd269-156f-435b-b472-c3af34c032ed\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1517 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1517\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1a437f5b-9ad6-4f28-8861-de404d511ae4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1a437f5b-9ad6-4f28-8861-de404d511ae4\"\ - },{\"properties\":{\"displayName\":\"Azure Monitor log profile should collect\ - \ logs for categories 'write,' 'delete,' and 'action'\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"This policy ensures that a log\ - \ profile collects logs for categories 'write,' 'delete,' and 'action'\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/logprofiles\",\"existenceCondition\":{\"allOf\":[{\"not\"\ - :{\"field\":\"Microsoft.Insights/logProfiles/categories[*]\",\"notEquals\"\ - :\"Write\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/categories[*]\"\ - ,\"notEquals\":\"Delete\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/categories[*]\"\ - ,\"notEquals\":\"Action\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1a4e592a-6a6e-44a5-9814-e36264ca96e7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1a4e592a-6a6e-44a5-9814-e36264ca96e7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Access to App Services\ - \ should be restricted\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Azure security center has discovered that the networking configuration\ - \ of some of your app services are overly permissive and allow inbound traffic\ - \ from ranges that are too broad\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/complianceResults\",\"name\":\"restrictAccessToAppServices\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1a833ff1-d297-4a0f-9944-888428f8e0ff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1a833ff1-d297-4a0f-9944-888428f8e0ff\"\ - },{\"properties\":{\"displayName\":\"Vulnerability assessment should be enabled\ - \ on SQL Managed Instance\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Audit each SQL Managed Instance which doesn't have recurring\ - \ vulnerability assessment scans enabled. Vulnerability assessment can discover,\ - \ track, and help you remediate potential database vulnerabilities.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/managedInstances\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/managedInstances/vulnerabilityAssessments\",\"name\":\"default\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/managedInstances/vulnerabilityAssessments/recurringScans.isEnabled\"\ - ,\"equals\":\"True\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1b7aa243-30e4-4c9e-bca8-d0d3022b634a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b7aa243-30e4-4c9e-bca8-d0d3022b634a\"\ - },{\"properties\":{\"displayName\":\"Public network access on Azure SQL Database\ - \ should be disabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Disabling the public network access property improves security\ - \ by ensuring your Azure SQL Database can only be accessed from a private\ - \ endpoint. This configuration denies all logins that match IP or virtual\ - \ network based firewall rules.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"SQL\"},\"parameters\":{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Sql/servers\"},{\"field\":\"Microsoft.Sql/servers/publicNetworkAccess\"\ - ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/1b8ca024-1d5c-4dec-8995-b1a932b41780\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b8ca024-1d5c-4dec-8995-b1a932b41780\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'PHP version' is the latest,\ - \ if used as a part of the Api app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ PHP software either due to security flaws or to include additional functionality.\ - \ Using the latest PHP version for API apps is recommended in order to take\ - \ advantage of security fixes, if any, and/or new functionalities of the latest\ - \ version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"App Service\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"PHPLatestVersion\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Latest PHP version\",\"description\":\"Latest supported\ - \ PHP version for App Services\"},\"defaultValue\":\"7.3\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"notContains\":\"PHP\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\"\ - ,\"equals\":\"\"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PHP|', parameters('PHPLatestVersion'))]\"},{\"field\"\ - :\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\"\ - :\"[parameters('PHPLatestVersion')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1bc1795e-d44a-4d48-9b3b-6fff0fd5f9ba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1bc1795e-d44a-4d48-9b3b-6fff0fd5f9ba\"\ - },{\"properties\":{\"displayName\":\"Deploy Dependency agent for Windows virtual\ - \ machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploy Dependency agent for Windows virtual machines if the VM Image (OS)\ - \ is in the list defined and the agent is not installed. The list of OS images\ - \ will be updated over time as support is updated.\",\"metadata\":{\"version\"\ - :\"1.3.0\",\"category\":\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Windows OS to add to scope\",\"description\"\ - :\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\"\ - ,\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ - roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"DependencyAgentWindows\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ - DependencyAgentWindows\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"vmExtensionType\":\"DependencyAgentWindows\",\"vmExtensionTypeHandlerVersion\"\ - :\"9.6\"},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"apiVersion\":\"2018-06-01\",\"location\":\"[parameters('location')]\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true}}],\"outputs\":{\"policy\":{\"type\":\"\ - string\",\"value\":\"[concat('Enabled extension for VM', ': ', parameters('vmName'))]\"\ - }}},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1c210e94-a481-4beb-95fa-1571b434fb04\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1c210e94-a481-4beb-95fa-1571b434fb04\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1072 - Wireless\ - \ Access | Antennas / Transmission Power Levels\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8f5ad423-50d6-4617-b058-69908f5586c9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8f5ad423-50d6-4617-b058-69908f5586c9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1520 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1520\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f2c513b-eb16-463b-b469-c10e5fa94f0a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f2c513b-eb16-463b-b469-c10e5fa94f0a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1519 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1519\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2f13915a-324c-4ab8-b45c-2eefeeefb098\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2f13915a-324c-4ab8-b45c-2eefeeefb098\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1518 - Personnel\ + \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1518\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d58f734-c052-40e9-8b2f-a1c2bff0b815\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d58f734-c052-40e9-8b2f-a1c2bff0b815\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1521 - Personnel\ + \ Termination | Automated Notification\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Personnel Security\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1072\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1521\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1ca29e41-34ec-4e70-aba9-6248aca18c31\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1ca29e41-34ec-4e70-aba9-6248aca18c31\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1656 - Secure\ - \ Name / Address Resolution Service (Authoritative Source)\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1656\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3cbddf9c-a3aa-4330-a0f5-4c0c1f1862e5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3cbddf9c-a3aa-4330-a0f5-4c0c1f1862e5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1523 - Personnel\ + \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1523\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1cb067d5-c8b5-4113-a7ee-0a493633924b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1cb067d5-c8b5-4113-a7ee-0a493633924b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1592 - External\ - \ Information System Services | Consistent Interests Of Consumers And Providers\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5577a310-2551-49c8-803b-36e0d5e55601\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5577a310-2551-49c8-803b-36e0d5e55601\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1524 - Personnel\ + \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1592\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1524\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d01ba6c-289f-42fd-a408-494b355b6222\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d01ba6c-289f-42fd-a408-494b355b6222\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1088 - Security\ - \ Awareness And Training Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Awareness\ - \ and Training control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1088\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/72f1cb4e-2439-4fe8-88ea-b8671ce3c268\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"72f1cb4e-2439-4fe8-88ea-b8671ce3c268\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1525 - Personnel\ + \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1525\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9be2f688-7a61-45e3-8230-e1ec93893f66\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9be2f688-7a61-45e3-8230-e1ec93893f66\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1526 - Access\ + \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1526\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/953e6261-a05a-44fd-8246-000e1a3edbb9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"953e6261-a05a-44fd-8246-000e1a3edbb9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1527 - Access\ + \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1527\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2823de66-332f-4bfd-94a3-3eb036cd3b67\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2823de66-332f-4bfd-94a3-3eb036cd3b67\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1530 - Third-Party\ + \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1530\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e8f9566-29f1-49cd-b61f-f8628a3cf993\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e8f9566-29f1-49cd-b61f-f8628a3cf993\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1528 - Access\ + \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1528\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/deb9797c-22f8-40e8-b342-a84003c924e6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"deb9797c-22f8-40e8-b342-a84003c924e6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1529 - Third-Party\ + \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1529\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d74fdc92-1cb8-4a34-9978-8556425cd14c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d74fdc92-1cb8-4a34-9978-8556425cd14c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1531 - Third-Party\ + \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1531\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f0643e0c-eee5-4113-8684-c608d05c5236\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0643e0c-eee5-4113-8684-c608d05c5236\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1533 - Third-Party\ + \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1533\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bba2a036-fb3b-4261-b1be-a13dfb5fbcaa\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bba2a036-fb3b-4261-b1be-a13dfb5fbcaa\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1532 - Third-Party\ + \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1532\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2c66299-9017-4d95-8040-8bdbf7901d52\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2c66299-9017-4d95-8040-8bdbf7901d52\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1522 - Personnel\ + \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1522\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/38b470cc-f939-4a15-80e0-9f0c74f2e2c9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"38b470cc-f939-4a15-80e0-9f0c74f2e2c9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1534 - Personnel\ + \ Sanctions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1534\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8b2b263e-cd05-4488-bcbf-4debec7a17d9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8b2b263e-cd05-4488-bcbf-4debec7a17d9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1535 - Personnel\ + \ Sanctions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1535\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9a165d2-967d-4733-8399-1074270dae2e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9a165d2-967d-4733-8399-1074270dae2e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1536 - Risk\ + \ Assessment Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1536\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d50f99d-1356-49c0-934a-45f742ba7783\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d50f99d-1356-49c0-934a-45f742ba7783\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy GitOps to Kubernetes\ - \ cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy deploys a 'sourceControlConfiguration' to Kubernetes clusters\ - \ to assure that the clusters get their source of truth from the defined git\ - \ repo. For instructions on using this policy, visit https://aka.ms/K8sGitOpsPolicy.\"\ - ,\"metadata\":{\"preview\":true,\"version\":\"1.0.0-preview\",\"category\"\ - :\"Kubernetes\"},\"parameters\":{\"configurationResourceName\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Preview]: Configuration resource\ - \ name\",\"description\":\"The name for the sourceControlConfiguration. Learn\ - \ more about setting up GitOps configuration: https://aka.ms/AzureArcK8sUsingGitOps.\"\ - }},\"operatorInstanceName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Operator instance name\",\"description\":\"The name of the operator\ - \ associated with this configuration. The instance name can contain up to\ - \ 353 lower-case alphanumeric characters, hyphen, or period. If enableHelmOperator\ - \ is true, then operatorInstanceName + operatorNamespace strings cannot exceed\ - \ 47 characters combined.\"}},\"operatorNamespace\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Preview]: Operator namespace\",\"description\"\ - :\"The namespace to use for the configuration operator. The namespace can\ - \ contain up to 353 lower-case alphanumeric characters, hyphen, or period.\ - \ If enableHelmOperator is true, then operatorInstanceName + operatorNamespace\ - \ strings cannot exceed 47 characters combined.\"}},\"operatorScope\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Operator scope\"\ - ,\"description\":\"The permission scope for the operator. Possible values\ - \ are 'cluster' (full access) or 'namespace' (restricted access).\"},\"allowedValues\"\ - :[\"cluster\",\"namespace\"],\"defaultValue\":\"namespace\"},\"operatorType\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Operator\ - \ type\",\"description\":\"The type of operator to install. Currently, 'Flux'\ - \ is supported.\"},\"allowedValues\":[\"Flux\"],\"defaultValue\":\"Flux\"\ - },\"operatorParams\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - [Preview]: Operator parameters\",\"description\":\"Parameters to set on the\ - \ Flux operator, separated by spaces. For example, --git-readonly --git-path=namespaces,workloads.\ - \ Learn more: http://aka.ms/AzureArcK8sFluxOperatorParams.\"},\"defaultValue\"\ - :\"\"},\"repositoryUrl\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Repository Url\",\"description\":\"The URL for the source control\ - \ repository. Private repo: git@github.com:Contoso/cluster-config\"}},\"enableHelmOperator\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Enable Helm\"\ - ,\"description\":\"Indicate whether to enable Helm for this instance of Flux.\ - \ Learn more: http://aka.ms/AzureArcK8sGitOpsWithHelm.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"true\"},\"chartVersion\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Preview]: Helm chart version\ - \ for installing Flux Helm\",\"description\":\"The version of the Helm chart\ - \ for installing Flux Helm. For example, 0.6.0\"},\"defaultValue\":\"0.6.0\"\ - },\"chartValues\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Helm chart parameters for installing Flux Helm\",\"description\":\"Parameters\ - \ for the Helm chart for installing Flux Helm, separated by spaces.\"},\"\ - defaultValue\":\"\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ - ]},\"then\":{\"effect\":\"DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations\"\ - ,\"name\":\"[parameters('configurationResourceName')]\",\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deploymentScope\":\"ResourceGroup\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/operatorParams\"\ - ,\"in\":[\"--git-readonly\",\"[parameters('operatorParams')]\",\"[concat('--git-readonly\ - \ ',parameters('operatorParams'))]\"]},{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/repositoryUrl\"\ - ,\"equals\":\"[parameters('repositoryUrl')]\"},{\"anyOf\":[{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/enableHelmOperator\"\ - ,\"equals\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/enableHelmOperator\"\ - ,\"equals\":\"true\"},{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/helmOperatorProperties.chartVersion\"\ - ,\"equals\":\"[parameters('chartVersion')]\"},{\"field\":\"Microsoft.KubernetesConfiguration/sourceControlConfigurations/helmOperatorProperties.chartValues\"\ - ,\"equals\":\"[parameters('chartValues')]\"}]}]}]},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"configurationResourceName\"\ - :{\"type\":\"string\"},\"clusterLocation\":{\"type\":\"string\"},\"clusterName\"\ - :{\"type\":\"string\"},\"operatorInstanceName\":{\"type\":\"string\"},\"operatorNamespace\"\ - :{\"type\":\"string\"},\"operatorScope\":{\"type\":\"string\"},\"operatorType\"\ - :{\"type\":\"string\"},\"operatorParams\":{\"type\":\"string\"},\"repositoryUrl\"\ - :{\"type\":\"string\"},\"enableHelmOperator\":{\"type\":\"string\"},\"chartVersion\"\ - :{\"type\":\"string\"},\"chartValues\":{\"type\":\"string\"},\"clusterResourceType\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[contains(parameters('clusterResourceType'),\ - \ 'connectedclusters')]\",\"type\":\"Microsoft.Kubernetes/connectedClusters/providers/sourceControlConfigurations\"\ - ,\"name\":\"[concat(parameters('clusterName'), '/Microsoft.KubernetesConfiguration/',\ - \ parameters('configurationResourceName'))]\",\"apiVersion\":\"2019-11-01-preview\"\ - ,\"properties\":{\"operatorInstanceName\":\"[parameters('operatorInstanceName')]\"\ - ,\"operatorNamespace\":\"[parameters('operatorNamespace')]\",\"operatorScope\"\ - :\"[parameters('operatorScope')]\",\"operatorType\":\"[parameters('operatorType')]\"\ - ,\"operatorParams\":\"[parameters('operatorParams')]\",\"repositoryUrl\":\"\ - [parameters('repositoryUrl')]\",\"enableHelmOperator\":\"[parameters('enableHelmOperator')]\"\ - ,\"helmOperatorProperties\":{\"chartVersion\":\"[parameters('chartVersion')]\"\ - ,\"chartValues\":\"[parameters('chartValues')]\"}}},{\"condition\":\"[contains(parameters('clusterResourceType'),\ - \ 'managedclusters')]\",\"type\":\"Microsoft.ContainerService/managedClusters/providers/sourceControlConfigurations\"\ - ,\"name\":\"[concat(parameters('clusterName'), '/Microsoft.KubernetesConfiguration/',\ - \ parameters('configurationResourceName'))]\",\"apiVersion\":\"2019-11-01-preview\"\ - ,\"properties\":{\"operatorInstanceName\":\"[parameters('operatorInstanceName')]\"\ - ,\"operatorNamespace\":\"[parameters('operatorNamespace')]\",\"operatorScope\"\ - :\"[parameters('operatorScope')]\",\"operatorType\":\"[parameters('operatorType')]\"\ - ,\"operatorParams\":\"[parameters('operatorParams')]\",\"repositoryUrl\":\"\ - [parameters('repositoryUrl')]\",\"enableHelmOperator\":\"[parameters('enableHelmOperator')]\"\ - ,\"helmOperatorProperties\":{\"chartVersion\":\"[parameters('chartVersion')]\"\ - ,\"chartValues\":\"[parameters('chartValues')]\"}}}]},\"parameters\":{\"clusterLocation\"\ - :{\"value\":\"[field('location')]\"},\"clusterName\":{\"value\":\"[field('name')]\"\ - },\"configurationResourceName\":{\"value\":\"[parameters('configurationResourceName')]\"\ - },\"operatorInstanceName\":{\"value\":\"[parameters('operatorInstanceName')]\"\ - },\"operatorNamespace\":{\"value\":\"[parameters('operatorNamespace')]\"},\"\ - operatorScope\":{\"value\":\"[parameters('operatorScope')]\"},\"operatorType\"\ - :{\"value\":\"[parameters('operatorType')]\"},\"operatorParams\":{\"value\"\ - :\"[parameters('operatorParams')]\"},\"repositoryUrl\":{\"value\":\"[parameters('repositoryUrl')]\"\ - },\"enableHelmOperator\":{\"value\":\"[parameters('enableHelmOperator')]\"\ - },\"chartVersion\":{\"value\":\"[parameters('chartVersion')]\"},\"chartValues\"\ - :{\"value\":\"[parameters('chartValues')]\"},\"clusterResourceType\":{\"value\"\ - :\"[field('type')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d61c4d2-aef2-432b-87fc-7f96b019b7e1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d61c4d2-aef2-432b-87fc-7f96b019b7e1\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e40d9de-2ad4-4cb5-8945-23143326a502\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e40d9de-2ad4-4cb5-8945-23143326a502\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1537 - Risk\ + \ Assessment Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1537\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b19454ca-0d70-42c0-acf5-ea1c1e5726d1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b19454ca-0d70-42c0-acf5-ea1c1e5726d1\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1538 - Security\ \ Categorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ @@ -3466,3751 +9335,754 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d7658b2-e827-49c3-a2ae-6d2bd0b45874\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d7658b2-e827-49c3-a2ae-6d2bd0b45874\"\ - },{\"properties\":{\"displayName\":\"Virtual machines should be migrated to\ - \ new Azure Resource Manager resources\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Use new Azure Resource Manager for your virtual\ - \ machines to provide security enhancements such as: stronger access control\ - \ (RBAC), better auditing, Azure Resource Manager based deployment and governance,\ - \ access to managed identities, access to key vault for secrets, Azure AD-based\ - \ authentication and support for tags and resource groups for easier security\ - \ management\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Compute\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"The effect determines what happens when the\ - \ policy rule is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\"\ - ,\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"in\":[\"Microsoft.ClassicCompute/virtualMachines\"\ - ,\"Microsoft.Compute/virtualMachines\"]},{\"value\":\"[field('type')]\",\"\ - equals\":\"Microsoft.ClassicCompute/virtualMachines\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d84d5fb-01f6-4d12-ba4f-4a26081d403d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d84d5fb-01f6-4d12-ba4f-4a26081d403d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1298 - Identification\ - \ And Authentication Policy And Procedures\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1298\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1dc784b5-4895-4d27-9d40-a06b032bd1ee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1dc784b5-4895-4d27-9d40-a06b032bd1ee\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit API Applications\ - \ that are not using latest supported .NET Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported .NET Framework\ - \ version for the latest security classes. Using older classes and types can\ - \ make your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestDotNet\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1de7b11d-1870-41a5-8181-507e7c663cfb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1de7b11d-1870-41a5-8181-507e7c663cfb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1595 - Developer\ - \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1595\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1542 - Risk\ + \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1542\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1e0414e7-6ef5-4182-8076-aa82fbb53341\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1e0414e7-6ef5-4182-8076-aa82fbb53341\"\ - },{\"properties\":{\"displayName\":\"Require a tag and its value on resources\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Enforces\ - \ a required tag and its value. Does not apply to resource groups.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Tags\"},\"parameters\":{\"tagName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\",\"description\"\ - :\"Name of the tag, such as 'environment'\"}},\"tagValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Value\",\"description\":\"Value of the\ - \ tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"not\":{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"equals\":\"[parameters('tagValue')]\"\ - }},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1e30110a-5ceb-460c-a204-c1c3969c6d62\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1e30110a-5ceb-460c-a204-c1c3969c6d62\"\ - },{\"properties\":{\"displayName\":\"An Azure Active Directory administrator\ - \ should be provisioned for SQL servers\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Audit provisioning of an Azure Active Directory\ - \ administrator for your SQL server to enable Azure AD authentication. Azure\ - \ AD authentication enables simplified permission management and centralized\ - \ identity management of database users and other Microsoft services\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/servers/administrators\"}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1f314764-cb73-4fc9-b863-8eca98ac36e9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1f314764-cb73-4fc9-b863-8eca98ac36e9\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Event\ - \ Hub to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Deploys the diagnostic settings for Event Hub\ - \ to stream to a regional Log Analytics workspace when any Event Hub which\ - \ is missing this diagnostic settings is created or updated.\",\"metadata\"\ - :{\"version\":\"1.1.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.EventHub/namespaces/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"ArchiveLogs\",\"enabled\":true,\"\ - retentionPolicy\":{\"enabled\":false,\"days\":0}},{\"category\":\"OperationalLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"AutoScaleLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"KafkaCoordinatorLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"KafkaUserErrorLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"EventHubVNetConnectionEvent\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"CustomerManagedKeyUserLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\"\ - :{\"location\":{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\"\ - :\"[field('name')]\"},\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"\ - },\"metricsEnabled\":{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\"\ - :{\"value\":\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"\ - [parameters('profileName')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1f6e93e8-6b31-41b1-83f6-36e449a42579\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1f6e93e8-6b31-41b1-83f6-36e449a42579\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Shutdown'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Security Options - Shutdown'. It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Shutdown:\ - \ Allow system to be shut down without having to log on\",\"description\"\ - :\"Specifies whether a computer can be shut down when a user is not logged\ - \ on. If this policy setting is enabled, the shutdown command is available\ - \ on the Windows logon screen.\"},\"defaultValue\":\"0\"},\"ShutdownClearVirtualMemoryPagefile\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Shutdown:\ - \ Clear virtual memory pagefile\",\"description\":\"Specifies whether the\ - \ virtual memory pagefile is cleared when the system is shut down. When this\ - \ policy setting is enabled, the system pagefile is cleared each time that\ - \ the system shuts down properly. For systems with large amounts of RAM, this\ - \ could result in substantial time needed to complete the shutdown.\"},\"\ - defaultValue\":\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsShutdown\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Shutdown: Allow system to be shut down without\ - \ having to log on;ExpectedValue', '=', parameters('ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn'),\ - \ ',', 'Shutdown: Clear virtual memory pagefile;ExpectedValue', '=', parameters('ShutdownClearVirtualMemoryPagefile')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsShutdown\"},\"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn\"\ - :{\"value\":\"[parameters('ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn')]\"\ - },\"ShutdownClearVirtualMemoryPagefile\":{\"value\":\"[parameters('ShutdownClearVirtualMemoryPagefile')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn\"\ - :{\"type\":\"string\"},\"ShutdownClearVirtualMemoryPagefile\":{\"type\":\"\ - string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Shutdown: Allow\ - \ system to be shut down without having to log on;ExpectedValue\",\"value\"\ - :\"[parameters('ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn')]\"},{\"\ - name\":\"Shutdown: Clear virtual memory pagefile;ExpectedValue\",\"value\"\ - :\"[parameters('ShutdownClearVirtualMemoryPagefile')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Shutdown: Allow\ - \ system to be shut down without having to log on;ExpectedValue\",\"value\"\ - :\"[parameters('ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn')]\"},{\"\ - name\":\"Shutdown: Clear virtual memory pagefile;ExpectedValue\",\"value\"\ - :\"[parameters('ShutdownClearVirtualMemoryPagefile')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1f8c20ce-3414-4496-8b26-0e902a1541da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1f8c20ce-3414-4496-8b26-0e902a1541da\"\ - },{\"properties\":{\"displayName\":\"Azure Cosmos DB account should use customer-managed\ - \ keys to encrypt data at rest\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Use customer-managed keys to control the encryption at\ - \ rest of the data stored in Azure Cosmos DB when this is a regulatory or\ - \ compliance requirement. Customer-managed keys also deliver double encryption\ - \ by adding a second layer of encryption on top of the default one done with\ - \ service-managed keys. See https://aka.ms/cosmosdb-cmk\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Cosmos DB\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"The desired effect of the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ - ,\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"Microsoft.DocumentDB/databaseAccounts/keyVaultKeyUri\",\"exists\"\ - :false},{\"field\":\"type\",\"equals\":\"Microsoft.DocumentDB/databaseAccounts\"\ - }]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1f905d99-2ab7-462c-a6b0-f709acca6c8f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1f905d99-2ab7-462c-a6b0-f709acca6c8f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1616 - System\ - \ And Communications Protection Policy And Procedures\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eab340d0-3d55-4826-a0e5-feebfeb0131d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eab340d0-3d55-4826-a0e5-feebfeb0131d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1539 - Security\ + \ Categorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1616\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1539\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2006457a-48b3-4f7b-8d2e-1532287f9929\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2006457a-48b3-4f7b-8d2e-1532287f9929\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1650 - Public\ - \ Key Infrastructure Certificates\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Communications\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1650\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aabb155f-e7a5-4896-a767-e918bfae2ee0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aabb155f-e7a5-4896-a767-e918bfae2ee0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1541 - Risk\ + \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1541\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/201d3740-bd16-4baf-b4b8-7cda352228b7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"201d3740-bd16-4baf-b4b8-7cda352228b7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Web ports should be restricted\ - \ on Network Security Groups associated to your VM\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Azure security center has discovered that\ - \ some of your virtual machines are running web applications, and the NSGs\ - \ associated to these virtual machines are overly permissive with regards\ - \ to the web application ports\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - unprotectedWebApplication\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/201ea587-7c90-41c3-910f-c280ae01cfd6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"201ea587-7c90-41c3-910f-c280ae01cfd6\"\ - },{\"properties\":{\"displayName\":\"VM Image Builder templates should use\ - \ private link\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit VM Image Builder templates that do not have a virtual network configured.\ - \ When a virtual network is not configured, a public IP is created and used\ - \ instead which may expose resources directly to the internet and increase\ - \ the potential attack surface.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"VM Image Builder\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.VirtualMachineImages/imageTemplates\"},{\"\ - field\":\"Microsoft.VirtualMachineImages/imageTemplates/vmProfile.vnetConfig\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/2154edb9-244f-4741-9970-660785bccdaa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2154edb9-244f-4741-9970-660785bccdaa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1181 - Baseline\ - \ Configuration | Retention Of Previous Configurations\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1181\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/70f6af82-7be6-44aa-9b15-8b9231b2e434\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"70f6af82-7be6-44aa-9b15-8b9231b2e434\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1540 - Security\ + \ Categorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1540\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21839937-d241-4fa5-95c6-b669253d9ab9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21839937-d241-4fa5-95c6-b669253d9ab9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1111 - Response\ - \ To Audit Processing Failures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Audit and Accountability control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1111\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f771f8cb-6642-45cc-9a15-8a41cd5c6977\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f771f8cb-6642-45cc-9a15-8a41cd5c6977\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1544 - Risk\ + \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1544\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21de687c-f15e-4e51-bf8d-f35c8619965b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21de687c-f15e-4e51-bf8d-f35c8619965b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1596 - Developer\ - \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1596\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/43ced7c9-cd53-456b-b0da-2522649a4271\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"43ced7c9-cd53-456b-b0da-2522649a4271\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1545 - Risk\ + \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1545\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21e25e01-0ae0-41be-919e-04ce92b8e8b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21e25e01-0ae0-41be-919e-04ce92b8e8b8\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Audit'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Audit'. For more information on Guest Configuration policies, please visit\ - \ https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"\ - category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsAudit\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21e2995e-683e-497a-9e81-2f42ad07050a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21e2995e-683e-497a-9e81-2f42ad07050a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1426 - Media\ - \ Protection Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1426\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3f4b171a-a56b-4328-8112-32cf7f947ee1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3f4b171a-a56b-4328-8112-32cf7f947ee1\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1543 - Risk\ + \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1543\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21f639bc-f42b-46b1-8f40-7a2a389c291a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21f639bc-f42b-46b1-8f40-7a2a389c291a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit API Apps that are\ - \ not using custom domains\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Use of custom domains protects a API app from common attacks\ - \ such as phishing and other DNS-related attacks.\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"\ - field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\"\ - :\"kind\",\"equals\":\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UsedCustomDomains\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/224da9fe-0d38-4e79-adb3-0a6e2af942ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"224da9fe-0d38-4e79-adb3-0a6e2af942ac\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1399 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd00b778-b5b5-49c0-a994-734ea7bd3624\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd00b778-b5b5-49c0-a994-734ea7bd3624\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1546 - Vulnerability\ + \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1399\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1546\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2256e638-eb23-480f-9e15-6cf1af0a76b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2256e638-eb23-480f-9e15-6cf1af0a76b3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1221 - Least\ - \ Functionality | Authorized Software / Whitelisting\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1221\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2ce1ea7e-4038-4e53-82f4-63e8859333c1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2ce1ea7e-4038-4e53-82f4-63e8859333c1\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1547 - Vulnerability\ + \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1547\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/22589a07-0007-486a-86ca-95355081ae2a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"22589a07-0007-486a-86ca-95355081ae2a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Account Management'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Account Management'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesAccountManagement\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/225e937e-d32e-4713-ab74-13ce95b3519a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"225e937e-d32e-4713-ab74-13ce95b3519a\"\ - },{\"properties\":{\"displayName\":\"Management ports should be closed on\ - \ your virtual machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Open remote management ports are exposing your VM to a high level of risk\ - \ from Internet-based attacks. These attacks attempt to brute force credentials\ - \ to gain admin access to the machine.\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"\ - Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"bc303248-3d14-44c2-96a0-55f5c326b5fe\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/22730e10-96f6-4aac-ad84-9383d35b5917\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"22730e10-96f6-4aac-ad84-9383d35b5917\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1493 - System\ - \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58abf9b8-c6d4-4b4b-bfb9-fe98fe295f52\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58abf9b8-c6d4-4b4b-bfb9-fe98fe295f52\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1548 - Vulnerability\ + \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1493\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1548\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/22b469b3-fccf-42da-aa3b-a28e6fb113ce\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"22b469b3-fccf-42da-aa3b-a28e6fb113ce\"\ - },{\"properties\":{\"displayName\":\"Only secure connections to your Azure\ - \ Cache for Redis should be enabled\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Audit enabling of only connections via SSL\ - \ to Azure Cache for Redis. Use of secure connections ensures authentication\ - \ between the server and the service and protects data in transit from network\ - \ layer attacks such as man-in-the-middle, eavesdropping, and session-hijacking\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cache\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"The effect determines what happens when the policy rule\ - \ is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Cache/redis\"},{\"field\":\"Microsoft.Cache/Redis/enableNonSslPort\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/22bee202-a82f-4305-9a2a-6d7f44d4dedb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"22bee202-a82f-4305-9a2a-6d7f44d4dedb\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not restrict the minimum password length to 14\ - \ characters\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines that do not restrict the minimum password length to 14 characters.\ - \ It also creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"2.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MinimumPasswordLength\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"MinimumPasswordLength\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/23020aa6-1135-4be2-bae2-149982b06eca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"23020aa6-1135-4be2-bae2-149982b06eca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1256 - Contingency\ - \ Plan | Identify Critical Assets\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1256\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3afe6c78-6124-4d95-b85c-eb8c0c9539cb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3afe6c78-6124-4d95-b85c-eb8c0c9539cb\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1551 - Vulnerability\ + \ Scanning | Update Tool Capability\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1551\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/232ab24b-810b-4640-9019-74a7d0d6a980\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"232ab24b-810b-4640-9019-74a7d0d6a980\"\ - },{\"properties\":{\"displayName\":\"Service Bus should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any Service Bus not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.ServiceBus/namespaces\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.ServiceBus/namespaces/virtualNetworkRules\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.ServiceBus/namespaces/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/235359c5-7c52-4b82-9055-01c75cf9f60e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"235359c5-7c52-4b82-9055-01c75cf9f60e\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not have\ - \ a minimum password age of 1 day\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Requires that prerequisites are deployed to the\ - \ policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if Windows machines that do not have a minimum password\ - \ age of 1 day\",\"metadata\":{\"category\":\"Guest Configuration\",\"version\"\ - :\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"MinimumPasswordAge\",\"version\":\"1.*\"}},\"parameters\":{\"\ - IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - MinimumPasswordAge\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/237b38db-ca4d-4259-9e47-7882441ca2c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"237b38db-ca4d-4259-9e47-7882441ca2c0\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Stream\ - \ Analytics to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Deploys the diagnostic settings for Stream\ - \ Analytics to stream to a regional Log Analytics workspace when any Stream\ - \ Analytics which is missing this diagnostic settings is created or updated.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - },\"profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.StreamAnalytics/streamingjobs\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.StreamAnalytics/streamingjobs/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Execution\",\"enabled\":\"\ - [parameters('logsEnabled')]\"},{\"category\":\"Authoring\",\"enabled\":\"\ - [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/237e0f7e-b0e8-4ec4-ad46-8c12cb66d673\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"237e0f7e-b0e8-4ec4-ad46-8c12cb66d673\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1268 - Alternate\ - \ Storage Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1268\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/23f6e984-3053-4dfc-ab48-543b764781f5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"23f6e984-3053-4dfc-ab48-543b764781f5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1122 - Audit\ - \ Review, Analysis, And Reporting | Permitted Actions\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1122\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/243ec95e-800c-49d4-ba52-1fdd9f6b8b57\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"243ec95e-800c-49d4-ba52-1fdd9f6b8b57\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1231 - Configuration\ - \ Management Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1231\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5bbda922-0172-4095-89e6-5b4a0bf03af7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5bbda922-0172-4095-89e6-5b4a0bf03af7\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1550 - Vulnerability\ + \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1550\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/244e0c05-cc45-4fe7-bf36-42dcf01f457d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"244e0c05-cc45-4fe7-bf36-42dcf01f457d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1082 - Information\ - \ Sharing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/902908fb-25a8-4225-a3a5-5603c80066c9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"902908fb-25a8-4225-a3a5-5603c80066c9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1549 - Vulnerability\ + \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1082\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1549\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/24d480ef-11a0-4b1b-8e70-4e023bf2be23\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"24d480ef-11a0-4b1b-8e70-4e023bf2be23\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have a maximum password age of 70 days\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that do not have a maximum password age of 70 days. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MaximumPasswordAge\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/24dde96d-f0b1-425e-884f-4a1421e2dcdc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"24dde96d-f0b1-425e-884f-4a1421e2dcdc\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Data Lake\ - \ Storage Gen1 to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Deploys the diagnostic settings for Data\ - \ Lake Storage Gen1 to stream to a regional Log Analytics workspace when any\ - \ Data Lake Storage Gen1 which is missing this diagnostic settings is created\ - \ or updated.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ - :\"DeployIfNotExists\"},\"profileName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Profile name\",\"description\":\"The diagnostic settings\ - \ profile name\"},\"defaultValue\":\"setbypolicy_logAnalytics\"},\"logAnalytics\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\"\ - ,\"description\":\"Select Log Analytics workspace from dropdown list. If this\ - \ workspace is outside of the scope of the assignment you must manually grant\ - \ 'Log Analytics Contributor' permissions (or similar) to the policy assignment's\ - \ principal ID.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"\ - metricsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ metrics\",\"description\":\"Whether to enable metrics stream to the Log\ - \ Analytics workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"\ - ],\"defaultValue\":\"False\"},\"logsEnabled\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Enable logs\",\"description\":\"Whether to enable logs\ - \ stream to the Log Analytics workspace - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - field\":\"type\",\"equals\":\"Microsoft.DataLakeStore/accounts\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"[parameters('profileName')]\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ - :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.DataLakeStore/accounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Audit\",\"enabled\":\"[parameters('logsEnabled')]\"\ - },{\"category\":\"Requests\",\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"\ - outputs\":{}},\"parameters\":{\"location\":{\"value\":\"[field('location')]\"\ - },\"resourceName\":{\"value\":\"[field('name')]\"},\"logAnalytics\":{\"value\"\ - :\"[parameters('logAnalytics')]\"},\"metricsEnabled\":{\"value\":\"[parameters('metricsEnabled')]\"\ - },\"logsEnabled\":{\"value\":\"[parameters('logsEnabled')]\"},\"profileName\"\ - :{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/25763a0a-5783-4f14-969e-79d4933eb74b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"25763a0a-5783-4f14-969e-79d4933eb74b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1372 - Incident\ - \ Reporting\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1372\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d6976a08-d969-4df2-bb38-29556c2eb48a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d6976a08-d969-4df2-bb38-29556c2eb48a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1552 - Vulnerability\ + \ Scanning | Update By Frequency / Prior To New Scan / When Identified\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this Risk Assessment control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1552\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/25b96717-c912-4c00-9143-4e487f411726\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"25b96717-c912-4c00-9143-4e487f411726\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1038 - Least\ - \ Privilege | Privileged Accounts\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1038\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/43684572-e4f1-4642-af35-6b933bc506da\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"43684572-e4f1-4642-af35-6b933bc506da\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1555 - Vulnerability\ + \ Scanning | Privileged Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this Risk Assessment control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1555\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/26692e88-71b7-4a5f-a8ac-9f31dd05bd8e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26692e88-71b7-4a5f-a8ac-9f31dd05bd8e\"\ - },{\"properties\":{\"displayName\":\"Endpoint protection solution should be\ - \ installed on virtual machine scale sets\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Audit the existence and health of an\ - \ endpoint protection solution on your virtual machines scale sets, to protect\ - \ them from threats and vulnerabilities.\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"e71020c2-860c-3235-cd39-04f3f8c936d2\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/26a828e1-e88f-464e-bbb3-c134a282b9de\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26a828e1-e88f-464e-bbb3-c134a282b9de\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1649 - Collaborative\ - \ Computing Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5afa8cab-1ed7-4e40-884c-64e0ac2059cc\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5afa8cab-1ed7-4e40-884c-64e0ac2059cc\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1553 - Vulnerability\ + \ Scanning | Breadth / Depth Of Coverage\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1649\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1553\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/26d292cc-b0b8-4c29-9337-68abc758bf7b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26d292cc-b0b8-4c29-9337-68abc758bf7b\"\ - },{\"properties\":{\"displayName\":\"Metric alert rules should be configured\ - \ on Batch accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit configuration of metric alert rules on Batch account to enable the\ - \ required metric\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Batch\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"metricName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Metric name\",\"description\":\"The metric name that an alert rule must\ - \ be enabled on\"}}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Batch/batchAccounts\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Insights/alertRules\",\"existenceScope\"\ - :\"Subscription\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/alertRules/isEnabled\"\ - ,\"equals\":\"true\"},{\"field\":\"Microsoft.Insights/alertRules/condition.dataSource.metricName\"\ - ,\"equals\":\"[parameters('metricName')]\"},{\"field\":\"Microsoft.Insights/alertRules/condition.dataSource.resourceUri\"\ - ,\"equals\":\"[concat('/subscriptions/', subscription().subscriptionId, '/resourcegroups/',\ - \ resourceGroup().name, '/providers/Microsoft.Batch/batchAccounts/', field('name'))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/26ee67a2-f81a-4ba8-b9ce-8550bd5ee1a7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26ee67a2-f81a-4ba8-b9ce-8550bd5ee1a7\"\ - },{\"properties\":{\"displayName\":\"Enable Automanage - Azure virtual machine\ - \ best practices\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Automanage enrolls, configures, and monitors virtual machines with Azure\ - \ VM best practice services. Use this policy to apply Automanage to your selected\ - \ scope.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Automanage\"\ - },\"parameters\":{\"automanageAccount\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Automanage account\",\"description\":\"Select Automanage\ - \ account from dropdown list. If this account is outside of the scope of the\ - \ assignment you must manually grant 'Contributor' permissions (or similar)\ - \ on the account to the policy assignment's principal ID.\",\"strongType\"\ - :\"Microsoft.Automanage/accounts\",\"assignPermissions\":true}},\"configurationProfileAssignment\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Configuration profile\"\ - ,\"description\":\"The management services provided are based on whether the\ - \ machine is intended to be used in a dev/test environment or production.\"\ - },\"allowedValues\":[\"Azure virtual machine best practices \u2013 Production\"\ - ,\"Azure virtual machine best practices \u2013 Dev/test\"],\"defaultValue\"\ - :\"Azure virtual machine best practices \u2013 Production\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":[\"eastus\",\"westus2\"\ - ,\"westcentralus\",\"westeurope\",\"canadacentral\"]},{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.Automanage/configurationProfileAssignments\",\"name\"\ - :\"default\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Automanage/configurationProfileAssignments/configurationProfile\"\ - ,\"equals\":\"[parameters('configurationProfileAssignment')]\"},{\"field\"\ - :\"Microsoft.Automanage/configurationProfileAssignments/accountId\",\"equals\"\ - :\"[parameters('automanageAccount')]\"}]},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"machineName\":{\"value\":\"[field('Name')]\"\ - },\"automanageAccount\":{\"value\":\"[parameters('automanageAccount')]\"},\"\ - configurationProfileAssignment\":{\"value\":\"[parameters('configurationProfileAssignment')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"machineName\":{\"type\"\ - :\"String\"},\"automanageAccount\":{\"type\":\"string\"},\"configurationProfileAssignment\"\ - :{\"type\":\"string\"}},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/providers/configurationProfileAssignments\"\ - ,\"apiVersion\":\"2020-06-30-preview\",\"name\":\"[concat(parameters('machineName'),\ - \ '/Microsoft.Automanage/', 'default')]\",\"properties\":{\"configurationProfile\"\ - :\"[parameters('configurationProfileAssignment')]\",\"accountId\":\"[parameters('automanageAccount')]\"\ - }}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/270610db-8c04-438a-a739-e8e6745b22d3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"270610db-8c04-438a-a739-e8e6745b22d3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1396 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1396\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/276af98f-4ff9-4e69-99fb-c9b2452fb85f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"276af98f-4ff9-4e69-99fb-c9b2452fb85f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1074 - Access\ - \ Control For Mobile Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1074\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/27a69937-af92-4198-9b86-08d355c7e59a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"27a69937-af92-4198-9b86-08d355c7e59a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1527 - Access\ - \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1527\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e5225fe-cdfb-4fce-9aec-0fe20dd53b62\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e5225fe-cdfb-4fce-9aec-0fe20dd53b62\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1554 - Vulnerability\ + \ Scanning | Discoverable Information\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1554\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2823de66-332f-4bfd-94a3-3eb036cd3b67\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2823de66-332f-4bfd-94a3-3eb036cd3b67\"\ - },{\"properties\":{\"displayName\":\"Deploy default Microsoft IaaSAntimalware\ - \ extension for Windows Server\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy deploys a Microsoft IaaSAntimalware extension\ - \ with a default configuration when a VM is not configured with the antimalware\ - \ extension.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Compute\"\ - },\"parameters\":{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"IaaSAntimalware\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Security\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"ExclusionsPaths\":{\"type\":\"string\"\ - ,\"defaultValue\":\"\",\"metadata\":{\"description\":\"Semicolon delimited\ - \ list of file paths or locations to exclude from scanning\"}},\"ExclusionsExtensions\"\ - :{\"type\":\"string\",\"defaultValue\":\"\",\"metadata\":{\"description\"\ - :\"Semicolon delimited list of file extensions to exclude from scanning\"\ - }},\"ExclusionsProcesses\":{\"type\":\"string\",\"defaultValue\":\"\",\"metadata\"\ - :{\"description\":\"Semicolon delimited list of process names to exclude from\ - \ scanning\"}},\"RealtimeProtectionEnabled\":{\"type\":\"string\",\"defaultValue\"\ - :\"true\",\"metadata\":{\"description\":\"Indicates whether or not real time\ - \ protection is enabled (default is true)\"}},\"ScheduledScanSettingsIsEnabled\"\ - :{\"type\":\"string\",\"defaultValue\":\"false\",\"metadata\":{\"description\"\ - :\"Indicates whether or not custom scheduled scan settings are enabled (default\ - \ is false)\"}},\"ScheduledScanSettingsScanType\":{\"type\":\"string\",\"\ - defaultValue\":\"Quick\",\"metadata\":{\"description\":\"Indicates whether\ - \ scheduled scan setting type is set to Quick or Full (default is Quick)\"\ - }},\"ScheduledScanSettingsDay\":{\"type\":\"string\",\"defaultValue\":\"7\"\ - ,\"metadata\":{\"description\":\"Day of the week for scheduled scan (1-Sunday,\ - \ 2-Monday, ..., 7-Saturday)\"}},\"ScheduledScanSettingsTime\":{\"type\":\"\ - string\",\"defaultValue\":\"120\",\"metadata\":{\"description\":\"When to\ - \ perform the scheduled scan, measured in minutes from midnight (0-1440).\ - \ For example: 0 = 12AM, 60 = 1AM, 120 = 2AM.\"}}},\"resources\":[{\"name\"\ - :\"[concat(parameters('vmName'),'/IaaSAntimalware')]\",\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"apiVersion\":\"2017-12-01\",\"\ - properties\":{\"publisher\":\"Microsoft.Azure.Security\",\"type\":\"IaaSAntimalware\"\ - ,\"typeHandlerVersion\":\"1.3\",\"autoUpgradeMinorVersion\":true,\"settings\"\ - :{\"AntimalwareEnabled\":true,\"RealtimeProtectionEnabled\":\"[parameters('RealtimeProtectionEnabled')]\"\ - ,\"ScheduledScanSettings\":{\"isEnabled\":\"[parameters('ScheduledScanSettingsIsEnabled')]\"\ - ,\"day\":\"[parameters('ScheduledScanSettingsDay')]\",\"time\":\"[parameters('ScheduledScanSettingsTime')]\"\ - ,\"scanType\":\"[parameters('ScheduledScanSettingsScanType')]\"},\"Exclusions\"\ - :{\"Extensions\":\"[parameters('ExclusionsExtensions')]\",\"Paths\":\"[parameters('ExclusionsPaths')]\"\ - ,\"Processes\":\"[parameters('ExclusionsProcesses')]\"}}}}]},\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"RealtimeProtectionEnabled\":{\"value\":\"true\"},\"ScheduledScanSettingsIsEnabled\"\ - :{\"value\":\"true\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2835b622-407b-4114-9198-6f7064cbe0dc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2835b622-407b-4114-9198-6f7064cbe0dc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1342 - Authenticator\ - \ Management | Hardware Token-Based Authentication\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1342\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/10984b4e-c93e-48d7-bf20-9c03b04e9eca\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"10984b4e-c93e-48d7-bf20-9c03b04e9eca\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1556 - Vulnerability\ + \ Scanning | Automated Trend Analyses\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1556\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/283a4e29-69d5-4c94-b99e-29acf003c899\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"283a4e29-69d5-4c94-b99e-29acf003c899\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1436 - Media\ - \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1436\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/28aab8b4-74fd-4b7c-9080-5a7be525d574\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28aab8b4-74fd-4b7c-9080-5a7be525d574\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1224 - Information\ - \ System Component Inventory | Updates During Installations / Removals\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1224\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/28cfa30b-7f72-47ce-ba3b-eed26c8d2c82\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28cfa30b-7f72-47ce-ba3b-eed26c8d2c82\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1148 - Security\ - \ Assessments | Independent Assessors\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Security Assessment\ - \ and Authorization control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1148\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/391ff8b3-afed-405e-9f7d-ef2f8168d5da\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"391ff8b3-afed-405e-9f7d-ef2f8168d5da\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1557 - Vulnerability\ + \ Scanning | Review Historic Audit Logs\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1557\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/28e62650-c7c2-4786-bdfa-17edc1673902\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28e62650-c7c2-4786-bdfa-17edc1673902\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1418 - Nonlocal\ - \ Maintenance | Comparable Security / Sanitization\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36fbe499-f2f2-41b6-880e-52d7ea1d94a5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36fbe499-f2f2-41b6-880e-52d7ea1d94a5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1558 - Vulnerability\ + \ Scanning | Correlate Scanning Information\",\"policyType\":\"Static\",\"\ + mode\":\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1418\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1558\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/28e633fd-284e-4ea7-88b4-02ca157ed713\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28e633fd-284e-4ea7-88b4-02ca157ed713\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Azure App Service plans\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Advanced threat protection leverages the scale\ - \ of the cloud, and the visibility that Azure has as a cloud provider, to\ - \ monitor for common web app attacks.\",\"metadata\":{\"version\":\"1.0.2\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/pricings\",\"name\":\"AppServices\",\"existenceScope\"\ - :\"subscription\",\"existenceCondition\":{\"field\":\"Microsoft.Security/pricings/pricingTier\"\ - ,\"equals\":\"Standard\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2913021d-f2fd-4f3d-b958-22354e2bdbcb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2913021d-f2fd-4f3d-b958-22354e2bdbcb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1634 - Boundary\ - \ Protection | Prevent Unauthorized Exfiltration\",\"policyType\":\"Static\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/65592b16-4367-42c5-a26e-d371be450e17\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"65592b16-4367-42c5-a26e-d371be450e17\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1560 - System\ + \ And Services Acquisition Policy And Procedures\",\"policyType\":\"Static\"\ ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1634\"\ + \ Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1560\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/292a7c44-37fa-4c68-af7c-9d836955ded2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"292a7c44-37fa-4c68-af7c-9d836955ded2\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - User Account Control'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - User Account Control'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsUserAccountControl\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/29829ec2-489d-4925-81b7-bda06b1718e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"29829ec2-489d-4925-81b7-bda06b1718e0\"\ - },{\"properties\":{\"displayName\":\"Append a tag and its value to resources\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Appends\ - \ the specified tag and value when any resource which is missing this tag\ - \ is created or updated. Does not modify the tags of resources created before\ - \ this policy was applied until those resources are changed. Does not apply\ - \ to resource groups. New 'modify' effect policies are available that support\ - \ remediation of tags on existing resources (see https://aka.ms/modifydoc).\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Tags\"},\"parameters\"\ - :{\"tagName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\"\ - ,\"description\":\"Name of the tag, such as 'environment'\"}},\"tagValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Value\",\"description\"\ - :\"Value of the tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },\"then\":{\"effect\":\"append\",\"details\":[{\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/2a0e14a6-b0a6-4fab-991a-187a4f81c498\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2a0e14a6-b0a6-4fab-991a-187a4f81c498\"\ - },{\"properties\":{\"displayName\":\"Storage accounts should restrict network\ - \ access using virtual network rules\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Protect your storage accounts from potential\ - \ threats using virtual network rules as a preferred method to IP-based filtering.\ - \ Disallowing IP-based filtering prevents public IPs from accessing your storage\ - \ accounts.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Storage\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the audit\ - \ policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Storage/storageAccounts\"},{\"anyOf\":[{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.defaultAction\"\ - ,\"notEquals\":\"Deny\"},{\"count\":{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.ipRules[*]\"\ - },\"greaterOrEquals\":1}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2a1a9cdf-e04d-429a-8416-3bfb72a1b26f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2a1a9cdf-e04d-429a-8416-3bfb72a1b26f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1219 - Least\ - \ Functionality | Authorized Software / Whitelisting\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1219\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e29e0915-5c2f-4d09-8806-048b749ad763\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e29e0915-5c2f-4d09-8806-048b749ad763\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1559 - System\ + \ And Services Acquisition Policy And Procedures\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1559\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2a39ac75-622b-4c88-9a3f-45b7373f7ef7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2a39ac75-622b-4c88-9a3f-45b7373f7ef7\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Policy Change'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Policy Change'\ - \ for auditing changes to system audit policies. This policy requires that\ - \ the Guest Configuration prerequisites have been deployed to the policy assignment\ - \ scope. For details, visit https://aka.ms/gcpol.\",\"metadata\":{\"category\"\ - :\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SystemAuditPoliciesPolicyChange\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"AuditAuthenticationPolicyChange\"\ - :\"Audit Authentication Policy Change;ExpectedValue\",\"AuditAuthorizationPolicyChange\"\ - :\"Audit Authorization Policy Change;ExpectedValue\"}}},\"parameters\":{\"\ - IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"AuditAuthenticationPolicyChange\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Audit Authentication\ - \ Policy Change\",\"description\":\"Specifies whether audit events are generated\ - \ when changes are made to authentication policy. This setting is useful for\ - \ tracking changes in domain-level and forest-level trust and privileges that\ - \ are granted to user accounts or groups.\"},\"allowedValues\":[\"No Auditing\"\ - ,\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\":\"Success\"\ - },\"AuditAuthorizationPolicyChange\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Audit Authorization Policy Change\",\"description\":\"Specifies\ - \ whether audit events are generated for assignment and removal of user rights\ - \ in user right policies, changes in security token object permission, resource\ - \ attributes changes and Central Access Policy changes for file system objects.\"\ - },\"allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and\ - \ Failure\"],\"defaultValue\":\"No Auditing\"},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesPolicyChange\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Authentication Policy Change;ExpectedValue',\ - \ '=', parameters('AuditAuthenticationPolicyChange'), ',', 'Audit Authorization\ - \ Policy Change;ExpectedValue', '=', parameters('AuditAuthorizationPolicyChange')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2a7a701e-dff3-4da9-9ec5-42cb98594c0b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2a7a701e-dff3-4da9-9ec5-42cb98594c0b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1274 - Alternate\ - \ Processing Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1274\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2aee175f-cd16-4825-939a-a85349d96210\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2aee175f-cd16-4825-939a-a85349d96210\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1603 - Developer\ - \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1603\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45692294-f074-42bd-ac54-16f1a3c07554\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45692294-f074-42bd-ac54-16f1a3c07554\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1561 - Allocation\ + \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1561\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2b909c26-162f-47ce-8e15-0c1f55632eac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2b909c26-162f-47ce-8e15-0c1f55632eac\"\ - },{\"properties\":{\"displayName\":\"Managed identity should be used in your\ - \ Web App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use a managed identity for enhanced authentication security\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2b9ad585-36bc-4615-b300-fd4435808332\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2b9ad585-36bc-4615-b300-fd4435808332\"\ - },{\"properties\":{\"displayName\":\"Cognitive Services accounts should enable\ - \ data encryption\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any Cognitive Services account not using data encryption.\ - \ For each Cognitive Services account with storage, should enable data encryption\ - \ with either customer managed or Microsoft managed key.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Cognitive Services\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"The effect determines what happens when the policy rule is\ - \ evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"},{\"field\"\ - :\"Microsoft.CognitiveServices/accounts/encryption.keySource\",\"exists\"\ - :\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/2bdd0062-9d75-436e-89df-487dd8e4b3c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2bdd0062-9d75-436e-89df-487dd8e4b3c7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1434 - Media\ - \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1434\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40364c3f-c331-4e29-b1e3-2fbe998ba2f5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40364c3f-c331-4e29-b1e3-2fbe998ba2f5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1562 - Allocation\ + \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1562\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c18f06b-a68d-41c3-8863-b8cd3acb5f8f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c18f06b-a68d-41c3-8863-b8cd3acb5f8f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1343 - Authenticator\ - \ Management | Expiration Of Cached Authenticators\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1343\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d4142013-7964-4163-a313-a900301c2cef\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d4142013-7964-4163-a313-a900301c2cef\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1563 - Allocation\ + \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1563\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c251a55-31eb-4e53-99c6-e9c43c393ac2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c251a55-31eb-4e53-99c6-e9c43c393ac2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1388 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1388\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9afe2edf-232c-4fdf-8e6a-e867a5c525fd\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9afe2edf-232c-4fdf-8e6a-e867a5c525fd\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1564 - System\ + \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1564\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c7c575a-d4c5-4f6f-bd49-dee97a8cba55\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c7c575a-d4c5-4f6f-bd49-dee97a8cba55\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1344 - Authenticator\ - \ Feedback\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1344\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/157f0ef9-143f-496d-b8f9-f8c8eeaad801\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"157f0ef9-143f-496d-b8f9-f8c8eeaad801\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1566 - System\ + \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1566\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c895fe7-2d8e-43a2-838c-3a533a5b355e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c895fe7-2d8e-43a2-838c-3a533a5b355e\"\ - },{\"properties\":{\"displayName\":\"SSH access from the Internet should be\ - \ blocked\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy audits any network security rule that allows SSH access from Internet\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Network\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Allow\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"},{\"anyOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange\"\ - ,\"equals\":\"*\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange\"\ - ,\"equals\":\"22\"},{\"value\":\"[if(and(not(empty(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'))),\ - \ contains(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),'-')),\ - \ and(lessOrEquals(int(first(split(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),\ - \ '-'))),22),greaterOrEquals(int(last(split(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),\ - \ '-'))),22)), 'false')]\",\"equals\":\"true\"},{\"count\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"where\":{\"value\":\"[if(and(not(empty(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')))),\ - \ contains(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),'-')),\ - \ and(lessOrEquals(int(first(split(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),\ - \ '-'))),22),greaterOrEquals(int(last(split(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),\ - \ '-'))),22)) , 'false')]\",\"equals\":\"true\"}},\"greater\":0},{\"not\"\ - :{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"notEquals\":\"*\"}},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"notEquals\":\"22\"}}]},{\"anyOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"*\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Internet\"},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]\"\ - ,\"notEquals\":\"*\"}},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]\"\ - ,\"notEquals\":\"Internet\"}}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c89a2e5-7285-40fe-afe0-ae8654b92fab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c89a2e5-7285-40fe-afe0-ae8654b92fab\"\ - },{\"properties\":{\"displayName\":\"Unattached disks should be encrypted\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ audits any unattached disk without encryption enabled.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Compute\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/disks\"},{\"\ - field\":\"Microsoft.Compute/disks/diskState\",\"equals\":\"Unattached\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/disks/encryptionSettingsCollection.enabled\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/disks/encryptionSettingsCollection.enabled\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2c89a2e5-7285-40fe-afe0-ae8654b92fb2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c89a2e5-7285-40fe-afe0-ae8654b92fb2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1593 - External\ - \ Information System Services | Processing, Storage, And Service Location\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Services Acquisition control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1593\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50ad3724-e2ac-4716-afcc-d8eabd97adb9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50ad3724-e2ac-4716-afcc-d8eabd97adb9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1567 - System\ + \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1567\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2cd0a426-b5f5-4fe0-9539-a6043cdbc6fa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2cd0a426-b5f5-4fe0-9539-a6043cdbc6fa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1546 - Vulnerability\ - \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1546\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e72edbf6-aa61-436d-a227-0f32b77194b3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e72edbf6-aa61-436d-a227-0f32b77194b3\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1565 - System\ + \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1565\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2ce1ea7e-4038-4e53-82f4-63e8859333c1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2ce1ea7e-4038-4e53-82f4-63e8859333c1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1414 - Nonlocal\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1414\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45ce2396-5c76-4654-9737-f8792ab3d26b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45ce2396-5c76-4654-9737-f8792ab3d26b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1568 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1568\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2ce63a52-e47b-4ae2-adbb-6e40d967f9e6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2ce63a52-e47b-4ae2-adbb-6e40d967f9e6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1679 - Malicious\ - \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b6a8eae8-9854-495a-ac82-d2cd3eac02a6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b6a8eae8-9854-495a-ac82-d2cd3eac02a6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1569 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1679\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1569\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2cf42a28-193e-41c5-98df-7688e7ef0a88\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2cf42a28-193e-41c5-98df-7688e7ef0a88\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1068 - Wireless\ - \ Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1068\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ad2f8e61-a564-4dfd-8eaa-816f5be8cb34\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ad2f8e61-a564-4dfd-8eaa-816f5be8cb34\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1570 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1570\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d045bca-a0fd-452e-9f41-4ec33769717c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d045bca-a0fd-452e-9f41-4ec33769717c\"\ - },{\"properties\":{\"displayName\":\"App Service should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any App Service not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"\ - like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Web/sites/virtualNetworkConnections\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/virtualnetworkconnections/vnetResourceId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d21331d-a4c2-4def-a9ad-ee4e1e023beb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d21331d-a4c2-4def-a9ad-ee4e1e023beb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1704 - Security\ - \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1704\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7fcf38d-bb09-4600-be7d-825046eb162a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7fcf38d-bb09-4600-be7d-825046eb162a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1571 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1571\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d44b6fa-1134-4ea6-ad4e-9edb68f65429\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d44b6fa-1134-4ea6-ad4e-9edb68f65429\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not store passwords using reversible encryption\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines that do not store passwords using reversible encryption.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"StorePasswordsUsingReversibleEncryption\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d60d3b7-aa10-454c-88a8-de39d99d17c6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d60d3b7-aa10-454c-88a8-de39d99d17c6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Linux VMs that allow remote connections from accounts without passwords\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Linux\ - \ virtual machines that allow remote connections from accounts without passwords.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"\ - qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid110\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d67222d-05fd-4526-a171-2ee132ad9e83\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d67222d-05fd-4526-a171-2ee132ad9e83\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1077 - Use\ - \ Of External Information Systems\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1077\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b11c985b-f2cd-4bd7-85f4-b52426edf905\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b11c985b-f2cd-4bd7-85f4-b52426edf905\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1573 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1573\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2dad3668-797a-412e-a798-07d3849a7a79\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2dad3668-797a-412e-a798-07d3849a7a79\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1149 - Security\ - \ Assessments | Specialized Assessments\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Security Assessment\ - \ and Authorization control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1149\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58c93053-7b98-4cf0-b99f-1beb985416c2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58c93053-7b98-4cf0-b99f-1beb985416c2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1572 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1572\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2e1b855b-a013-481a-aeeb-2bcb129fd35d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2e1b855b-a013-481a-aeeb-2bcb129fd35d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1497 - System\ - \ Security Plan | Plan / Coordinate With Other Organizational Entities\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1497\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/04f5fb00-80bb-48a9-a75b-4cb4d4c97c36\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"04f5fb00-80bb-48a9-a75b-4cb4d4c97c36\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1574 - Acquisition\ + \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1574\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2e3c5583-1729-4d36-8771-59c32f090a22\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2e3c5583-1729-4d36-8771-59c32f090a22\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1000 - Access\ - \ Control Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1000\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f935dab-83d6-47b8-85ef-68b8584161b9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f935dab-83d6-47b8-85ef-68b8584161b9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1576 - Acquisition\ + \ Process | Design / Implementation Information For Security Controls\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this System and Services Acquisition control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1576\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2ef3cc79-733e-48ed-ab6f-7bf439e9b406\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2ef3cc79-733e-48ed-ab6f-7bf439e9b406\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1519 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1519\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f18c885-ade3-48c5-80b1-8f9216019c18\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f18c885-ade3-48c5-80b1-8f9216019c18\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1577 - Acquisition\ + \ Process | Continuous Monitoring Plan\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1577\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2f13915a-324c-4ab8-b45c-2eefeeefb098\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2f13915a-324c-4ab8-b45c-2eefeeefb098\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - System objects'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - System objects'\ - \ for case insensitivity for non-Windows subsystems and permissions of internal\ - \ system objects. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsSystemobjects\",\"version\":\"1.*\"\ - }},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of this policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsSystemobjects\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2f262ace-812a-4fd0-b731-b38ba9e9708d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2f262ace-812a-4fd0-b731-b38ba9e9708d\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Network traffic data collection\ - \ agent should be installed on Windows virtual machines\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Security Center uses the\ - \ Microsoft Dependency agent to collect network traffic data from your Azure\ - \ virtual machines to enable advanced network protection features such as\ - \ traffic visualization on the network map, network hardening recommendations\ - \ and specific network threats.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ - ,\"category\":\"Monitoring\",\"preview\":\"true\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\"\ - ,\"description\":\"Enable or disable Dependency Agent for Windows VMs monitoring\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ - ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ - ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ - ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ - 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ - ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ - ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ - ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ - existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"DependencyAgentWindows\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2f2ee1de-44aa-4762-b6bd-0893fc3f306d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2f2ee1de-44aa-4762-b6bd-0893fc3f306d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1144 - Security\ - \ Assessments\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1144\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d922484a-8cfc-4a6b-95a4-77d6a685407f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d922484a-8cfc-4a6b-95a4-77d6a685407f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1575 - Acquisition\ + \ Process | Functional Properties Of Security Controls\",\"policyType\":\"\ + Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1575\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2fa15ff1-a693-4ee4-b094-324818dc9a51\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2fa15ff1-a693-4ee4-b094-324818dc9a51\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1090 - Security\ - \ Awareness Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1090\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93e1bb73-1b08-4dbe-9c62-8e2e92e7ec41\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93e1bb73-1b08-4dbe-9c62-8e2e92e7ec41\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1578 - Acquisition\ + \ Process | Functions / Ports / Protocols / Services In Use\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1578\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2fb740e5-cbc7-4d10-8686-d1bf826652b1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2fb740e5-cbc7-4d10-8686-d1bf826652b1\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Web Application should\ - \ only be accessible over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Use of HTTPS ensures server/service authentication and\ - \ protects data in transit from network layer eavesdropping attacks.\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\"\ - ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\"\ - :[{\"field\":\"kind\",\"equals\":\"app\"},{\"field\":\"kind\",\"equals\":\"\ - WebApp\"},{\"field\":\"kind\",\"equals\":\"app,linux\"},{\"field\":\"kind\"\ - ,\"equals\":\"app,linux,container\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - OnlyHttpsForWebApplication\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2fde8a98-6892-426a-83ba-050e640c0ce0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2fde8a98-6892-426a-83ba-050e640c0ce0\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Network Access'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Network Access'. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsNetworkAccess\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/30040dab-4e75-4456-8273-14b8f75d91d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"30040dab-4e75-4456-8273-14b8f75d91d9\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Azure Storage accounts\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Advanced threat protection provides detections\ - \ of unusual and potentially harmful attempts to access or exploit Storage\ - \ accounts.\",\"metadata\":{\"version\":\"1.0.2\",\"category\":\"Security\ - \ Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/pricings\"\ - ,\"name\":\"StorageAccounts\",\"existenceScope\":\"subscription\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/pricings/pricingTier\",\"equals\":\"Standard\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/308fbb08-4ab8-4e67-9b29-592e93fb94fa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"308fbb08-4ab8-4e67-9b29-592e93fb94fa\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines missing any of\ - \ specified members in the Administrators group\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the local Administrators group does not contain\ - \ one or more members that are listed in the policy parameter.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AdministratorsGroupMembersToInclude\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"MembersToInclude\":\"[LocalGroup]AdministratorsGroup;MembersToInclude\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"MembersToInclude\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Members to include\"\ - ,\"description\":\"A semicolon-separated list of members that should be included\ - \ in the Administrators local group. Ex: Administrator; myUser1; myUser2\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToInclude\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;MembersToInclude',\ - \ '=', parameters('MembersToInclude')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/30f71ea1-ac77-4f26-9fc5-2d926bbd4ba7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"30f71ea1-ac77-4f26-9fc5-2d926bbd4ba7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that are not joined to the specified domain\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines that are\ - \ not joined to the specified domain. It also creates a system-assigned managed\ - \ identity and deploys the VM extension for Guest Configuration. This policy\ - \ should only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"DomainName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Domain Name (FQDN)\",\"description\":\"The fully qualified\ - \ domain name (FQDN) that the Windows VMs should be joined to\"}}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDomainMembership\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[DomainMembership]WindowsDomainMembership;DomainName',\ - \ '=', parameters('DomainName')))]\"},\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsDomainMembership\"\ - },\"DomainName\":{\"value\":\"[parameters('DomainName')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"DomainName\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[DomainMembership]WindowsDomainMembership;DomainName\"\ - ,\"value\":\"[parameters('DomainName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[DomainMembership]WindowsDomainMembership;DomainName\"\ - ,\"value\":\"[parameters('DomainName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/315c850a-272d-4502-8935-b79010405970\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"315c850a-272d-4502-8935-b79010405970\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1042 - Least\ - \ Privilege | Auditing Use Of Privileged Functions\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1042\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45b7b644-5f91-498e-9d89-7402532d3645\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45b7b644-5f91-498e-9d89-7402532d3645\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1579 - Acquisition\ + \ Process | Use Of Approved Piv Products\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1579\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/319dc4f0-0fed-4ac9-8fc3-7aeddee82c07\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"319dc4f0-0fed-4ac9-8fc3-7aeddee82c07\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1698 - Information\ - \ System Monitoring | Individuals Posing Greater Risk\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1698\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e54c7ef-7457-430b-9a3e-ef8881d4a8e0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e54c7ef-7457-430b-9a3e-ef8881d4a8e0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1580 - Information\ + \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1580\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/31b752c1-05a9-432a-8fce-c39b56550119\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"31b752c1-05a9-432a-8fce-c39b56550119\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Audit Log Analytics Agent\ - \ Deployment - VM Image (OS) unlisted\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Reports VMs as non-compliant if the VM Image\ - \ (OS) is not in the list defined and the agent is not installed. The list\ - \ of OS images will be updated over time as support is updated.\",\"metadata\"\ - :{\"version\":\"1.0.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"\ - parameters\":{\"listOfImageIdToInclude_windows\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Optional: List of VM images that have supported\ - \ Windows OS to add to scope\",\"description\":\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]},\"listOfImageIdToInclude_linux\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"[Preview]: Optional: List of VM images that\ - \ have supported Linux OS to add to scope\",\"description\":\"Example value:\ - \ '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"not\":{\"anyOf\":[{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_windows')]\"\ - },{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_linux')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\"\ - ,\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7.*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\"\ - ,\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}}]},\"then\"\ - :{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32133ab0-ee4b-4b44-98d6-042180979d50\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32133ab0-ee4b-4b44-98d6-042180979d50\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1587 - External\ - \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/854db8ac-6adf-42a0-bef3-b73f764f40b9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"854db8ac-6adf-42a0-bef3-b73f764f40b9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1582 - Information\ + \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Services Acquisition\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1587\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1582\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32820956-9c6d-4376-934c-05cd8525be7c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32820956-9c6d-4376-934c-05cd8525be7c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1333 - Authenticator\ - \ Management | Pki-Based Authentication\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Identification and\ - \ Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1333\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd9e2f38-259b-462c-bfad-0ad7ab4e65c5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd9e2f38-259b-462c-bfad-0ad7ab4e65c5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1583 - Information\ + \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1583\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3298d6bf-4bc6-4278-a95d-f7ef3ac6e594\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3298d6bf-4bc6-4278-a95d-f7ef3ac6e594\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs on which the specified services are not installed and\ - \ 'Running'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines on which the specified services are not installed and 'Running'.\ - \ It also creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"ServiceName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Service names (supports wildcards)\",\"description\":\"A\ - \ semicolon-separated list of the names of the services that should be installed\ - \ and 'Running'. e.g. 'WinRm;Wi*'\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsServiceStatus\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsServiceStatus]WindowsServiceStatus1;ServiceName',\ - \ '=', parameters('ServiceName')))]\"},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsServiceStatus\"\ - },\"ServiceName\":{\"value\":\"[parameters('ServiceName')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ServiceName\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName\"\ - ,\"value\":\"[parameters('ServiceName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName\"\ - ,\"value\":\"[parameters('ServiceName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32b1e4d4-6cd5-47b4-a935-169da8a5c262\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32b1e4d4-6cd5-47b4-a935-169da8a5c262\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1445 - Physical\ - \ And Environmental Protection Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical\ - \ and Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1445\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0882d488-8e80-4466-bc0f-0cd15b6cb66d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0882d488-8e80-4466-bc0f-0cd15b6cb66d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1584 - Information\ + \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1584\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32d07d59-2716-4972-b37b-214a67ac4a37\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32d07d59-2716-4972-b37b-214a67ac4a37\"\ - },{\"properties\":{\"displayName\":\"Azure SQL Database should have the minimal\ - \ TLS version of 1.2\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Setting minimal TLS version to 1.2 improves security by ensuring\ - \ your Azure SQL Database can only be accessed from clients using TLS 1.2.\ - \ Using versions of TLS less than 1.2 is not reccomended since they have well\ - \ documented security vunerabilities.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Sql/servers\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Sql/servers/minimalTlsVersion\",\"exists\":false},{\"field\":\"\ - Microsoft.Sql/servers/minimalTlsVersion\",\"notEquals\":\"1.2\"}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32e6bbec-16b6-44c2-be37-c5b672d103cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32e6bbec-16b6-44c2-be37-c5b672d103cf\"\ - },{\"properties\":{\"displayName\":\"Deploy the Linux Guest Configuration\ - \ extension to enable Guest Configuration assignments on Linux VMs\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy deploys the\ - \ Linux Guest Configuration extension to Linux virtual machines hosted in\ - \ Azure that are supported by Guest Configuration. The Linux Guest Configuration\ - \ extension is a prerequisite for all Linux Guest Configuration assignments\ - \ and must deployed to machines before using any Linux Guest Configuration\ - \ policy definition. For more information on Guest Configuration, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzurePolicyforLinux\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.GuestConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"ConfigurationforLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\",\"type\"\ - :\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/331e8ea8-378a-410f-a2e5-ae22f38bb0da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"331e8ea8-378a-410f-a2e5-ae22f38bb0da\"\ - },{\"properties\":{\"displayName\":\"MySQL server should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits MySQL servers not configured to use a virtual network\ - \ service endpoint. For more details, visit https://aka.ms/mysqlvnet.\",\"\ - metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforMySQL/servers/virtualNetworkRules\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforMySQL/servers/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3375856c-3824-4e0e-ae6a-79e011dd4c47\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3375856c-3824-4e0e-ae6a-79e011dd4c47\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Audit'\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Windows machines should have the specified Group\ - \ Policy settings in the category 'Security Options - Audit' for forcing audit\ - \ policy subcategory and shutting down if unable to log security audits. This\ - \ policy requires that the Guest Configuration prerequisites have been deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsAudit\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits\":\"Audit: Shut\ - \ down system immediately if unable to log security audits;ExpectedValue\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Audit: Shut down system\ - \ immediately if unable to log security audits\",\"description\":\"Audits\ - \ if the system will shut down when unable to log Security events.\"},\"defaultValue\"\ - :\"0\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsAudit\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit: Shut down system immediately if unable\ - \ to log security audits;ExpectedValue', '=', parameters('AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/33936777-f2ac-45aa-82ec-07958ec9ade4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"33936777-f2ac-45aa-82ec-07958ec9ade4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1282 - Telecommunications\ - \ Services | Single Points Of Failure\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5864522b-ff1d-4979-a9f8-58bee1fb174c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5864522b-ff1d-4979-a9f8-58bee1fb174c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1581 - Information\ + \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Services Acquisition\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1282\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1581\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34042a97-ec6d-4263-93d2-8c1c46823b2a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34042a97-ec6d-4263-93d2-8c1c46823b2a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Linux VMs that have accounts without passwords\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a Guest\ - \ Configuration assignment to audit Linux virtual machines that have accounts\ - \ without passwords. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid232\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"PasswordPolicy_msid232\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3470477a-b35a-49db-aca5-1073d04524fe\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3470477a-b35a-49db-aca5-1073d04524fe\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1151 - System\ - \ Interconnections\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1151\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/742b549b-7a25-465f-b83c-ea1ffb4f4e0e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"742b549b-7a25-465f-b83c-ea1ffb4f4e0e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1585 - Security\ + \ Engineering Principles\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1585\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/347e3b69-7fb7-47df-a8ef-71a1a7b44bca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"347e3b69-7fb7-47df-a8ef-71a1a7b44bca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1412 - Nonlocal\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1412\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d57f8732-5cdc-4cda-8d27-ab148e1f3a55\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d57f8732-5cdc-4cda-8d27-ab148e1f3a55\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1586 - External\ + \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1586\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3492d949-0dbb-4589-88b3-7b59601cc764\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3492d949-0dbb-4589-88b3-7b59601cc764\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1475 - Emergency\ - \ Lighting\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1475\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e3b2fbd-8f37-4766-a64d-3f37703dcb51\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e3b2fbd-8f37-4766-a64d-3f37703dcb51\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1587 - External\ + \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1587\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34a63848-30cf-4081-937e-ce1a1c885501\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34a63848-30cf-4081-937e-ce1a1c885501\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1060 - Remote\ - \ Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1060\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/32820956-9c6d-4376-934c-05cd8525be7c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"32820956-9c6d-4376-934c-05cd8525be7c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1589 - External\ + \ Information System Services | Risk Assessments / Organizational Approvals\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1589\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34a987fd-2003-45de-a120-014956581f2b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34a987fd-2003-45de-a120-014956581f2b\"\ - },{\"properties\":{\"displayName\":\"Storage accounts should restrict network\ - \ access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Network access to storage accounts should be restricted. Configure network\ - \ rules so only applications from allowed networks can access the storage\ - \ account. To allow connections from specific internet or on-premise clients,\ - \ access can be granted to traffic from specific Azure virtual networks or\ - \ to public internet IP address ranges\",\"metadata\":{\"version\":\"1.1.0\"\ - ,\"category\":\"Storage\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"The effect determines\ - \ what happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"\ - },{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.defaultAction\"\ - ,\"notEquals\":\"Deny\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34c877ad-507e-4c82-993e-3452a6e0ad3c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34c877ad-507e-4c82-993e-3452a6e0ad3c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1341 - Authenticator\ - \ Management | Multiple Information System Accounts\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1341\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86ec7f9b-9478-40ff-8cfd-6a0d510081a8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86ec7f9b-9478-40ff-8cfd-6a0d510081a8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1588 - External\ + \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1588\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34cb7e92-fe4c-4826-b51e-8cd203fa5d35\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34cb7e92-fe4c-4826-b51e-8cd203fa5d35\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Logic Apps should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Logic Apps\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Logic/workflows\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/34f95f76-5386-4de7-b824-0d8478470c9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34f95f76-5386-4de7-b824-0d8478470c9d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1210 - Configuration\ - \ Settings\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1210\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68ebae26-e0e0-4ecb-8379-aabf633b51e9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68ebae26-e0e0-4ecb-8379-aabf633b51e9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1591 - External\ + \ Information System Services | Ident. Of Functions / Ports / Protocols /\ + \ Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1591\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f751cdb7-fbee-406b-969b-815d367cb9b3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f751cdb7-fbee-406b-969b-815d367cb9b3\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1593 - External\ + \ Information System Services | Processing, Storage, And Service Location\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1593\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3502c968-c490-4570-8167-1476f955e9b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3502c968-c490-4570-8167-1476f955e9b8\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have a maximum password age of 70 days\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ that do not have a maximum password age of 70 days. It also creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration. This\ - \ policy should only be used along with its corresponding audit policy in\ - \ an initiative. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"2.2.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MaximumPasswordAge\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"MaximumPasswordAge\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/356a906e-05e5-4625-8729-90771e0ee934\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"356a906e-05e5-4625-8729-90771e0ee934\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Object Access'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Object Access'\ - \ for auditing file, registry, SAM, storage, filtering, kernel, and other\ - \ system types. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SystemAuditPoliciesObjectAccess\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"AuditDetailedFileShare\":\"Audit Detailed\ - \ File Share;ExpectedValue\",\"AuditFileShare\":\"Audit File Share;ExpectedValue\"\ - ,\"AuditFileSystem\":\"Audit File System;ExpectedValue\"}}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"AuditDetailedFileShare\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Audit Detailed File\ - \ Share\",\"description\":\"If this policy setting is enabled, access to all\ - \ shared files and folders on the system is audited. Auditing for Success\ - \ can lead to very high volumes of events.\"},\"allowedValues\":[\"No Auditing\"\ - ,\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\":\"No Auditing\"\ - },\"AuditFileShare\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Audit File Share\",\"description\":\"Specifies whether to audit events related\ - \ to file shares: creation, deletion, modification, and access attempts. Also,\ - \ it shows failed SMB SPN checks. Event volumes can be high on DCs and File\ - \ Servers.\"},\"allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"\ - Success and Failure\"],\"defaultValue\":\"No Auditing\"},\"AuditFileSystem\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Audit File System\"\ - ,\"description\":\"Specifies whether audit events are generated when users\ - \ attempt to access file system objects. Audit events are generated only for\ - \ objects that have configured system access control lists (SACLs).\"},\"\ - allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"\ - ],\"defaultValue\":\"No Auditing\"},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesObjectAccess\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Detailed File Share;ExpectedValue', '=',\ - \ parameters('AuditDetailedFileShare'), ',', 'Audit File Share;ExpectedValue',\ - \ '=', parameters('AuditFileShare'), ',', 'Audit File System;ExpectedValue',\ - \ '=', parameters('AuditFileSystem')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/35781875-8026-4628-b19b-f6efb4d88a1d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"35781875-8026-4628-b19b-f6efb4d88a1d\"\ - },{\"properties\":{\"displayName\":\"CORS should not allow every resource\ - \ to access your API App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Cross-Origin Resource Sharing (CORS) should not allow all\ - \ domains to access your API app. Allow only required domains to interact\ - \ with your API app.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"\ - like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]\",\"notEquals\":\"\ - *\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/358c20a6-3f9e-4f0e-97ff-c6ce485e2aac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"358c20a6-3f9e-4f0e-97ff-c6ce485e2aac\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1659 - Architecture\ - \ And Provisioning For Name / Address Resolution Service\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1659\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2cd0a426-b5f5-4fe0-9539-a6043cdbc6fa\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2cd0a426-b5f5-4fe0-9539-a6043cdbc6fa\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1594 - Developer\ + \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1594\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/042ba2a1-8bb8-45f4-b080-c78cf62b90e9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"042ba2a1-8bb8-45f4-b080-c78cf62b90e9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1596 - Developer\ + \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1596\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/21e25e01-0ae0-41be-919e-04ce92b8e8b8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21e25e01-0ae0-41be-919e-04ce92b8e8b8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1595 - Developer\ + \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1595\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1e0414e7-6ef5-4182-8076-aa82fbb53341\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1e0414e7-6ef5-4182-8076-aa82fbb53341\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1597 - Developer\ + \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1597\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68b250ec-2e4f-4eee-898a-117a9fda7016\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68b250ec-2e4f-4eee-898a-117a9fda7016\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1592 - External\ + \ Information System Services | Consistent Interests Of Consumers And Providers\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1592\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/35a4102f-a778-4a2e-98c2-971056288df8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"35a4102f-a778-4a2e-98c2-971056288df8\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Windows Firewall Properties'\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Windows Firewall Properties' for\ - \ firewall state, connections, rule management, and notifications. This policy\ - \ requires that the Guest Configuration prerequisites have been deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_WindowsFirewallProperties\",\"version\":\"1.*\"\ - ,\"configurationParameter\":{\"WindowsFirewallDomainUseProfileSettings\":\"\ - Windows Firewall: Domain: Firewall state;ExpectedValue\",\"WindowsFirewallDomainBehaviorForOutboundConnections\"\ - :\"Windows Firewall: Domain: Outbound connections;ExpectedValue\",\"WindowsFirewallDomainApplyLocalConnectionSecurityRules\"\ - :\"Windows Firewall: Domain: Settings: Apply local connection security rules;ExpectedValue\"\ - ,\"WindowsFirewallDomainApplyLocalFirewallRules\":\"Windows Firewall: Domain:\ - \ Settings: Apply local firewall rules;ExpectedValue\",\"WindowsFirewallDomainDisplayNotifications\"\ - :\"Windows Firewall: Domain: Settings: Display a notification;ExpectedValue\"\ - ,\"WindowsFirewallPrivateUseProfileSettings\":\"Windows Firewall: Private:\ - \ Firewall state;ExpectedValue\",\"WindowsFirewallPrivateBehaviorForOutboundConnections\"\ - :\"Windows Firewall: Private: Outbound connections;ExpectedValue\",\"WindowsFirewallPrivateApplyLocalConnectionSecurityRules\"\ - :\"Windows Firewall: Private: Settings: Apply local connection security rules;ExpectedValue\"\ - ,\"WindowsFirewallPrivateApplyLocalFirewallRules\":\"Windows Firewall: Private:\ - \ Settings: Apply local firewall rules;ExpectedValue\",\"WindowsFirewallPrivateDisplayNotifications\"\ - :\"Windows Firewall: Private: Settings: Display a notification;ExpectedValue\"\ - ,\"WindowsFirewallPublicUseProfileSettings\":\"Windows Firewall: Public: Firewall\ - \ state;ExpectedValue\",\"WindowsFirewallPublicBehaviorForOutboundConnections\"\ - :\"Windows Firewall: Public: Outbound connections;ExpectedValue\",\"WindowsFirewallPublicApplyLocalConnectionSecurityRules\"\ - :\"Windows Firewall: Public: Settings: Apply local connection security rules;ExpectedValue\"\ - ,\"WindowsFirewallPublicApplyLocalFirewallRules\":\"Windows Firewall: Public:\ - \ Settings: Apply local firewall rules;ExpectedValue\",\"WindowsFirewallPublicDisplayNotifications\"\ - :\"Windows Firewall: Public: Settings: Display a notification;ExpectedValue\"\ - ,\"WindowsFirewallDomainAllowUnicastResponse\":\"Windows Firewall: Domain:\ - \ Allow unicast response;ExpectedValue\",\"WindowsFirewallPrivateAllowUnicastResponse\"\ - :\"Windows Firewall: Private: Allow unicast response;ExpectedValue\",\"WindowsFirewallPublicAllowUnicastResponse\"\ - :\"Windows Firewall: Public: Allow unicast response;ExpectedValue\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"WindowsFirewallDomainUseProfileSettings\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Domain):\ - \ Use profile settings\",\"description\":\"Specifies whether Windows Firewall\ - \ with Advanced Security uses the settings for the Domain profile to filter\ - \ network traffic. If you select Off, Windows Firewall with Advanced Security\ - \ will not use any of the firewall rules or connection security rules for\ - \ this profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainBehaviorForOutboundConnections\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Domain):\ - \ Behavior for outbound connections\",\"description\":\"Specifies the behavior\ - \ for outbound connections for the Domain profile that do not match an outbound\ - \ firewall rule. The default value of 0 means to allow connections, and a\ - \ value of 1 means to block connections.\"},\"defaultValue\":\"0\"},\"WindowsFirewallDomainApplyLocalConnectionSecurityRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Domain):\ - \ Apply local connection security rules\",\"description\":\"Specifies whether\ - \ local administrators are allowed to create connection security rules that\ - \ apply together with connection security rules configured by Group Policy\ - \ for the Domain profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Domain):\ - \ Apply local firewall rules\",\"description\":\"Specifies whether local administrators\ - \ are allowed to create local firewall rules that apply together with firewall\ - \ rules configured by Group Policy for the Domain profile.\"},\"defaultValue\"\ - :\"1\"},\"WindowsFirewallDomainDisplayNotifications\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Windows Firewall (Domain): Display notifications\"\ - ,\"description\":\"Specifies whether Windows Firewall with Advanced Security\ - \ displays notifications to the user when a program is blocked from receiving\ - \ inbound connections, for the Domain profile.\"},\"defaultValue\":\"1\"},\"\ - WindowsFirewallPrivateUseProfileSettings\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Windows Firewall (Private): Use profile settings\",\"\ - description\":\"Specifies whether Windows Firewall with Advanced Security\ - \ uses the settings for the Private profile to filter network traffic. If\ - \ you select Off, Windows Firewall with Advanced Security will not use any\ - \ of the firewall rules or connection security rules for this profile.\"},\"\ - defaultValue\":\"1\"},\"WindowsFirewallPrivateBehaviorForOutboundConnections\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Private):\ - \ Behavior for outbound connections\",\"description\":\"Specifies the behavior\ - \ for outbound connections for the Private profile that do not match an outbound\ - \ firewall rule. The default value of 0 means to allow connections, and a\ - \ value of 1 means to block connections.\"},\"defaultValue\":\"0\"},\"WindowsFirewallPrivateApplyLocalConnectionSecurityRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Private):\ - \ Apply local connection security rules\",\"description\":\"Specifies whether\ - \ local administrators are allowed to create connection security rules that\ - \ apply together with connection security rules configured by Group Policy\ - \ for the Private profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPrivateApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Private):\ - \ Apply local firewall rules\",\"description\":\"Specifies whether local administrators\ - \ are allowed to create local firewall rules that apply together with firewall\ - \ rules configured by Group Policy for the Private profile.\"},\"defaultValue\"\ - :\"1\"},\"WindowsFirewallPrivateDisplayNotifications\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Windows Firewall (Private): Display notifications\"\ - ,\"description\":\"Specifies whether Windows Firewall with Advanced Security\ - \ displays notifications to the user when a program is blocked from receiving\ - \ inbound connections, for the Private profile.\"},\"defaultValue\":\"1\"\ - },\"WindowsFirewallPublicUseProfileSettings\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Windows Firewall (Public): Use profile settings\",\"description\"\ - :\"Specifies whether Windows Firewall with Advanced Security uses the settings\ - \ for the Public profile to filter network traffic. If you select Off, Windows\ - \ Firewall with Advanced Security will not use any of the firewall rules or\ - \ connection security rules for this profile.\"},\"defaultValue\":\"1\"},\"\ - WindowsFirewallPublicBehaviorForOutboundConnections\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Windows Firewall (Public): Behavior for outbound\ - \ connections\",\"description\":\"Specifies the behavior for outbound connections\ - \ for the Public profile that do not match an outbound firewall rule. The\ - \ default value of 0 means to allow connections, and a value of 1 means to\ - \ block connections.\"},\"defaultValue\":\"0\"},\"WindowsFirewallPublicApplyLocalConnectionSecurityRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Public):\ - \ Apply local connection security rules\",\"description\":\"Specifies whether\ - \ local administrators are allowed to create connection security rules that\ - \ apply together with connection security rules configured by Group Policy\ - \ for the Public profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPublicApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Windows Firewall (Public):\ - \ Apply local firewall rules\",\"description\":\"Specifies whether local administrators\ - \ are allowed to create local firewall rules that apply together with firewall\ - \ rules configured by Group Policy for the Public profile.\"},\"defaultValue\"\ - :\"1\"},\"WindowsFirewallPublicDisplayNotifications\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Windows Firewall (Public): Display notifications\"\ - ,\"description\":\"Specifies whether Windows Firewall with Advanced Security\ - \ displays notifications to the user when a program is blocked from receiving\ - \ inbound connections, for the Public profile.\"},\"defaultValue\":\"1\"},\"\ - WindowsFirewallDomainAllowUnicastResponse\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Windows Firewall: Domain: Allow unicast response\",\"\ - description\":\"Specifies whether Windows Firewall with Advanced Security\ - \ permits the local computer to receive unicast responses to its outgoing\ - \ multicast or broadcast messages; for the Domain profile.\"},\"defaultValue\"\ - :\"0\"},\"WindowsFirewallPrivateAllowUnicastResponse\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Windows Firewall: Private: Allow unicast\ - \ response\",\"description\":\"Specifies whether Windows Firewall with Advanced\ - \ Security permits the local computer to receive unicast responses to its\ - \ outgoing multicast or broadcast messages; for the Private profile.\"},\"\ - defaultValue\":\"0\"},\"WindowsFirewallPublicAllowUnicastResponse\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Windows Firewall: Public: Allow\ - \ unicast response\",\"description\":\"Specifies whether Windows Firewall\ - \ with Advanced Security permits the local computer to receive unicast responses\ - \ to its outgoing multicast or broadcast messages; for the Public profile.\"\ - },\"defaultValue\":\"1\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_WindowsFirewallProperties\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Windows Firewall: Domain: Firewall state;ExpectedValue',\ - \ '=', parameters('WindowsFirewallDomainUseProfileSettings'), ',', 'Windows\ - \ Firewall: Domain: Outbound connections;ExpectedValue', '=', parameters('WindowsFirewallDomainBehaviorForOutboundConnections'),\ - \ ',', 'Windows Firewall: Domain: Settings: Apply local connection security\ - \ rules;ExpectedValue', '=', parameters('WindowsFirewallDomainApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallDomainApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Domain: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallDomainDisplayNotifications'), ',', 'Windows Firewall:\ - \ Private: Firewall state;ExpectedValue', '=', parameters('WindowsFirewallPrivateUseProfileSettings'),\ - \ ',', 'Windows Firewall: Private: Outbound connections;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPrivateBehaviorForOutboundConnections'), ',',\ - \ 'Windows Firewall: Private: Settings: Apply local connection security rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Private: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPrivateDisplayNotifications'), ',', 'Windows\ - \ Firewall: Public: Firewall state;ExpectedValue', '=', parameters('WindowsFirewallPublicUseProfileSettings'),\ - \ ',', 'Windows Firewall: Public: Outbound connections;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPublicBehaviorForOutboundConnections'), ',',\ - \ 'Windows Firewall: Public: Settings: Apply local connection security rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPublicApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPublicApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Public: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPublicDisplayNotifications'), ',', 'Windows Firewall:\ - \ Domain: Allow unicast response;ExpectedValue', '=', parameters('WindowsFirewallDomainAllowUnicastResponse'),\ - \ ',', 'Windows Firewall: Private: Allow unicast response;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateAllowUnicastResponse'), ',', 'Windows\ - \ Firewall: Public: Allow unicast response;ExpectedValue', '=', parameters('WindowsFirewallPublicAllowUnicastResponse')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/35d9882c-993d-44e6-87d2-db66ce21b636\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"35d9882c-993d-44e6-87d2-db66ce21b636\"\ - },{\"properties\":{\"displayName\":\"Gateway subnets should not be configured\ - \ with a network security group\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"This policy denies if a gateway subnet is configured with\ - \ a network security group. Assigning a network security group to a gateway\ - \ subnet will cause the gateway to stop functioning.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Network\"},\"parameters\":{},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ - },{\"field\":\"name\",\"equals\":\"GatewaySubnet\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"true\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/35f9c03a-cc27-418e-9c0c-539ff999d010\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"35f9c03a-cc27-418e-9c0c-539ff999d010\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1043 - Least\ - \ Privilege | Prohibit Non-Privileged Users From Executing Privileged Functions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d01ba6c-289f-42fd-a408-494b355b6222\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d01ba6c-289f-42fd-a408-494b355b6222\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1599 - Developer\ + \ Configuration Management | Software / Firmware Integrity Verification\"\ ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Access Control control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1043\"\ + \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1599\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0004bbf0-5099-4179-869e-e9ffe5fb0945\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0004bbf0-5099-4179-869e-e9ffe5fb0945\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1598 - Developer\ + \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1598\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/361a77f6-0f9c-4748-8eec-bc13aaaa2455\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"361a77f6-0f9c-4748-8eec-bc13aaaa2455\"\ - },{\"properties\":{\"displayName\":\"Deploy Advanced Threat Protection on\ - \ Storage Accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy enables Advanced Threat Protection on Storage Accounts.\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Storage\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/advancedThreatProtectionSettings\",\"name\":\"current\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/advancedThreatProtectionSettings/isEnabled\"\ - ,\"equals\":\"true\"},\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"storageAccountName\":{\"\ - type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-01-01\",\"type\"\ - :\"Microsoft.Storage/storageAccounts/providers/advancedThreatProtectionSettings\"\ - ,\"name\":\"[concat(parameters('storageAccountName'), '/Microsoft.Security/current')]\"\ - ,\"properties\":{\"isEnabled\":true}}]},\"parameters\":{\"storageAccountName\"\ - :{\"value\":\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/361c2074-3595-4e5d-8cab-4f21dffc835c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"361c2074-3595-4e5d-8cab-4f21dffc835c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1313 - Identifier\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1313\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ae7e1f5e-2d63-4b38-91ef-bce14151cce3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ae7e1f5e-2d63-4b38-91ef-bce14151cce3\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1600 - Developer\ + \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1600\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36220f5b-79a1-4cdb-8c74-2d2449f9a510\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36220f5b-79a1-4cdb-8c74-2d2449f9a510\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1630 - Boundary\ - \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1630\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c53f3123-d233-44a7-930b-f40d3bfeb7d6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c53f3123-d233-44a7-930b-f40d3bfeb7d6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1601 - Developer\ + \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1601\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3643717a-3897-4bfd-8530-c7c96b26b2a0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3643717a-3897-4bfd-8530-c7c96b26b2a0\"\ - },{\"properties\":{\"displayName\":\"Automation account variables should be\ - \ encrypted\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"It is important to enable encryption of Automation account variable assets\ - \ when storing sensitive data\",\"metadata\":{\"version\":\"1.1.0\",\"category\"\ - :\"Automation\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"The effect determines what\ - \ happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Automation/automationAccounts/variables\"\ - },{\"field\":\"Microsoft.Automation/automationAccounts/variables/isEncrypted\"\ - ,\"notEquals\":\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3657f5a0-770e-44a3-b44e-9431ba1e9735\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3657f5a0-770e-44a3-b44e-9431ba1e9735\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1339 - Authenticator\ - \ Management | Protection Of Authenticators\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1339\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0ee79a0c-addf-4ce9-9b3c-d9576ed5e20e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0ee79a0c-addf-4ce9-9b3c-d9576ed5e20e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1604 - Developer\ + \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1604\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/367ae386-db7f-4167-b672-984ff86277c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"367ae386-db7f-4167-b672-984ff86277c0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1685 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1685\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44dbba23-0b61-478e-89c7-b3084667782f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44dbba23-0b61-478e-89c7-b3084667782f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1602 - Developer\ + \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1602\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36b0ef30-366f-4b1b-8652-a3511df11f53\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36b0ef30-366f-4b1b-8652-a3511df11f53\"\ - },{\"properties\":{\"displayName\":\"Deploy Threat Detection on SQL servers\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ ensures that Threat Detection is enabled on SQL Servers.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\"\ - :{\"effect\":\"DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"name\":\"Default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/securityAlertPolicies.state\"\ - ,\"equals\":\"Enabled\"},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"serverName\":{\"type\":\"\ - string\"}},\"variables\":{},\"resources\":[{\"name\":\"[concat(parameters('serverName'),\ - \ '/Default')]\",\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"apiVersion\":\"2017-03-01-preview\",\"properties\":{\"state\":\"Enabled\"\ - ,\"emailAccountAdmins\":true}}]},\"parameters\":{\"serverName\":{\"value\"\ - :\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36d49e87-48c4-4f2e-beed-ba4ed02b71f5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36d49e87-48c4-4f2e-beed-ba4ed02b71f5\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Network Security'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Network Security'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ Security: Configure encryption types allowed for Kerberos\",\"description\"\ - :\"Specifies the encryption types that Kerberos is allowed to use.\"},\"defaultValue\"\ - :\"2147483644\"},\"NetworkSecurityLANManagerAuthenticationLevel\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network security:\ - \ LAN Manager authentication level\",\"description\":\"Specify which challenge-response\ - \ authentication protocol is used for network logons. This choice affects\ - \ the level of authentication protocol used by clients, the level of session\ - \ security negotiated, and the level of authentication accepted by servers.\"\ - },\"defaultValue\":\"5\"},\"NetworkSecurityLDAPClientSigningRequirements\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ security: LDAP client signing requirements\",\"description\":\"Specify the\ - \ level of data signing that is requested on behalf of clients that issue\ - \ LDAP BIND requests.\"},\"defaultValue\":\"1\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ security: Minimum session security for NTLM SSP based (including secure\ - \ RPC) clients\",\"description\":\"Specifies which behaviors are allowed by\ - \ clients for applications using the NTLM Security Support Provider (SSP).\ - \ The SSP Interface (SSPI) is used by applications that need authentication\ - \ services. See https://docs.microsoft.com/en-us/windows/security/threat-protection/security-policy-settings/network-security-minimum-session-security-for-ntlm-ssp-based-including-secure-rpc-servers\ - \ for more information.\"},\"defaultValue\":\"537395200\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ security: Minimum session security for NTLM SSP based (including secure\ - \ RPC) servers\",\"description\":\"Specifies which behaviors are allowed by\ - \ servers for applications using the NTLM Security Support Provider (SSP).\ - \ The SSP Interface (SSPI) is used by applications that need authentication\ - \ services.\"},\"defaultValue\":\"537395200\"}},\"policyRule\":{\"if\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsNetworkSecurity\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Network Security: Configure encryption types\ - \ allowed for Kerberos;ExpectedValue', '=', parameters('NetworkSecurityConfigureEncryptionTypesAllowedForKerberos'),\ - \ ',', 'Network security: LAN Manager authentication level;ExpectedValue',\ - \ '=', parameters('NetworkSecurityLANManagerAuthenticationLevel'), ',', 'Network\ - \ security: LDAP client signing requirements;ExpectedValue', '=', parameters('NetworkSecurityLDAPClientSigningRequirements'),\ - \ ',', 'Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) clients;ExpectedValue', '=', parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients'),\ - \ ',', 'Network security: Minimum session security for NTLM SSP based (including\ - \ secure RPC) servers;ExpectedValue', '=', parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsNetworkSecurity\"},\"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos\"\ - :{\"value\":\"[parameters('NetworkSecurityConfigureEncryptionTypesAllowedForKerberos')]\"\ - },\"NetworkSecurityLANManagerAuthenticationLevel\":{\"value\":\"[parameters('NetworkSecurityLANManagerAuthenticationLevel')]\"\ - },\"NetworkSecurityLDAPClientSigningRequirements\":{\"value\":\"[parameters('NetworkSecurityLDAPClientSigningRequirements')]\"\ - },\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients\"\ - :{\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients')]\"\ - },\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers\"\ - :{\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"NetworkSecurityConfigureEncryptionTypesAllowedForKerberos\"\ - :{\"type\":\"string\"},\"NetworkSecurityLANManagerAuthenticationLevel\":{\"\ - type\":\"string\"},\"NetworkSecurityLDAPClientSigningRequirements\":{\"type\"\ - :\"string\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients\"\ - :{\"type\":\"string\"},\"NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Network Security:\ - \ Configure encryption types allowed for Kerberos;ExpectedValue\",\"value\"\ - :\"[parameters('NetworkSecurityConfigureEncryptionTypesAllowedForKerberos')]\"\ - },{\"name\":\"Network security: LAN Manager authentication level;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkSecurityLANManagerAuthenticationLevel')]\"\ - },{\"name\":\"Network security: LDAP client signing requirements;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkSecurityLDAPClientSigningRequirements')]\"\ - },{\"name\":\"Network security: Minimum session security for NTLM SSP based\ - \ (including secure RPC) clients;ExpectedValue\",\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients')]\"\ - },{\"name\":\"Network security: Minimum session security for NTLM SSP based\ - \ (including secure RPC) servers;ExpectedValue\",\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Network Security:\ - \ Configure encryption types allowed for Kerberos;ExpectedValue\",\"value\"\ - :\"[parameters('NetworkSecurityConfigureEncryptionTypesAllowedForKerberos')]\"\ - },{\"name\":\"Network security: LAN Manager authentication level;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkSecurityLANManagerAuthenticationLevel')]\"\ - },{\"name\":\"Network security: LDAP client signing requirements;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkSecurityLDAPClientSigningRequirements')]\"\ - },{\"name\":\"Network security: Minimum session security for NTLM SSP based\ - \ (including secure RPC) clients;ExpectedValue\",\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCClients')]\"\ - },{\"name\":\"Network security: Minimum session security for NTLM SSP based\ - \ (including secure RPC) servers;ExpectedValue\",\"value\":\"[parameters('NetworkSecurityMinimumSessionSecurityForNTLMSSPBasedIncludingSecureRPCServers')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36e17963-7202-494a-80c3-f508211c826b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36e17963-7202-494a-80c3-f508211c826b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1557 - Vulnerability\ - \ Scanning | Review Historic Audit Logs\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1557\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ddae2e97-a449-499f-a1c8-aea4a7e52ec9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ddae2e97-a449-499f-a1c8-aea4a7e52ec9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1605 - Developer\ + \ Security Testing And Evaluation | Static Code Analysis\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1605\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36fbe499-f2f2-41b6-880e-52d7ea1d94a5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36fbe499-f2f2-41b6-880e-52d7ea1d94a5\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Interactive Logon'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Interactive Logon'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsInteractiveLogon\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsInteractiveLogon\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3750712b-43d0-478e-9966-d2c26f6141b9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3750712b-43d0-478e-9966-d2c26f6141b9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1624 - Boundary\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1624\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/37d079e3-d6aa-4263-a069-dd7ac6dd9684\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"37d079e3-d6aa-4263-a069-dd7ac6dd9684\"\ - },{\"properties\":{\"displayName\":\"Storage accounts should be migrated to\ - \ new Azure Resource Manager resources\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Use new Azure Resource Manager for your storage\ - \ accounts to provide security enhancements such as: stronger access control\ - \ (RBAC), better auditing, Azure Resource Manager based deployment and governance,\ - \ access to managed identities, access to key vault for secrets, Azure AD-based\ - \ authentication and support for tags and resource groups for easier security\ - \ management\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Storage\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"The effect determines what happens when the\ - \ policy rule is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\"\ - ,\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"in\":[\"Microsoft.ClassicStorage/storageAccounts\"\ - ,\"Microsoft.Storage/StorageAccounts\"]},{\"value\":\"[field('type')]\",\"\ - equals\":\"Microsoft.ClassicStorage/storageAccounts\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/37e0d2fe-28a5-43d6-a273-67d37d1f5606\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"37e0d2fe-28a5-43d6-a273-67d37d1f5606\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1335 - Authenticator\ - \ Management | Pki-Based Authentication\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Identification and\ - \ Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1335\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0062eb8b-dc75-4718-8ea5-9bb4a9606655\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0062eb8b-dc75-4718-8ea5-9bb4a9606655\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1603 - Developer\ + \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1603\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/382016f3-d4ba-4e15-9716-55077ec4dc2a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"382016f3-d4ba-4e15-9716-55077ec4dc2a\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in IoT Hub should be\ - \ enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"Internet of Things\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Devices/IotHubs\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"not\":{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"}},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/383856f8-de7f-44a2-81fc-e5135b5c2aa4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"383856f8-de7f-44a2-81fc-e5135b5c2aa4\"\ - },{\"properties\":{\"displayName\":\"Deploy the Windows Guest Configuration\ - \ extension to enable Guest Configuration assignments on Windows VMs\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ deploys the Windows Guest Configuration extension to Windows virtual machines\ - \ hosted in Azure that are supported by Guest Configuration. The Windows Guest\ - \ Configuration extension is a prerequisite for all Windows Guest Configuration\ - \ assignments and must deployed to machines before using any Windows Guest\ - \ Configuration policy definition. For more information on Guest Configuration,\ - \ visit https://aka.ms/gcpol.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\"},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzurePolicyforWindows\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.GuestConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"ConfigurationforWindows\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/385f5831-96d4-41db-9a3c-cd3af78aaae6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"385f5831-96d4-41db-9a3c-cd3af78aaae6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1081 - Information\ - \ Sharing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2b909c26-162f-47ce-8e15-0c1f55632eac\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2b909c26-162f-47ce-8e15-0c1f55632eac\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1606 - Developer\ + \ Security Testing And Evaluation | Threat And Vulnerability Analyses\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this System and Services Acquisition control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1081\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1606\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3867f2a9-23bb-4729-851f-c3ad98580caf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3867f2a9-23bb-4729-851f-c3ad98580caf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1522 - Personnel\ - \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1522\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/baa8a9a4-5bbe-4c72-98f6-a3a47ae2b1ca\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"baa8a9a4-5bbe-4c72-98f6-a3a47ae2b1ca\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1607 - Developer\ + \ Security Testing And Evaluation | Dynamic Code Analysis\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1607\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/38b470cc-f939-4a15-80e0-9f0c74f2e2c9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"38b470cc-f939-4a15-80e0-9f0c74f2e2c9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1416 - Nonlocal\ - \ Maintenance | Document Nonlocal Maintenance\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/976a74cf-b192-4d35-8cab-2068f272addb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"976a74cf-b192-4d35-8cab-2068f272addb\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1608 - Supply\ + \ Chain Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1608\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b73b7b3b-677c-4a2a-b949-ad4dc4acd89f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b73b7b3b-677c-4a2a-b949-ad4dc4acd89f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1609 - Development\ + \ Process, Standards, And Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1416\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1609\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/38dfd8a3-5290-4099-88b7-4081f4c4d8ae\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"38dfd8a3-5290-4099-88b7-4081f4c4d8ae\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1397 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1397\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e93fa71-42ac-41a7-b177-efbfdc53c69f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e93fa71-42ac-41a7-b177-efbfdc53c69f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1610 - Development\ + \ Process, Standards, And Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Services Acquisition\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1610\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/391af4ab-1117-46b9-b2c7-78bbd5cd995b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"391af4ab-1117-46b9-b2c7-78bbd5cd995b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1556 - Vulnerability\ - \ Scanning | Automated Trend Analyses\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1556\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9f3fb54-4222-46a1-a308-4874061f8491\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9f3fb54-4222-46a1-a308-4874061f8491\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1612 - Developer\ + \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1612\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/391ff8b3-afed-405e-9f7d-ef2f8168d5da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"391ff8b3-afed-405e-9f7d-ef2f8168d5da\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Advanced data security\ - \ settings for SQL Managed Instance should contain an email address for security\ - \ alerts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Ensure that an email address is provided for the 'Send alerts to' field\ - \ in the advanced data security settings. This email address receives alert\ - \ notifications when anomalous activities are detected on SQL Managed Instance.\"\ - ,\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\":\"SQL\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"\ - equals\":\"Microsoft.Sql/managedInstances\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/managedInstances/securityAlertPolicies\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAddresses[*]\"\ - ,\"notEquals\":\"\"},{\"field\":\"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAddresses[*]\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3965c43d-b5f4-482e-b74a-d89ee0e0b3a8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3965c43d-b5f4-482e-b74a-d89ee0e0b3a8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1232 - Configuration\ - \ Management Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1232\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2037b3d-8b04-4171-8610-e6d4f1d08db5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2037b3d-8b04-4171-8610-e6d4f1d08db5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1613 - Developer\ + \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1613\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/396ba986-eac1-4d6d-85c4-d3fda6b78272\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"396ba986-eac1-4d6d-85c4-d3fda6b78272\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1246 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1246\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fe2ad78b-8748-4bff-a924-f74dfca93f30\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fe2ad78b-8748-4bff-a924-f74dfca93f30\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1611 - Developer-Provided\ + \ Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Services Acquisition control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1611\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fdda8a0c-ac32-43f6-b2f4-7dc1df03f43f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fdda8a0c-ac32-43f6-b2f4-7dc1df03f43f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1615 - System\ + \ And Communications Protection Policy And Procedures\",\"policyType\":\"\ + Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1615\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/398eb61e-8111-40d5-a0c9-003df28f1753\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"398eb61e-8111-40d5-a0c9-003df28f1753\"\ - },{\"properties\":{\"displayName\":\"FTPS only should be required in your\ - \ Function App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Enable FTPS enforcement for enhanced security\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"\ - field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/ftpsState\",\"\ - in\":[\"FtpsOnly\",\"Disabled\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/399b2637-a50f-4f95-96f8-3a145476eb15\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"399b2637-a50f-4f95-96f8-3a145476eb15\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1680 - Malicious\ - \ Code Protection | Central Management\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1680\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f35e02aa-0a55-49f8-8811-8abfa7e6f2c0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f35e02aa-0a55-49f8-8811-8abfa7e6f2c0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1614 - Developer\ + \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Services\ + \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1614\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/399cd6ee-0e18-41db-9dea-cde3bd712f38\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"399cd6ee-0e18-41db-9dea-cde3bd712f38\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1228 - Information\ - \ System Component Inventory | Accountability Information\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1228\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8154e3b3-cc52-40be-9407-7756581d71f6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8154e3b3-cc52-40be-9407-7756581d71f6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1616 - System\ + \ And Communications Protection Policy And Procedures\",\"policyType\":\"\ + Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1616\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/39c54140-5902-4079-8bb5-ad31936fe764\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"39c54140-5902-4079-8bb5-ad31936fe764\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1039 - Least\ - \ Privilege | Review Of User Privileges\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2006457a-48b3-4f7b-8d2e-1532287f9929\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2006457a-48b3-4f7b-8d2e-1532287f9929\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1617 - Application\ + \ Partitioning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1039\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1617\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3a7b9de4-a8a2-4672-914d-c5f6752aa7f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3a7b9de4-a8a2-4672-914d-c5f6752aa7f9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1648 - Collaborative\ - \ Computing Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a631d8f5-eb81-4f9d-9ee1-74431371e4a3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a631d8f5-eb81-4f9d-9ee1-74431371e4a3\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1618 - Security\ + \ Function Isolation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this System and Communications Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1648\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1618\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3a9eb14b-495a-4ebb-933c-ce4ef5264e32\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3a9eb14b-495a-4ebb-933c-ce4ef5264e32\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Administrative Templates - Control Panel'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Administrative Templates - Control\ - \ Panel' for input personalization and prevention of enabling lock screens.\ - \ This policy requires that the Guest Configuration prerequisites have been\ - \ deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_AdministrativeTemplatesControlPanel\",\"version\"\ - :\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Include Arc connected servers\",\"description\"\ - :\"By selecting this option, you agree to be charged monthly per Arc connected\ - \ machine.\"},\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_AdministrativeTemplatesControlPanel\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3aa2661b-02d7-4ba6-99bc-dc36b10489fd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3aa2661b-02d7-4ba6-99bc-dc36b10489fd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1315 - Identifier\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1315\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f52f89aa-4489-4ec4-950e-8c96a036baa9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f52f89aa-4489-4ec4-950e-8c96a036baa9\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1619 - Information\ + \ In Shared Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Communications Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1619\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3aa87116-f1a1-4edb-bfbf-14e036f8d454\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3aa87116-f1a1-4edb-bfbf-14e036f8d454\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Pod Security Policies should\ - \ be defined on Kubernetes Services\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Define Pod Security Policies to reduce the attack\ - \ vector by removing unnecessary application privileges. It is recommended\ - \ to configure Pod Security Policies to only allow pods to access the resources\ - \ which they have permissions to access.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Disabled\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.ContainerService/managedClusters/enablePodSecurityPolicy\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ContainerService/managedClusters/enablePodSecurityPolicy\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3abeb944-26af-43ee-b83d-32aaf060fb94\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3abeb944-26af-43ee-b83d-32aaf060fb94\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1548 - Vulnerability\ - \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1548\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3afe6c78-6124-4d95-b85c-eb8c0c9539cb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3afe6c78-6124-4d95-b85c-eb8c0c9539cb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1266 - Contingency\ - \ Plan Testing | Alternate Processing Site\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1266\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c722e569-cb52-45f3-a643-836547d016e1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c722e569-cb52-45f3-a643-836547d016e1\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1620 - Denial\ + \ Of Service Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Communications Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1620\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3b4a3eb2-c25d-40bf-ad41-5094b6f59cee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3b4a3eb2-c25d-40bf-ad41-5094b6f59cee\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1003 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1003\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d17c826b-1dec-43e1-a984-7b71c446649c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d17c826b-1dec-43e1-a984-7b71c446649c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1590 - External\ + \ Information System Services | Risk Assessments / Organizational Approvals\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Services Acquisition control\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1590\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3b68b179-3704-4ff7-b51d-7d65374d165d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3b68b179-3704-4ff7-b51d-7d65374d165d\"\ - },{\"properties\":{\"displayName\":\"An activity log alert should exist for\ - \ specific Security operations\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"This policy audits specific Security operations with no\ - \ activity log alerts configured.\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"operationName\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Operation Name\",\"description\"\ - :\"Security Operation name for which activity log alert should exist\"},\"\ - allowedValues\":[\"Microsoft.Security/policies/write\",\"Microsoft.Security/securitySolutions/write\"\ - ,\"Microsoft.Security/securitySolutions/delete\"]}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - }]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/ActivityLogAlerts\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/enabled\",\"equals\":\"\ - true\"},{\"count\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]\"\ - ,\"where\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"Security\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"[parameters('operationName')]\"}]}]}},\"equals\":2},{\"not\"\ - :{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"}},{\"not\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3b980d31-7904-4bb7-8575-5665739a8052\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3b980d31-7904-4bb7-8575-5665739a8052\"\ - },{\"properties\":{\"displayName\":\"Deploy Dependency agent for Windows virtual\ - \ machine scale sets\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Deploy Dependency agent for Windows virtual machine scale\ - \ sets if the VM Image (OS) is in the list defined and the agent is not installed.\ - \ The list of OS images will be updated over time as support is updated. Note:\ - \ if your scale set upgradePolicy is set to Manual, you need to apply the\ - \ extension to the all virtual machines in the set by calling upgrade on them.\ - \ In CLI this would be az vmss update-instances.\",\"metadata\":{\"version\"\ - :\"1.3.0\",\"category\":\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Windows OS to add to scope\",\"description\"\ - :\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\"\ - ,\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"DependencyAgentWindows\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"}]},\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ - DependencyAgentWindows\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"vmExtensionType\":\"DependencyAgentWindows\",\"vmExtensionTypeHandlerVersion\"\ - :\"9.7\"},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"apiVersion\":\"2018-06-01\",\"location\":\"[parameters('location')]\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true}}],\"outputs\":{\"policy\":{\"type\":\"\ - string\",\"value\":\"[concat('Enabled extension for: ', parameters('vmName'))]\"\ - }}},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3be22e3b-d919-47aa-805e-8985dbeb0ad9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3be22e3b-d919-47aa-805e-8985dbeb0ad9\"\ - },{\"properties\":{\"displayName\":\"PostgreSQL server should use a virtual\ - \ network service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits PostgreSQL servers not configured to\ - \ use a virtual network service endpoint. For more details, visit https://aka.ms/postgresqlvnet.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforPostgreSQL/servers/virtualNetworkRules\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforPostgreSQL/servers/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3c14b034-bcb6-4905-94e7-5b8e98a47b65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3c14b034-bcb6-4905-94e7-5b8e98a47b65\"\ - },{\"properties\":{\"displayName\":\"Deploy Log Analytics agent for Windows\ - \ virtual machine scale sets\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploy Log Analytics agent for Windows virtual machine\ - \ scale sets if the VM Image (OS) is in the list defined and the agent is\ - \ not installed. The list of OS images will be updated over time as support\ - \ is updated. Note: if your scale set upgradePolicy is set to Manual, you\ - \ need to apply the extension to the all VMs in the set by calling upgrade\ - \ on them. In CLI this would be az vmss update-instances.\",\"metadata\":{\"\ - version\":\"1.1.0\",\"category\":\"Monitoring\"},\"parameters\":{\"logAnalytics\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\"\ - ,\"description\":\"Select Log Analytics workspace from dropdown list. If this\ - \ workspace is outside of the scope of the assignment you must manually grant\ - \ 'Log Analytics Contributor' permissions (or similar) to the policy assignment's\ - \ principal ID.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"\ - listOfImageIdToInclude\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Optional: List of VM images that have supported Windows OS to add to scope\"\ - ,\"description\":\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\"\ - ,\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"}]},\"deployment\":{\"\ - properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"variables\":{\"vmExtensionName\":\"MicrosoftMonitoringAgent\",\"vmExtensionPublisher\"\ - :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"MicrosoftMonitoringAgent\"\ - ,\"vmExtensionTypeHandlerVersion\":\"1.0\"},\"resources\":[{\"name\":\"[concat(parameters('vmName'),\ - \ '/', variables('vmExtensionName'))]\",\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"apiVersion\":\"2018-06-01\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'),\ - \ '2015-03-20').customerId]\",\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\"\ - :{\"workspaceKey\":\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ - }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for: ', parameters('vmName'))]\"}}},\"parameters\":{\"vmName\"\ - :{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/3c1b3629-c8f8-4bf6-862c-037cb9094038\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3c1b3629-c8f8-4bf6-862c-037cb9094038\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities in security configuration\ - \ on your virtual machine scale sets should be remediated\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Audit the OS vulnerabilities\ - \ on your virtual machine scale sets to protect them from attacks.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"8941d121-f740-35f6-952c-6561d2b38d36\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3c735d8a-a4ba-4a3a-b7cf-db7754cf57f4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3c735d8a-a4ba-4a3a-b7cf-db7754cf57f4\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf296b8c-f391-4ea4-9198-be3c9d39dd1f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf296b8c-f391-4ea4-9198-be3c9d39dd1f\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1621 - Resource\ \ Availability\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this System and Communications Protection control\"\ @@ -7220,551 +10092,134 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3cb9f731-744a-4691-a481-ca77b0411538\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3cb9f731-744a-4691-a481-ca77b0411538\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1521 - Personnel\ - \ Termination | Automated Notification\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Personnel Security\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1622 - Boundary\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1622\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ecf56554-164d-499a-8d00-206b07c27bed\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ecf56554-164d-499a-8d00-206b07c27bed\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1623 - Boundary\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1623\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/02ce1b22-412a-4528-8630-c42146f917ed\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"02ce1b22-412a-4528-8630-c42146f917ed\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1624 - Boundary\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1624\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/37d079e3-d6aa-4263-a069-dd7ac6dd9684\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"37d079e3-d6aa-4263-a069-dd7ac6dd9684\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1625 - Boundary\ + \ Protection | Access Points\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Communications Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1521\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1625\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3cbddf9c-a3aa-4330-a0f5-4c0c1f1862e5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3cbddf9c-a3aa-4330-a0f5-4c0c1f1862e5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1127 - Time\ - \ Stamps\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1127\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9b66a4d-70a1-4b47-8fa1-289cec68c605\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9b66a4d-70a1-4b47-8fa1-289cec68c605\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1626 - Boundary\ + \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1626\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e8f6bddd-6d67-439a-88d4-c5fe39a79341\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8f6bddd-6d67-439a-88d4-c5fe39a79341\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1627 - Boundary\ + \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1627\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd73310d-76fc-422d-bda4-3a077149f179\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd73310d-76fc-422d-bda4-3a077149f179\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1628 - Boundary\ + \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1628\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/67de62b4-a737-4781-8861-3baed3c35069\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"67de62b4-a737-4781-8861-3baed3c35069\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1629 - Boundary\ + \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1629\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c171b095-7756-41de-8644-a062a96043f2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c171b095-7756-41de-8644-a062a96043f2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1630 - Boundary\ + \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1630\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3643717a-3897-4bfd-8530-c7c96b26b2a0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3643717a-3897-4bfd-8530-c7c96b26b2a0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1632 - Boundary\ + \ Protection | Prevent Split Tunneling For Remote Devices\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1632\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3ce328db-aef3-48ed-9f81-2ab7cf839c66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3ce328db-aef3-48ed-9f81-2ab7cf839c66\"\ - },{\"properties\":{\"displayName\":\"Add system-assigned managed identity\ - \ to enable Guest Configuration assignments on virtual machines with no identities\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ adds a system-assigned managed identity to virtual machines hosted in Azure\ - \ that are supported by Guest Configuration but do not have any managed identities.\ - \ A system-assigned managed identity is a prerequisite for all Guest Configuration\ - \ assignments and must be added to machines before using any Guest Configuration\ - \ policy definitions. For more information on Guest Configuration, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"value\":\"[requestContext().apiVersion]\",\"greaterOrEquals\"\ - :\"2018-10-01\"},{\"anyOf\":[{\"field\":\"identity.type\",\"exists\":\"false\"\ - },{\"field\":\"identity.type\",\"equals\":\"None\"}]}]},\"then\":{\"effect\"\ - :\"modify\",\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"identity.type\"\ - ,\"value\":\"SystemAssigned\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3cf2ab00-13f1-4d0c-8971-2ac904541a7e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3cf2ab00-13f1-4d0c-8971-2ac904541a7e\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that have extra\ - \ accounts in the Administrators group\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the local Administrators group contains members that\ - \ are not listed in the policy parameter.\",\"metadata\":{\"category\":\"\ - Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AdministratorsGroupMembers\",\"version\"\ - :\"1.*\",\"configurationParameter\":{\"Members\":\"[LocalGroup]AdministratorsGroup;Members\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"Members\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Members\",\"description\"\ - :\"A semicolon-separated list of all the expected members of the Administrators\ - \ local group. Ex: Administrator; myUser1; myUser2\"},\"allowedValues\":[],\"\ - defaultValue\":\"Administrator\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembers\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;Members', '=',\ - \ parameters('Members')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3d2a3320-2a72-4c67-ac5f-caa40fbee2b2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3d2a3320-2a72-4c67-ac5f-caa40fbee2b2\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Search\ - \ Services to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Search Services to\ - \ stream to a regional Event Hub when any Search Services which is missing\ - \ this diagnostic settings is created or updated.\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ - :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"\ - },\"eventHubRuleId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Event Hub Authorization Rule Id\",\"description\":\"The Event Hub authorization\ - \ rule Id for Azure Diagnostics. The authorization rule needs to be at Event\ - \ Hub namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource\ - \ group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization\ - \ rule}\",\"strongType\":\"Microsoft.EventHub/Namespaces/AuthorizationRules\"\ - ,\"assignPermissions\":true}},\"eventHubLocation\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Event Hub Location\",\"description\":\"The location\ - \ the Event Hub resides in. Only Search Services in this location will be\ - \ linked to this Event Hub.\",\"strongType\":\"location\"},\"defaultValue\"\ - :\"\"},\"metricsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Enable metrics\",\"description\":\"Whether to enable metrics stream to\ - \ the Event Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"\ - defaultValue\":\"False\"},\"logsEnabled\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Enable logs\",\"description\":\"Whether to enable logs\ - \ stream to the Event Hub - True or False\"},\"allowedValues\":[\"True\"\ - ,\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Search/searchServices\"},{\"\ - anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\"},{\"\ - field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"[parameters('profileName')]\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ - :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Search/searchServices/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"OperationLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3d5da587-71bd-41f5-ac95-dd3330c2d58d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3d5da587-71bd-41f5-ac95-dd3330c2d58d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Devices'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Devices'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsDevices\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3d7b154e-2700-4c8c-9e46-cb65ac1578c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3d7b154e-2700-4c8c-9e46-cb65ac1578c2\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy default Log Analytics\ - \ Agent for Ubuntu VMs\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy deploys the Log Analytics Agent on Ubuntu VMs,\ - \ and connects to the selected Log Analytics workspace\",\"metadata\":{\"\ - version\":\"1.0.0-deprecated\",\"category\":\"Compute\",\"deprecated\":true},\"\ - parameters\":{\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Log Analytics workspace\",\"description\":\"Select Log Analytics\ - \ workspace from dropdown list. If this workspace is outside of the scope\ - \ of the assignment you must manually grant 'Log Analytics Contributor' permissions\ - \ (or similar) to the policy assignment's principal ID.\",\"strongType\":\"\ - omsWorkspace\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - equals\":\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"in\"\ - :[\"18.04-LTS\",\"16.04-LTS\",\"16.04.0-LTS\",\"14.04.2-LTS\",\"12.04.5-LTS\"\ - ]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"}]},\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"resources\":[{\"name\":\"[concat(parameters('vmName'),'/omsPolicy')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"apiVersion\":\"2017-12-01\",\"properties\":{\"\ - publisher\":\"Microsoft.EnterpriseCloud.Monitoring\",\"type\":\"OmsAgentForLinux\"\ - ,\"typeHandlerVersion\":\"1.4\",\"autoUpgradeMinorVersion\":true,\"settings\"\ - :{\"workspaceId\":\"[reference(parameters('logAnalytics'), '2015-03-20').customerId]\"\ - },\"protectedSettings\":{\"workspaceKey\":\"[listKeys(parameters('logAnalytics'),\ - \ '2015-03-20').primarySharedKey]\"}}}],\"outputs\":{\"policy\":{\"type\"\ - :\"string\",\"value\":\"[concat('Enabled monitoring for Linux VM', ': ', parameters('vmName'))]\"\ - }}},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"},\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3d8640fc-63f6-4734-8dcb-cfd3d8c78f38\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3d8640fc-63f6-4734-8dcb-cfd3d8c78f38\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1385 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1385\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3e495e65-8663-49ca-9b38-9f45e800bc58\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3e495e65-8663-49ca-9b38-9f45e800bc58\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not have\ - \ the specified Windows PowerShell modules installed\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if a module isn't available in a location specified\ - \ by the environment variable PSModulePath.\",\"metadata\":{\"category\":\"\ - Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"WindowsPowerShellModules\",\"version\"\ - :\"1.*\",\"configurationParameter\":{\"Modules\":\"[PowerShellModules]PowerShellModules1;Modules\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"Modules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"PowerShell Modules\"\ - ,\"description\":\"A semicolon-separated list of the names of the PowerShell\ - \ modules that should be installed. You may also specify a specific version\ - \ of a module that should be installed by including a comma after the module\ - \ name, followed by the desired version. Example: PSDscResources; SqlServerDsc,\ - \ 12.0.0.0; ComputerManagementDsc, 6.1.0.0\"}},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - WindowsPowerShellModules\",\"existenceCondition\":{\"allOf\":[{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[PowerShellModules]PowerShellModules1;Modules',\ - \ '=', parameters('Modules')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3e4e2bd5-15a2-4628-b3e1-58977e9793f3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3e4e2bd5-15a2-4628-b3e1-58977e9793f3\"\ - },{\"properties\":{\"displayName\":\"Azure Monitor solution 'Security and\ - \ Audit' must be deployed\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"This policy ensures that Security and Audit is deployed.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.OperationsManagement/solutions\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.OperationsManagement/solutions/provisioningState\"\ - ,\"equals\":\"Succeeded\"},{\"field\":\"name\",\"like\":\"Security(*)\"}]}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/3e596b57-105f-48a6-be97-03e9243bad6e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3e596b57-105f-48a6-be97-03e9243bad6e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1160 - Security\ - \ Authorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1160\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3e797ca6-2aa8-4333-b335-7036f1110c05\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3e797ca6-2aa8-4333-b335-7036f1110c05\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1545 - Risk\ - \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ce9073a-77fa-48f0-96b1-87aa8e6091c2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ce9073a-77fa-48f0-96b1-87aa8e6091c2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1633 - Boundary\ + \ Protection | Route Traffic To Authenticated Proxy Servers\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1545\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1633\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3f4b171a-a56b-4328-8112-32cf7f947ee1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3f4b171a-a56b-4328-8112-32cf7f947ee1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1179 - Baseline\ - \ Configuration | Reviews And Updates\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1179\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/07557aa0-e02f-4460-9a81-8ecd2fed601a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"07557aa0-e02f-4460-9a81-8ecd2fed601a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1634 - Boundary\ + \ Protection | Prevent Unauthorized Exfiltration\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1634\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3f9ce557-c8ab-4e6c-bb2c-9b8ed002c46c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3f9ce557-c8ab-4e6c-bb2c-9b8ed002c46c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit API Applications\ - \ that are not using latest supported PHP Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported PHP version for\ - \ the latest security classes. Using older classes and types can make your\ - \ application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestPHP\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3fe37002-5d00-4b37-a301-da09e3a0ca66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3fe37002-5d00-4b37-a301-da09e3a0ca66\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Network Access'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Network Access'\ - \ for including access for anonymous users, local accounts, and remote access\ - \ to the registry. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsNetworkAccess\",\"version\":\"1.*\"\ - ,\"configurationParameter\":{\"NetworkAccessRemotelyAccessibleRegistryPaths\"\ - :\"Network access: Remotely accessible registry paths;ExpectedValue\",\"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths\"\ - :\"Network access: Remotely accessible registry paths and sub-paths;ExpectedValue\"\ - ,\"NetworkAccessSharesThatCanBeAccessedAnonymously\":\"Network access: Shares\ - \ that can be accessed anonymously;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"NetworkAccessRemotelyAccessibleRegistryPaths\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Network access: Remotely\ - \ accessible registry paths\",\"description\":\"Specifies which registry paths\ - \ will be accessible over the network, regardless of the users or groups listed\ - \ in the access control list (ACL) of the `winreg` registry key.\"},\"defaultValue\"\ - :\"System\\\\CurrentControlSet\\\\Control\\\\ProductOptions|#|System\\\\CurrentControlSet\\\ - \\Control\\\\Server Applications|#|Software\\\\Microsoft\\\\Windows NT\\\\\ - CurrentVersion\"},\"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Network access: Remotely\ - \ accessible registry paths and sub-paths\",\"description\":\"Specifies which\ - \ registry paths and sub-paths will be accessible over the network, regardless\ - \ of the users or groups listed in the access control list (ACL) of the `winreg`\ - \ registry key.\"},\"defaultValue\":\"System\\\\CurrentControlSet\\\\Control\\\ - \\Print\\\\Printers|#|System\\\\CurrentControlSet\\\\Services\\\\Eventlog|#|Software\\\ - \\Microsoft\\\\OLAP Server|#|Software\\\\Microsoft\\\\Windows NT\\\\CurrentVersion\\\ - \\Print|#|Software\\\\Microsoft\\\\Windows NT\\\\CurrentVersion\\\\Windows|#|System\\\ - \\CurrentControlSet\\\\Control\\\\ContentIndex|#|System\\\\CurrentControlSet\\\ - \\Control\\\\Terminal Server|#|System\\\\CurrentControlSet\\\\Control\\\\\ - Terminal Server\\\\UserConfig|#|System\\\\CurrentControlSet\\\\Control\\\\\ - Terminal Server\\\\DefaultUserConfiguration|#|Software\\\\Microsoft\\\\Windows\ - \ NT\\\\CurrentVersion\\\\Perflib|#|System\\\\CurrentControlSet\\\\Services\\\ - \\SysmonLog\"},\"NetworkAccessSharesThatCanBeAccessedAnonymously\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Network access: Shares that can\ - \ be accessed anonymously\",\"description\":\"Specifies which network shares\ - \ can be accessed by anonymous users. The default configuration for this policy\ - \ setting has little effect because all users have to be authenticated before\ - \ they can access shared resources on the server.\"},\"defaultValue\":\"0\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsNetworkAccess\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Network access: Remotely accessible registry\ - \ paths;ExpectedValue', '=', parameters('NetworkAccessRemotelyAccessibleRegistryPaths'),\ - \ ',', 'Network access: Remotely accessible registry paths and sub-paths;ExpectedValue',\ - \ '=', parameters('NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths'),\ - \ ',', 'Network access: Shares that can be accessed anonymously;ExpectedValue',\ - \ '=', parameters('NetworkAccessSharesThatCanBeAccessedAnonymously')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3ff60f98-7fa4-410a-9f7f-0b00f5afdbdd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3ff60f98-7fa4-410a-9f7f-0b00f5afdbdd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1561 - Allocation\ - \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1561\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/292a7c44-37fa-4c68-af7c-9d836955ded2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"292a7c44-37fa-4c68-af7c-9d836955ded2\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1631 - Boundary\ + \ Protection | Deny By Default / Allow By Exception\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1631\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40364c3f-c331-4e29-b1e3-2fbe998ba2f5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40364c3f-c331-4e29-b1e3-2fbe998ba2f5\"\ - },{\"properties\":{\"displayName\":\"Secure transfer to storage accounts should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit requirement of Secure transfer in your storage account. Secure transfer\ - \ is an option that forces your storage account to accept requests only from\ - \ secure connections (HTTPS). Use of HTTPS ensures authentication between\ - \ the server and the service and protects data in transit from network layer\ - \ attacks such as man-in-the-middle, eavesdropping, and session-hijacking\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Storage\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"The effect determines what happens when the policy rule\ - \ is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"},{\"anyOf\":[{\"\ - allOf\":[{\"value\":\"[requestContext().apiVersion]\",\"less\":\"2019-04-01\"\ - },{\"field\":\"Microsoft.Storage/storageAccounts/supportsHttpsTrafficOnly\"\ - ,\"exists\":\"false\"}]},{\"field\":\"Microsoft.Storage/storageAccounts/supportsHttpsTrafficOnly\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/404c3081-a854-4457-ae30-26a93ef643f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"404c3081-a854-4457-ae30-26a93ef643f9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1100 - Audit\ - \ And Accountability Policy And Procedures\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1100\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/74ae9b8e-e7bb-4c9c-992f-c535282f7a2c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74ae9b8e-e7bb-4c9c-992f-c535282f7a2c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1635 - Boundary\ + \ Protection | Host-Based Protection\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Communications\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1635\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4057863c-ca7d-47eb-b1e0-503580cba8a4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4057863c-ca7d-47eb-b1e0-503580cba8a4\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/87551b5d-1deb-4d0f-86cc-9dc14cb4bf7e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"87551b5d-1deb-4d0f-86cc-9dc14cb4bf7e\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1637 - Boundary\ \ Protection | Fail Secure\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ ,\"description\":\"Microsoft implements this System and Communications Protection\ @@ -7774,978 +10229,302 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4075bedc-c62a-4635-bede-a01be89807f3\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4075bedc-c62a-4635-bede-a01be89807f3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Administrative Templates - System'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Administrative Templates\ - \ - System'. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AlwaysUseClassicLogon\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Always use classic logon\",\"description\"\ - :\"Specifies whether to force the user to log on to the computer using the\ - \ classic logon screen. This setting only works when the computer is not on\ - \ a domain.\"},\"defaultValue\":\"0\"},\"BootStartDriverInitializationPolicy\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Boot-Start\ - \ Driver Initialization Policy\",\"description\":\"Specifies which boot-start\ - \ drivers are initialized based on a classification determined by an Early\ - \ Launch Antimalware boot-start driver.\"},\"defaultValue\":\"3\"},\"EnableWindowsNTPClient\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Enable\ - \ Windows NTP Client\",\"description\":\"Specifies whether the Windows NTP\ - \ Client is enabled. Enabling the Windows NTP Client allows your computer\ - \ to synchronize its computer clock with other NTP servers.\"},\"defaultValue\"\ - :\"1\"},\"TurnOnConveniencePINSignin\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Deprecated]: Turn on convenience PIN sign-in\",\"description\"\ - :\"Specifies whether a domain user can sign in using a convenience PIN.\"\ - },\"defaultValue\":\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesSystem\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Always use classic logon;ExpectedValue', '=',\ - \ parameters('AlwaysUseClassicLogon'), ',', 'Boot-Start Driver Initialization\ - \ Policy;ExpectedValue', '=', parameters('BootStartDriverInitializationPolicy'),\ - \ ',', 'Enable Windows NTP Client;ExpectedValue', '=', parameters('EnableWindowsNTPClient'),\ - \ ',', 'Turn on convenience PIN sign-in;ExpectedValue', '=', parameters('TurnOnConveniencePINSignin')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_AdministrativeTemplatesSystem\"},\"AlwaysUseClassicLogon\"\ - :{\"value\":\"[parameters('AlwaysUseClassicLogon')]\"},\"BootStartDriverInitializationPolicy\"\ - :{\"value\":\"[parameters('BootStartDriverInitializationPolicy')]\"},\"EnableWindowsNTPClient\"\ - :{\"value\":\"[parameters('EnableWindowsNTPClient')]\"},\"TurnOnConveniencePINSignin\"\ - :{\"value\":\"[parameters('TurnOnConveniencePINSignin')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AlwaysUseClassicLogon\":{\"type\":\"string\"},\"\ - BootStartDriverInitializationPolicy\":{\"type\":\"string\"},\"EnableWindowsNTPClient\"\ - :{\"type\":\"string\"},\"TurnOnConveniencePINSignin\":{\"type\":\"string\"\ - }},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Always use classic\ - \ logon;ExpectedValue\",\"value\":\"[parameters('AlwaysUseClassicLogon')]\"\ - },{\"name\":\"Boot-Start Driver Initialization Policy;ExpectedValue\",\"value\"\ - :\"[parameters('BootStartDriverInitializationPolicy')]\"},{\"name\":\"Enable\ - \ Windows NTP Client;ExpectedValue\",\"value\":\"[parameters('EnableWindowsNTPClient')]\"\ - },{\"name\":\"Turn on convenience PIN sign-in;ExpectedValue\",\"value\":\"\ - [parameters('TurnOnConveniencePINSignin')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Always use classic\ - \ logon;ExpectedValue\",\"value\":\"[parameters('AlwaysUseClassicLogon')]\"\ - },{\"name\":\"Boot-Start Driver Initialization Policy;ExpectedValue\",\"value\"\ - :\"[parameters('BootStartDriverInitializationPolicy')]\"},{\"name\":\"Enable\ - \ Windows NTP Client;ExpectedValue\",\"value\":\"[parameters('EnableWindowsNTPClient')]\"\ - },{\"name\":\"Turn on convenience PIN sign-in;ExpectedValue\",\"value\":\"\ - [parameters('TurnOnConveniencePINSignin')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40917425-69db-4018-8dae-2a0556cef899\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40917425-69db-4018-8dae-2a0556cef899\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1202 - Access\ - \ Restrictions For Change\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Configuration Management control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1202\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40a2a83b-74f2-4c02-ae65-f460a5d2792a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40a2a83b-74f2-4c02-ae65-f460a5d2792a\"\ - },{\"properties\":{\"displayName\":\"Azure Machine Learning workspaces should\ - \ use private link\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Evaluate Azure Machine Learning workspaces that do not have at least one\ - \ approved private endpoint connection. Clients in a virtual network can securely\ - \ access resources that have private endpoint connections through private\ - \ links. For more information, visit: https://aka.ms/azureml-workspaces-privatelink.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Machine Learning\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.MachineLearningServices/workspaces\"\ - },{\"count\":{\"field\":\"Microsoft.MachineLearningServices/workspaces/privateEndpointConnections[*]\"\ - ,\"where\":{\"field\":\"Microsoft.MachineLearningServices/workspaces/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40cec1dd-a100-4920-b15b-3024fe8901ab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40cec1dd-a100-4920-b15b-3024fe8901ab\"\ - },{\"properties\":{\"displayName\":\"Inherit a tag from the subscription if\ - \ missing\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Adds the specified tag with its value from the containing subscription\ - \ when any resource missing this tag is created or updated. Existing resources\ - \ can be remediated by triggering a remediation task. If the tag exists with\ - \ a different value it will not be changed.\",\"metadata\":{\"category\":\"\ - Tags\",\"version\":\"1.0.0\"},\"parameters\":{\"tagName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Name of the\ - \ tag, such as 'environment'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"},{\"\ - value\":\"[subscription().tags[parameters('tagName')]]\",\"notEquals\":\"\"\ - }]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"add\",\"field\":\"[concat('tags[', parameters('tagName'),\ - \ ']')]\",\"value\":\"[subscription().tags[parameters('tagName')]]\"}]}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/40df99da-1232-49b1-a39a-6da8d878f469\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40df99da-1232-49b1-a39a-6da8d878f469\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1438 - Media\ - \ Sanitization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1438\"},\"policyRule\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1636 - Boundary\ + \ Protection | Isolation Of Security Tools / Mechanisms / Support Components\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Communications Protection control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1636\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/40fcc635-52a2-4dbc-9523-80a1f4aa1de6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40fcc635-52a2-4dbc-9523-80a1f4aa1de6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1365 - Incident\ - \ Handling | Continuity Of Operations\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1365\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7b694eed-7081-43c6-867c-41c76c961043\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7b694eed-7081-43c6-867c-41c76c961043\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1638 - Boundary\ + \ Protection | Dynamic Isolation / Segregation\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1638\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4116891d-72f7-46ee-911c-8056cc8dcbd5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4116891d-72f7-46ee-911c-8056cc8dcbd5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1022 - Account\ - \ Management | Shared / Group Account Credential Termination\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1022\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/49b99653-32cd-405d-a135-e7d60a9aae1f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"49b99653-32cd-405d-a135-e7d60a9aae1f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1641 - Transmission\ + \ Confidentiality And Integrity | Cryptographic Or Alternate Physical Protection\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Communications Protection control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1641\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/411f7e2d-9a0b-4627-a0b9-1700432db47d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"411f7e2d-9a0b-4627-a0b9-1700432db47d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1464 - Monitoring\ - \ Physical Access | Intrusion Alarms / Surveillance Equipment\",\"policyType\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d39d4f68-7346-4133-8841-15318a714a24\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d39d4f68-7346-4133-8841-15318a714a24\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1639 - Boundary\ + \ Protection | Isolation Of Information System Components\",\"policyType\"\ :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1464\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/41256567-1795-4684-b00b-a1308ce43cac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"41256567-1795-4684-b00b-a1308ce43cac\"\ - },{\"properties\":{\"displayName\":\"Azure Monitor should collect activity\ - \ logs from all regions\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"This policy audits the Azure Monitor log profile which does not export\ - \ activities from all Azure supported regions including global.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/logProfiles\",\"existenceCondition\":{\"allOf\":[{\"not\"\ - :{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\",\"notEquals\"\ - :\"australiacentral\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"australiacentral2\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"australiaeast\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"australiasoutheast\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"brazilsouth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"canadacentral\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"canadaeast\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"centralindia\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"centralus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"eastasia\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"eastus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"eastus2\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"francecentral\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"francesouth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"japaneast\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"japanwest\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"koreacentral\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"koreasouth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"northcentralus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"northeurope\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"southafricanorth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"southafricawest\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"southcentralus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"southindia\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"southeastasia\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"uaecentral\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"uaenorth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"uksouth\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"ukwest\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"westcentralus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"westeurope\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"westindia\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"westus\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"westus2\"}},{\"not\":{\"field\":\"Microsoft.Insights/logProfiles/locations[*]\"\ - ,\"notEquals\":\"global\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/41388f1c-2db0-4c25-95b2-35d7f5ccbfa9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"41388f1c-2db0-4c25-95b2-35d7f5ccbfa9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1263 - Contingency\ - \ Plan Testing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1263\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1639\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/41472613-3b05-49f6-8fe8-525af113ce17\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"41472613-3b05-49f6-8fe8-525af113ce17\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1096 - Role-Based\ - \ Security Training | Practical Exercises\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Awareness and Training\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1096\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/420c1477-aa43-49d0-bd7e-c4abdd9addff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"420c1477-aa43-49d0-bd7e-c4abdd9addff\"\ - },{\"properties\":{\"displayName\":\"Audit Windows VMs with a pending reboot\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Requires\ - \ that prerequisites are deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol. Machines are non-compliant if the machine is\ - \ pending reboot for any of the following reasons: component based servicing,\ - \ Windows Update, pending file rename, pending computer rename, configuration\ - \ manager pending reboot. Each detection has a unique registry path.\",\"\ - metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"WindowsPendingReboot\",\"version\":\"1.*\"}},\"parameters\":{\"\ - IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"}},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPendingReboot\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4221adbc-5c0f-474f-88b7-037a99e6114c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4221adbc-5c0f-474f-88b7-037a99e6114c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1260 - Contingency\ - \ Training | Simulated Events\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Contingency Planning control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/78e8e649-50f6-4fe3-99ac-fedc2e63b03f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"78e8e649-50f6-4fe3-99ac-fedc2e63b03f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1642 - Network\ + \ Disconnect\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1260\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1642\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/42254fc4-2738-4128-9613-72aaa4f0d9c3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"42254fc4-2738-4128-9613-72aaa4f0d9c3\"\ - },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ - \ use the specified mode for Azure Front Door Service\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Mandates the use of 'Detection'\ - \ or 'Prevention' mode to be active on all Web Application Firewall policies\ - \ for Azure Front Door Service.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ - defaultValue\":\"Audit\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Mode Requirement\",\"description\":\"Mode required for\ - \ all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"],\"\ - defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Network/frontdoorwebapplicationfirewallpolicies\"\ - },{\"field\":\"Microsoft.Network/frontdoorWebApplicationFirewallPolicies/policySettings.mode\"\ - ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/425bea59-a659-4cbb-8d31-34499bd030b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"425bea59-a659-4cbb-8d31-34499bd030b8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1694 - Information\ - \ System Monitoring | Analyze Communications Traffic Anomalies\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1694\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53397227-5ee3-4b23-9e5e-c8a767ce6928\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53397227-5ee3-4b23-9e5e-c8a767ce6928\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1643 - Cryptographic\ + \ Key Establishment And Management\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Communications\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1643\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/426c4ac9-ff17-49d0-acd7-a13c157081c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"426c4ac9-ff17-49d0-acd7-a13c157081c0\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Batch accounts should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Batch\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/428256e6-1fac-4f48-a757-df34c2b3336d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"428256e6-1fac-4f48-a757-df34c2b3336d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Detailed Tracking'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Detailed Tracking'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditProcessTermination\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Audit Process Termination\",\"description\"\ - :\"Specifies whether audit events are generated when a process has exited.\ - \ Recommended for monitoring termination of critical processes.\"},\"allowedValues\"\ - :[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\"\ - :\"No Auditing\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesDetailedTracking\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Process Termination;ExpectedValue', '=',\ - \ parameters('AuditProcessTermination')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SystemAuditPoliciesDetailedTracking\"\ - },\"AuditProcessTermination\":{\"value\":\"[parameters('AuditProcessTermination')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditProcessTermination\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Process\ - \ Termination;ExpectedValue\",\"value\":\"[parameters('AuditProcessTermination')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Process\ - \ Termination;ExpectedValue\",\"value\":\"[parameters('AuditProcessTermination')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/42a07bbf-ffcf-459a-b4b1-30ecd118a505\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"42a07bbf-ffcf-459a-b4b1-30ecd118a505\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1174 - Configuration\ - \ Management Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Configuration Management\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d8d492c-dd7a-46f7-a723-fa66a425b87c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d8d492c-dd7a-46f7-a723-fa66a425b87c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1640 - Transmission\ + \ Confidentiality And Integrity\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Communications Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1174\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1640\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/42a9a714-8fbb-43ac-b115-ea12d2bd652f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"42a9a714-8fbb-43ac-b115-ea12d2bd652f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1137 - Audit\ - \ Generation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1137\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4344df62-88ab-4637-b97b-bcaf2ec97e7c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4344df62-88ab-4637-b97b-bcaf2ec97e7c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1367 - Incident\ - \ Handling | Insider Threats - Specific Capabilities\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident\ - \ Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1367\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/05a289ce-6a20-4b75-a0f3-dc8601b6acd0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"05a289ce-6a20-4b75-a0f3-dc8601b6acd0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1644 - Cryptographic\ + \ Key Establishment And Management | Availability\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1644\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/435b2547-6374-4f87-b42d-6e8dbe6ae62a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"435b2547-6374-4f87-b42d-6e8dbe6ae62a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1552 - Vulnerability\ - \ Scanning | Update By Frequency / Prior To New Scan / When Identified\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Risk Assessment control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1552\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7211477-c970-446b-b4af-062f37461147\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7211477-c970-446b-b4af-062f37461147\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1645 - Cryptographic\ + \ Key Establishment And Management | Symmetric Keys\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1645\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/43684572-e4f1-4642-af35-6b933bc506da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"43684572-e4f1-4642-af35-6b933bc506da\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - System settings'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - System settings'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: System\ - \ settings: Use Certificate Rules on Windows Executables for Software Restriction\ - \ Policies\",\"description\":\"Specifies whether digital certificates are\ - \ processed when software restriction policies are enabled and a user or process\ - \ attempts to run software with an .exe file name extension. It enables or\ - \ disables certificate rules (a type of software restriction policies rule).\ - \ For certificate rules to take effect in software restriction policies, you\ - \ must enable this policy setting.\"},\"defaultValue\":\"1\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsSystemsettings\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('System settings: Use Certificate Rules on Windows\ - \ Executables for Software Restriction Policies;ExpectedValue', '=', parameters('SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsSystemsettings\"},\"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies\"\ - :{\"value\":\"[parameters('SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"System settings:\ - \ Use Certificate Rules on Windows Executables for Software Restriction Policies;ExpectedValue\"\ - ,\"value\":\"[parameters('SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"System settings:\ - \ Use Certificate Rules on Windows Executables for Software Restriction Policies;ExpectedValue\"\ - ,\"value\":\"[parameters('SystemSettingsUseCertificateRulesOnWindowsExecutablesForSoftwareRestrictionPolicies')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/437a1f8f-8552-47a8-8b12-a2fee3269dd5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"437a1f8f-8552-47a8-8b12-a2fee3269dd5\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Account Logon'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Account Logon'\ - \ for auditing credential validation and other account logon events. This\ - \ policy requires that the Guest Configuration prerequisites have been deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SystemAuditPoliciesAccountLogon\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"AuditCredentialValidation\":\"Audit Credential\ - \ Validation;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\"\ - ,\"description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"AuditCredentialValidation\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Audit Credential Validation\",\"description\"\ - :\"Specifies whether audit events are generated when credentials are submitted\ - \ for a user account logon request. This setting is especially useful for\ - \ monitoring unsuccessful attempts, to find brute-force attacks, account enumeration,\ - \ and potential account compromise events on domain controllers.\"},\"allowedValues\"\ - :[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\"\ - :\"Success and Failure\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesAccountLogon\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Credential Validation;ExpectedValue',\ - \ '=', parameters('AuditCredentialValidation')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/43bb60fe-1d7e-4b82-9e93-496bfc99e7d5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"43bb60fe-1d7e-4b82-9e93-496bfc99e7d5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1544 - Risk\ - \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1544\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/43ced7c9-cd53-456b-b0da-2522649a4271\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"43ced7c9-cd53-456b-b0da-2522649a4271\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1398 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1398\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/afbd0baf-ff1a-4447-a86f-088a97347c0c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"afbd0baf-ff1a-4447-a86f-088a97347c0c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1646 - Cryptographic\ + \ Key Establishment And Management | Asymmetric Keys\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1646\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/443e8f3d-b51a-45d8-95a7-18b0e42f4dc4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"443e8f3d-b51a-45d8-95a7-18b0e42f4dc4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Monitor permissive network\ - \ access in Azure Security Center\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - All\",\"description\":\"Network Security Groups with too permissive rules\ - \ will be monitored by Azure Security Center as recommendations\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/complianceResults\",\"name\":\"permissiveNetworkAccess\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44452482-524f-4bf4-b852-0bff7cc4a3ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44452482-524f-4bf4-b852-0bff7cc4a3ed\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1066 - Remote\ - \ Access | Disconnect / Disable Access\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/506814fa-b930-4b10-894e-a45b98c40e1a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"506814fa-b930-4b10-894e-a45b98c40e1a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1648 - Collaborative\ + \ Computing Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1066\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1648\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4455c2e8-c65d-4acf-895e-304916f90b36\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4455c2e8-c65d-4acf-895e-304916f90b36\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1720 - Spam\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3a9eb14b-495a-4ebb-933c-ce4ef5264e32\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3a9eb14b-495a-4ebb-933c-ce4ef5264e32\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1647 - Cryptographic\ \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1720\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44b9a7cd-f36a-491a-a48b-6d04ae7c4221\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44b9a7cd-f36a-491a-a48b-6d04ae7c4221\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1334 - Authenticator\ - \ Management | Pki-Based Authentication\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Identification and\ - \ Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1334\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1647\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44bfdadc-8c2e-4c30-9c99-f005986fabcd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44bfdadc-8c2e-4c30-9c99-f005986fabcd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1604 - Developer\ - \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1604\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/791cfc15-6974-42a0-9f4c-2d4b82f4a78c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"791cfc15-6974-42a0-9f4c-2d4b82f4a78c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1650 - Public\ + \ Key Infrastructure Certificates\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Communications\ + \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1650\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44dbba23-0b61-478e-89c7-b3084667782f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44dbba23-0b61-478e-89c7-b3084667782f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1712 - Software,\ - \ Firmware, And Information Integrity\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1712\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/201d3740-bd16-4baf-b4b8-7cda352228b7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"201d3740-bd16-4baf-b4b8-7cda352228b7\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1649 - Collaborative\ + \ Computing Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1649\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44e543aa-41db-42aa-98eb-8a5eb1db53f0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44e543aa-41db-42aa-98eb-8a5eb1db53f0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1310 - Device\ - \ Identification And Authentication\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Identification and Authentication\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1310\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/26d292cc-b0b8-4c29-9337-68abc758bf7b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26d292cc-b0b8-4c29-9337-68abc758bf7b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1651 - Mobile\ + \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ + Microsoft implements this System and Communications Protection control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1651\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/450d7ede-823d-4931-a99d-57f6a38807dc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"450d7ede-823d-4931-a99d-57f6a38807dc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1559 - System\ - \ And Services Acquisition Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1559\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6db63528-c9ba-491c-8a80-83e1e6977a50\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6db63528-c9ba-491c-8a80-83e1e6977a50\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1652 - Mobile\ + \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ + Microsoft implements this System and Communications Protection control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1652\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45692294-f074-42bd-ac54-16f1a3c07554\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45692294-f074-42bd-ac54-16f1a3c07554\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1578 - Acquisition\ - \ Process | Functions / Ports / Protocols / Services In Use\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1578\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6998e84a-2d29-4e10-8962-76754d4f772d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6998e84a-2d29-4e10-8962-76754d4f772d\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1654 - Voice\ + \ Over Internet Protocol\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Communications Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1654\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45b7b644-5f91-498e-9d89-7402532d3645\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45b7b644-5f91-498e-9d89-7402532d3645\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1565 - System\ - \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a2ee16e-ab1f-414a-800b-d1608835862b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a2ee16e-ab1f-414a-800b-d1608835862b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1655 - Voice\ + \ Over Internet Protocol\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Communications Protection\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1565\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1655\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/45ce2396-5c76-4654-9737-f8792ab3d26b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"45ce2396-5c76-4654-9737-f8792ab3d26b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1337 - Authenticator\ - \ Management | In-Person Or Trusted Third-Party Registration\",\"policyType\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/121eab72-390e-4629-a7e2-6d6184f57c6b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"121eab72-390e-4629-a7e2-6d6184f57c6b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1657 - Secure\ + \ Name / Address Resolution Service (Authoritative Source)\",\"policyType\"\ :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Identification and Authentication control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1337\"},\"policyRule\"\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1657\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/463e5220-3f79-4e24-a63f-343e4096cd22\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"463e5220-3f79-4e24-a63f-343e4096cd22\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Require SQL Server version\ - \ 12.0\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - This policy ensures all SQL servers use version 12.0. This policy is deprecated\ - \ because it is no longer possible to create an Azure SQL server with any\ - \ version other than 12.0.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"SQL\",\"deprecated\":true},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },{\"not\":{\"field\":\"Microsoft.Sql/servers/version\",\"equals\":\"12.0\"\ - }}]},\"then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/464dbb85-3d5f-4a1d-bb09-95a9b5dd19cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"464dbb85-3d5f-4a1d-bb09-95a9b5dd19cf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1346 - Identification\ - \ And Authentication (Non-Organizational Users)\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1346\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90f01329-a100-43c2-af31-098996135d2b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90f01329-a100-43c2-af31-098996135d2b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1656 - Secure\ + \ Name / Address Resolution Service (Authoritative Source)\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1656\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/464dc8ce-2200-4720-87a5-dc5952924cc6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"464dc8ce-2200-4720-87a5-dc5952924cc6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using latest supported Python Framework\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"Use the latest supported Python\ - \ version for the latest security classes. Using older classes and types can\ - \ make your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"app\"},{\"field\":\"kind\",\"equals\":\"WebApp\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestPython\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/46544d7b-1f0d-46f5-81da-5c1351de1b06\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"46544d7b-1f0d-46f5-81da-5c1351de1b06\"\ - },{\"properties\":{\"displayName\":\"Require automatic OS image patching on\ - \ Virtual Machine Scale Sets\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"This policy enforces enabling automatic OS image patching\ - \ on Virtual Machine Scale Sets to always keep Virtual Machines secure by\ - \ safely applying latest security patches every month.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Compute\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/upgradePolicy.automaticOSUpgradePolicy.enableAutomaticOSUpgrade\"\ - ,\"notEquals\":\"True\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/upgradePolicy.automaticOSUpgrade\"\ - ,\"notEquals\":\"True\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/465f0161-0087-490a-9ad9-ad6217f4f43a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"465f0161-0087-490a-9ad9-ad6217f4f43a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1368 - Incident\ - \ Handling | Correlation With External Organizations\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident\ - \ Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1368\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1cb067d5-c8b5-4113-a7ee-0a493633924b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1cb067d5-c8b5-4113-a7ee-0a493633924b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1658 - Secure\ + \ Name / Address Resolution Service (Recursive Or Caching Resolver)\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1658\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/465f32da-0ace-4603-8d1b-7be5a3a702de\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"465f32da-0ace-4603-8d1b-7be5a3a702de\"\ - },{\"properties\":{\"displayName\":\"Cognitive Services accounts should use\ - \ customer owned storage\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any Cognitive Services account not using\ - \ customer owned storage.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Cognitive Services\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"The effect determines\ - \ what happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"\ - },{\"count\":{\"field\":\"Microsoft.CognitiveServices/accounts/userOwnedStorage[*]\"\ - },\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/46aa9b05-0e60-4eae-a88b-1e9d374fa515\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"46aa9b05-0e60-4eae-a88b-1e9d374fa515\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1062 - Remote\ - \ Access | Protection Of Confidentiality / Integrity Using Encryption\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1062\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/063b540e-4bdc-4e7a-a569-3a42ddf22098\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"063b540e-4bdc-4e7a-a569-3a42ddf22098\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1653 - Mobile\ + \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ + Microsoft implements this System and Communications Protection control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1653\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4708723f-e099-4af1-bbf9-b6df7642e444\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4708723f-e099-4af1-bbf9-b6df7642e444\"\ - },{\"properties\":{\"displayName\":\"Azure Cosmos DB key based metadata write\ - \ access should be disabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy enables you to ensure all Azure Cosmos DB accounts\ - \ disable key based metadata write access.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Cosmos DB\"},\"parameters\":{},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DocumentDB/databaseAccounts\"\ - },{\"field\":\"Microsoft.DocumentDB/databaseAccounts/disableKeyBasedMetadataWriteAccess\"\ - ,\"notEquals\":true}]},\"then\":{\"effect\":\"append\",\"details\":[{\"field\"\ - :\"Microsoft.DocumentDB/databaseAccounts/disableKeyBasedMetadataWriteAccess\"\ - ,\"value\":true}]}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4750c32b-89c0-46af-bfcb-2e4541a818d5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4750c32b-89c0-46af-bfcb-2e4541a818d5\"\ - },{\"properties\":{\"displayName\":\"Automatic provisioning of the Log Analytics\ - \ monitoring agent should be enabled on your subscription\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"Enable automatic provisioning\ - \ of the Log Analytics monitoring agent in order to collect security data\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/autoProvisioningSettings\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Security/autoProvisioningSettings/autoProvision\"\ - ,\"equals\":\"On\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/475aae12-b88a-4572-8b36-9b712b2b3a17\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"475aae12-b88a-4572-8b36-9b712b2b3a17\"\ - },{\"properties\":{\"displayName\":\"Adaptive application controls for defining\ - \ safe applications should be enabled on your machines\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"Enable application controls to\ - \ define the list of known-safe applications running on your machines, and\ - \ alert you when other applications run. This helps harden your machines against\ - \ malware. To simplify the process of configuring and maintaining your rules,\ - \ Security Center uses machine learning to analyze the applications running\ - \ on each machine and suggest the list of known-safe applications.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"35f45c95-27cf-4e52-891f-8390d1de5828\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/47a6b606-51aa-4496-8bb7-64b11cf66adc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"47a6b606-51aa-4496-8bb7-64b11cf66adc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1359 - Incident\ - \ Response Testing | Coordination With Related Plans\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident\ - \ Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1359\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6b1c00a7-7fd0-42b0-8c5b-c45f6fa1f71b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6b1c00a7-7fd0-42b0-8c5b-c45f6fa1f71b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1659 - Architecture\ + \ And Provisioning For Name / Address Resolution Service\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1659\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/47bc7ea0-7d13-4f7c-a154-b903f7194253\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"47bc7ea0-7d13-4f7c-a154-b903f7194253\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1165 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/35a4102f-a778-4a2e-98c2-971056288df8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"35a4102f-a778-4a2e-98c2-971056288df8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1660 - Session\ + \ Authenticity\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1165\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1660\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/47e10916-6c9e-446b-b0bd-ff5fd439d79d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"47e10916-6c9e-446b-b0bd-ff5fd439d79d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1048 - System\ - \ Use Notification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/63096613-ce83-43e5-96f4-e588e8813554\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"63096613-ce83-43e5-96f4-e588e8813554\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1661 - Session\ + \ Authenticity | Invalidate Session Identifiers At Logout\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Communications Protection control\",\"metadata\":{\"version\"\ :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1048\"},\"policyRule\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1661\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/483e7ca9-82b3-45a2-be97-b93163a0deb7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"483e7ca9-82b3-45a2-be97-b93163a0deb7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1033 - Separation\ - \ Of Duties\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1033\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4c643c9a-1be7-4016-a5e7-e4bada052920\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4c643c9a-1be7-4016-a5e7-e4bada052920\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1663 - Protection\ + \ Of Information At Rest\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Communications Protection\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1663\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/48540f01-fc11-411a-b160-42807c68896e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"48540f01-fc11-411a-b160-42807c68896e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1477 - Fire\ - \ Protection | Detection Devices / Systems\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ - \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1477\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/60171210-6dde-40af-a144-bf2670518bfa\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60171210-6dde-40af-a144-bf2670518bfa\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1662 - Fail\ + \ In Known State\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1662\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4862a63c-6c74-4a9d-a221-89af3c374503\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4862a63c-6c74-4a9d-a221-89af3c374503\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1484 - Water\ - \ Damage Protection | Automation Support\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1484\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/165cb91f-7ea8-4ab7-beaf-8636b98c9d15\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"165cb91f-7ea8-4ab7-beaf-8636b98c9d15\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1664 - Protection\ + \ Of Information At Rest | Cryptographic Protection\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1664\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/486b006a-3653-45e8-b41c-a052d3e05456\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"486b006a-3653-45e8-b41c-a052d3e05456\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit IP restrictions configuration\ - \ for an API App\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"IP Restrictions allow you to define a list of IP addresses that are allowed\ - \ to access your app. Use of IP Restrictions protects an API app from common\ - \ attacks.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ - Security Center\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"\ - },{\"anyof\":[{\"field\":\"kind\",\"equals\":\"api\"},{\"field\":\"kind\"\ - ,\"equals\":\"apiApp\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - ConfigureIPRestrictions\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/48893b84-a2c8-4d9a-badf-835d5d1b7d53\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"48893b84-a2c8-4d9a-badf-835d5d1b7d53\"\ - },{\"properties\":{\"displayName\":\"Geo-redundant backup should be enabled\ - \ for Azure Database for PostgreSQL\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"This policy audits any Azure Database for PostgreSQL\ - \ with geo-redundant backup not enabled.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"},{\"field\":\"\ - Microsoft.DBforPostgreSQL/servers/storageProfile.geoRedundantBackup\",\"notEquals\"\ - :\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/48af4db5-9b8b-401c-8e74-076be876a430\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"48af4db5-9b8b-401c-8e74-076be876a430\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2cdf6b8-9505-4619-b579-309ba72037ac\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2cdf6b8-9505-4619-b579-309ba72037ac\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1665 - Process\ + \ Isolation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Communications Protection control\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ + ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1665\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5df3a55c-8456-44d4-941e-175f79332512\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5df3a55c-8456-44d4-941e-175f79332512\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1667 - System\ + \ And Information Integrity Policy And Procedures\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1667\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d61880dc-6e38-4f2a-a30c-3406a98f8220\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d61880dc-6e38-4f2a-a30c-3406a98f8220\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1666 - System\ + \ And Information Integrity Policy And Procedures\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1666\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12e30ee3-61e6-4509-8302-a871e8ebb91e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12e30ee3-61e6-4509-8302-a871e8ebb91e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1668 - Flaw\ + \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1668\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8fb0966e-be1d-42c3-baca-60df5c0bcc61\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fb0966e-be1d-42c3-baca-60df5c0bcc61\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1669 - Flaw\ \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this System and Information Integrity control\",\"\ @@ -8755,354 +10534,71 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/48f2f62b-5743-4415-a143-288adc0e078d\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"48f2f62b-5743-4415-a143-288adc0e078d\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - User Account Control'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - User Account Control'\ - \ for mode for admins, behavior of elevation prompt, and virtualizing file\ - \ and registry write failures. This policy requires that the Guest Configuration\ - \ prerequisites have been deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SecurityOptionsUserAccountControl\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"UACAdminApprovalModeForTheBuiltinAdministratorAccount\"\ - :\"User Account Control: Admin Approval Mode for the Built-in Administrator\ - \ account;ExpectedValue\",\"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode\"\ - :\"User Account Control: Behavior of the elevation prompt for administrators\ - \ in Admin Approval Mode;ExpectedValue\",\"UACDetectApplicationInstallationsAndPromptForElevation\"\ - :\"User Account Control: Detect application installations and prompt for elevation;ExpectedValue\"\ - ,\"UACRunAllAdministratorsInAdminApprovalMode\":\"User Account Control: Run\ - \ all administrators in Admin Approval Mode;ExpectedValue\"}}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"UACAdminApprovalModeForTheBuiltinAdministratorAccount\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"UAC: Admin Approval\ - \ Mode for the Built-in Administrator account\",\"description\":\"Specifies\ - \ the behavior of Admin Approval Mode for the built-in Administrator account.\"\ - },\"defaultValue\":\"1\"},\"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"UAC: Behavior of the\ - \ elevation prompt for administrators in Admin Approval Mode\",\"description\"\ - :\"Specifies the behavior of the elevation prompt for administrators.\"},\"\ - defaultValue\":\"2\"},\"UACDetectApplicationInstallationsAndPromptForElevation\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"UAC: Detect application\ - \ installations and prompt for elevation\",\"description\":\"Specifies the\ - \ behavior of application installation detection for the computer.\"},\"defaultValue\"\ - :\"1\"},\"UACRunAllAdministratorsInAdminApprovalMode\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"UAC: Run all administrators in Admin Approval\ - \ Mode\",\"description\":\"Specifies the behavior of all User Account Control\ - \ (UAC) policy settings for the computer.\"},\"defaultValue\":\"1\"},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of this policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsUserAccountControl\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('User Account Control: Admin Approval Mode for\ - \ the Built-in Administrator account;ExpectedValue', '=', parameters('UACAdminApprovalModeForTheBuiltinAdministratorAccount'),\ - \ ',', 'User Account Control: Behavior of the elevation prompt for administrators\ - \ in Admin Approval Mode;ExpectedValue', '=', parameters('UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode'),\ - \ ',', 'User Account Control: Detect application installations and prompt\ - \ for elevation;ExpectedValue', '=', parameters('UACDetectApplicationInstallationsAndPromptForElevation'),\ - \ ',', 'User Account Control: Run all administrators in Admin Approval Mode;ExpectedValue',\ - \ '=', parameters('UACRunAllAdministratorsInAdminApprovalMode')))]\"}]}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/492a29ed-d143-4f03-b6a4-705ce081b463\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"492a29ed-d143-4f03-b6a4-705ce081b463\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1376 - Incident\ - \ Response Assistance | Coordination With External Providers\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Incident Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1376\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1670 - Flaw\ + \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1670\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/493a95f3-f2e3-47d0-af02-65e6d6decc2f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"493a95f3-f2e3-47d0-af02-65e6d6decc2f\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Java version' is the latest,\ - \ if used as a part of the Web app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Java software either due to security flaws or to include additional functionality.\ - \ Using the latest Java version for web apps is recommended in order to take\ - \ advantage of security fixes, if any, and/or new functionalities of the latest\ - \ version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"App Service\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"JavaLatestVersion\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Latest Java version\",\"description\":\"Latest supported\ - \ Java version for App Services\"},\"defaultValue\":\"11\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"notContains\":\"JAVA\"},{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\"\ - ,\"equals\":\"\"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"like\":\"[concat('*', parameters('JavaLatestVersion'))]\"},{\"field\":\"\ - Microsoft.Web/sites/config/web.javaVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\",\"like\"\ - :\"[concat(parameters('JavaLatestVersion'), '*')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/496223c3-ad65-4ecd-878a-bae78737e9ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"496223c3-ad65-4ecd-878a-bae78737e9ed\"\ - },{\"properties\":{\"displayName\":\"Add system-assigned managed identity\ - \ to enable Guest Configuration assignments on VMs with a user-assigned identity\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ adds a system-assigned managed identity to virtual machines hosted in Azure\ - \ that are supported by Guest Configuration and have at least one user-assigned\ - \ identity but do not have a system-assigned managed identity. A system-assigned\ - \ managed identity is a prerequisite for all Guest Configuration assignments\ - \ and must be added to machines before using any Guest Configuration policy\ - \ definitions. For more information on Guest Configuration, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"value\":\"[requestContext().apiVersion]\",\"greaterOrEquals\"\ - :\"2018-10-01\"},{\"field\":\"identity.type\",\"contains\":\"UserAssigned\"\ - },{\"field\":\"identity.type\",\"notContains\":\"SystemAssigned\"}]},\"then\"\ - :{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"identity.type\"\ - ,\"value\":\"[concat(field('identity.type'), ',SystemAssigned')]\"}]}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/497dff13-db2a-4c0f-8603-28fa3b331ab6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"497dff13-db2a-4c0f-8603-28fa3b331ab6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Audit'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Security Options - Audit'. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Audit: Shut down system immediately\ - \ if unable to log security audits\",\"description\":\"Audits if the system\ - \ will shut down when unable to log Security events.\"},\"defaultValue\":\"\ - 0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsAudit\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit: Shut down system immediately if unable\ - \ to log security audits;ExpectedValue', '=', parameters('AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsAudit\"},\"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits\"\ - :{\"value\":\"[parameters('AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit: Shut down\ - \ system immediately if unable to log security audits;ExpectedValue\",\"value\"\ - :\"[parameters('AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit: Shut down\ - \ system immediately if unable to log security audits;ExpectedValue\",\"value\"\ - :\"[parameters('AuditShutDownSystemImmediatelyIfUnableToLogSecurityAudits')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/498b810c-59cd-4222-9338-352ba146ccf3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"498b810c-59cd-4222-9338-352ba146ccf3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1329 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1329\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c6108469-57ee-4666-af7e-79ba61c7ae0c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c6108469-57ee-4666-af7e-79ba61c7ae0c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1671 - Flaw\ + \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1671\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/498f6234-3e20-4b6a-a880-cbd646d973bd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"498f6234-3e20-4b6a-a880-cbd646d973bd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1638 - Boundary\ - \ Protection | Dynamic Isolation / Segregation\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1638\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c5bbef7-a316-415b-9b38-29753ce8e698\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c5bbef7-a316-415b-9b38-29753ce8e698\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1672 - Flaw\ + \ Remediation | Central Management\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1672\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/49b99653-32cd-405d-a135-e7d60a9aae1f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"49b99653-32cd-405d-a135-e7d60a9aae1f\"\ - },{\"properties\":{\"displayName\":\"Append a tag and its value to resource\ - \ groups\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - Appends the specified tag and value when any resource group which is missing\ - \ this tag is created or updated. Does not modify the tags of resource groups\ - \ created before this policy was applied until those resource groups are changed.\ - \ New 'modify' effect policies are available that support remediation of tags\ - \ on existing resources (see https://aka.ms/modifydoc).\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Tags\"},\"parameters\":{\"tagName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\",\"description\"\ - :\"Name of the tag, such as 'environment'\"}},\"tagValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Value\",\"description\":\"Value of the\ - \ tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\"\ - :\"false\"}]},\"then\":{\"effect\":\"append\",\"details\":[{\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/49c88fc8-6fd1-46fd-a676-f12d1d3a4c71\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"49c88fc8-6fd1-46fd-a676-f12d1d3a4c71\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1294 - Information\ - \ System Backup | Transfer To Alternate Storage Site\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1294\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b45fe972-904e-45a4-ac20-673ba027a301\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b45fe972-904e-45a4-ac20-673ba027a301\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1673 - Flaw\ + \ Remediation | Automated Flaw Remediation Status\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1673\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/49dbe627-2c1e-438c-979e-dd7a39bbf81d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"49dbe627-2c1e-438c-979e-dd7a39bbf81d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1218 - Least\ - \ Functionality | Prevent Program Execution\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1218\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dff0b90d-5a6f-491c-b2f8-b90aa402d844\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dff0b90d-5a6f-491c-b2f8-b90aa402d844\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1674 - Flaw\ + \ Remediation | Time To Remediate Flaws / Benchmarks For Corrective Actions\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1674\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93e9e233-dd0a-4bde-aea5-1371bce0e002\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93e9e233-dd0a-4bde-aea5-1371bce0e002\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1676 - Malicious\ + \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1676\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4a1d0394-b9f5-493e-9e83-563fd0ac4df8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4a1d0394-b9f5-493e-9e83-563fd0ac4df8\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c10fb58b-56a8-489e-9ce3-7ffe24e78e4b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c10fb58b-56a8-489e-9ce3-7ffe24e78e4b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1675 - Flaw\ + \ Remediation | Time To Remediate Flaws / Benchmarks For Corrective Actions\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1675\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/facb66e0-1c48-478a-bed5-747a312323e1\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"facb66e0-1c48-478a-bed5-747a312323e1\"\ },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1677 - Malicious\ \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ :\"Microsoft implements this System and Information Integrity control\",\"\ @@ -9112,1110 +10608,500 @@ interactions: ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4a248e1e-040f-43e5-bff2-afc3a57a3923\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4a248e1e-040f-43e5-bff2-afc3a57a3923\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1094 - Role-Based\ - \ Security Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1094\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1678 - Malicious\ + \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1678\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4b1853e0-8973-446b-b567-09d901d31a09\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4b1853e0-8973-446b-b567-09d901d31a09\"\ - },{\"properties\":{\"displayName\":\"Azure Event Grid topics should use private\ - \ links\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit Azure Event Grid topics that do not have at least one approved private\ - \ endpoint connection. Clients in a virtual network can securely access resources\ - \ that have private endpoint connections via private links. For more information,\ - \ visit https://aka.ms/privateendpoints.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Event Grid\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.EventGrid/topics\"},{\"count\":{\"field\"\ - :\"Microsoft.EventGrid/topics/privateEndpointConnections[*]\",\"where\":{\"\ - field\":\"Microsoft.EventGrid/topics/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4b90e17e-8448-49db-875e-bd83fb6f804f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4b90e17e-8448-49db-875e-bd83fb6f804f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1114 - Response\ - \ To Audit Processing Failures | Real-Time Alerts\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and\ - \ Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1114\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd533cb0-b416-4be7-8e86-4d154824dfd7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd533cb0-b416-4be7-8e86-4d154824dfd7\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1680 - Malicious\ + \ Code Protection | Central Management\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1680\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4c090801-59bc-4454-bb33-e0455133486a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4c090801-59bc-4454-bb33-e0455133486a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1364 - Incident\ - \ Handling | Dynamic Reconfiguration\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1364\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/399cd6ee-0e18-41db-9dea-cde3bd712f38\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"399cd6ee-0e18-41db-9dea-cde3bd712f38\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1681 - Malicious\ + \ Code Protection | Automatic Updates\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1681\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4c615c2a-dc83-4dda-8220-abce7b50c9bc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4c615c2a-dc83-4dda-8220-abce7b50c9bc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1661 - Session\ - \ Authenticity | Invalidate Session Identifiers At Logout\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1661\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12623e7e-4736-4b2e-b776-c1600f35f93a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12623e7e-4736-4b2e-b776-c1600f35f93a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1679 - Malicious\ + \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1679\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4c643c9a-1be7-4016-a5e7-e4bada052920\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4c643c9a-1be7-4016-a5e7-e4bada052920\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1373 - Incident\ - \ Reporting | Automated Reporting\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Incident Response control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1373\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2cf42a28-193e-41c5-98df-7688e7ef0a88\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2cf42a28-193e-41c5-98df-7688e7ef0a88\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1682 - Malicious\ + \ Code Protection | Nonsignature-Based Detection\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1682\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4cca950f-c3b7-492a-8e8f-ea39663c14f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4cca950f-c3b7-492a-8e8f-ea39663c14f9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1632 - Boundary\ - \ Protection | Prevent Split Tunneling For Remote Devices\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1632\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/62b638c5-29d7-404b-8d93-f21e4b1ce198\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"62b638c5-29d7-404b-8d93-f21e4b1ce198\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1683 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1683\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ce9073a-77fa-48f0-96b1-87aa8e6091c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ce9073a-77fa-48f0-96b1-87aa8e6091c2\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not have\ - \ a maximum password age of 70 days\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if Windows machines that do not have a maximum password\ - \ age of 70 days\",\"metadata\":{\"category\":\"Guest Configuration\",\"version\"\ - :\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"MaximumPasswordAge\",\"version\":\"1.*\"}},\"parameters\":{\"\ - IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - MaximumPasswordAge\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ceb8dc2-559c-478b-a15b-733fbf1e3738\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ceb8dc2-559c-478b-a15b-733fbf1e3738\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Linux VMs that do not have the specified applications installed\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Linux virtual machines\ - \ that do not have the specified applications installed. It also creates a\ - \ system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"3.0.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - ApplicationName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Application names\",\"description\":\"A semicolon-separated list of the\ - \ names of the applications that should be installed. e.g. 'python; powershell'\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"qubole-inc\"\ - ,\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"installed_application_linux\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent',\ - \ '=', concat('packages: [', replace(parameters('ApplicationName'), ';', ','),\ - \ ']')))]\"},\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"installed_application_linux\"},\"ApplicationName\":{\"value\":\"[parameters('ApplicationName')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ApplicationName\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent\"\ - ,\"value\":\"[concat('packages: [', replace(parameters('ApplicationName'),\ - \ ';', ','), ']')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent\"\ - ,\"value\":\"[concat('packages: [', replace(parameters('ApplicationName'),\ - \ ';', ','), ']')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4d1c04de-2172-403f-901b-90608c35c721\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4d1c04de-2172-403f-901b-90608c35c721\"\ - },{\"properties\":{\"displayName\":\"FTPS should be required in your Web App\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Enable\ - \ FTPS enforcement for enhanced security\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/ftpsState\",\"\ - in\":[\"FtpsOnly\",\"Disabled\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4d24b6d4-5e53-4a4f-a7f4-618fa573ee4b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4d24b6d4-5e53-4a4f-a7f4-618fa573ee4b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1155 - System\ - \ Interconnections | Restrictions On External System Connections\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Security Assessment and Authorization control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1155\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8c79fee4-88dd-44ce-bbd4-4de88948c4f8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8c79fee4-88dd-44ce-bbd4-4de88948c4f8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1684 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1684\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4d33f9f1-12d0-46ad-9fbd-8f8046694977\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4d33f9f1-12d0-46ad-9fbd-8f8046694977\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1156 - Plan\ - \ Of Action And Milestones\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Security Assessment and Authorization\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1156\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16bfdb59-db38-47a5-88a9-2e9371a638cf\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16bfdb59-db38-47a5-88a9-2e9371a638cf\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1686 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1686\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4d52e864-9a3b-41ee-8f03-520815fe5378\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4d52e864-9a3b-41ee-8f03-520815fe5378\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1312 - Identifier\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e17085c5-0be8-4423-b39b-a52d3d1402e5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e17085c5-0be8-4423-b39b-a52d3d1402e5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1685 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1312\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1685\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4d6a5968-9eef-4c18-8534-376790ab7274\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4d6a5968-9eef-4c18-8534-376790ab7274\"\ - },{\"properties\":{\"displayName\":\"Deploy Dependency agent for Linux virtual\ - \ machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploy Dependency agent for Linux virtual machines if the VM Image (OS)\ - \ is in the list defined and the agent is not installed.\",\"metadata\":{\"\ - version\":\"1.3.0\",\"category\":\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Linux OS to add to scope\",\"description\":\"\ - Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"14.04.0-LTS\"\ - ,\"14.04.1-LTS\",\"14.04.5-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"16.04-LTS\",\"16.04.0-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"18.04-LTS\"]}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"in\":[\"12-SP2\",\"12-SP3\",\"12-SP4\"]}]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\",\"Centos-LVM\"\ - ,\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"DependencyAgentLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ - DependencyAgentLinux\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"vmExtensionType\":\"DependencyAgentLinux\",\"vmExtensionTypeHandlerVersion\"\ - :\"9.6\"},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"apiVersion\":\"2018-06-01\",\"location\":\"[parameters('location')]\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true}}],\"outputs\":{\"policy\":{\"type\":\"\ - string\",\"value\":\"[concat('Enabled extension for VM', ': ', parameters('vmName'))]\"\ - }}},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4da21710-ce6f-4e06-8cdb-5cc4c93ffbee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4da21710-ce6f-4e06-8cdb-5cc4c93ffbee\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Virtual Machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Advanced threat protection provides real-time threat protection\ - \ for virtual machine workloads and generates hardening recommendations as\ - \ well as alerts about suspicious activities.\",\"metadata\":{\"version\"\ - :\"1.0.2\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/pricings\",\"name\":\"VirtualMachines\",\"existenceScope\"\ - :\"subscription\",\"existenceCondition\":{\"field\":\"Microsoft.Security/pricings/pricingTier\"\ - ,\"equals\":\"Standard\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4da35fc9-c9e7-4960-aec9-797fe7d9051d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4da35fc9-c9e7-4960-aec9-797fe7d9051d\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Data Lake\ - \ Analytics to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Data Lake Analytics\ - \ to stream to a regional Event Hub when any Data Lake Analytics which is\ - \ missing this diagnostic settings is created or updated.\",\"metadata\":{\"\ - version\":\"2.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_eventHub\"},\"eventHubRuleId\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Event Hub Authorization Rule Id\",\"description\":\"The\ - \ Event Hub authorization rule Id for Azure Diagnostics. The authorization\ - \ rule needs to be at Event Hub namespace level. e.g. /subscriptions/{subscription\ - \ Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ - \ in. Only Data Lake Analytics in this location will be linked to this Event\ - \ Hub.\",\"strongType\":\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"\ - description\":\"Whether to enable metrics stream to the Event Hub - True or\ - \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Event Hub\ - \ - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DataLakeAnalytics/accounts\"},{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\"\ - ,\"equals\":\"\"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.DataLakeAnalytics/accounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Audit\",\"enabled\":\"[parameters('logsEnabled')]\"\ - },{\"category\":\"Requests\",\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"\ - outputs\":{}},\"parameters\":{\"location\":{\"value\":\"[field('location')]\"\ - },\"resourceName\":{\"value\":\"[field('name')]\"},\"eventHubRuleId\":{\"\ - value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\":{\"value\"\ - :\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\":\"[parameters('logsEnabled')]\"\ - },\"profileName\":{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/4daddf25-4823-43d4-88eb-2419eb6dcc08\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4daddf25-4823-43d4-88eb-2419eb6dcc08\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1394 - System\ - \ Maintenance Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1394\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36b0ef30-366f-4b1b-8652-a3511df11f53\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36b0ef30-366f-4b1b-8652-a3511df11f53\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1687 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1687\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4db56f68-3f50-45ab-88f3-ca46f5379a94\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4db56f68-3f50-45ab-88f3-ca46f5379a94\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1702 - Information\ - \ System Monitoring | Indicators Of Compromise\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1702\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a87fc7f-301e-49f3-ba2a-4d74f424fa97\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a87fc7f-301e-49f3-ba2a-4d74f424fa97\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1689 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1689\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4dfc0855-92c4-4641-b155-a55ddd962362\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4dfc0855-92c4-4641-b155-a55ddd962362\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1001 - Access\ - \ Control Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1001\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/de901f2f-a01a-4456-97f0-33cda7966172\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"de901f2f-a01a-4456-97f0-33cda7966172\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1688 - Information\ + \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1688\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e26f8c3-4bf3-4191-b8fc-d888805101b7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e26f8c3-4bf3-4191-b8fc-d888805101b7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1083 - Publicly\ - \ Accessible Content\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1083\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/063c3f09-e0f0-4587-8fd5-f4276fae675f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"063c3f09-e0f0-4587-8fd5-f4276fae675f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1690 - Information\ + \ System Monitoring | System-Wide Intrusion Detection System\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1690\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e319cb6-2ca3-4a58-ad75-e67f484e50ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e319cb6-2ca3-4a58-ad75-e67f484e50ec\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1579 - Acquisition\ - \ Process | Use Of Approved Piv Products\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1579\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2567a23-d1c3-4783-99f3-d471302a4d6b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2567a23-d1c3-4783-99f3-d471302a4d6b\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1693 - Information\ + \ System Monitoring | System-Generated Alerts\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1693\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e54c7ef-7457-430b-9a3e-ef8881d4a8e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e54c7ef-7457-430b-9a3e-ef8881d4a8e0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1247 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1247\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a450eba6-2efc-4a00-846a-5804a93c6b77\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a450eba6-2efc-4a00-846a-5804a93c6b77\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1692 - Information\ + \ System Monitoring | Inbound And Outbound Communications Traffic\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1692\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e666db5-b2ef-4b06-aac6-09bfce49151b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e666db5-b2ef-4b06-aac6-09bfce49151b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1196 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1196\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ecda928-9df4-4dd7-8f44-641a91e470e8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ecda928-9df4-4dd7-8f44-641a91e470e8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1691 - Information\ + \ System Monitoring | Automated Tools For Real-Time Analysis\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1691\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e7f4ea4-dd62-44f6-8886-ac6137cf52b0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e7f4ea4-dd62-44f6-8886-ac6137cf52b0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1134 - Protection\ - \ Of Audit Information | Access By Subset Of Privileged Users\",\"policyType\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/71475fb4-49bd-450b-a1a5-f63894c24725\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"71475fb4-49bd-450b-a1a5-f63894c24725\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1694 - Information\ + \ System Monitoring | Analyze Communications Traffic Anomalies\",\"policyType\"\ :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1134\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e95f70e-181c-4422-9da2-43079710c789\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e95f70e-181c-4422-9da2-43079710c789\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1267 - Alternate\ - \ Storage Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1267\"},\"policyRule\"\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1694\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4e97ba1d-be5d-4953-8da4-0cccf28f4805\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4e97ba1d-be5d-4953-8da4-0cccf28f4805\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1192 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1192\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/426c4ac9-ff17-49d0-acd7-a13c157081c0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"426c4ac9-ff17-49d0-acd7-a13c157081c0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1696 - Information\ + \ System Monitoring | Correlate Monitoring Information\",\"policyType\":\"\ + Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1696\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ebd97f7-b105-4f50-8daf-c51465991240\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ebd97f7-b105-4f50-8daf-c51465991240\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1139 - Audit\ - \ Generation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1139\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/69d2a238-20ab-4206-a6dc-f302bf88b1b8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69d2a238-20ab-4206-a6dc-f302bf88b1b8\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1695 - Information\ + \ System Monitoring | Wireless Intrusion Detection\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1695\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/13fcf812-ec82-4eda-9b89-498de9efd620\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"13fcf812-ec82-4eda-9b89-498de9efd620\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1698 - Information\ + \ System Monitoring | Individuals Posing Greater Risk\",\"policyType\":\"\ + Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1698\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ed62522-de00-4dda-9810-5205733d2f34\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ed62522-de00-4dda-9810-5205733d2f34\"\ - },{\"properties\":{\"displayName\":\"A maximum of 3 owners should be designated\ - \ for your subscription\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"It is recommended to designate up to 3 subscription owners in order to\ - \ reduce the potential for breach by a compromised owner.\",\"metadata\":{\"\ - version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"6f90a6d6-d4d6-0794-0ec1-98fa77878c2e\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4f11b553-d42e-4e3a-89be-32ca364cad4c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f11b553-d42e-4e3a-89be-32ca364cad4c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1442 - Media\ - \ Sanitization | Nondestructive Techniques\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Media Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1442\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/31b752c1-05a9-432a-8fce-c39b56550119\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"31b752c1-05a9-432a-8fce-c39b56550119\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1699 - Information\ + \ System Monitoring | Privileged Users\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1699\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4f26049b-2c5a-4841-9ff3-d48a26aae475\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f26049b-2c5a-4841-9ff3-d48a26aae475\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1182 - Baseline\ - \ Configuration | Configure Systems, Components, Or Devices For High-Risk\ - \ Areas\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1182\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/69c7bee8-bc19-4129-a51e-65a7b39d3e7c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69c7bee8-bc19-4129-a51e-65a7b39d3e7c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1697 - Information\ + \ System Monitoring | Analyze Traffic / Covert Exfiltration\",\"policyType\"\ + :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1697\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4f34f554-da4b-4786-8d66-7915c90893da\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f34f554-da4b-4786-8d66-7915c90893da\"\ - },{\"properties\":{\"displayName\":\"A security contact email address should\ - \ be provided for your subscription\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Enter an email address to receive notifications\ - \ when Azure Security Center detects compromised resources\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/securityContacts\",\"existenceCondition\":{\"field\":\"\ - Microsoft.Security/securityContacts/email\",\"notEquals\":\"\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/4f4f78b8-e367-4b10-a341-d9a4ad5cf1c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f4f78b8-e367-4b10-a341-d9a4ad5cf1c7\"\ - },{\"properties\":{\"displayName\":\"Add a tag to resources\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Adds the specified tag\ - \ and value when any resource missing this tag is created or updated. Existing\ - \ resources can be remediated by triggering a remediation task. If the tag\ - \ exists with a different value it will not be changed. Does not modify tags\ - \ on resource groups.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Tag Name\",\"description\":\"Name of the tag, such as 'environment'\"\ - }},\"tagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Value\"\ - ,\"description\":\"Value of the tag, such as 'production'\"}}},\"policyRule\"\ - :{\"if\":{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\"\ - :\"false\"},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"add\",\"field\":\"[concat('tags[', parameters('tagName'),\ - \ ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4f9dc7db-30c1-420c-b61a-e1d640128d26\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4f9dc7db-30c1-420c-b61a-e1d640128d26\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Storage account public access\ - \ should be disallowed\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Anonymous public read access to containers and blobs in Azure\ - \ Storage is a convenient way to share data, but might present security risks.\ - \ To prevent data breaches caused by undesired anonymous access, Microsoft\ - \ recommends preventing public access to a storage account unless your scenario\ - \ requires it.\",\"metadata\":{\"version\":\"1.0.1-preview\",\"category\"\ - :\"Storage\",\"preview\":true},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"The\ - \ effect determines what happens when the policy rule is evaluated to match\"\ - },\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"\ - audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Storage/storageAccounts\"},{\"not\":{\"field\":\"Microsoft.Storage/storageAccounts/allowBlobPublicAccess\"\ - ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4fa4b6c0-31ca-4c0d-b10d-24b96f62a751\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4fa4b6c0-31ca-4c0d-b10d-24b96f62a751\"\ - },{\"properties\":{\"displayName\":\"A vulnerability assessment solution should\ - \ be enabled on your virtual machines\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Audits virtual machines to detect whether they\ - \ are running a supported vulnerability assessment solution. A core component\ - \ of every cyber risk and security program is the identification and analysis\ - \ of vulnerabilities. Azure Security Center's standard pricing tier includes\ - \ vulnerability scanning for your virtual machines at no extra cost. Additionally,\ - \ Security Center can automatically deploy this tool for you.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"550e890b-e652-4d22-8274-60b3bdb24c63\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"NotApplicable\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/501541f7-f7e7-4cd6-868c-4190fdad3ac9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"501541f7-f7e7-4cd6-868c-4190fdad3ac9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1485 - Delivery\ - \ And Removal\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1485\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9873db2-18ad-46b3-a11a-1a1f8cbf0335\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9873db2-18ad-46b3-a11a-1a1f8cbf0335\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1700 - Information\ + \ System Monitoring | Unauthorized Network Services\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1700\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50301354-95d0-4a11-8af5-8039ecf6d38b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50301354-95d0-4a11-8af5-8039ecf6d38b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1646 - Cryptographic\ - \ Key Establishment And Management | Asymmetric Keys\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1646\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7831b4ba-c3f4-4cb1-8c11-ef8d59438cd5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7831b4ba-c3f4-4cb1-8c11-ef8d59438cd5\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1701 - Information\ + \ System Monitoring | Host-Based Devices\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1701\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/506814fa-b930-4b10-894e-a45b98c40e1a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"506814fa-b930-4b10-894e-a45b98c40e1a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1566 - System\ - \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1566\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f25bc08f-27cb-43b6-9a23-014d00700426\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f25bc08f-27cb-43b6-9a23-014d00700426\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1702 - Information\ + \ System Monitoring | Indicators Of Compromise\",\"policyType\":\"Static\"\ + ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ + \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1702\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50ad3724-e2ac-4716-afcc-d8eabd97adb9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50ad3724-e2ac-4716-afcc-d8eabd97adb9\"\ - },{\"properties\":{\"displayName\":\"A custom IPsec/IKE policy must be applied\ - \ to all Azure virtual network gateway connections\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"This policy ensures that all Azure virtual\ - \ network gateway connections use a custom Internet Protocol Security(Ipsec)/Internet\ - \ Key Exchange(IKE) policy. Supported algorithms and key strengths - https://aka.ms/AA62kb0\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"IPsecEncryption\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"IPsec Encryption\",\"\ - description\":\"IPsec Encryption\"}},\"IPsecIntegrity\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"IPsec Integrity\",\"description\":\"IPsec\ - \ Integrity\"}},\"IKEEncryption\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"IKE Encryption\",\"description\":\"IKE Encryption\"}},\"IKEIntegrity\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"IKE Integrity\",\"description\"\ - :\"IKE Integrity\"}},\"DHGroup\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"DH Group\",\"description\":\"DH Group\"}},\"PFSGroup\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"PFS Group\",\"description\":\"PFS Group\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/connections\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].ipsecEncryption\"\ - ,\"notIn\":\"[parameters('IPsecEncryption')]\"},{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].ipsecIntegrity\"\ - ,\"notIn\":\"[parameters('IPsecIntegrity')]\"},{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].ikeEncryption\"\ - ,\"notIn\":\"[parameters('IKEEncryption')]\"},{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].ikeIntegrity\"\ - ,\"notIn\":\"[parameters('IKEIntegrity')]\"},{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].dhGroup\"\ - ,\"notIn\":\"[parameters('DHGroup')]\"},{\"field\":\"Microsoft.Network/connections/ipsecPolicies[*].pfsGroup\"\ - ,\"notIn\":\"[parameters('PFSGroup')]\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50b83b09-03da-41c1-b656-c293c914862b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50b83b09-03da-41c1-b656-c293c914862b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1248 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1248\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4dfc0855-92c4-4641-b155-a55ddd962362\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4dfc0855-92c4-4641-b155-a55ddd962362\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1704 - Security\ + \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1704\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/50fc602d-d8e0-444b-a039-ad138ee5deb0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"50fc602d-d8e0-444b-a039-ad138ee5deb0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1386 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1386\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2d44b6fa-1134-4ea6-ad4e-9edb68f65429\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2d44b6fa-1134-4ea6-ad4e-9edb68f65429\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1705 - Security\ + \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1705\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5120193e-91fd-4f9d-bc6d-194f94734065\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5120193e-91fd-4f9d-bc6d-194f94734065\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1352 - Incident\ - \ Response Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Incident Response control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1352\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f82e3639-fa2b-4e06-a786-932d8379b972\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f82e3639-fa2b-4e06-a786-932d8379b972\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1706 - Security\ + \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1706\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/518cb545-bfa8-43f8-a108-3b7d5037469a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"518cb545-bfa8-43f8-a108-3b7d5037469a\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Azure Kubernetes Service clusters\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Advanced threat protection provides real-time\ - \ threat protection for containerized environments and generates alerts for\ - \ suspicious activities.\",\"metadata\":{\"version\":\"1.0.2\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/pricings\"\ - ,\"name\":\"KubernetesService\",\"existenceScope\":\"subscription\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/pricings/pricingTier\",\"equals\":\"Standard\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/523b5cd1-3e23-492f-a539-13118b6d1e3a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"523b5cd1-3e23-492f-a539-13118b6d1e3a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1642 - Network\ - \ Disconnect\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1642\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f475ee0e-f560-4c9b-876b-04a77460a404\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f475ee0e-f560-4c9b-876b-04a77460a404\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1707 - Security\ + \ Alerts, Advisories, And Directives | Automated Alerts And Advisories\",\"\ + policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ + \ this System and Information Integrity control\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1707\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53397227-5ee3-4b23-9e5e-c8a767ce6928\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53397227-5ee3-4b23-9e5e-c8a767ce6928\"\ - },{\"properties\":{\"displayName\":\"Connection throttling should be enabled\ - \ for PostgreSQL database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy helps audit any PostgreSQL databases\ - \ in your environment without Connection throttling enabled. This setting\ - \ enables temporary connection throttling per IP for too many invalid password\ - \ login failures.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DBforPostgreSQL/servers\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.DBforPostgreSQL/servers/configurations\"\ - ,\"name\":\"connection_throttling\",\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/configurations/value\"\ - ,\"equals\":\"ON\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5345bb39-67dc-4960-a1bf-427e16b9a0bd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5345bb39-67dc-4960-a1bf-427e16b9a0bd\"\ - },{\"properties\":{\"displayName\":\"Azure SignalR Service should use private\ - \ links\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit Azure SignalR Service resources that do not have at least one approved\ - \ private endpoint connection. Clients in a virtual network can securely access\ - \ resources that have private endpoint connections through private links.\ - \ For more information, visit: https://aka.ms/asrs/privatelink.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"SignalR\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.SignalRService/SignalR\"\ - },{\"count\":{\"field\":\"Microsoft.SignalRService/SignalR/privateEndpointConnections[*]\"\ - ,\"where\":{\"field\":\"Microsoft.SignalRService/SignalR/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53503636-bcc9-4748-9663-5348217f160f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53503636-bcc9-4748-9663-5348217f160f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1467 - Visitor\ - \ Access Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1467\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd4a2ac8-868a-4702-a345-6c896c3361ce\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd4a2ac8-868a-4702-a345-6c896c3361ce\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1709 - Security\ + \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Information Integrity\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1709\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5350cbf9-8bdd-4904-b22a-e88be84ca49d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5350cbf9-8bdd-4904-b22a-e88be84ca49d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1183 - Baseline\ - \ Configuration | Configure Systems, Components, Or Devices For High-Risk\ - \ Areas\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1183\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5352e3e0-e63a-452e-9e5f-9c1d181cff9c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5352e3e0-e63a-452e-9e5f-9c1d181cff9c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1029 - Information\ - \ Flow Enforcement | Security Policy Filters\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/025992d6-7fee-4137-9bbf-2ffc39c0686c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"025992d6-7fee-4137-9bbf-2ffc39c0686c\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1708 - Security\ + \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Information Integrity\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1029\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1708\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53ac8f8e-c2b5-4d44-8a2d-058e9ced9b69\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53ac8f8e-c2b5-4d44-8a2d-058e9ced9b69\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1270 - Alternate\ - \ Storage Site | Recovery Time / Point Objectives\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1270\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a1e2c88-13de-4959-8ee7-47e3d74f1f48\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a1e2c88-13de-4959-8ee7-47e3d74f1f48\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1710 - Security\ + \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Information Integrity\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1710\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53c76a39-2097-408a-b237-b279f7b4614d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53c76a39-2097-408a-b237-b279f7b4614d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1040 - Least\ - \ Privilege | Review Of User Privileges\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1040\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/af2a93c8-e6dd-4c94-acdd-4a2eedfc478e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"af2a93c8-e6dd-4c94-acdd-4a2eedfc478e\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1703 - Security\ + \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1703\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/54205576-cec9-463f-ba44-b4b3f5d0a84c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"54205576-cec9-463f-ba44-b4b3f5d0a84c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1015 - Account\ - \ Management | Disable Inactive Accounts\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1015\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/804faf7d-b687-40f7-9f74-79e28adf4205\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"804faf7d-b687-40f7-9f74-79e28adf4205\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1711 - Security\ + \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ + description\":\"Microsoft implements this System and Information Integrity\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1711\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/544a208a-9c3f-40bc-b1d1-d7e144495c14\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"544a208a-9c3f-40bc-b1d1-d7e144495c14\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1026 - Account\ - \ Management | Disable Accounts For High-Risk Individuals\",\"policyType\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b083a535-a66a-41ec-ba7f-f9498bf67cde\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b083a535-a66a-41ec-ba7f-f9498bf67cde\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1713 - Software,\ + \ Firmware, And Information Integrity | Integrity Checks\",\"policyType\"\ :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1026\"\ + \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ + /providers/Microsoft.PolicyInsights/policyMetadata/ACF1713\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0d87c70b-5012-48e9-994b-e70dd4b8def0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0d87c70b-5012-48e9-994b-e70dd4b8def0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1712 - Software,\ + \ Firmware, And Information Integrity\",\"policyType\":\"Static\",\"mode\"\ + :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1712\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/55419419-c597-4cd4-b51e-009fd2266783\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"55419419-c597-4cd4-b51e-009fd2266783\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1045 - Unsuccessful\ - \ Logon Attempts\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1045\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44e543aa-41db-42aa-98eb-8a5eb1db53f0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44e543aa-41db-42aa-98eb-8a5eb1db53f0\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1714 - Software,\ + \ Firmware, And Information Integrity | Automated Notifications Of Integrity\ + \ Violations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1714\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e12494fa-b81e-4080-af71-7dbacc2da0ec\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e12494fa-b81e-4080-af71-7dbacc2da0ec\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1715 - Software,\ + \ Firmware, And Information Integrity | Automated Response To Integrity Violations\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1715\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/554d2dd6-f3a8-4ad5-b66f-5ce23bd18892\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"554d2dd6-f3a8-4ad5-b66f-5ce23bd18892\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Firewall should be enabled\ - \ on Key Vault\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"The key vault firewall prevents unauthorized traffic from reaching your\ - \ key vault and provides an additional layer of protection for your secrets.\ - \ Enable the key vault firewall to make sure that only traffic from allowed\ - \ networks can access your key vault.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ - ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ - },{\"field\":\"Microsoft.KeyVault/vaults/networkAcls.defaultAction\",\"notEquals\"\ - :\"Deny\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/55615ac9-af46-4a59-874e-391cc3dfb490\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"55615ac9-af46-4a59-874e-391cc3dfb490\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1523 - Personnel\ - \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1523\"},\"policyRule\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd469ae0-71a8-4adc-aafc-de6949ca3339\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd469ae0-71a8-4adc-aafc-de6949ca3339\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1716 - Software,\ + \ Firmware, And Information Integrity | Integration Of Detection And Response\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1716\"},\"policyRule\"\ :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5577a310-2551-49c8-803b-36e0d5e55601\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5577a310-2551-49c8-803b-36e0d5e55601\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1113 - Response\ - \ To Audit Processing Failures | Audit Storage Capacity\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1113\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e54c325e-42a0-4dcf-b105-046e0f6f590f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e54c325e-42a0-4dcf-b105-046e0f6f590f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1718 - Software,\ + \ Firmware, And Information Integrity | Binary Or Machine Executable Code\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1718\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0dced7ab-9ce5-4137-93aa-14c13e06ab17\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0dced7ab-9ce5-4137-93aa-14c13e06ab17\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1717 - Software,\ + \ Firmware, And Information Integrity | Binary Or Machine Executable Code\"\ + ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ + \ implements this System and Information Integrity control\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ + :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1717\"},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/967773fc-d9ab-4a4e-8ff6-f5e9e3f5dbef\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"967773fc-d9ab-4a4e-8ff6-f5e9e3f5dbef\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1719 - Spam\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1719\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/562afd61-56be-4313-8fe4-b9564aa4ba7d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"562afd61-56be-4313-8fe4-b9564aa4ba7d\"\ - },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ - \ be enabled for Application Gateway\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires Web Application Firewall (WAF) on\ - \ any Application Gateway. A Web Application Firewall provides greater security\ - \ for your other Azure resources.\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/applicationGateways\"\ - },{\"field\":\"Microsoft.Network/applicationGateways/webApplicationFirewallConfiguration\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/564feb30-bf6a-4854-b4bb-0d2d2d1e6c66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"564feb30-bf6a-4854-b4bb-0d2d2d1e6c66\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1212 - Configuration\ - \ Settings | Automated Central Management / Application / Verification\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1212\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c13da9b4-fe14-4fe2-853a-5997c9d4215a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c13da9b4-fe14-4fe2-853a-5997c9d4215a\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1720 - Spam\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1720\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/56d970ee-4efc-49c8-8a4e-5916940d784c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"56d970ee-4efc-49c8-8a4e-5916940d784c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1403 - Controlled\ - \ Maintenance | Automated Maintenance Activities\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/44b9a7cd-f36a-491a-a48b-6d04ae7c4221\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"44b9a7cd-f36a-491a-a48b-6d04ae7c4221\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1722 - Spam\ + \ Protection | Automatic Updates\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Information Integrity\ \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1403\"\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1722\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/57149289-d52b-4f40-9fe6-5233c1ef80f7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"57149289-d52b-4f40-9fe6-5233c1ef80f7\"\ - },{\"properties\":{\"displayName\":\"CORS should not allow every resource\ - \ to access your Web Applications\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Cross-Origin Resource Sharing (CORS) should not\ - \ allow all domains to access your web application. Allow only required domains\ - \ to interact with your web app.\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/config/web.cors.allowedOrigins[*]\",\"notEquals\"\ - :\"*\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5744710e-cc2f-4ee8-8809-3b11e89f4bc9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5744710e-cc2f-4ee8-8809-3b11e89f4bc9\"\ - },{\"properties\":{\"displayName\":\"Audit Windows web servers that are not\ - \ using secure communication protocols\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the registry key HKLM:\\\\SYSTEM\\\\CurrentControlSet\\\ - \\Control\\\\SecurityProviders\\\\SCHANNEL\\\\Protocols includes protocols\ - \ less secure than what is selected in the policy parameter.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AuditSecureProtocol\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"MinimumTLSVersion\":\"\ - [SecureWebServer]s1;MinimumTLSVersion\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"MinimumTLSVersion\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Minimum TLS version\",\"description\":\"The\ - \ minimum TLS protocol version that should be enabled. Windows web servers\ - \ with lower TLS versions will be marked as non-compliant.\"},\"allowedValues\"\ - :[\"1.1\",\"1.2\"],\"defaultValue\":\"1.1\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AuditSecureProtocol\",\"existenceCondition\":{\"allOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[SecureWebServer]s1;MinimumTLSVersion', '=',\ - \ parameters('MinimumTLSVersion')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5752e6d6-1206-46d8-8ab1-ecc2f71a8112\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5752e6d6-1206-46d8-8ab1-ecc2f71a8112\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1162 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1162\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1da06bd-25b6-4127-a301-c313d6873fff\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1da06bd-25b6-4127-a301-c313d6873fff\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1723 - Information\ + \ Input Validation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1723\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5770f3d6-8c2b-4f6f-bf0e-c8c8fc36d592\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5770f3d6-8c2b-4f6f-bf0e-c8c8fc36d592\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1054 - Session\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1054\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5807e1b4-ba5e-4718-8689-a0ca05a191b2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5807e1b4-ba5e-4718-8689-a0ca05a191b2\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Detailed Tracking'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Detailed\ - \ Tracking' for auditing DPAPI, process creation/termination, RPC events,\ - \ and PNP activity. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SystemAuditPoliciesDetailedTracking\",\"version\"\ - :\"1.*\",\"configurationParameter\":{\"AuditProcessTermination\":\"Audit Process\ - \ Termination;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\"\ - ,\"description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"AuditProcessTermination\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Audit Process Termination\",\"description\"\ - :\"Specifies whether audit events are generated when a process has exited.\ - \ Recommended for monitoring termination of critical processes.\"},\"allowedValues\"\ - :[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\"\ - :\"No Auditing\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of this policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesDetailedTracking\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Process Termination;ExpectedValue', '=',\ - \ parameters('AuditProcessTermination')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58383b73-94a9-4414-b382-4146eb02611b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58383b73-94a9-4414-b382-4146eb02611b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1584 - Information\ - \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1584\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e91927a0-ac1d-44a0-95f8-5185f9dfce9f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e91927a0-ac1d-44a0-95f8-5185f9dfce9f\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1724 - Error\ + \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1724\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5864522b-ff1d-4979-a9f8-58bee1fb174c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5864522b-ff1d-4979-a9f8-58bee1fb174c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1547 - Vulnerability\ - \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1547\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d07594d1-0307-4c08-94db-5d71ff31f0f6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d07594d1-0307-4c08-94db-5d71ff31f0f6\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1727 - Memory\ + \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1727\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58abf9b8-c6d4-4b4b-bfb9-fe98fe295f52\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58abf9b8-c6d4-4b4b-bfb9-fe98fe295f52\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines on which Windows\ - \ Serial Console is not enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if the machine does not have the Serial Console software installed\ - \ or if the EMS port number or baud rate are not configured with the same\ - \ values as the policy parameters.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"WindowsSerialConsole\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"EMSPortNumber\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber\"\ - ,\"EMSBaudRate\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"EMSPortNumber\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"EMS Port Number\",\"\ - description\":\"An integer indicating the COM port to be used for the Emergency\ - \ Management Services (EMS) console redirection. For more information on EMS\ - \ settings, please visit https://aka.ms/gcpolwsc\"},\"allowedValues\":[\"\ - 1\",\"2\",\"3\",\"4\"],\"defaultValue\":\"1\"},\"EMSBaudRate\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"EMS Baud Rate\",\"description\":\"\ - An integer indicating the baud rate to be used for the Emergency Management\ - \ Services (EMS) console redirection. For more information on EMS settings,\ - \ please visit https://aka.ms/gcpolwsc\"},\"allowedValues\":[\"9600\",\"19200\"\ - ,\"38400\",\"57600\",\"115200\"],\"defaultValue\":\"115200\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsSerialConsole\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber',\ - \ '=', parameters('EMSPortNumber'), ',', '[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate',\ - \ '=', parameters('EMSBaudRate')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58c460e9-7573-4bb2-9676-339c2f2486bb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58c460e9-7573-4bb2-9676-339c2f2486bb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1573 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/697175a7-9715-4e89-b98b-c6f605888fa3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"697175a7-9715-4e89-b98b-c6f605888fa3\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1725 - Error\ + \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ + :\"Microsoft implements this System and Information Integrity control\",\"\ metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1573\"\ + additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1725\"\ },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58c93053-7b98-4cf0-b99f-1beb985416c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58c93053-7b98-4cf0-b99f-1beb985416c2\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/afc234b5-456b-4aa5-b3e2-ce89108124cc\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"afc234b5-456b-4aa5-b3e2-ce89108124cc\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1726 - Information\ + \ Handling And Retention\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ + ,\"description\":\"Microsoft implements this System and Information Integrity\ + \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ + \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1726\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/baff1279-05e0-4463-9a70-8ba5de4c7aa4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"baff1279-05e0-4463-9a70-8ba5de4c7aa4\"\ + },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1721 - Spam\ + \ Protection | Central Management\",\"policyType\":\"Static\",\"mode\":\"\ + Indexed\",\"description\":\"Microsoft implements this System and Information\ + \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1721\"\ + },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ + ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d207aaef-7c4d-4f8c-9dce-4d62dfa3d29a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d207aaef-7c4d-4f8c-9dce-4d62dfa3d29a\"\ + },{\"properties\":{\"displayName\":\"Allow managing tenant ids to onboard\ + \ through Azure Lighthouse\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ + description\":\"Restricting Azure Lighthouse delegations to specific managing\ + \ tenants increases security by limiting those who can manage your Azure resources.\"\ + ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Lighthouse\"},\"parameters\"\ + :{\"listOfAllowedTenants\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed tenants\",\"description\":\"List of the tenants IDs that can be\ + \ onboarded through Azure Lighthouse\"}}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.ManagedServices/registrationDefinitions\"\ + },{\"not\":{\"field\":\"Microsoft.ManagedServices/registrationDefinitions/managedByTenantId\"\ + ,\"in\":\"[parameters('listOfAllowedTenants')]\"}}]},\"then\":{\"effect\"\ + :\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a8a51a3-ad87-4def-96f3-65a1839242b6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a8a51a3-ad87-4def-96f3-65a1839242b6\"\ + },{\"properties\":{\"displayName\":\"Application definition for Managed Application\ + \ should use customer provided storage account\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Use your own storage account to control\ + \ the application definition data when this is a regulatory or compliance\ + \ requirement. You can choose to store your managed application definition\ + \ within a storage account provided by you during creation, so that its location\ + \ and access can be fully managed by you to fulfill regulatory compliance\ + \ requirements.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Managed\ + \ Application\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"\ + defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ + type\",\"equals\":\"Microsoft.Solutions/applicationDefinitions\"},{\"field\"\ + :\"Microsoft.Solutions/applicationDefinitions/storageAccountId\",\"exists\"\ + :\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ + /providers/Microsoft.Authorization/policyDefinitions/9db7917b-1607-4e7d-a689-bca978dd0633\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9db7917b-1607-4e7d-a689-bca978dd0633\"\ },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure Function app is\ \ using the latest version of TLS encryption\",\"policyType\":\"BuiltIn\"\ ,\"mode\":\"Indexed\",\"description\":\"Please use /providers/Microsoft.Authorization/policyDefinitions/f9d614c5-c173-4d56-95a7-b4437057d193\ @@ -10234,454 +11120,192 @@ interactions: ,\"name\":\"web\",\"existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.minTlsVersion\"\ ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/58d94fc1-a072-47c2-bd37-9cdb38e77453\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"58d94fc1-a072-47c2-bd37-9cdb38e77453\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1063 - Remote\ - \ Access | Managed Access Control Points\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1063\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/593ce201-54b2-4dd0-b34f-c308005d7780\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"593ce201-54b2-4dd0-b34f-c308005d7780\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1463 - Monitoring\ - \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1463\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/59721f87-ae25-4db0-a2a4-77cc5b25d495\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"59721f87-ae25-4db0-a2a4-77cc5b25d495\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1425 - Timely\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1425\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5983d99c-f39b-4c32-a3dc-170f19f6941b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5983d99c-f39b-4c32-a3dc-170f19f6941b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1512 - Personnel\ - \ Screening\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1512\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5a8324ad-f599-429b-aaed-f9c6e8c987a8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5a8324ad-f599-429b-aaed-f9c6e8c987a8\"\ - },{\"properties\":{\"displayName\":\"Operating system version should be the\ - \ most current version for your cloud service roles\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Keeping the operating system (OS) on the\ - \ most recent supported version for your cloud service roles enhances the\ - \ systems security posture.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.ClassicCompute/domainNames/slots/roles\"]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"8bc390da-9eb6-938d-25ed-44a35d9bcc9d\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"NotApplicable\"\ - ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5a913c68-0590-402c-a531-e57e19379da3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5a913c68-0590-402c-a531-e57e19379da3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have a minimum password age of 1 day\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that do not have a minimum password age of 1 day. For more information on\ - \ Guest Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MinimumPasswordAge\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5aa11bbc-5c76-4302-80e5-aba46a4282e7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5aa11bbc-5c76-4302-80e5-aba46a4282e7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1032 - Separation\ - \ Of Duties\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1032\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5aa85661-d618-46b8-a20f-ca40a86f0751\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5aa85661-d618-46b8-a20f-ca40a86f0751\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not restrict the minimum password length to 14 characters\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines that do not restrict the minimum password length to 14\ - \ characters. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MinimumPasswordLength\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5aebc8d1-020d-4037-89a0-02043a7524ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5aebc8d1-020d-4037-89a0-02043a7524ec\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1555 - Vulnerability\ - \ Scanning | Privileged Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Risk Assessment control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1555\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5afa8cab-1ed7-4e40-884c-64e0ac2059cc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5afa8cab-1ed7-4e40-884c-64e0ac2059cc\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that allow re-use\ - \ of the previous 24 passwords\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if Windows machines that allow re-use of the previous 24 passwords\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"EnforcePasswordHistory\",\"version\":\"1.*\"}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - EnforcePasswordHistory\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b054a0d-39e2-4d53-bea3-9734cad2c69b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b054a0d-39e2-4d53-bea3-9734cad2c69b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1205 - Access\ - \ Restrictions For Change | Signed Components\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1205\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b070cab-0fb8-4e48-ad29-fc90b4c2797c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b070cab-0fb8-4e48-ad29-fc90b4c2797c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1005 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1005\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b626abc-26d4-4e22-9de8-3831818526b1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b626abc-26d4-4e22-9de8-3831818526b1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1105 - Audit\ - \ Events\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1105\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b73f57b-587d-4470-a344-0b0ae805f459\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b73f57b-587d-4470-a344-0b0ae805f459\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Linux VMs that have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Linux virtual machines\ - \ that have the specified applications installed. For more information on\ - \ Guest Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"\ - qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"not_installed_application_linux\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b842acb-0fe7-41b0-9f40-880ec4ad84d8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b842acb-0fe7-41b0-9f40-880ec4ad84d8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1433 - Media\ - \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1433\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b879b41-2728-41c5-ad24-9ee2c37cbe65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b879b41-2728-41c5-ad24-9ee2c37cbe65\"\ - },{\"properties\":{\"displayName\":\"Container registries should be encrypted\ - \ with a customer-managed key (CMK)\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Audit container registries that do not have\ - \ encryption enabled with customer-managed keys (CMK). Azure automatically\ - \ encrypts registry contents at rest with service-managed keys. You can supplement\ - \ default encryption with an additional encryption layer using a key that\ - \ you create and manage in Azure Key Vault. For more information on CMK encryption,\ - \ please visit: https://aka.ms/acr/CMK.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Container Registry\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerRegistry/registries\"\ - },{\"not\":{\"field\":\"Microsoft.ContainerRegistry/registries/encryption.status\"\ - ,\"equals\":\"enabled\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5b9159ae-1701-4a6f-9a7a-aa9c8ddd0580\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5b9159ae-1701-4a6f-9a7a-aa9c8ddd0580\"\ - },{\"properties\":{\"displayName\":\"Ensure WEB app has 'Client Certificates\ - \ (Incoming client certificates)' set to 'On'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Client certificates allow for the\ - \ app to request a certificate for incoming requests. Only clients that have\ - \ a valid certificate will be able to reach the app.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"app*\"},{\"field\":\"Microsoft.Web/sites/clientCertEnabled\",\"\ - equals\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/5bb220d9-2698-4ee4-8404-b9c30c9df609\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5bb220d9-2698-4ee4-8404-b9c30c9df609\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs on which the remote connection status does not match the\ - \ specified one\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines on which the remote host connection status does not match the specified\ - \ one. It also creates a system-assigned managed identity and deploys the\ - \ VM extension for Guest Configuration. This policy should only be used along\ - \ with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"host\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Remote Host Name\",\"description\":\"Specifies the Domain\ - \ Name System (DNS) name or IP address of the remote host machine.\"}},\"\ - port\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Port\",\"description\":\"The TCP port number on the remote host name.\"\ - }},\"shouldConnect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - [Deprecated]: Should connect to remote host\",\"description\":\"Must be 'True'\ - \ or 'False'. 'True' indicates that the virtual machine should be able to\ - \ establish a connection with the remote host specified, so the machine will\ - \ be non-compliant if it cannot establish a connection. 'False' indicates\ - \ that the virtual machine should not be able to establish a connection with\ - \ the remote host specified, so the machine will be non-compliant if it can\ - \ establish a connection.\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"False\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsRemoteConnection\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsRemoteConnection]WindowsRemoteConnection1;host',\ - \ '=', parameters('host'), ',', '[WindowsRemoteConnection]WindowsRemoteConnection1;port',\ - \ '=', parameters('port'), ',', '[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect',\ - \ '=', parameters('shouldConnect')))]\"},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsRemoteConnection\"\ - },\"host\":{\"value\":\"[parameters('host')]\"},\"port\":{\"value\":\"[parameters('port')]\"\ - },\"shouldConnect\":{\"value\":\"[parameters('shouldConnect')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"host\":{\"type\":\"string\"},\"port\":{\"type\":\"\ - string\"},\"shouldConnect\":{\"type\":\"string\"}},\"resources\":[{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;host\"\ - ,\"value\":\"[parameters('host')]\"},{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;port\"\ - ,\"value\":\"[parameters('port')]\"},{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect\"\ - ,\"value\":\"[parameters('shouldConnect')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;host\"\ - ,\"value\":\"[parameters('host')]\"},{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;port\"\ - ,\"value\":\"[parameters('port')]\"},{\"name\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect\"\ - ,\"value\":\"[parameters('shouldConnect')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5bb36dda-8a78-4df9-affd-4f05a8612a8a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5bb36dda-8a78-4df9-affd-4f05a8612a8a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1551 - Vulnerability\ - \ Scanning | Update Tool Capability\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1551\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5bbda922-0172-4095-89e6-5b4a0bf03af7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5bbda922-0172-4095-89e6-5b4a0bf03af7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Network Security'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Network Security'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure WEB app is using\ + \ the latest version of TLS encryption \",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Please use /providers/Microsoft.Authorization/policyDefinitions/f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b\ + \ instead. The TLS(Transport Layer Security) protocol secures transmission\ + \ of data over the internet using standard encryption technology. Encryption\ + \ should be set with the latest version of TLS. App service allows TLS 1.2\ + \ by default, which is the recommended TLS level by industry standards, such\ + \ as PCI DSS.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ + :\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ + },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ + existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.minTlsVersion\"\ + ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6ad61431-88ce-4357-a0e1-6da43f292bd7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6ad61431-88ce-4357-a0e1-6da43f292bd7\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Log Analytics agent should\ + \ be installed on your Linux Azure Arc machines\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"This policy audits Linux Azure Arc\ + \ machines if the Log Analytics agent is not installed.\",\"metadata\":{\"\ + version\":\"1.0.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ + \ the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.HybridCompute/machines\"},{\"field\":\"Microsoft.HybridCompute/imageOffer\"\ + ,\"like\":\"linux*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"\ + details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"existenceCondition\"\ + :{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/842c54e8-c2f9-4d79-ae8d-38d8b8019373\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"842c54e8-c2f9-4d79-ae8d-38d8b8019373\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Log Analytics agent should\ + \ be installed on your Windows Azure Arc machines\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"This policy audits Windows Azure Arc\ + \ machines if the Log Analytics agent is not installed.\",\"metadata\":{\"\ + version\":\"1.0.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ + \ the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.HybridCompute/machines\"},{\"field\":\"Microsoft.HybridCompute/imageOffer\"\ + ,\"like\":\"windows*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"\ + existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d69b1763-b96d-40b8-a2d9-ca31e9fd0d3e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d69b1763-b96d-40b8-a2d9-ca31e9fd0d3e\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ + \ only in Asia data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Allows resource creation in the following locations only:\ + \ East Asia, Southeast Asia, West India, South India, Central India, Japan\ + \ East, Japan West\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ + :\"General\",\"deprecated\":true},\"parameters\":{},\"policyRule\":{\"if\"\ + :{\"not\":{\"field\":\"location\",\"in\":[\"eastasia\",\"southeastasia\",\"\ + westindia\",\"southindia\",\"centralindia\",\"japaneast\",\"japanwest\"]}},\"\ + then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c1b9cbed-08e3-427d-b9ce-7c535b1e9b94\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c1b9cbed-08e3-427d-b9ce-7c535b1e9b94\"\ + },{\"properties\":{\"displayName\":\"Deploy associations for a custom provider\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys\ + \ an association resource that associates selected resource types to the specified\ + \ custom provider. This policy deployment does not support nested resource\ + \ types.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Custom Provider\"\ + },\"parameters\":{\"targetCustomProviderId\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Custom provider ID\",\"description\":\"Resource ID of\ + \ the Custom provider to which resources need to be associated.\"}},\"resourceTypesToAssociate\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Resource types to associate\"\ + ,\"description\":\"The list of resource types to be associated to the custom\ + \ provider.\",\"strongType\":\"resourceTypes\"}},\"associationNamePrefix\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Association name prefix\"\ + ,\"description\":\"Prefix to be added to the name of the association resource\ + \ being created.\"},\"defaultValue\":\"DeployedByPolicy\"}},\"policyRule\"\ + :{\"if\":{\"field\":\"type\",\"in\":\"[parameters('resourceTypesToAssociate')]\"\ + },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.CustomProviders/Associations\"\ + ,\"name\":\"[concat(parameters('associationNamePrefix'), '-', uniqueString(parameters('targetCustomProviderId')))]\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"associatedResourceName\"\ + :{\"type\":\"string\"},\"resourceTypesToAssociate\":{\"type\":\"string\"},\"\ + targetCustomProviderId\":{\"type\":\"string\"},\"associationNamePrefix\":{\"\ + type\":\"string\"}},\"variables\":{\"resourceType\":\"[concat(parameters('resourceTypesToAssociate'),\ + \ '/providers/associations')]\",\"resourceName\":\"[concat(parameters('associatedResourceName'),\ + \ '/microsoft.customproviders/', parameters('associationNamePrefix'), '-',\ + \ uniqueString(parameters('targetCustomProviderId')))]\"},\"resources\":[{\"\ + type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2017-05-10\",\"\ + name\":\"[concat(deployment().Name, '-2')]\",\"properties\":{\"mode\":\"Incremental\"\ + ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"type\":\"[variables('resourceType')]\"\ + ,\"name\":\"[variables('resourceName')]\",\"apiVersion\":\"2018-09-01-preview\"\ + ,\"properties\":{\"targetResourceId\":\"[parameters('targetCustomProviderId')]\"\ + }}]}}}]},\"parameters\":{\"resourceTypesToAssociate\":{\"value\":\"[field('type')]\"\ + },\"associatedResourceName\":{\"value\":\"[field('name')]\"},\"targetCustomProviderId\"\ + :{\"value\":\"[parameters('targetCustomProviderId')]\"},\"associationNamePrefix\"\ + :{\"value\":\"[parameters('associationNamePrefix')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c15c281f-ea5c-44cd-90b8-fc3c14d13f0c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c15c281f-ea5c-44cd-90b8-fc3c14d13f0c\"\ + },{\"properties\":{\"displayName\":\"Deploy associations for a managed application\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys\ + \ an association resource that associates selected resource types to the specified\ + \ managed application. This policy deployment does not support nested resource\ + \ types.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Managed Application\"\ + },\"parameters\":{\"targetManagedApplicationId\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Managed application ID\",\"description\":\"Resource ID\ + \ of the managed application to which resources need to be associated.\"}},\"\ + resourceTypesToAssociate\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Resource types to associate\",\"description\":\"The list of resource types\ + \ to be associated to the managed application.\",\"strongType\":\"resourceTypes\"\ + }},\"associationNamePrefix\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Association name prefix\",\"description\":\"Prefix to be added to the name\ + \ of the association resource being created.\"},\"defaultValue\":\"DeployedByPolicy\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":\"[parameters('resourceTypesToAssociate')]\"\ + },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.CustomProviders/Associations\"\ + ,\"name\":\"[concat(parameters('associationNamePrefix'), '-', uniqueString(parameters('targetManagedApplicationId')))]\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"associatedResourceName\"\ + :{\"type\":\"string\"},\"resourceTypesToAssociate\":{\"type\":\"string\"},\"\ + targetManagedApplicationId\":{\"type\":\"string\"},\"associationNamePrefix\"\ + :{\"type\":\"string\"}},\"variables\":{\"resourceType\":\"[concat(parameters('resourceTypesToAssociate'),\ + \ '/providers/associations')]\",\"resourceName\":\"[concat(parameters('associatedResourceName'),\ + \ '/microsoft.customproviders/', parameters('associationNamePrefix'), '-',\ + \ uniqueString(parameters('targetManagedApplicationId')))]\"},\"resources\"\ + :[{\"type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2017-05-10\"\ + ,\"name\":\"[concat(deployment().Name, '-2')]\",\"properties\":{\"mode\":\"\ + Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"type\":\"[variables('resourceType')]\"\ + ,\"name\":\"[variables('resourceName')]\",\"apiVersion\":\"2018-09-01-preview\"\ + ,\"properties\":{\"targetResourceId\":\"[parameters('targetManagedApplicationId')]\"\ + }}]}}}]},\"parameters\":{\"resourceTypesToAssociate\":{\"value\":\"[field('type')]\"\ + },\"associatedResourceName\":{\"value\":\"[field('name')]\"},\"targetManagedApplicationId\"\ + :{\"value\":\"[parameters('targetManagedApplicationId')]\"},\"associationNamePrefix\"\ + :{\"value\":\"[parameters('associationNamePrefix')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17763ad9-70c0-4794-9397-53d765932634\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17763ad9-70c0-4794-9397-53d765932634\"\ + },{\"properties\":{\"displayName\":\"Require encryption on Data Lake Store\ + \ accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"This policy ensures encryption is enabled on all Data Lake Store accounts\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Data Lake\"},\"parameters\"\ + :{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataLakeStore/accounts\"\ + },{\"field\":\"Microsoft.DataLakeStore/accounts/encryptionState\",\"equals\"\ + :\"Disabled\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7ff3161-0087-490a-9ad9-ad6217f4f43a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7ff3161-0087-490a-9ad9-ad6217f4f43a\"\ + },{\"properties\":{\"displayName\":\"Deploy Advanced Threat Protection for\ + \ Cosmos DB Accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"This policy enables Advanced Threat Protection across Cosmos\ + \ DB accounts.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cosmos\ + \ DB\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"DeployIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ + :\"Microsoft.DocumentDB/databaseAccounts\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.Security/advancedThreatProtectionSettings\"\ + ,\"name\":\"current\",\"existenceCondition\":{\"field\":\"Microsoft.Security/advancedThreatProtectionSettings/isEnabled\"\ + ,\"equals\":\"true\"},\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"cosmosDbAccountName\":{\"\ + type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-01-01\",\"type\"\ + :\"Microsoft.DocumentDB/databaseAccounts/providers/advancedThreatProtectionSettings\"\ + ,\"name\":\"[concat(parameters('cosmosDbAccountName'), '/Microsoft.Security/current')]\"\ + ,\"properties\":{\"isEnabled\":true}}]},\"parameters\":{\"cosmosDbAccountName\"\ + :{\"value\":\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b5f04e03-92a3-4b09-9410-2cc5e5047656\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b5f04e03-92a3-4b09-9410-2cc5e5047656\"\ + },{\"properties\":{\"displayName\":\"Enable Automanage - Azure virtual machine\ + \ best practices\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Automanage enrolls, configures, and monitors virtual machines with Azure\ + \ VM best practice services. Use this policy to apply Automanage to your selected\ + \ scope.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Automanage\"\ + },\"parameters\":{\"automanageAccount\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Automanage account\",\"description\":\"Select Automanage\ + \ account from dropdown list. If this account is outside of the scope of the\ + \ assignment you must manually grant 'Contributor' permissions (or similar)\ + \ on the account to the policy assignment's principal ID.\",\"strongType\"\ + :\"Microsoft.Automanage/accounts\",\"assignPermissions\":true}},\"configurationProfileAssignment\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Configuration profile\"\ + ,\"description\":\"The management services provided are based on whether the\ + \ machine is intended to be used in a dev/test environment or production.\"\ + },\"allowedValues\":[\"Azure virtual machine best practices \u2013 Production\"\ + ,\"Azure virtual machine best practices \u2013 Dev/test\"],\"defaultValue\"\ + :\"Azure virtual machine best practices \u2013 Production\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":[\"eastus\",\"westus2\"\ + ,\"westcentralus\",\"westeurope\",\"canadacentral\"]},{\"field\":\"type\"\ ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ @@ -10708,263 +11332,192 @@ interactions: ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ + :\"SQL2008*\"}]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ + :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ],\"type\":\"Microsoft.Automanage/configurationProfileAssignments\",\"name\"\ + :\"default\",\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Automanage/configurationProfileAssignments/configurationProfile\"\ + ,\"equals\":\"[parameters('configurationProfileAssignment')]\"},{\"field\"\ + :\"Microsoft.Automanage/configurationProfileAssignments/accountId\",\"equals\"\ + :\"[parameters('automanageAccount')]\"}]},\"deployment\":{\"properties\":{\"\ + mode\":\"incremental\",\"parameters\":{\"machineName\":{\"value\":\"[field('Name')]\"\ + },\"automanageAccount\":{\"value\":\"[parameters('automanageAccount')]\"},\"\ + configurationProfileAssignment\":{\"value\":\"[parameters('configurationProfileAssignment')]\"\ + }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"machineName\":{\"type\"\ + :\"String\"},\"automanageAccount\":{\"type\":\"string\"},\"configurationProfileAssignment\"\ + :{\"type\":\"string\"}},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/providers/configurationProfileAssignments\"\ + ,\"apiVersion\":\"2020-06-30-preview\",\"name\":\"[concat(parameters('machineName'),\ + \ '/Microsoft.Automanage/', 'default')]\",\"properties\":{\"configurationProfile\"\ + :\"[parameters('configurationProfileAssignment')]\",\"accountId\":\"[parameters('automanageAccount')]\"\ + }}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/270610db-8c04-438a-a739-e8e6745b22d3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"270610db-8c04-438a-a739-e8e6745b22d3\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy Dependency agent to\ + \ Windows Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"This policy deploys the Dependency agent to Windows Azure\ + \ Arc machines if the agent isn't installed.\",\"metadata\":{\"version\":\"\ + 1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsNetworkSecurity\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c028d2a-1889-45f6-b821-31f42711ced8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c028d2a-1889-45f6-b821-31f42711ced8\"\ - },{\"properties\":{\"displayName\":\"Audit Log Analytics agent deployment\ - \ in virtual machine scale sets - VM Image (OS) unlisted\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Reports virtual machine\ - \ scale sets as non-compliant if the VM Image (OS) is not in the list defined\ - \ and the agent is not installed. The list of OS images will be updated over\ - \ time as support is updated.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude_windows\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM images that\ - \ have supported Windows OS to add to scope\",\"description\":\"Example value:\ - \ '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]},\"listOfImageIdToInclude_linux\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"Optional: List of VM images that have supported\ - \ Linux OS to add to scope\",\"description\":\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"not\":{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_windows')]\"\ - },{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_linux')]\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7.*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\"\ - ,\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}}]},\"then\"\ - :{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c3bc7b8-a64c-4e08-a9cd-7ff0f31e1138\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c3bc7b8-a64c-4e08-a9cd-7ff0f31e1138\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1671 - Flaw\ - \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1671\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c5bbef7-a316-415b-9b38-29753ce8e698\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c5bbef7-a316-415b-9b38-29753ce8e698\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1067 - Wireless\ - \ Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1067\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c5e54f6-0127-44d0-8b61-f31dc8dd6190\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c5e54f6-0127-44d0-8b61-f31dc8dd6190\"\ - },{\"properties\":{\"displayName\":\"External accounts with write permissions\ - \ should be removed from your subscription\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"All\",\"description\":\"External accounts with write privileges should\ - \ be removed from your subscription in order to prevent unmonitored access.\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"04e7147b-0deb-9796-2e5c-0336343ceb3d\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5c607a2e-c700-4744-8254-d77e7c9eb5e4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5c607a2e-c700-4744-8254-d77e7c9eb5e4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1483 - Water\ - \ Damage Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1483\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5cb81060-3c8a-4968-bcdc-395a1801f6c1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5cb81060-3c8a-4968-bcdc-395a1801f6c1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1362 - Incident\ - \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1362\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5d169442-d6ef-439b-8dca-46c2c3248214\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5d169442-d6ef-439b-8dca-46c2c3248214\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1014 - Account\ - \ Management | Removal Of Temporary / Emergency Accounts\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1014\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5dee936c-8037-4df1-ab35-6635733da48c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5dee936c-8037-4df1-ab35-6635733da48c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1665 - Process\ - \ Isolation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1665\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5df3a55c-8456-44d4-941e-175f79332512\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5df3a55c-8456-44d4-941e-175f79332512\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Function App should only\ - \ be accessible over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Use of HTTPS ensures server/service authentication and protects\ - \ data in transit from network layer eavesdropping attacks.\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"\ - field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\"\ - :\"kind\",\"equals\":\"functionapp\"},{\"field\":\"kind\",\"equals\":\"functionapp,linux\"\ - },{\"field\":\"kind\",\"equals\":\"functionapp,linux,container\"}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"OnlyHttpsForFunctionApp\",\"existenceCondition\":{\"field\":\"\ - Microsoft.Security/complianceResults/resourceStatus\",\"in\":[\"OffByPolicy\"\ - ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5df82f4f-773a-4a2d-97a2-422a806f1a55\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5df82f4f-773a-4a2d-97a2-422a806f1a55\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1251 - Contingency\ - \ Plan | Coordinate With Related Plans\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1251\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5e2b3730-8c14-4081-8893-19dbb5de7348\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e2b3730-8c14-4081-8893-19dbb5de7348\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using latest supported .NET Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported .NET Framework\ - \ version for the latest security classes. Using older classes and types can\ - \ make your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"app\"},{\"field\":\"kind\",\"equals\":\"WebApp\"},{\"field\":\"kind\",\"\ - equals\":\"app,linux\"},{\"field\":\"kind\",\"equals\":\"app,linux,container\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Security/complianceResults\",\"name\":\"UseLatestDotNet\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5e3315e0-a414-4efb-a4d2-c7bd2b0443d2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e3315e0-a414-4efb-a4d2-c7bd2b0443d2\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that do not have the specified applications installed. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WhitelistedApplication\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5e393799-e3ca-4e43-a9a5-0ec4648a57d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e393799-e3ca-4e43-a9a5-0ec4648a57d9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1116 - Audit\ - \ Review, Analysis, And Reporting\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1116\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5e47bc51-35d1-44b8-92af-e2f2d8b67635\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e47bc51-35d1-44b8-92af-e2f2d8b67635\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1208 - Configuration\ - \ Settings\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1208\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5ea87673-d06b-456f-a324-8abcee5c159f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5ea87673-d06b-456f-a324-8abcee5c159f\"\ + }]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"DependencyAgentWindows\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ + Microsoft.HybridCompute/machines/extensions/provisioningState\",\"equals\"\ + :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"}},\"variables\":{\"DaExtensionName\":\"\ + DependencyAgentWindows\",\"DaExtensionType\":\"DependencyAgentWindows\"},\"\ + resources\":[{\"type\":\"Microsoft.HybridCompute/machines\",\"apiVersion\"\ + :\"2020-03-11-preview\",\"name\":\"[parameters('vmName')]\",\"location\":\"\ + [parameters('location')]\",\"resources\":[{\"type\":\"extensions\",\"apiVersion\"\ + :\"2020-03-11-preview\",\"name\":\"[variables('DaExtensionName')]\",\"location\"\ + :\"[parameters('location')]\",\"dependsOn\":[\"[concat('Microsoft.HybridCompute/machines/',\ + \ parameters('vmName'))]\"],\"properties\":{\"publisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ + ,\"type\":\"[variables('DaExtensionType')]\",\"autoUpgradeMinorVersion\":true,\"\ + settings\":{}}}]}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\"\ + :\"[concat('Enabled DA extension for VM', ': ', parameters('vmName'))]\"}}},\"\ + parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ + value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/91cb9edd-cd92-4d2f-b2f2-bdd8d065a3d4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"91cb9edd-cd92-4d2f-b2f2-bdd8d065a3d4\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy Dependency agent to\ + \ hybrid Linux Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Indexed\",\"description\":\"This policy deploys the Dependency agent to Linux\ + \ Azure Arc machines if the agent isn't installed.\",\"metadata\":{\"version\"\ + :\"1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ + },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]},\"\ + then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"DependencyAgentLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ + Microsoft.HybridCompute/machines/extensions/provisioningState\",\"equals\"\ + :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ + DependencyAgentLinux\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ + ,\"vmExtensionType\":\"DependencyAgentLinux\"},\"resources\":[{\"name\":\"\ + [concat(parameters('vmName'), '/', variables('vmExtensionName'))]\",\"type\"\ + :\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"[parameters('location')]\"\ + ,\"apiVersion\":\"2019-12-12\",\"properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\"\ + ,\"type\":\"[variables('vmExtensionType')]\",\"settings\":{}}}],\"outputs\"\ + :{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled DA extension\ + \ for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"vmName\":{\"\ + value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/deacecc0-9f84-44d2-bb82-46f32d766d43\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"deacecc0-9f84-44d2-bb82-46f32d766d43\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Web Application Firewall\ + \ should be enabled for Azure Front Door Service or Application Gateway\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Requires\ + \ Web Application Firewall on any Azure Front Door Service or Application\ + \ Gateway. A Web Application Firewall provides greater security for your other\ + \ Azure resources.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ + :\"Network\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Deny\"}},\"policyRule\"\ + :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/frontdoors\"\ + },{\"field\":\"Microsoft.Network/frontdoors/frontendEndpoints[*].webApplicationFirewallPolicyLink.id\"\ + ,\"exists\":\"false\"}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/applicationGateways\"\ + },{\"field\":\"Microsoft.Network/applicationGateways/webApplicationFirewallConfiguration\"\ + ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/be7ed5c8-2660-4136-8216-e6f3412ba909\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"be7ed5c8-2660-4136-8216-e6f3412ba909\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ + \ only in European data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Allows resource creation in the following locations only:\ + \ North Europe, West Europe\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ + ,\"category\":\"General\",\"deprecated\":true},\"parameters\":{},\"policyRule\"\ + :{\"if\":{\"not\":{\"field\":\"location\",\"in\":[\"northeurope\",\"westeurope\"\ + ]}},\"then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/94c19f19-8192-48cd-a11b-e37099d3e36b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"94c19f19-8192-48cd-a11b-e37099d3e36b\"\ + },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Recovery\ + \ Services Vault to Log Analytics workspace for resource specific categories.\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploy\ + \ Diagnostic Settings for Recovery Services Vault to stream to Log Analytics\ + \ workspace for Resource specific categories. If any of the Resource specific\ + \ categories are not enabled, a new diagnostic setting is created.\",\"metadata\"\ + :{\"version\":\"1.0.2\",\"category\":\"Backup\"},\"parameters\":{\"profileName\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ + :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_logAnalytics\"\ + },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ + \ Analytics workspace\",\"description\":\"Select Log Analytics workspace from\ + \ dropdown list. If this workspace is outside of the scope of the assignment\ + \ you must manually grant 'Log Analytics Contributor' permissions (or similar)\ + \ to the policy assignment's principal ID.\",\"strongType\":\"omsWorkspace\"\ + ,\"assignPermissions\":true}},\"tagName\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Exclusion Tag Name\",\"description\":\"Name of the tag\ + \ to use for excluding vaults from this policy. This should be used along\ + \ with the Exclusion Tag Value parameter.\"},\"defaultValue\":\"\"},\"tagValue\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Value\"\ + ,\"description\":\"Value of the tag to use for excluding vaults from this\ + \ policy. This should be used along with the Exclusion Tag Name parameter.\"\ + },\"defaultValue\":\"\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"\ + type\",\"equals\":\"Microsoft.RecoveryServices/vaults\"},{\"not\":{\"field\"\ + :\"[concat('tags[',parameters('tagName'), ']')]\",\"equals\":\"[parameters('tagValue')]\"\ + }}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ + ,\"existenceCondition\":{\"allof\":[{\"count\":{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\"\ + ,\"where\":{\"allof\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].Category\"\ + ,\"in\":[\"CoreAzureBackup\",\"AddonAzureBackupJobs\",\"AddonAzureBackupAlerts\"\ + ,\"AddonAzureBackupPolicy\",\"AddonAzureBackupStorage\",\"AddonAzureBackupProtectedInstance\"\ + ]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].Enabled\",\"\ + equals\":\"True\"}]}},\"Equals\":6},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ + ,\"notEquals\":\"\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logAnalyticsDestinationType\"\ + ,\"equals\":\"Dedicated\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vaultName\":{\"type\":\"\ + string\"},\"logAnalytics\":{\"type\":\"string\"},\"profileName\":{\"type\"\ + :\"string\"}},\"variables\":{},\"resources\":[{\"type\":\"Microsoft.RecoveryServices/vaults/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('vaultName'),\ + \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"dependsOn\"\ + :[],\"properties\":{\"workspaceId\":\"[parameters('logAnalytics')]\",\"logAnalyticsDestinationType\"\ + :\"Dedicated\",\"metrics\":[],\"logs\":[{\"category\":\"CoreAzureBackup\"\ + ,\"enabled\":\"true\"},{\"category\":\"AddonAzureBackupAlerts\",\"enabled\"\ + :\"true\"},{\"category\":\"AddonAzureBackupJobs\",\"enabled\":\"true\"},{\"\ + category\":\"AddonAzureBackupPolicy\",\"enabled\":\"true\"},{\"category\"\ + :\"AddonAzureBackupProtectedInstance\",\"enabled\":\"true\"},{\"category\"\ + :\"AddonAzureBackupStorage\",\"enabled\":\"true\"}]}}],\"outputs\":{\"policy\"\ + :{\"type\":\"string\",\"value\":\"[concat(parameters('logAnalytics'), 'configured\ + \ for resource logs for ', ': ', parameters('vaultName'), '/', 'Microsoft.Insights/',\ + \ parameters('profileName'))]\"}}},\"parameters\":{\"logAnalytics\":{\"value\"\ + :\"[parameters('logAnalytics')]\"},\"vaultName\":{\"value\":\"[field('name')]\"\ + },\"profileName\":{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/c717fb0c-d118-4c43-ab3d-ece30ac81fb3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c717fb0c-d118-4c43-ab3d-ece30ac81fb3\"\ + },{\"properties\":{\"displayName\":\"Azure API for FHIR should use a customer-managed\ + \ key (CMK) to encrypt data at rest\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Use a customer-managed key to control the encryption\ + \ at rest of the data stored in Azure API for FHIR when this is a regulatory\ + \ or compliance requirement. Customer-managed keys also deliver double encryption\ + \ by adding a second layer of encryption on top of the default one done with\ + \ service-managed keys.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ + :\"API for FHIR\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"audit\",\"disabled\"],\"defaultValue\"\ + :\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.HealthcareApis/services\"},{\"field\":\"Microsoft.HealthcareApis/services/cosmosDbConfiguration.keyVaultKeyUri\"\ + ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/051cba44-2429-45b9-9649-46cec11c7119\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"051cba44-2429-45b9-9649-46cec11c7119\"\ + },{\"properties\":{\"displayName\":\"CORS should not allow every domain to\ + \ access your API for FHIR\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Cross-Origin Resource Sharing (CORS) should not allow all\ + \ domains to access your API for FHIR. To protect your API for FHIR, remove\ + \ access for all domains and explicitly define the domains allowed to connect.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"API for FHIR\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"audit\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"\ + if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HealthcareApis/services\"\ + },{\"not\":{\"field\":\"Microsoft.HealthcareApis/services/corsConfiguration.origins[*]\"\ + ,\"notEquals\":\"*\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/0fea8f8a-4169-495d-8307-30ec335f387d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0fea8f8a-4169-495d-8307-30ec335f387d\"\ },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ \ only in India data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ ,\"description\":\"Allows resource creation in the following locations only:\ @@ -10973,424 +11526,1228 @@ interactions: :{\"if\":{\"not\":{\"field\":\"location\",\"in\":[\"westindia\",\"southindia\"\ ,\"centralindia\"]}},\"then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5ee85ce5-e7eb-44d6-b4a2-32a24be1ca54\"\ ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5ee85ce5-e7eb-44d6-b4a2-32a24be1ca54\"\ - },{\"properties\":{\"displayName\":\"Deploy Log Analytics agent for Linux\ - \ virtual machine scale sets\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploy Log Analytics agent for Linux virtual machine scale\ - \ sets if the VM Image (OS) is in the list defined and the agent is not installed.\ - \ Note: if your scale set upgradePolicy is set to Manual, you need to apply\ - \ the extension to the all VMs in the set by calling upgrade on them. In CLI\ - \ this would be az vmss update-instances.\",\"metadata\":{\"version\":\"1.1.0\"\ - ,\"category\":\"Monitoring\"},\"parameters\":{\"logAnalytics\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\",\"description\"\ - :\"Select Log Analytics workspace from dropdown list. If this workspace is\ - \ outside of the scope of the assignment you must manually grant 'Log Analytics\ - \ Contributor' permissions (or similar) to the policy assignment's principal\ - \ ID.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Linux OS to add to scope\",\"description\":\"\ - Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\",\"\ - RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7.*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\"\ - ,\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"}]},\"deployment\":{\"\ - properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + },{\"properties\":{\"displayName\":\"Diagnostic logs in IoT Hub should be\ + \ enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ + \ trails to use for investigation purposes; when a security incident occurs\ + \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.1\"\ + ,\"category\":\"Internet of Things\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ + ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ + ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ + :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Devices/IotHubs\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ + :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ + anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"greaterOrEquals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\"\ + :\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\":\"true\"\ + }]},{\"allOf\":[{\"not\":{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"equals\":\"true\"}},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"true\"}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/383856f8-de7f-44a2-81fc-e5135b5c2aa4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"383856f8-de7f-44a2-81fc-e5135b5c2aa4\"\ + },{\"properties\":{\"displayName\":\"Audit delegation of scopes to a managing\ + \ tenant\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ + Audit delegation of scopes to a managing tenant via Azure Lighthouse.\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Lighthouse\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ + if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ManagedServices/registrationAssignments\"\ + },{\"value\":\"true\",\"equals\":\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/76bed37b-484f-430f-a009-fd7592dff818\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"76bed37b-484f-430f-a009-fd7592dff818\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy Log Analytics agent\ + \ to Linux Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"This policy deploys the Log Analytics agent to Linux Azure\ + \ Arc machines if the agent isn't installed.\",\"metadata\":{\"version\":\"\ + 1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"parameters\"\ + :{\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Log Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ + \ the agent should be connected to. If this workspace is outside of the scope\ + \ of the assignment you must manually grant 'Log Analytics Contributor' permissions\ + \ (or similar) to the policy assignment's principal ID.\",\"strongType\":\"\ + omsWorkspace\",\"assignPermissions\":true}}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"},{\"\ + field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]},\"then\"\ + :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ }},\"variables\":{\"vmExtensionName\":\"OMSAgentForLinux\",\"vmExtensionPublisher\"\ :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"OmsAgentForLinux\"\ - ,\"vmExtensionTypeHandlerVersion\":\"1.7\"},\"resources\":[{\"name\":\"[concat(parameters('vmName'),\ - \ '/', variables('vmExtensionName'))]\",\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"apiVersion\":\"2018-06-01\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'),\ - \ '2015-03-20').customerId]\",\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\"\ - :{\"workspaceKey\":\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ + },\"resources\":[{\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ + ,\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"\ + [parameters('location')]\",\"apiVersion\":\"2019-12-12\",\"properties\":{\"\ + publisher\":\"[variables('vmExtensionPublisher')]\",\"type\":\"[variables('vmExtensionType')]\"\ + ,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'), '2015-03-20').customerId]\"\ + ,\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\":{\"workspaceKey\"\ + :\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ + }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ + \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ + vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ + },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d2b61b4-1d14-4a63-be30-d4498e7ad2cf\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d2b61b4-1d14-4a63-be30-d4498e7ad2cf\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy Log Analytics agent\ + \ to Windows Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"This policy deploys the Log Analytics agent to Windows\ + \ Azure Arc machines if the agent isn't installed.\",\"metadata\":{\"version\"\ + :\"1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"parameters\"\ + :{\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Log Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ + \ the agent should be connected to. If this workspace is outside of the scope\ + \ of the assignment you must manually grant 'Log Analytics Contributor' permissions\ + \ (or similar) to the policy assignment's principal ID.\",\"strongType\":\"\ + omsWorkspace\",\"assignPermissions\":true}}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"},{\"\ + field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"}]},\"\ + then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ + ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ + }},\"variables\":{\"vmExtensionName\":\"MicrosoftMonitoringAgent\",\"vmExtensionPublisher\"\ + :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"MicrosoftMonitoringAgent\"\ + },\"resources\":[{\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ + ,\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"\ + [parameters('location')]\",\"apiVersion\":\"2019-12-12\",\"properties\":{\"\ + publisher\":\"[variables('vmExtensionPublisher')]\",\"type\":\"[variables('vmExtensionType')]\"\ + ,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'), '2015-03-20').customerId]\"\ + ,\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\":{\"workspaceKey\"\ + :\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for: ', parameters('vmName'))]\"}}},\"parameters\":{\"vmName\"\ - :{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ + \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ + vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/5ee9e9ed-0b42-41b7-8c9c-3cfb2fbe2069\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5ee9e9ed-0b42-41b7-8c9c-3cfb2fbe2069\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Private endpoint should be\ - \ configured for Key Vault\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Private link provides a way to connect key vault to your\ - \ Azure resources without sending traffic over the public internet. Private\ - \ link provides defense in depth protection against data exfiltration.\",\"\ - metadata\":{\"version\":\"1.0.1-preview\",\"category\":\"Key Vault\",\"preview\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/69af7d4a-7b18-4044-93a9-2651498ef203\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69af7d4a-7b18-4044-93a9-2651498ef203\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Web Application Firewall\ + \ should be a set mode for Application Gateway and Azure Front Door Service\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Mandates\ + \ detect or prevent mode to be active on all Web Application Firewall policies\ + \ for Azure Front Door and Application Gateway. Web Application Firewall policies\ + \ can have a consistent mode configuration across a resource group.\",\"metadata\"\ + :{\"version\":\"1.0.0-deprecated\",\"category\":\"Network\",\"deprecated\"\ :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.KeyVault/vaults\"},{\"anyOf\":[{\"field\":\"Microsoft.KeyVault/vaults/privateEndpointConnections\"\ - ,\"exists\":\"false\"},{\"count\":{\"field\":\"Microsoft.KeyVault/vaults/privateEndpointConnections[*]\"\ - },\"equals\":0}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f0bc445-3935-4915-9981-011aa2b46147\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f0bc445-3935-4915-9981-011aa2b46147\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities in Azure Container Registry\ - \ images should be remediated\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Container image vulnerability assessment scans your registry\ - \ for security vulnerabilities on each pushed container image and exposes\ - \ detailed findings for each image (powered by Qualys). Resolving the vulnerabilities\ - \ can greatly improve your containers' security posture and protect them from\ - \ attacks.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"\ + :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ + defaultValue\":\"Deny\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Deprecated]: Mode Requirement\",\"description\":\"Mode\ + \ required for all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"\ + ],\"defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ + allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/frontdoorwebapplicationfirewallpolicies\"\ + },{\"field\":\"Microsoft.Network/frontdoorWebApplicationFirewallPolicies/policySettings.mode\"\ + ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies\"\ + },{\"field\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies/policySettings.mode\"\ + ,\"notEquals\":\"[parameters('modeRequirement')]\"}]}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f6b68e5a-7207-4638-a1fb-47d90404209e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f6b68e5a-7207-4638-a1fb-47d90404209e\"\ + },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ + \ MariaDB servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Private endpoint connections enforce secure communication by enabling private\ + \ connectivity to Azure Database for MariaDB. Configure a private endpoint\ + \ connection to enable access to traffic coming only from known networks and\ + \ prevent access from all other IP addresses, including within Azure.\",\"\ + metadata\":{\"version\":\"1.0.2\",\"category\":\"SQL\"},\"parameters\":{\"\ + effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ + description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMariaDB/servers\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.DBforMariaDB/servers/privateEndpointConnections\",\"existenceCondition\"\ + :{\"field\":\"Microsoft.DBforMariaDB/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ + ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a1302fb-a631-4106-9753-f3d494733990\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a1302fb-a631-4106-9753-f3d494733990\"\ + },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ + \ MySQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Private endpoint connections enforce secure communication by enabling private\ + \ connectivity to Azure Database for MySQL. Configure a private endpoint connection\ + \ to enable access to traffic coming only from known networks and prevent\ + \ access from all other IP addresses, including within Azure.\",\"metadata\"\ + :{\"version\":\"1.0.2\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ + policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.DBforMySQL/servers/privateEndpointConnections\",\"existenceCondition\"\ + :{\"field\":\"Microsoft.DBforMySQL/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ + ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7595c971-233d-4bcf-bd18-596129188c49\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7595c971-233d-4bcf-bd18-596129188c49\"\ + },{\"properties\":{\"displayName\":\"Public network access should be disabled\ + \ for MySQL flexible servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Disabling the public network access property improves security\ + \ by ensuring your Azure Database for MySQL flexible servers can only be accessed\ + \ from a private endpoint. This configuration strictly disables access from\ + \ any public address space outside of Azure IP range and denies all logins\ + \ that match IP or virtual network-based firewall rules.\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"\ + allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/flexibleServers\"\ + },{\"field\":\"Microsoft.DBforMySQL/flexibleServers/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c9299215-ae47-4f50-9c54-8a392f68a052\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c9299215-ae47-4f50-9c54-8a392f68a052\"\ + },{\"properties\":{\"displayName\":\"Infrastructure encryption should be enabled\ + \ for Azure Database for MySQL servers\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Enable infrastructure encryption for Azure\ + \ Database for MySQL servers to have higher level of assurance that the data\ + \ is secure. When infrastructure encryption is enabled, the data at rest is\ + \ encrypted twice using FIPS 140-2 compliant Microsoft managed keys.\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"\ + effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ + description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ + },{\"field\":\"Microsoft.DBforMySQL/servers/infrastructureEncryption\",\"\ + notEquals\":\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3a58212a-c829-4f13-9872-6371df2fd0b4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3a58212a-c829-4f13-9872-6371df2fd0b4\"\ + },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ + \ PostgreSQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"Private endpoint connections enforce secure communication\ + \ by enabling private connectivity to Azure Database for PostgreSQL. Configure\ + \ a private endpoint connection to enable access to traffic coming only from\ + \ known networks and prevent access from all other IP addresses, including\ + \ within Azure.\",\"metadata\":{\"version\":\"1.0.2\",\"category\":\"SQL\"\ },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerRegistry/registries\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"dbd0cb49-b563-45e7-9724-889e799fa648\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"equals\":\"Healthy\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f0f936f-2f01-4bf5-b6be-d423792fa562\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f0f936f-2f01-4bf5-b6be-d423792fa562\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1576 - Acquisition\ - \ Process | Design / Implementation Information For Security Controls\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this System and Services Acquisition control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1576\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f18c885-ade3-48c5-80b1-8f9216019c18\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f18c885-ade3-48c5-80b1-8f9216019c18\"\ - },{\"properties\":{\"displayName\":\"External accounts with read permissions\ - \ should be removed from your subscription\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"All\",\"description\":\"External accounts with read privileges should\ - \ be removed from your subscription in order to prevent unmonitored access.\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Microsoft.DBforPostgreSQL/servers\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.DBforPostgreSQL/servers/privateEndpointConnections\"\ + ,\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ + ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0564d078-92f5-4f97-8398-b9f58a51f70b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0564d078-92f5-4f97-8398-b9f58a51f70b\"\ + },{\"properties\":{\"displayName\":\"Public network access should be disabled\ + \ for PostgreSQL flexible servers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Indexed\",\"description\":\"Disabling the public network access property improves\ + \ security by ensuring your Azure Database for PostgreSQL flexible servers\ + \ can only be accessed from a private endpoint. This configuration strictly\ + \ disables access from any public address space outside of Azure IP range\ + \ and denies all logins that match IP or virtual network-based firewall rules.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/flexibleServers\"\ + },{\"field\":\"Microsoft.DBforPostgreSQL/flexibleServers/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5e1de0e3-42cb-4ebc-a86d-61d0c619ca48\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e1de0e3-42cb-4ebc-a86d-61d0c619ca48\"\ + },{\"properties\":{\"displayName\":\"Infrastructure encryption should be enabled\ + \ for Azure Database for PostgreSQL servers\",\"policyType\":\"BuiltIn\",\"\ + mode\":\"Indexed\",\"description\":\"Enable infrastructure encryption for\ + \ Azure Database for PostgreSQL servers to have higher level of assurance\ + \ that the data is secure. When infrastructure encryption is enabled, the\ + \ data at rest is encrypted twice using FIPS 140-2 compliant Microsoft managed\ + \ keys\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ + },{\"field\":\"Microsoft.DBforPostgreSQL/servers/infrastructureEncryption\"\ + ,\"notEquals\":\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/24fba194-95d6-48c0-aea7-f65bf859c598\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"24fba194-95d6-48c0-aea7-f65bf859c598\"\ + },{\"properties\":{\"displayName\":\"Deploy Advanced Threat Protection on\ + \ Storage Accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"This policy enables Advanced Threat Protection on Storage Accounts.\",\"\ + metadata\":{\"version\":\"1.0.0\",\"category\":\"Storage\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Security/advancedThreatProtectionSettings\",\"name\":\"current\"\ + ,\"existenceCondition\":{\"field\":\"Microsoft.Security/advancedThreatProtectionSettings/isEnabled\"\ + ,\"equals\":\"true\"},\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"storageAccountName\":{\"\ + type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-01-01\",\"type\"\ + :\"Microsoft.Storage/storageAccounts/providers/advancedThreatProtectionSettings\"\ + ,\"name\":\"[concat(parameters('storageAccountName'), '/Microsoft.Security/current')]\"\ + ,\"properties\":{\"isEnabled\":true}}]},\"parameters\":{\"storageAccountName\"\ + :{\"value\":\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/361c2074-3595-4e5d-8cab-4f21dffc835c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"361c2074-3595-4e5d-8cab-4f21dffc835c\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ + \ only in United States data centers\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Allows resource creation in the following locations\ + \ only: Central US, East US, East US2, North Central US, South Central US,\ + \ West US\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ + General\",\"deprecated\":true},\"parameters\":{},\"policyRule\":{\"if\":{\"\ + not\":{\"field\":\"location\",\"in\":[\"centralus\",\"eastus\",\"eastus2\"\ + ,\"northcentralus\",\"southcentralus\",\"westus\"]}},\"then\":{\"effect\"\ + :\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/983211ba-f348-4758-983b-21fa29294869\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"983211ba-f348-4758-983b-21fa29294869\"\ + },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ + \ use the specified mode for Azure Front Door Service\",\"policyType\":\"\ + BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Mandates the use of 'Detection'\ + \ or 'Prevention' mode to be active on all Web Application Firewall policies\ + \ for Azure Front Door Service.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ + defaultValue\":\"Audit\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Mode Requirement\",\"description\":\"Mode required for\ + \ all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"],\"\ + defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Network/frontdoorwebapplicationfirewallpolicies\"\ + },{\"field\":\"Microsoft.Network/frontdoorWebApplicationFirewallPolicies/policySettings.mode\"\ + ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/425bea59-a659-4cbb-8d31-34499bd030b8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"425bea59-a659-4cbb-8d31-34499bd030b8\"\ + },{\"properties\":{\"displayName\":\"Web Application Firewall (WAF) should\ + \ use the specified mode for Application Gateway\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Mandates the use of 'Detection' or\ + \ 'Prevention' mode to be active on all Web Application Firewall policies\ + \ for Application Gateway.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ + defaultValue\":\"Audit\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Mode Requirement\",\"description\":\"Mode required for\ + \ all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"],\"\ + defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies\"\ + },{\"field\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies/policySettings.mode\"\ + ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12430be1-6cc8-4527-a9a8-e3d38f250096\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12430be1-6cc8-4527-a9a8-e3d38f250096\"\ + },{\"properties\":{\"displayName\":\"Vulnerabilities on your SQL servers on\ + \ machine should be remediated\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"SQL Vulnerability Assessment scans your database for security\ + \ vulnerabilities, and exposes any deviations from best practices such as\ + \ misconfigurations, excessive permissions, and unprotected sensitive data.\ + \ Resolving the vulnerabilities found can greatly improve your database security\ + \ posture.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"\ + },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"a8c6a4ad-d51e-88fe-2979-d3ee3c864f8b\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f76cf89-fbf2-47fd-a3f4-b891fa780b60\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f76cf89-fbf2-47fd-a3f4-b891fa780b60\"\ - },{\"properties\":{\"displayName\":\"Audit Windows virtual machines on which\ - \ the Windows Guest Configuration extension is not enabled\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy audits Windows\ - \ virtual machines hosted in Azure that are supported by Guest Configuration\ - \ but do not have the Guest Configuration extension enabled. For more information\ - \ on Guest Configuration, visit https://aka.ms/gcpol.\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Guest Configuration\"},\"parameters\":{\"effect\"\ + AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ + Microsoft.Compute/virtualMachines\",\"Microsoft.HybridCompute/machines\"]},\"\ + then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ + ,\"name\":\"f97aa83c-9b63-4f9a-99f6-b22c4398f936\",\"existenceCondition\"\ + :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"NotApplicable\"\ + ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6ba6d016-e7c3-4842-b8f2-4992ebc0d72d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6ba6d016-e7c3-4842-b8f2-4992ebc0d72d\"\ + },{\"properties\":{\"displayName\":\"Azure Batch account should use customer-managed\ + \ keys to encrypt data\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"Use customer-managed keys (CMKs) to manage the encryption\ + \ at rest of your Batch account's data. By default, customer data is encrypted\ + \ with service-managed keys, but CMKs are commonly required to meet regulatory\ + \ compliance standards. CMKs enable the data to be encrypted with an Azure\ + \ Key Vault key created and owned by you. You have full control and responsibility\ + \ for the key lifecycle, including rotation and management. Learn more about\ + \ CMK encryption at https://aka.ms/Batch-CMK.\",\"metadata\":{\"version\"\ + :\"1.0.1\",\"category\":\"Batch\"},\"parameters\":{\"effect\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"The desired\ + \ effect of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ + ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"},{\"field\":\"Microsoft.Batch/batchAccounts/encryption.keySource\"\ + ,\"notEquals\":\"Microsoft.KeyVault\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/99e9ccd8-3db9-4592-b0d1-14b1715a4d8a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"99e9ccd8-3db9-4592-b0d1-14b1715a4d8a\"\ + },{\"properties\":{\"displayName\":\"Azure Stack Edge devices should use double-encryption\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"To secure\ + \ the data at rest on the device, ensure it's double-encrypted, the access\ + \ to data is controlled, and once the device is deactivated, the data is securely\ + \ erased off the data disks. Double encryption is the use of two layers of\ + \ encryption: BitLocker XTS-AES 256-bit encryption on the data volumes and\ + \ built-in encryption of the hard drives. Learn more in the security overview\ + \ documentation for the specific Stack Edge device.\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Azure Stack Edge\"},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"The desired effect of the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.DataBoxEdge/DataBoxEdgeDevices\"\ + },{\"field\":\"Microsoft.DataboxEdge/DataBoxEdgeDevices/sku.name\",\"notIn\"\ + :[\"TEA_1Node\",\"TEA_1Node_UPS\",\"TEA_1Node_Heater\",\"TEA_1Node_UPS_Heater\"\ + ,\"TEA_4Node_Heater\",\"TEA_4Node_UPS_Heater\",\"TMA\",\"EdgePR_Base\",\"\ + EdgePR_Base_UPS\",\"EdgeMR_Mini\"]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b4ac1030-89c5-4697-8e00-28b5ba6a8811\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4ac1030-89c5-4697-8e00-28b5ba6a8811\"\ + },{\"properties\":{\"displayName\":\"Workbooks should be saved to storage\ + \ accounts that you control\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"With bring your own storage (BYOS), your workbooks are\ + \ uploaded into a storage account that you control. That means you control\ + \ the encryption-at-rest policy, the lifetime management policy, and network\ + \ access. You will, however, be responsible for the costs associated with\ + \ that storage account. For more information, visit https://aka.ms/workbooksByos\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Audit, Deny, or Disable the execution of this policy\"\ + },\"allowedValues\":[\"deny\",\"audit\",\"disabled\"],\"defaultValue\":\"\ + audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"microsoft.insights/workbooks\"},{\"field\":\"microsoft.insights/workbooks/storageUri\"\ + ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/6fc8115b-2008-441f-8c61-9b722c1e537f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6fc8115b-2008-441f-8c61-9b722c1e537f\"\ + },{\"properties\":{\"displayName\":\"Bot Service endpoint should be a valid\ + \ HTTPS URI\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Data can be tampered with during transmission. Protocols exist that provide\ + \ encryption to address problems of misuse and tampering. To ensure your bots\ + \ are communicating only over encrypted channels, set the endpoint to a valid\ + \ HTTPS URI. This ensures the HTTPS protocol is used to encrypt your data\ + \ in transit and is also often a requirement for compliance with regulatory\ + \ or industry standards. Please visit: https://docs.microsoft.com/azure/bot-service/bot-builder-security-guidelines.\"\ + ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Bot Service\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The desired effect of the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.BotService/botServices\"\ + },{\"field\":\"Microsoft.BotService/botServices/endpoint\",\"notLike\":\"\ + https://*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ + /providers/Microsoft.Authorization/policyDefinitions/6164527b-e1ee-4882-8673-572f425f5e0a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6164527b-e1ee-4882-8673-572f425f5e0a\"\ + },{\"properties\":{\"displayName\":\"Azure data factories should be encrypted\ + \ with a customer-managed key (CMK)\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Use customer-managed keys (CMKs) to manage\ + \ the encryption at rest of your Azure Data Factory. By default, customer\ + \ data is encrypted with service-managed keys, but CMKs are commonly required\ + \ to meet regulatory compliance standards. CMKs enable the data to be encrypted\ + \ with an Azure Key Vault key created and owned by you. You have full control\ + \ and responsibility for the key lifecycle, including rotation and management.\ + \ Learn more about CMK encryption at https://aka.ms/adf-cmk.\",\"metadata\"\ + :{\"version\":\"1.0.1\",\"category\":\"Data Factory\"},\"parameters\":{\"\ + effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ + description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataFactory/factories\"\ + },{\"field\":\"Microsoft.DataFactory/factories/encryption.vaultBaseUrl\",\"\ + exists\":false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/4ec52d6d-beb7-40c4-9a9e-fe753254690e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ec52d6d-beb7-40c4-9a9e-fe753254690e\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy - Configure Linux machines\ + \ to automatically install the Azure Security agent\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Configure Linux machines to automatically\ + \ install the Azure Security agent. Security Center collects events from the\ + \ agent and uses them to provide security alerts and tailored hardening tasks\ + \ (recommendations). Create a resource group and Log Analytics workspace in\ + \ the same region as the machine to store audit records. Target virtual machines\ + \ must be in a supported location.\",\"metadata\":{\"category\":\"Security\ + \ Center\",\"version\":\"1.0.0-preview\",\"preview\":true},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":[\"australiacentral\",\"australiaeast\",\"\ + australiasoutheast\",\"centralindia\",\"centralus\",\"eastasia\",\"eastus2euap\"\ + ,\"eastus\",\"eastus2\",\"germanywestcentral\",\"japaneast\",\"northcentralus\"\ + ,\"northeurope\",\"southcentralus\",\"southeastasia\",\"uksouth\",\"westcentralus\"\ + ,\"westeurope\",\"westus\",\"westus2\"]},{\"anyOf\":[{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"SLES\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\"\ + ,\"SLES-Priority\",\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"equals\":\"Oracle-Linux\"},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"7*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"debian\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"9\"}]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Debian\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"debian-10\"]},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"10\"}]}]}]},\"then\":{\"\ + effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ + ,\"deploymentScope\":\"subscription\",\"existenceCondition\":{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/virtualMachines/extensions/type\",\"equals\":\"\ + AzureSecurityLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/Publisher\"\ + ,\"equals\":\"Microsoft.Azure.Security.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ + ,\"in\":[\"Succeeded\",\"Provisioning succeeded\"]}]},\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"deployment\":{\"location\":\"eastus\",\"properties\":{\"mode\":\"incremental\"\ + ,\"parameters\":{\"resourceGroup\":{\"value\":\"[resourceGroup().name]\"},\"\ + location\":{\"value\":\"[field('location')]\"},\"vmName\":{\"value\":\"[field('name')]\"\ + }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceGroup\":{\"type\"\ + :\"string\"},\"location\":{\"type\":\"string\"},\"vmName\":{\"type\":\"string\"\ + }},\"variables\":{\"pairedLocations\":{\"australiacentral\":\"australiacentral\"\ + ,\"australiaeast\":\"australiaeast\",\"australiasoutheast\":\"australiasoutheast\"\ + ,\"centralindia\":\"centralindia\",\"centralus\":\"centralus\",\"eastasia\"\ + :\"eastasia\",\"eastus2euap\":\"eastus2euap\",\"eastus\":\"eastus\",\"eastus2\"\ + :\"eastus2\",\"germanywestcentral\":\"germanywestcentral\",\"japaneast\":\"\ + japaneast\",\"northcentralus\":\"northcentralus\",\"northeurope\":\"northeurope\"\ + ,\"southcentralus\":\"southcentralus\",\"southeastasia\":\"southeastasia\"\ + ,\"uksouth\":\"uksouth\",\"westcentralus\":\"westcentralus\",\"westeurope\"\ + :\"westeurope\",\"westus\":\"westus\",\"westus2\":\"westus2\"},\"locationLongNameToShortMap\"\ + :{\"australiacentral\":\"CAU\",\"australiaeast\":\"EAU\",\"australiasoutheast\"\ + :\"SEAU\",\"centralindia\":\"CIN\",\"centralus\":\"CUS\",\"eastasia\":\"EA\"\ + ,\"eastus2euap\":\"eus2p\",\"eastus\":\"EUS\",\"eastus2\":\"EUS2\",\"germanywestcentral\"\ + :\"DEWC\",\"japaneast\":\"EJP\",\"northcentralus\":\"NCUS\",\"northeurope\"\ + :\"NEU\",\"southcentralus\":\"SCUS\",\"southeastasia\":\"SEA\",\"uksouth\"\ + :\"SUK\",\"westcentralus\":\"WCUS\",\"westeurope\":\"WEU\",\"westus\":\"WUS\"\ + ,\"westus2\":\"WUS2\"},\"locationCode\":\"[variables('locationLongNameToShortMap')[variables('pairedLocations')[parameters('location')]]]\"\ + ,\"subscriptionId\":\"[subscription().subscriptionId]\",\"defaultRGName\"\ + :\"[concat('DefaultResourceGroup-', variables('locationCode'))]\",\"defaultRGLocation\"\ + :\"[variables('pairedLocations')[parameters('location')]]\",\"workspaceName\"\ + :\"[concat('defaultWorkspace-', variables('subscriptionId'),'-', variables('locationCode'))]\"\ + ,\"dcrName\":\"[concat('Microsoft-Security-', variables('locationCode'), '-dcr')]\"\ + ,\"dcrId\":\"[concat('/subscriptions/', variables('subscriptionId'), '/resourceGroups/',\ + \ variables('defaultRGName'), '/providers/Microsoft.Insights/dataCollectionRules/',\ + \ variables('dcrName'))]\",\"dcraName\":\"[concat(parameters('vmName'),'/Microsoft.Insights/Security-RulesAssociation')]\"\ + ,\"deployAzureSecurityLinuxAgent\":\"[concat('deployAzureSecurityLinuxAgent-',\ + \ uniqueString(deployment().name))]\",\"deployDefaultAscResourceGroup\":\"\ + [concat('deployDefaultAscResourceGroup-', uniqueString(deployment().name))]\"\ + ,\"deployDataCollectionRulesAssociation\":\"[concat('deployDataCollectionRulesAssociation-',\ + \ uniqueString(deployment().name))]\"},\"resources\":[{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"[variables('deployAzureSecurityLinuxAgent')]\",\"apiVersion\"\ + :\"2020-06-01\",\"resourceGroup\":\"[parameters('resourceGroup')]\",\"properties\"\ + :{\"mode\":\"Incremental\",\"expressionEvaluationOptions\":{\"scope\":\"inner\"\ + },\"parameters\":{\"location\":{\"value\":\"[parameters('location')]\"},\"\ + vmName\":{\"value\":\"[parameters('vmName')]\"}},\"template\":{\"$schema\"\ + :\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ + string\"},\"vmName\":{\"type\":\"string\"}},\"variables\":{},\"resources\"\ + :[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"[concat(parameters('vmName'),\ + \ '/', 'AzureSecurityLinuxAgent')]\",\"apiVersion\":\"2019-03-01\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Security.Monitoring\"\ + ,\"type\":\"AzureSecurityLinuxAgent\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :\"true\",\"settings\":{},\"protectedsettings\":{}}}]}}},{\"type\":\"Microsoft.Resources/resourceGroups\"\ + ,\"name\":\"[variables('defaultRGName')]\",\"apiVersion\":\"2019-05-01\",\"\ + location\":\"[variables('defaultRGLocation')]\"},{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"[variables('deployDefaultAscResourceGroup')]\",\"apiVersion\"\ + :\"2020-06-01\",\"resourceGroup\":\"[variables('defaultRGName')]\",\"properties\"\ + :{\"mode\":\"Incremental\",\"expressionEvaluationOptions\":{\"scope\":\"inner\"\ + },\"parameters\":{\"defaultRGLocation\":{\"value\":\"[variables('defaultRGLocation')]\"\ + },\"workspaceName\":{\"value\":\"[variables('workspaceName')]\"},\"dcrName\"\ + :{\"value\":\"[variables('dcrName')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"defaultRGLocation\":{\"\ + type\":\"string\"},\"workspaceName\":{\"type\":\"string\"},\"dcrName\":{\"\ + type\":\"string\"}},\"variables\":{\"securitySolution\":{\"Name\":\"[Concat('Security',\ + \ '(', parameters('workspaceName'), ')')]\",\"GalleryName\":\"Security\"},\"\ + securityCenterFreeSolution\":{\"Name\":\"[Concat('SecurityCenterFree', '(',\ + \ parameters('workspaceName'), ')')]\",\"GalleryName\":\"SecurityCenterFree\"\ + }},\"resources\":[{\"type\":\"Microsoft.OperationalInsights/workspaces\",\"\ + name\":\"[parameters('workspaceName')]\",\"apiVersion\":\"2015-11-01-preview\"\ + ,\"location\":\"[parameters('defaultRGLocation')]\",\"properties\":{\"sku\"\ + :{\"name\":\"pernode\"},\"retentionInDays\":30,\"features\":{\"searchVersion\"\ + :1}}},{\"type\":\"Microsoft.OperationsManagement/solutions\",\"name\":\"[variables('securitySolution').Name]\"\ + ,\"apiVersion\":\"2015-11-01-preview\",\"location\":\"[parameters('defaultRGLocation')]\"\ + ,\"dependsOn\":[\"[parameters('workspaceName')]\"],\"properties\":{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + },\"plan\":{\"name\":\"[variables('securitySolution').Name]\",\"publisher\"\ + :\"Microsoft\",\"product\":\"[Concat('OMSGallery/', variables('securitySolution').GalleryName)]\"\ + ,\"promotionCode\":\"\"}},{\"type\":\"Microsoft.OperationsManagement/solutions\"\ + ,\"name\":\"[variables('securityCenterFreeSolution').Name]\",\"apiVersion\"\ + :\"2015-11-01-preview\",\"location\":\"[parameters('defaultRGLocation')]\"\ + ,\"dependsOn\":[\"[parameters('workspaceName')]\"],\"properties\":{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + },\"plan\":{\"name\":\"[variables('securityCenterFreeSolution').Name]\",\"\ + publisher\":\"Microsoft\",\"product\":\"[Concat('OMSGallery/', variables('securityCenterFreeSolution').GalleryName)]\"\ + ,\"promotionCode\":\"\"}},{\"type\":\"Microsoft.Insights/dataCollectionRules\"\ + ,\"name\":\"[parameters('dcrName')]\",\"apiVersion\":\"2019-11-01-preview\"\ + ,\"location\":\"[parameters('defaultRGLocation')]\",\"dependsOn\":[\"[parameters('workspaceName')]\"\ + ],\"properties\":{\"description\":\"Data collection rule for Azure Security\ + \ Center. Deleting this rule will break the detection of security vulnerabilities.\"\ + ,\"dataSources\":{\"windowsEventLogs\":[{\"name\":\"RomeDetectionEventDataSource\"\ + ,\"streams\":[\"Microsoft-RomeDetectionEvent\"],\"scheduledTransferPeriod\"\ + :\"PT5M\",\"xPathQueries\":[\"Security!*\",\"Microsoft-Windows-AppLocker/EXE\ + \ and DLL!*\"]}],\"syslog\":[{\"name\":\"SyslogDataSource\",\"streams\":[\"\ + Microsoft-Syslog\"],\"facilityNames\":[\"kern\",\"auth\",\"authpriv\",\"cron\"\ + ,\"user\",\"daemon\",\"syslog\",\"local0\"],\"logLevels\":[\"Debug\",\"Critical\"\ + ,\"Emergency\"]}],\"extensions\":[{\"extensionName\":\"AzureSecurityLinuxAgent\"\ + ,\"name\":\"AscLinuxDataSource\",\"streams\":[\"Microsoft-OperationLog\",\"\ + Microsoft-SecurityBaseline\",\"Microsoft-SecurityBaselineSummary\",\"Microsoft-ProcessInvestigator\"\ + ,\"Microsoft-Auditd\",\"Microsoft-ProtectionStatus\",\"Microsoft-Heartbeat\"\ + ],\"extensionSettings\":{\"scanners\":[{\"name\":\"heartbeat\",\"frequency\"\ + :\"PT1H\"},{\"name\":\"time\",\"frequency\":\"PT8H\"},{\"name\":\"antimalware\"\ + ,\"frequency\":\"PT8H\"},{\"name\":\"codeintegrity\",\"frequency\":\"P1D\"\ + },{\"name\":\"processinvestigator\",\"frequency\":\"PT1H\"},{\"name\":\"baseline\"\ + ,\"frequency\":\"P1D\",\"options\":[{\"name\":\"Baseline\",\"value\":\"Azure.Ubuntu\"\ + },{\"name\":\"AscBaseline\",\"value\":\"OMS.Linux\"}]},{\"name\":\"docker\"\ + ,\"frequency\":\"P1D\",\"options\":[{\"name\":\"Baseline\",\"value\":\"Azure.Docker.Linux\"\ + },{\"name\":\"AscBaseline\",\"value\":\"OMS.Docker.Linux\"}]}]}},{\"extensionName\"\ + :\"AzureSecurityWindowsAgent\",\"name\":\"AsaWindowsDataSource\",\"streams\"\ + :[\"Microsoft-OperationLog\",\"Microsoft-SecurityBaseline\",\"Microsoft-ProcessInvestigator\"\ + ,\"Microsoft-ProtectionStatus\",\"Microsoft-SecurityBaselineSummary\"],\"\ + extensionSettings\":{\"scanners\":[{\"name\":\"heartbeat\",\"frequency\":\"\ + PT1H\"},{\"name\":\"baseline\",\"frequency\":\"P1D\"},{\"name\":\"antimalware\"\ + ,\"frequency\":\"P1D\"},{\"name\":\"processinvestigator\",\"frequency\":\"\ + PT1H\"}]}}]},\"destinations\":{\"logAnalytics\":[{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + ,\"name\":\"LogAnalyticsDest\"}]},\"dataFlows\":[{\"streams\":[\"Microsoft-Syslog\"\ + ,\"Microsoft-OperationLog\",\"Microsoft-SecurityBaseline\",\"Microsoft-SecurityBaselineSummary\"\ + ,\"Microsoft-RomeDetectionEvent\",\"Microsoft-ProcessInvestigator\",\"Microsoft-Auditd\"\ + ,\"Microsoft-ProtectionStatus\",\"Microsoft-Heartbeat\"],\"destinations\"\ + :[\"LogAnalyticsDest\"]}]}}]}},\"dependsOn\":[\"[resourceId('Microsoft.Resources/resourceGroups',\ + \ variables('defaultRGName'))]\"]},{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"[variables('deployDataCollectionRulesAssociation')]\",\"apiVersion\"\ + :\"2020-06-01\",\"resourceGroup\":\"[parameters('resourceGroup')]\",\"dependsOn\"\ + :[\"[variables('deployDefaultAscResourceGroup')]\"],\"properties\":{\"mode\"\ + :\"Incremental\",\"expressionEvaluationOptions\":{\"scope\":\"inner\"},\"\ + parameters\":{\"location\":{\"value\":\"[parameters('location')]\"},\"vmName\"\ + :{\"value\":\"[parameters('vmName')]\"},\"dcrId\":{\"value\":\"[variables('dcrId')]\"\ + },\"dcraName\":{\"value\":\"[variables('dcraName')]\"}},\"template\":{\"$schema\"\ + :\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ + string\"},\"vmName\":{\"type\":\"string\"},\"dcrId\":{\"type\":\"string\"\ + },\"dcraName\":{\"type\":\"string\"}},\"variables\":{},\"resources\":[{\"\ + type\":\"Microsoft.Compute/virtualMachines/providers/dataCollectionRuleAssociations\"\ + ,\"name\":\"[parameters('dcraName')]\",\"apiVersion\":\"2019-11-01-preview\"\ + ,\"properties\":{\"description\":\"Association of data collection rule for\ + \ Azure Security Center. Deleting this association will break the detection\ + \ of security vulnerabilities for this virtual machine.\",\"dataCollectionRuleId\"\ + :\"[parameters('dcrId')]\"}}]}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f8eb305-9c9f-4abe-9bb0-df220d9faba2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f8eb305-9c9f-4abe-9bb0-df220d9faba2\"\ + },{\"properties\":{\"displayName\":\"Azure HDInsight clusters should use encryption\ + \ at host to encrypt data at rest\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Indexed\",\"description\":\"Enabling encryption at host helps protect and\ + \ safeguard your data to meet your organizational security and compliance\ + \ commitments. When you enable encryption at host, data stored on the VM host\ + \ is encrypted at rest and flows encrypted to the Storage service.\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"HDInsight\"},\"parameters\":{\"effect\"\ :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"\ - details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\"\ - :\"AzurePolicyforWindows\",\"existenceCondition\":{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/publisher\",\"equals\":\"Microsoft.GuestConfiguration\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\",\"equals\"\ - :\"ConfigurationforWindows\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5fc23db3-dd4d-4c56-bcc7-43626243e601\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5fc23db3-dd4d-4c56-bcc7-43626243e601\"\ - },{\"properties\":{\"displayName\":\"Add or replace a tag on resources\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Adds or replaces\ - \ the specified tag and value when any resource is created or updated. Existing\ - \ resources can be remediated by triggering a remediation task. Does not modify\ - \ tags on resource groups.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Tag Name\",\"description\":\"Name of the tag, such as 'environment'\"\ - }},\"tagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Value\"\ - ,\"description\":\"Value of the tag, such as 'production'\"}}},\"policyRule\"\ - :{\"if\":{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"notEquals\"\ - :\"[parameters('tagValue')]\"},\"then\":{\"effect\":\"modify\",\"details\"\ - :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/5ffd78d9-436d-4b41-a421-5baa819e3008\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5ffd78d9-436d-4b41-a421-5baa819e3008\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1663 - Protection\ - \ Of Information At Rest\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1663\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/60171210-6dde-40af-a144-bf2670518bfa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60171210-6dde-40af-a144-bf2670518bfa\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Object Access'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Object Access'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesObjectAccess\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/60aeaf73-a074-417a-905f-7ce9df0ff77b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60aeaf73-a074-417a-905f-7ce9df0ff77b\"\ - },{\"properties\":{\"displayName\":\"Storage Accounts should use a virtual\ - \ network service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any Storage Account not configured to\ - \ use a virtual network service endpoint.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Network\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Storage/storageAccounts/networkAcls.defaultAction\",\"\ - notEquals\":\"Deny\"},{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.virtualNetworkRules[*].id\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/60d21c4f-21a3-4d94-85f4-b924e6aeeda4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60d21c4f-21a3-4d94-85f4-b924e6aeeda4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows web servers that are not using secure communication protocols\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ web servers that are not using secure communication protocols (TLS 1.1 or\ - \ TLS 1.2). For more information on Guest Configuration policies, please visit\ - \ https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"\ - category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HDInsight/clusters\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.HDInsight/clusters/diskEncryptionProperties.encryptionAtHost\"\ + ,\"exists\":false},{\"field\":\"Microsoft.HDInsight/clusters/diskEncryptionProperties.encryptionAtHost\"\ + ,\"equals\":false}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/1fd32ebd-e4c3-4e13-a54a-d7422d4d95f6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1fd32ebd-e4c3-4e13-a54a-d7422d4d95f6\"\ + },{\"properties\":{\"displayName\":\"Vulnerability assessment should be enabled\ + \ on your Synapse workspaces\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Discover, track, and remediate potential vulnerabilities\ + \ by configuring recurring SQL vulnerability assessment scans on your Synapse\ + \ workspaces.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Synapse\"\ + },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ + AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Synapse/workspaces\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.Synapse/workspaces/vulnerabilityAssessments\"\ + ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Synapse/workspaces/vulnerabilityAssessments/recurringScans.isEnabled\"\ + ,\"equals\":\"True\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0049a6b3-a662-4f3e-8635-39cf44ace45a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0049a6b3-a662-4f3e-8635-39cf44ace45a\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure disaster recovery\ + \ on virtual machines by enabling replication\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Virtual machines without disaster\ + \ recovery configurations are vulnerable to outages and other disruptions.\ + \ If the virtual machine does not already have disaster recovery configured,\ + \ this would initiate the same by enabling replication using preset configurations\ + \ to facilitate business continuity. To learn more about disaster recovery,\ + \ visit https://aka.ms/asr-doc.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Compute\"},\"parameters\":{\"sourceRegion\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Source Region\",\"description\":\"Region in which the\ + \ virtual machine is originally deployed\",\"strongType\":\"location\"}},\"\ + targetRegion\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Target\ + \ Region\",\"description\":\"Region to be used to deploy the virtual machine\ + \ in case of a natural disaster\",\"strongType\":\"location\"}},\"targetResourceGroupId\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Target Resource Group\"\ + ,\"description\":\"Resource group to be used to create the virtual machine\ + \ in the target region\",\"assignPermissions\":true}},\"vaultResourceGroupId\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Vault Resource Group\"\ + ,\"description\":\"The resource group containing the recovery services vault\ + \ used for disaster recovery configurations\",\"assignPermissions\":true}},\"\ + vaultId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Recovery Services\ + \ Vault\",\"description\":\"ID of the recovery services vault to be used for\ + \ disaster recovery configurations\",\"strongType\":\"Microsoft.RecoveryServices/vaults\"\ + }},\"recoveryNetworkId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Recovery Virtual Network\",\"description\":\"Existing Recovery Virtual\ + \ Network ID or name of the Virtual Network to be created in Target Region\"\ + ,\"strongType\":\"Microsoft.Network/virtualNetworks\"},\"defaultValue\":\"\ + \"},\"targetZone\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Target\ + \ Availability Zone\",\"description\":\"Availability zone in the designated\ + \ target region to be used by virtual machines during disaster\"},\"defaultValue\"\ + :\"\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Compute/virtualMachines\"},{\"field\":\"location\",\"equals\"\ + :\"[parameters('sourceRegion')]\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.vhd.uri\"\ + ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.encryptionSettings\"\ + ,\"exists\":\"false\"},{\"anyOf\":[{\"allOf\":[{\"field\":\"location\",\"\ + equals\":\"[parameters('targetRegion')]\"},{\"field\":\"Microsoft.Compute/virtualMachines/zones\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/zones[*]\"\ + ,\"notEquals\":\"[parameters('targetZone')]\"}]},{\"allOf\":[{\"field\":\"\ + location\",\"notEquals\":\"[parameters('targetRegion')]\"},{\"field\":\"Microsoft.Compute/virtualMachines/zones\"\ + ,\"exists\":\"true\"},{\"value\":\"[length(parameters('targetZone'))]\",\"\ + greater\":0}]},{\"allOf\":[{\"field\":\"location\",\"notEquals\":\"[parameters('targetRegion')]\"\ + },{\"field\":\"Microsoft.Compute/virtualMachines/zones\",\"exists\":\"false\"\ + }]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"\ + Microsoft.Resources/links\",\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/8e3af657-a8ff-443c-a75c-2fe8c4bcb635\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"name\",\"like\":\"ASR-Protect-*\"\ + },{\"field\":\"Microsoft.Resources/links/targetId\",\"contains\":\"/replicationProtectedItems/\"\ + }]},\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\"\ + :{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"apiVersion\":{\"type\":\"\ + String\"},\"avSetId\":{\"type\":\"String\"},\"dataDiskIds\":{\"type\":\"object\"\ + },\"osDiskId\":{\"type\":\"String\"},\"ppgId\":{\"type\":\"String\"},\"recoveryNetworkId\"\ + :{\"type\":\"String\"},\"recoverySubscriptionId\":{\"type\":\"String\"},\"\ + sourceRegion\":{\"type\":\"String\"},\"sourceResourceGroupName\":{\"type\"\ + :\"String\"},\"targetRegion\":{\"type\":\"String\"},\"targetResourceGroupName\"\ + :{\"type\":\"String\"},\"targetZone\":{\"type\":\"String\"},\"vaultName\"\ + :{\"type\":\"String\"},\"vaultResourceGroupName\":{\"type\":\"String\"},\"\ + vmId\":{\"type\":\"String\"},\"vmZones\":{\"type\":\"Object\"}},\"variables\"\ + :{\"avSetApiVersion\":\"2019-03-01\",\"deploymentApiVersion\":\"2017-05-10\"\ + ,\"vmApiVersion\":\"2019-07-01\",\"ppgApiVersion\":\"2019-12-01\",\"portalLinkPrefix\"\ + :\"https://portal.azure.com/#@microsoft.onmicrosoft.com/resource\",\"schemaLink\"\ + :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"defaultAvSet\":\"defaultAvSet-asr\",\"defaultPPG\":\"defaultPPG-asr\",\"\ + eligibilityResultsDefault\":\"default\",\"protectedItemSuffix\":\"-policy\"\ + ,\"recoveryAvSetPrefix\":\"RecoveryAvSet-\",\"recoveryPPGPrefix\":\"RecoveryPPG-\"\ + ,\"avSetType\":\"Microsoft.Compute/availabilitySets\",\"deploymentType\":\"\ + Microsoft.Resources/deployments\",\"networkType\":\"Microsoft.Network/virtualNetworks\"\ + ,\"ppgType\":\"Microsoft.Compute/proximityPlacementGroups\",\"replicationEligibilityResultsType\"\ + :\"Microsoft.RecoveryServices/replicationEligibilityResults\",\"storageType\"\ + :\"Microsoft.Storage/storageAccounts\",\"vaultType\":\"Microsoft.RecoveryServices/vaults\"\ + ,\"avSetTemplateName\":\"[concat(variables('recoveryAvSetPrefix'), last(split(parameters('vmId'),\ + \ '/')))]\",\"avSetTemplateName64\":\"[if(greater(length(variables('avSetTemplateName')),\ + \ 64), substring(variables('avSetTemplateName'), 0, 64), variables('avSetTemplateName'))]\"\ + ,\"ppgTemplateName\":\"[concat(variables('recoveryPPGPrefix'), last(split(parameters('vmId'),\ + \ '/')))]\",\"ppgTemplateName64\":\"[if(greater(length(variables('ppgTemplateName')),\ + \ 64), substring(variables('ppgTemplateName'), 0, 64), variables('ppgTemplateName'))]\"\ + ,\"replicationProtectedIntentTemplateName\":\"[concat('ASR-', parameters('sourceResourceGroupName'),\ + \ '-', last(split(parameters('vmId'), '/')))]\",\"replicationProtectedIntentTemplateName64\"\ + :\"[if(greater(length(variables('replicationProtectedIntentTemplateName')),\ + \ 64), substring(variables('replicationProtectedIntentTemplateName'), 0, 64),\ + \ variables('replicationProtectedIntentTemplateName'))]\",\"vmDataDiskIds\"\ + :\"[array(parameters('dataDiskIds').rawValue)]\",\"vmDiskCount\":\"[add(length(variables('vmDataDiskIds')),\ + \ int(1))]\",\"diskIds\":\"[concat(array(parameters('osDiskId')), array(parameters('dataDiskIds').rawValue))]\"\ + ,\"vaultId\":\"[resourceId(parameters('vaultResourceGroupName'), variables('vaultType'),\ + \ parameters('vaultName'))]\",\"eligibilityResultsId\":\"[extensionResourceId(parameters('vmId'),\ + \ variables('replicationEligibilityResultsType'), variables('eligibilityResultsDefault'))]\"\ + ,\"protectedIntentName\":\"[concat(parameters('vaultName'), '/', guid(resourceGroup().id,\ + \ last(split(parameters('vmId'), '/'))), variables('protectedItemSuffix'))]\"\ + ,\"recoveryAvSetName\":\"[if(empty(parameters('avSetId')), variables('defaultAvSet'),\ + \ concat(last(split(parameters('avSetId'), '/')), '-asr'))]\",\"recoveryAvSetId\"\ + :\"[if(empty(parameters('avSetId')), '', resourceId(parameters('targetResourceGroupName'),\ + \ variables('avSetType'), variables('recoveryAvSetName')))]\",\"recoveryAvType\"\ + :\"[if(not(empty(parameters('avSetId'))), 'AvailabilitySet', if(greater(length(parameters('vmZones').rawValue),\ + \ 0), 'AvailabilityZone', 'Single'))]\",\"recoveryAvZone\":\"[if(greater(length(parameters('vmZones').rawValue),\ + \ 0), parameters('targetZone'), '')]\",\"recoveryPPGName\":\"[if(empty(parameters('ppgId')),\ + \ variables('defaultPPG'), concat(last(split(parameters('ppgId'), '/')), '-asr'))]\"\ + ,\"recoveryPPGId\":\"[if(empty(parameters('ppgId')), '', resourceId(parameters('targetResourceGroupName'),\ + \ variables('ppgType'), variables('recoveryPPGName')))]\",\"targetResourceGroupId\"\ + :\"[concat('/subscriptions/', parameters('recoverySubscriptionId'), '/resourceGroups/',\ + \ parameters('targetResourceGroupName'))]\"},\"resources\":[{\"condition\"\ + :\"[not(empty(parameters('ppgId')))]\",\"apiVersion\":\"[variables('deploymentApiVersion')]\"\ + ,\"name\":\"[variables('ppgTemplateName64')]\",\"type\":\"Microsoft.Resources/deployments\"\ + ,\"resourceGroup\":\"[parameters('targetResourceGroupName')]\",\"properties\"\ + :{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"[variables('schemaLink')]\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ + :[{\"condition\":\"[not(empty(parameters('ppgId')))]\",\"type\":\"[variables('ppgType')]\"\ + ,\"name\":\"[variables('recoveryPPGName')]\",\"apiVersion\":\"[variables('ppgApiVersion')]\"\ + ,\"location\":\"[parameters('targetRegion')]\",\"properties\":{\"proximityPlacementGroupType\"\ + :\"[if(empty(parameters('ppgId')), 'Standard', reference(parameters('ppgId'),\ + \ variables('ppgApiVersion')).proximityPlacementGroupType)]\"}}]},\"parameters\"\ + :{}}},{\"condition\":\"[not(empty(parameters('avSetId')))]\",\"apiVersion\"\ + :\"[variables('deploymentApiVersion')]\",\"name\":\"[variables('avSetTemplateName64')]\"\ + ,\"type\":\"Microsoft.Resources/deployments\",\"resourceGroup\":\"[parameters('targetResourceGroupName')]\"\ + ,\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"[variables('schemaLink')]\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ + :[{\"condition\":\"[not(empty(parameters('avSetId')))]\",\"type\":\"[variables('avSetType')]\"\ + ,\"sku\":{\"name\":\"[if(empty(parameters('avSetId')), 'Aligned', reference(parameters('avSetId'),\ + \ variables('avSetApiVersion'), 'Full').sku.name)]\"},\"name\":\"[variables('recoveryAvSetName')]\"\ + ,\"apiVersion\":\"[variables('avSetApiVersion')]\",\"location\":\"[parameters('targetRegion')]\"\ + ,\"tags\":{},\"properties\":{\"platformUpdateDomainCount\":\"[if(empty(parameters('avSetId')),\ + \ '5', reference(parameters('avSetId'), variables('avSetApiVersion')).platformUpdateDomainCount)]\"\ + ,\"platformFaultDomainCount\":\"[if(empty(parameters('avSetId')), '2', reference(parameters('avSetId'),\ + \ variables('avSetApiVersion')).platformFaultDomainCount)]\",\"proximityPlacementGroup\"\ + :\"[if(empty(parameters('ppgId')), json('null'), json(concat('{', '\\\"id\\\ + \"', ':', '\\\"', variables('recoveryPPGId'), '\\\"', '}')))]\"}}]},\"parameters\"\ + :{}},\"dependsOn\":[\"[variables('ppgTemplateName64')]\"]},{\"apiVersion\"\ + :\"[variables('deploymentApiVersion')]\",\"name\":\"[variables('replicationProtectedIntentTemplateName64')]\"\ + ,\"type\":\"Microsoft.Resources/deployments\",\"resourceGroup\":\"[parameters('vaultResourceGroupName')]\"\ + ,\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"[variables('schemaLink')]\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ + :[{\"type\":\"Microsoft.RecoveryServices/vaults/replicationProtectionIntents\"\ + ,\"name\":\"[variables('protectedIntentName')]\",\"apiVersion\":\"[parameters('apiVersion')]\"\ + ,\"properties\":{\"providerSpecificDetails\":{\"instanceType\":\"A2A\",\"\ + fabricObjectId\":\"[parameters('vmId')]\",\"primaryLocation\":\"[parameters('sourceRegion')]\"\ + ,\"recoveryLocation\":\"[parameters('targetRegion')]\",\"recoverySubscriptionId\"\ + :\"[parameters('recoverySubscriptionId')]\",\"recoveryAvailabilityType\":\"\ + [variables('recoveryAvType')]\",\"recoveryAvailabilityZone\":\"[variables('recoveryAvZone')]\"\ + ,\"recoveryResourceGroupId\":\"[variables('targetResourceGroupId')]\",\"recoveryAvailabilitySetCustomInput\"\ + :\"[if(empty(parameters('avSetId')), json('null'), json(concat('{', '\\\"\ + resourceType\\\"', ':', '\\\"Existing\\\",', '\\\"recoveryAvailabilitySetId\\\ + \"', ':', '\\\"', variables('recoveryAvSetId'), '\\\"', '}')))]\",\"recoveryProximityPlacementGroupCustomInput\"\ + :\"[if(empty(parameters('ppgId')), json('null'), json(concat('{', '\\\"resourceType\\\ + \"', ':', '\\\"Existing\\\",', '\\\"recoveryProximityPlacementGroupId\\\"\ + ', ':', '\\\"', variables('recoveryPPGId'), '\\\"', '}')))]\",\"recoveryVirtualNetworkCustomInput\"\ + :\"[if(contains(parameters('recoveryNetworkId'), '/'), json(concat('{', '\\\ + \"resourceType\\\"', ':', '\\\"Existing\\\",', '\\\"recoveryVirtualNetworkId\\\ + \"', ':', '\\\"', parameters('recoveryNetworkId'), '\\\"', '}')), json(concat('{',\ + \ '\\\"resourceType\\\"', ':', '\\\"New\\\",', '\\\"recoveryVirtualNetworkName\\\ + \"', ':', '\\\"', parameters('recoveryNetworkId'), '\\\"', '}')))]\",\"vmDisks\"\ + :[],\"copy\":[{\"name\":\"vmManagedDisks\",\"count\":\"[variables('vmDiskCount')]\"\ + ,\"input\":{\"diskId\":\"[if(equals(copyIndex('vmManagedDisks'), int(0)),\ + \ reference(parameters('vmId'), variables('vmApiVersion')).storageProfile.osDisk.managedDisk.Id,\ + \ variables('vmDataDiskIds')[sub(copyIndex('vmManagedDisks'), int(1))])]\"\ + ,\"recoveryResourceGroupCustomInput\":{\"resourceType\":\"Existing\",\"recoveryResourceGroupId\"\ + :\"[variables('targetResourceGroupId')]\"}}}]}}}],\"outputs\":{\"vmName\"\ + :{\"value\":\"[last(split(parameters('vmId'), '/'))]\",\"type\":\"string\"\ + },\"availabilitySetUrl\":{\"value\":\"[if(empty(parameters('avSetId')), '',\ + \ concat(variables('portalLinkPrefix'), variables('recoveryAvSetId')))]\"\ + ,\"type\":\"string\"},\"proximityPlacementGroupUrl\":{\"value\":\"[if(empty(parameters('ppgId')),\ + \ '', concat(variables('portalLinkPrefix'), variables('recoveryPPGId')))]\"\ + ,\"type\":\"string\"},\"replicationEligibilityResults\":{\"value\":\"[reference(variables('eligibilityResultsId'),\ + \ parameters('apiVersion'))]\",\"type\":\"Object\"}}},\"parameters\":{}},\"\ + dependsOn\":[\"[variables('ppgTemplateName64')]\",\"[variables('avSetTemplateName64')]\"\ + ]}],\"outputs\":{}},\"parameters\":{\"apiVersion\":{\"value\":\"2018-07-10\"\ + },\"avSetId\":{\"value\":\"[field('Microsoft.Compute/virtualMachines/availabilitySet.id')]\"\ + },\"dataDiskIds\":{\"value\":{\"rawValue\":\"[field('Microsoft.Compute/virtualMachines/storageProfile.dataDisks[*].managedDisk.id')]\"\ + ,\"emptyArray\":[]}},\"osDiskId\":{\"value\":\"[field('Microsoft.Compute/virtualMachines/storageProfile.osDisk.managedDisk.id')]\"\ + },\"ppgId\":{\"value\":\"[field('Microsoft.Compute/virtualMachines/proximityPlacementGroup.id')]\"\ + },\"recoveryNetworkId\":{\"value\":\"[parameters('recoveryNetworkId')]\"},\"\ + recoverySubscriptionId\":{\"value\":\"[subscription().subscriptionId]\"},\"\ + sourceRegion\":{\"value\":\"[parameters('sourceRegion')]\"},\"sourceResourceGroupName\"\ + :{\"value\":\"[resourcegroup().Name]\"},\"targetRegion\":{\"value\":\"[parameters('targetRegion')]\"\ + },\"targetResourceGroupName\":{\"value\":\"[last(split(parameters('targetResourceGroupId'),\ + \ '/'))]\"},\"targetZone\":{\"value\":\"[parameters('targetZone')]\"},\"vaultName\"\ + :{\"value\":\"[last(split(parameters('vaultId'), '/'))]\"},\"vaultResourceGroupName\"\ + :{\"value\":\"[last(split(parameters('vaultResourceGroupId'), '/'))]\"},\"\ + vmId\":{\"value\":\"[field('id')]\"},\"vmZones\":{\"value\":{\"rawValue\"\ + :\"[field('Microsoft.Compute/virtualMachines/zones')]\",\"emptyArray\":[]}}}}}}}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/ac34a73f-9fa5-4067-9247-a3ecae514468\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac34a73f-9fa5-4067-9247-a3ecae514468\"\ + },{\"properties\":{\"displayName\":\"Azure HDInsight clusters should use customer-managed\ + \ keys to encrypt data at rest\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Use customer-managed keys (CMK) to manage the encryption\ + \ at rest of your Azure HDInsight clusters. By default, customer data is encrypted\ + \ with service-managed keys, but CMKs are commonly required to meet regulatory\ + \ compliance standards. CMKs enable the data to be encrypted with an Azure\ + \ Key Vault key created and owned by you. You have full control and responsibility\ + \ for the key lifecycle, including rotation and management. Learn more about\ + \ CMK encryption at https://aka.ms/hdi.cmk. \",\"metadata\":{\"version\":\"\ + 1.0.1\",\"category\":\"HDInsight\"},\"parameters\":{\"effect\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"\ + allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HDInsight/clusters\"},{\"\ + field\":\"Microsoft.HDInsight/clusters/diskEncryptionProperties.keyName\"\ + ,\"exists\":false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/64d314f6-6062-4780-a861-c23e8951bee5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"64d314f6-6062-4780-a861-c23e8951bee5\"\ + },{\"properties\":{\"displayName\":\"Azure HDInsight clusters should use encryption\ + \ in transit to encrypt communication between Azure HDInsight cluster nodes\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Data can\ + \ be tampered with during transmission between Azure HDInsight cluster nodes.\ + \ Enabling encryption in transit addresses problems of misuse and tampering\ + \ during this transmission.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"HDInsight\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ + defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ + type\",\"equals\":\"Microsoft.HDInsight/clusters\"},{\"anyOf\":[{\"field\"\ + :\"Microsoft.HDInsight/clusters/encryptionInTransitProperties.isEncryptionInTransitEnabled\"\ + ,\"exists\":false},{\"field\":\"Microsoft.HDInsight/clusters/encryptionInTransitProperties.isEncryptionInTransitEnabled\"\ + ,\"equals\":false}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/d9da03a1-f3c3-412a-9709-947156872263\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d9da03a1-f3c3-412a-9709-947156872263\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy - Configure Windows\ + \ machines to automatically install the Azure Security agent\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Configure Windows machines\ + \ to automatically install the Azure Security agent. Security Center collects\ + \ events from the agent and uses them to provide security alerts and tailored\ + \ hardening tasks (recommendations). Create a resource group and Log Analytics\ + \ workspace in the same region as the machine to store audit records. Target\ + \ virtual machines must be in a supported location.\",\"metadata\":{\"category\"\ + :\"Security Center\",\"version\":\"1.0.0-preview\",\"preview\":true},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":[\"australiacentral\",\"australiaeast\",\"\ + australiasoutheast\",\"centralindia\",\"centralus\",\"eastasia\",\"eastus2euap\"\ + ,\"eastus\",\"eastus2\",\"germanywestcentral\",\"japaneast\",\"northcentralus\"\ + ,\"northeurope\",\"southcentralus\",\"southeastasia\",\"uksouth\",\"westcentralus\"\ + ,\"westeurope\",\"westus\",\"westus2\"]},{\"anyOf\":[{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ + ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ + ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ + ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ + 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ + ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ + ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ + ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ + ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ + ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ + :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ + :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ + *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ + :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ + deploymentScope\":\"subscription\",\"existenceCondition\":{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/virtualMachines/extensions/type\",\"equals\":\"\ + AzureSecurityWindowsAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/Publisher\"\ + ,\"equals\":\"Microsoft.Azure.Security.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ + ,\"in\":[\"Succeeded\",\"Provisioning succeeded\"]}]},\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"deployment\":{\"location\":\"eastus\",\"properties\":{\"mode\":\"incremental\"\ + ,\"parameters\":{\"resourceGroup\":{\"value\":\"[resourceGroup().name]\"},\"\ + location\":{\"value\":\"[field('location')]\"},\"vmName\":{\"value\":\"[field('name')]\"\ + }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceGroup\":{\"type\"\ + :\"string\"},\"location\":{\"type\":\"string\"},\"vmName\":{\"type\":\"string\"\ + }},\"variables\":{\"pairedLocations\":{\"australiacentral\":\"australiacentral\"\ + ,\"australiaeast\":\"australiaeast\",\"australiasoutheast\":\"australiasoutheast\"\ + ,\"centralindia\":\"centralindia\",\"centralus\":\"centralus\",\"eastasia\"\ + :\"eastasia\",\"eastus2euap\":\"eastus2euap\",\"eastus\":\"eastus\",\"eastus2\"\ + :\"eastus2\",\"germanywestcentral\":\"germanywestcentral\",\"japaneast\":\"\ + japaneast\",\"northcentralus\":\"northcentralus\",\"northeurope\":\"northeurope\"\ + ,\"southcentralus\":\"southcentralus\",\"southeastasia\":\"southeastasia\"\ + ,\"uksouth\":\"uksouth\",\"westcentralus\":\"westcentralus\",\"westeurope\"\ + :\"westeurope\",\"westus\":\"westus\",\"westus2\":\"westus2\"},\"locationLongNameToShortMap\"\ + :{\"australiacentral\":\"CAU\",\"australiaeast\":\"EAU\",\"australiasoutheast\"\ + :\"SEAU\",\"centralindia\":\"CIN\",\"centralus\":\"CUS\",\"eastasia\":\"EA\"\ + ,\"eastus2euap\":\"eus2p\",\"eastus\":\"EUS\",\"eastus2\":\"EUS2\",\"germanywestcentral\"\ + :\"DEWC\",\"japaneast\":\"EJP\",\"northcentralus\":\"NCUS\",\"northeurope\"\ + :\"NEU\",\"southcentralus\":\"SCUS\",\"southeastasia\":\"SEA\",\"uksouth\"\ + :\"SUK\",\"westcentralus\":\"WCUS\",\"westeurope\":\"WEU\",\"westus\":\"WUS\"\ + ,\"westus2\":\"WUS2\"},\"locationCode\":\"[variables('locationLongNameToShortMap')[variables('pairedLocations')[parameters('location')]]]\"\ + ,\"subscriptionId\":\"[subscription().subscriptionId]\",\"defaultRGName\"\ + :\"[concat('DefaultResourceGroup-', variables('locationCode'))]\",\"defaultRGLocation\"\ + :\"[variables('pairedLocations')[parameters('location')]]\",\"workspaceName\"\ + :\"[concat('defaultWorkspace-', variables('subscriptionId'),'-', variables('locationCode'))]\"\ + ,\"dcrName\":\"[concat('Microsoft-Security-', variables('locationCode'), '-dcr')]\"\ + ,\"dcrId\":\"[concat('/subscriptions/', variables('subscriptionId'), '/resourceGroups/',\ + \ variables('defaultRGName'), '/providers/Microsoft.Insights/dataCollectionRules/',\ + \ variables('dcrName'))]\",\"dcraName\":\"[concat(parameters('vmName'),'/Microsoft.Insights/Security-RulesAssociation')]\"\ + ,\"deployAzureSecurityWindowsAgent\":\"[concat('deployAzureSecurityWindowsAgent-',\ + \ uniqueString(deployment().name))]\",\"deployDefaultAscResourceGroup\":\"\ + [concat('deployDefaultAscResourceGroup-', uniqueString(deployment().name))]\"\ + ,\"deployDataCollectionRulesAssociation\":\"[concat('deployDataCollectionRulesAssociation-',\ + \ uniqueString(deployment().name))]\"},\"resources\":[{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"[variables('deployAzureSecurityWindowsAgent')]\",\"apiVersion\"\ + :\"2020-06-01\",\"resourceGroup\":\"[parameters('resourceGroup')]\",\"properties\"\ + :{\"mode\":\"Incremental\",\"expressionEvaluationOptions\":{\"scope\":\"inner\"\ + },\"parameters\":{\"location\":{\"value\":\"[parameters('location')]\"},\"\ + vmName\":{\"value\":\"[parameters('vmName')]\"}},\"template\":{\"$schema\"\ + :\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ + string\"},\"vmName\":{\"type\":\"string\"}},\"variables\":{},\"resources\"\ + :[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"[concat(parameters('vmName'),\ + \ '/', 'AzureSecurityWindowsAgent')]\",\"apiVersion\":\"2019-03-01\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Security.Monitoring\"\ + ,\"type\":\"AzureSecurityWindowsAgent\",\"typeHandlerVersion\":\"1.0\",\"\ + autoUpgradeMinorVersion\":\"true\",\"settings\":{},\"protectedsettings\":{}}}]}}},{\"\ + type\":\"Microsoft.Resources/resourceGroups\",\"name\":\"[variables('defaultRGName')]\"\ + ,\"apiVersion\":\"2019-05-01\",\"location\":\"[variables('defaultRGLocation')]\"\ + },{\"type\":\"Microsoft.Resources/deployments\",\"name\":\"[variables('deployDefaultAscResourceGroup')]\"\ + ,\"apiVersion\":\"2020-06-01\",\"resourceGroup\":\"[variables('defaultRGName')]\"\ + ,\"properties\":{\"mode\":\"Incremental\",\"expressionEvaluationOptions\"\ + :{\"scope\":\"inner\"},\"parameters\":{\"defaultRGLocation\":{\"value\":\"\ + [variables('defaultRGLocation')]\"},\"workspaceName\":{\"value\":\"[variables('workspaceName')]\"\ + },\"dcrName\":{\"value\":\"[variables('dcrName')]\"}},\"template\":{\"$schema\"\ + :\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"defaultRGLocation\":{\"\ + type\":\"string\"},\"workspaceName\":{\"type\":\"string\"},\"dcrName\":{\"\ + type\":\"string\"}},\"variables\":{\"securitySolution\":{\"Name\":\"[Concat('Security',\ + \ '(', parameters('workspaceName'), ')')]\",\"GalleryName\":\"Security\"},\"\ + securityCenterFreeSolution\":{\"Name\":\"[Concat('SecurityCenterFree', '(',\ + \ parameters('workspaceName'), ')')]\",\"GalleryName\":\"SecurityCenterFree\"\ + }},\"resources\":[{\"type\":\"Microsoft.OperationalInsights/workspaces\",\"\ + name\":\"[parameters('workspaceName')]\",\"apiVersion\":\"2015-11-01-preview\"\ + ,\"location\":\"[parameters('defaultRGLocation')]\",\"properties\":{\"sku\"\ + :{\"name\":\"pernode\"},\"retentionInDays\":30,\"features\":{\"searchVersion\"\ + :1}}},{\"type\":\"Microsoft.OperationsManagement/solutions\",\"name\":\"[variables('securitySolution').Name]\"\ + ,\"apiVersion\":\"2015-11-01-preview\",\"location\":\"[parameters('defaultRGLocation')]\"\ + ,\"dependsOn\":[\"[parameters('workspaceName')]\"],\"properties\":{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + },\"plan\":{\"name\":\"[variables('securitySolution').Name]\",\"publisher\"\ + :\"Microsoft\",\"product\":\"[Concat('OMSGallery/', variables('securitySolution').GalleryName)]\"\ + ,\"promotionCode\":\"\"}},{\"type\":\"Microsoft.OperationsManagement/solutions\"\ + ,\"name\":\"[variables('securityCenterFreeSolution').Name]\",\"apiVersion\"\ + :\"2015-11-01-preview\",\"location\":\"[parameters('defaultRGLocation')]\"\ + ,\"dependsOn\":[\"[parameters('workspaceName')]\"],\"properties\":{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + },\"plan\":{\"name\":\"[variables('securityCenterFreeSolution').Name]\",\"\ + publisher\":\"Microsoft\",\"product\":\"[Concat('OMSGallery/', variables('securityCenterFreeSolution').GalleryName)]\"\ + ,\"promotionCode\":\"\"}},{\"type\":\"Microsoft.Insights/dataCollectionRules\"\ + ,\"name\":\"[parameters('dcrName')]\",\"apiVersion\":\"2019-11-01-preview\"\ + ,\"location\":\"[parameters('defaultRGLocation')]\",\"dependsOn\":[\"[parameters('workspaceName')]\"\ + ],\"properties\":{\"description\":\"Data collection rule for Azure Security\ + \ Center. Deleting this rule will break the detection of security vulnerabilities.\"\ + ,\"dataSources\":{\"windowsEventLogs\":[{\"name\":\"RomeDetectionEventDataSource\"\ + ,\"streams\":[\"Microsoft-RomeDetectionEvent\"],\"scheduledTransferPeriod\"\ + :\"PT5M\",\"xPathQueries\":[\"Security!*\",\"Microsoft-Windows-AppLocker/EXE\ + \ and DLL!*\"]}],\"syslog\":[{\"name\":\"SyslogDataSource\",\"streams\":[\"\ + Microsoft-Syslog\"],\"facilityNames\":[\"kern\",\"auth\",\"authpriv\",\"cron\"\ + ,\"user\",\"daemon\",\"syslog\",\"local0\"],\"logLevels\":[\"Debug\",\"Critical\"\ + ,\"Emergency\"]}],\"extensions\":[{\"extensionName\":\"AzureSecurityLinuxAgent\"\ + ,\"name\":\"AscLinuxDataSource\",\"streams\":[\"Microsoft-OperationLog\",\"\ + Microsoft-SecurityBaseline\",\"Microsoft-SecurityBaselineSummary\",\"Microsoft-ProcessInvestigator\"\ + ,\"Microsoft-Auditd\",\"Microsoft-ProtectionStatus\",\"Microsoft-Heartbeat\"\ + ],\"extensionSettings\":{\"scanners\":[{\"name\":\"heartbeat\",\"frequency\"\ + :\"PT1H\"},{\"name\":\"time\",\"frequency\":\"PT8H\"},{\"name\":\"antimalware\"\ + ,\"frequency\":\"PT8H\"},{\"name\":\"codeintegrity\",\"frequency\":\"P1D\"\ + },{\"name\":\"processinvestigator\",\"frequency\":\"PT1H\"},{\"name\":\"baseline\"\ + ,\"frequency\":\"P1D\",\"options\":[{\"name\":\"Baseline\",\"value\":\"Azure.Ubuntu\"\ + },{\"name\":\"AscBaseline\",\"value\":\"OMS.Linux\"}]},{\"name\":\"docker\"\ + ,\"frequency\":\"P1D\",\"options\":[{\"name\":\"Baseline\",\"value\":\"Azure.Docker.Linux\"\ + },{\"name\":\"AscBaseline\",\"value\":\"OMS.Docker.Linux\"}]}]}},{\"extensionName\"\ + :\"AzureSecurityWindowsAgent\",\"name\":\"AsaWindowsDataSource\",\"streams\"\ + :[\"Microsoft-OperationLog\",\"Microsoft-SecurityBaseline\",\"Microsoft-ProcessInvestigator\"\ + ,\"Microsoft-ProtectionStatus\",\"Microsoft-SecurityBaselineSummary\"],\"\ + extensionSettings\":{\"scanners\":[{\"name\":\"heartbeat\",\"frequency\":\"\ + PT1H\"},{\"name\":\"baseline\",\"frequency\":\"P1D\"},{\"name\":\"antimalware\"\ + ,\"frequency\":\"P1D\"},{\"name\":\"processinvestigator\",\"frequency\":\"\ + PT1H\"}]}}]},\"destinations\":{\"logAnalytics\":[{\"workspaceResourceId\"\ + :\"[resourceId('Microsoft.OperationalInsights/workspaces/', parameters('workspaceName'))]\"\ + ,\"name\":\"LogAnalyticsDest\"}]},\"dataFlows\":[{\"streams\":[\"Microsoft-Syslog\"\ + ,\"Microsoft-OperationLog\",\"Microsoft-SecurityBaseline\",\"Microsoft-SecurityBaselineSummary\"\ + ,\"Microsoft-RomeDetectionEvent\",\"Microsoft-ProcessInvestigator\",\"Microsoft-Auditd\"\ + ,\"Microsoft-ProtectionStatus\",\"Microsoft-Heartbeat\"],\"destinations\"\ + :[\"LogAnalyticsDest\"]}]}}]}},\"dependsOn\":[\"[resourceId('Microsoft.Resources/resourceGroups',\ + \ variables('defaultRGName'))]\"]},{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"[variables('deployDataCollectionRulesAssociation')]\",\"apiVersion\"\ + :\"2020-06-01\",\"resourceGroup\":\"[parameters('resourceGroup')]\",\"dependsOn\"\ + :[\"[variables('deployDefaultAscResourceGroup')]\"],\"properties\":{\"mode\"\ + :\"Incremental\",\"expressionEvaluationOptions\":{\"scope\":\"inner\"},\"\ + parameters\":{\"location\":{\"value\":\"[parameters('location')]\"},\"vmName\"\ + :{\"value\":\"[parameters('vmName')]\"},\"dcrId\":{\"value\":\"[variables('dcrId')]\"\ + },\"dcraName\":{\"value\":\"[variables('dcraName')]\"}},\"template\":{\"$schema\"\ + :\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ + string\"},\"vmName\":{\"type\":\"string\"},\"dcrId\":{\"type\":\"string\"\ + },\"dcraName\":{\"type\":\"string\"}},\"variables\":{},\"resources\":[{\"\ + type\":\"Microsoft.Compute/virtualMachines/providers/dataCollectionRuleAssociations\"\ + ,\"name\":\"[parameters('dcraName')]\",\"apiVersion\":\"2019-11-01-preview\"\ + ,\"properties\":{\"description\":\"Association of data collection rule for\ + \ Azure Security Center. Deleting this association will break the detection\ + \ of security vulnerabilities for this virtual machine.\",\"dataCollectionRuleId\"\ + :\"[parameters('dcrId')]\"}}]}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1537496a-b1e8-482b-a06a-1cc2415cdc7b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1537496a-b1e8-482b-a06a-1cc2415cdc7b\"\ + },{\"properties\":{\"displayName\":\"[ASC Private Preview] Deploy - Configure\ + \ system-assigned managed identity to enable Azure Monitor assignments on\ + \ VMs\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ + [ASC Private Preview] Configure system-assigned managed identity to virtual\ + \ machines hosted in Azure that are supported by Azure Monitor that do not\ + \ have a system-assigned managed identity. A system-assigned managed identity\ + \ is a prerequisite for all Azure Monitor assignments and must be added to\ + \ machines before using any Azure Monitor extension. Target virtual machines\ + \ must be in a supported location.\",\"metadata\":{\"category\":\"Monitoring\"\ + ,\"version\":\"1.1.0-preview\",\"preview\":true},\"policyRule\":{\"if\":{\"\ + allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":[\"australiacentral\",\"australiaeast\",\"\ + australiasoutheast\",\"centralindia\",\"centralus\",\"eastasia\",\"eastus2euap\"\ + ,\"eastus\",\"eastus2\",\"germanywestcentral\",\"japaneast\",\"northcentralus\"\ + ,\"northeurope\",\"southcentralus\",\"southeastasia\",\"uksouth\",\"westcentralus\"\ + ,\"westeurope\",\"westus\",\"westus2\"]},{\"anyOf\":[{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"SLES\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\"\ + ,\"SLES-Priority\",\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"equals\":\"Oracle-Linux\"},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"7*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"debian\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"9\"}]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Debian\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"debian-10\"]},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"10\"}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ + ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ + ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ + ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ + 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ + ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ + ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ + ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ + ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ + ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ + :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ + :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ + *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ + :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Windows-10\"}]}]},{\"value\":\"[requestContext().apiVersion]\"\ + ,\"greaterOrEquals\":\"2018-10-01\"},{\"field\":\"identity.type\",\"notContains\"\ + :\"SystemAssigned\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/17b3de92-f710-4cf4-aa55-0e7859f1ed7b\"\ + ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"identity.type\"\ + ,\"value\":\"[if(contains(field('identity.type'), 'UserAssigned'), concat(field('identity.type'),\ + \ ',SystemAssigned'), 'SystemAssigned')]\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/17b3de92-f710-4cf4-aa55-0e7859f1ed7b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"17b3de92-f710-4cf4-aa55-0e7859f1ed7b\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy - Configure Windows\ + \ Azure Monitor agent to enable Azure Monitor assignments on Windows virtual\ + \ machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Configure Windows Azure Monitor agent to Windows virtual machines hosted\ + \ in Azure that are supported by Azure Monitor. Azure Monitor agent collects\ + \ events from the virtual machine that can be used to provide recommendations.\ + \ Target virtual machines must be in a supported location.\",\"metadata\"\ + :{\"category\":\"Monitoring\",\"version\":\"1.0.0-preview\",\"preview\":true},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":[\"australiacentral\",\"australiaeast\",\"\ + australiasoutheast\",\"centralindia\",\"centralus\",\"eastasia\",\"eastus2euap\"\ + ,\"eastus\",\"eastus2\",\"germanywestcentral\",\"japaneast\",\"northcentralus\"\ + ,\"northeurope\",\"southcentralus\",\"southeastasia\",\"uksouth\",\"westcentralus\"\ + ,\"westeurope\",\"westus\",\"westus2\"]},{\"anyOf\":[{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ + ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ + ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ + ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ + 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ + ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ + ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ + ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ + ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ + ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AuditSecureProtocol\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/60ffe3e2-4604-4460-8f22-0f1da058266c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60ffe3e2-4604-4460-8f22-0f1da058266c\"\ - },{\"properties\":{\"displayName\":\"Deploy Advanced Data Security on SQL\ - \ servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy enables Advanced Data Security on SQL Servers. This includes\ - \ turning on Threat Detection and Vulnerability Assessment. It will automatically\ - \ create a storage account in the same region and resource group as the SQL\ - \ server to store scan results, with a 'sqlva' prefix.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\"\ - :{\"effect\":\"DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"name\":\"Default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/securityAlertPolicies.state\"\ - ,\"equals\":\"Enabled\"},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"serverName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"}},\"variables\":{\"serverResourceGroupName\"\ - :\"[resourceGroup().name]\",\"subscriptionId\":\"[subscription().subscriptionId]\"\ - ,\"uniqueStorage\":\"[uniqueString(variables('subscriptionId'), variables('serverResourceGroupName'),\ - \ parameters('location'))]\",\"storageName\":\"[tolower(concat('sqlva', variables('uniqueStorage')))]\"\ - },\"resources\":[{\"type\":\"Microsoft.Storage/storageAccounts\",\"name\"\ - :\"[variables('storageName')]\",\"apiVersion\":\"2019-04-01\",\"location\"\ - :\"[parameters('location')]\",\"sku\":{\"name\":\"Standard_LRS\"},\"kind\"\ - :\"StorageV2\",\"properties\":{}},{\"name\":\"[concat(parameters('serverName'),\ - \ '/Default')]\",\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"apiVersion\":\"2017-03-01-preview\",\"properties\":{\"state\":\"Enabled\"\ - ,\"emailAccountAdmins\":true}},{\"name\":\"[concat(parameters('serverName'),\ - \ '/Default')]\",\"type\":\"Microsoft.Sql/servers/vulnerabilityAssessments\"\ - ,\"apiVersion\":\"2018-06-01-preview\",\"properties\":{\"storageContainerPath\"\ - :\"[concat(reference(resourceId('Microsoft.Storage/storageAccounts', variables('storageName'))).primaryEndpoints.blob,\ - \ 'vulnerability-assessment')]\",\"storageAccountAccessKey\":\"[listKeys(resourceId('Microsoft.Storage/storageAccounts',\ - \ variables('storageName')), '2018-02-01').keys[0].value]\",\"recurringScans\"\ - :{\"isEnabled\":true,\"emailSubscriptionAdmins\":true,\"emails\":[]}},\"dependsOn\"\ - :[\"[concat('Microsoft.Storage/storageAccounts/', variables('storageName'))]\"\ - ,\"[concat('Microsoft.Sql/servers/', parameters('serverName'), '/securityAlertPolicies/Default')]\"\ - ]}]},\"parameters\":{\"serverName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6134c3db-786f-471e-87bc-8f479dc890f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6134c3db-786f-471e-87bc-8f479dc890f6\"\ - },{\"properties\":{\"displayName\":\"Configure time zone on Windows machines.\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to set specified time zone on Windows\ - \ virtual machines.\",\"metadata\":{\"version\":\"1.1.0\",\"category\":\"\ - Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ]},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ + :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ + :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ + *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ + :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"Windows-10\"}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzureMonitorWindowsAgent\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitor\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ + ,\"equals\":\"AzureMonitorWindowsAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ + value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"}},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ + ,\"name\":\"[concat(parameters('vmName'), '/AzureMonitorWindowsAgent')]\"\ + ,\"apiVersion\":\"2019-07-01\",\"location\":\"[parameters('location')]\",\"\ + properties\":{\"publisher\":\"Microsoft.Azure.Monitor\",\"type\":\"AzureMonitorWindowsAgent\"\ + ,\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ + :{},\"protectedSettings\":{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ca817e41-e85a-4783-bc7f-dc532d36235e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ca817e41-e85a-4783-bc7f-dc532d36235e\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Windows machines should meet\ + \ requirements of the Azure Security Center baseline\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ + \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ + \ Machines are non-compliant if the machine is not configured correctly for\ + \ one of the recommendations in the Azure Security Center baseline.\",\"metadata\"\ + :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0-preview\",\"preview\"\ + :true,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ + :{\"name\":\"AzureWindowsBaseline\",\"version\":\"1.*\"}},\"parameters\":{\"\ + IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + [Preview]: Include Arc connected servers\",\"description\":\"By selecting\ \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"TimeZone\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Time zone\",\"description\"\ - :\"The expected time zone\"},\"allowedValues\":[\"(UTC-12:00) International\ - \ Date Line West\",\"(UTC-11:00) Coordinated Universal Time-11\",\"(UTC-10:00)\ - \ Aleutian Islands\",\"(UTC-10:00) Hawaii\",\"(UTC-09:30) Marquesas Islands\"\ - ,\"(UTC-09:00) Alaska\",\"(UTC-09:00) Coordinated Universal Time-09\",\"(UTC-08:00)\ - \ Baja California\",\"(UTC-08:00) Coordinated Universal Time-08\",\"(UTC-08:00)\ - \ Pacific Time (US & Canada)\",\"(UTC-07:00) Arizona\",\"(UTC-07:00) Chihuahua,\ - \ La Paz, Mazatlan\",\"(UTC-07:00) Mountain Time (US & Canada)\",\"(UTC-06:00)\ - \ Central America\",\"(UTC-06:00) Central Time (US & Canada)\",\"(UTC-06:00)\ - \ Easter Island\",\"(UTC-06:00) Guadalajara, Mexico City, Monterrey\",\"(UTC-06:00)\ - \ Saskatchewan\",\"(UTC-05:00) Bogota, Lima, Quito, Rio Branco\",\"(UTC-05:00)\ - \ Chetumal\",\"(UTC-05:00) Eastern Time (US & Canada)\",\"(UTC-05:00) Haiti\"\ - ,\"(UTC-05:00) Havana\",\"(UTC-05:00) Indiana (East)\",\"(UTC-05:00) Turks\ - \ and Caicos\",\"(UTC-04:00) Asuncion\",\"(UTC-04:00) Atlantic Time (Canada)\"\ - ,\"(UTC-04:00) Caracas\",\"(UTC-04:00) Cuiaba\",\"(UTC-04:00) Georgetown,\ - \ La Paz, Manaus, San Juan\",\"(UTC-04:00) Santiago\",\"(UTC-03:30) Newfoundland\"\ - ,\"(UTC-03:00) Araguaina\",\"(UTC-03:00) Brasilia\",\"(UTC-03:00) Cayenne,\ - \ Fortaleza\",\"(UTC-03:00) City of Buenos Aires\",\"(UTC-03:00) Greenland\"\ - ,\"(UTC-03:00) Montevideo\",\"(UTC-03:00) Punta Arenas\",\"(UTC-03:00) Saint\ - \ Pierre and Miquelon\",\"(UTC-03:00) Salvador\",\"(UTC-02:00) Coordinated\ - \ Universal Time-02\",\"(UTC-02:00) Mid-Atlantic - Old\",\"(UTC-01:00) Azores\"\ - ,\"(UTC-01:00) Cabo Verde Is.\",\"(UTC) Coordinated Universal Time\",\"(UTC+00:00)\ - \ Dublin, Edinburgh, Lisbon, London\",\"(UTC+00:00) Monrovia, Reykjavik\"\ - ,\"(UTC+00:00) Sao Tome\",\"(UTC+01:00) Casablanca\",\"(UTC+01:00) Amsterdam,\ - \ Berlin, Bern, Rome, Stockholm, Vienna\",\"(UTC+01:00) Belgrade, Bratislava,\ - \ Budapest, Ljubljana, Prague\",\"(UTC+01:00) Brussels, Copenhagen, Madrid,\ - \ Paris\",\"(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb\",\"(UTC+01:00) West\ - \ Central Africa\",\"(UTC+02:00) Amman\",\"(UTC+02:00) Athens, Bucharest\"\ - ,\"(UTC+02:00) Beirut\",\"(UTC+02:00) Cairo\",\"(UTC+02:00) Chisinau\",\"\ - (UTC+02:00) Damascus\",\"(UTC+02:00) Gaza, Hebron\",\"(UTC+02:00) Harare,\ - \ Pretoria\",\"(UTC+02:00) Helsinki, Kyiv, Riga, Sofia, Tallinn, Vilnius\"\ - ,\"(UTC+02:00) Jerusalem\",\"(UTC+02:00) Kaliningrad\",\"(UTC+02:00) Khartoum\"\ - ,\"(UTC+02:00) Tripoli\",\"(UTC+02:00) Windhoek\",\"(UTC+03:00) Baghdad\"\ - ,\"(UTC+03:00) Istanbul\",\"(UTC+03:00) Kuwait, Riyadh\",\"(UTC+03:00) Minsk\"\ - ,\"(UTC+03:00) Moscow, St. Petersburg\",\"(UTC+03:00) Nairobi\",\"(UTC+03:30)\ - \ Tehran\",\"(UTC+04:00) Abu Dhabi, Muscat\",\"(UTC+04:00) Astrakhan, Ulyanovsk\"\ - ,\"(UTC+04:00) Baku\",\"(UTC+04:00) Izhevsk, Samara\",\"(UTC+04:00) Port Louis\"\ - ,\"(UTC+04:00) Saratov\",\"(UTC+04:00) Tbilisi\",\"(UTC+04:00) Volgograd\"\ - ,\"(UTC+04:00) Yerevan\",\"(UTC+04:30) Kabul\",\"(UTC+05:00) Ashgabat, Tashkent\"\ - ,\"(UTC+05:00) Ekaterinburg\",\"(UTC+05:00) Islamabad, Karachi\",\"(UTC+05:00)\ - \ Qyzylorda\",\"(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi\",\"(UTC+05:30)\ - \ Sri Jayawardenepura\",\"(UTC+05:45) Kathmandu\",\"(UTC+06:00) Astana\",\"\ - (UTC+06:00) Dhaka\",\"(UTC+06:00) Omsk\",\"(UTC+06:30) Yangon (Rangoon)\"\ - ,\"(UTC+07:00) Bangkok, Hanoi, Jakarta\",\"(UTC+07:00) Barnaul, Gorno-Altaysk\"\ - ,\"(UTC+07:00) Hovd\",\"(UTC+07:00) Krasnoyarsk\",\"(UTC+07:00) Novosibirsk\"\ - ,\"(UTC+07:00) Tomsk\",\"(UTC+08:00) Beijing, Chongqing, Hong Kong, Urumqi\"\ - ,\"(UTC+08:00) Irkutsk\",\"(UTC+08:00) Kuala Lumpur, Singapore\",\"(UTC+08:00)\ - \ Perth\",\"(UTC+08:00) Taipei\",\"(UTC+08:00) Ulaanbaatar\",\"(UTC+08:45)\ - \ Eucla\",\"(UTC+09:00) Chita\",\"(UTC+09:00) Osaka, Sapporo, Tokyo\",\"(UTC+09:00)\ - \ Pyongyang\",\"(UTC+09:00) Seoul\",\"(UTC+09:00) Yakutsk\",\"(UTC+09:30)\ - \ Adelaide\",\"(UTC+09:30) Darwin\",\"(UTC+10:00) Brisbane\",\"(UTC+10:00)\ - \ Canberra, Melbourne, Sydney\",\"(UTC+10:00) Guam, Port Moresby\",\"(UTC+10:00)\ - \ Hobart\",\"(UTC+10:00) Vladivostok\",\"(UTC+10:30) Lord Howe Island\",\"\ - (UTC+11:00) Bougainville Island\",\"(UTC+11:00) Chokurdakh\",\"(UTC+11:00)\ - \ Magadan\",\"(UTC+11:00) Norfolk Island\",\"(UTC+11:00) Sakhalin\",\"(UTC+11:00)\ - \ Solomon Is., New Caledonia\",\"(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky\"\ - ,\"(UTC+12:00) Auckland, Wellington\",\"(UTC+12:00) Coordinated Universal\ - \ Time+12\",\"(UTC+12:00) Fiji\",\"(UTC+12:00) Petropavlovsk-Kamchatsky -\ - \ Old\",\"(UTC+12:45) Chatham Islands\",\"(UTC+13:00) Coordinated Universal\ - \ Time+13\",\"(UTC+13:00) Nuku'alofa\",\"(UTC+13:00) Samoa\",\"(UTC+14:00)\ - \ Kiritimati Island\"]}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ + },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\"\ + ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ + :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ + }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ + ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ + ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ + :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ @@ -11399,24110 +12756,4269 @@ interactions: :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"SetWindowsTimeZone\",\"existenceCondition\":{\"allOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsTimeZone]WindowsTimeZone1;TimeZone',\ - \ '=', parameters('TimeZone')))]\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ + :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ + AzureWindowsBaseline\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ + ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/72650e9f-97bc-4b2a-ab5f-9781a9fcecbc\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"72650e9f-97bc-4b2a-ab5f-9781a9fcecbc\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Deploy - Configure Linux Azure\ + \ Monitor agent to enable Azure Monitor assignments on Linux virtual machines\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Configure\ + \ Linux Azure Monitor agent to Linux virtual machines hosted in Azure that\ + \ are supported by Azure Monitor. Azure Monitor agent collects events from\ + \ the virtual machine that can be used to provide recommendations. Target\ + \ virtual machines must be in a supported location.\",\"metadata\":{\"category\"\ + :\"Monitoring\",\"version\":\"1.0.0-preview\",\"preview\":true},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":[\"australiacentral\",\"australiaeast\",\"\ + australiasoutheast\",\"centralindia\",\"centralus\",\"eastasia\",\"eastus2euap\"\ + ,\"eastus\",\"eastus2\",\"germanywestcentral\",\"japaneast\",\"northcentralus\"\ + ,\"northeurope\",\"southcentralus\",\"southeastasia\",\"uksouth\",\"westcentralus\"\ + ,\"westeurope\",\"westus\",\"westus2\"]},{\"anyOf\":[{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"SLES\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\"\ + ,\"SLES-Priority\",\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"12*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"14.04*LTS\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"equals\":\"Oracle-Linux\"},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ + :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"7*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"debian\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"9\"}]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Debian\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"debian-10\"]},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"10\"}]}]}]},\"then\":{\"\ + effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzureMonitorLinuxAgent\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitor\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ + ,\"equals\":\"AzureMonitorLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ + ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"},\"type\":{\"value\":\"[field('type')]\"},\"\ - configurationName\":{\"value\":\"SetWindowsTimeZone\"},\"TimeZone\":{\"value\"\ - :\"[parameters('TimeZone')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"TimeZone\":{\"type\":\"string\"}},\"resources\":[{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"assignmentType\":\"DeployAndAutoCorrect\",\"configurationParameter\"\ - :[{\"name\":\"[WindowsTimeZone]WindowsTimeZone1;TimeZone\",\"value\":\"[parameters('TimeZone')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"assignmentType\":\"DeployAndAutoCorrect\",\"configurationParameter\"\ - :[{\"name\":\"[WindowsTimeZone]WindowsTimeZone1;TimeZone\",\"value\":\"[parameters('TimeZone')]\"\ - }]}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6141c932-9384-44c6-a395-59e4c057d7c9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6141c932-9384-44c6-a395-59e4c057d7c9\"\ - },{\"properties\":{\"displayName\":\"Service Fabric clusters should have the\ - \ ClusterProtectionLevel property set to EncryptAndSign\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Service Fabric provides three\ - \ levels of protection (None, Sign and EncryptAndSign) for node-to-node communication\ - \ using a primary cluster certificate. Set the protection level to ensure\ - \ that all node-to-node messages are encrypted and digitally signed\",\"metadata\"\ - :{\"version\":\"1.1.0\",\"category\":\"Service Fabric\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"The effect determines what happens when the policy rule is\ - \ evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.ServiceFabric/clusters\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.ServiceFabric/clusters/fabricSettings[*].name\",\"notEquals\"\ - :\"Security\"},{\"field\":\"Microsoft.ServiceFabric/clusters/fabricSettings[*].parameters[*].name\"\ - ,\"notEquals\":\"ClusterProtectionLevel\"},{\"field\":\"Microsoft.ServiceFabric/clusters/fabricSettings[*].parameters[*].value\"\ - ,\"notEquals\":\"EncryptAndSign\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/617c02be-7f02-4efd-8836-3180d47b6c68\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"617c02be-7f02-4efd-8836-3180d47b6c68\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1110 - Audit\ - \ Storage Capacity\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1110\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6182bfa7-0f2a-43f5-834a-a2ddf31c13c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6182bfa7-0f2a-43f5-834a-a2ddf31c13c7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1415 - Nonlocal\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1415\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/61a1dd98-b259-4840-abd5-fbba7ee0da83\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"61a1dd98-b259-4840-abd5-fbba7ee0da83\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1153 - System\ - \ Interconnections\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1153\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/61cf3125-142c-4754-8a16-41ab4d529635\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"61cf3125-142c-4754-8a16-41ab4d529635\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - System objects'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - System objects'. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsSystemobjects\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/620e58b5-ac75-49b4-993f-a9d4f0459636\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"620e58b5-ac75-49b4-993f-a9d4f0459636\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines on which the Log\ - \ Analytics agent is not connected as expected\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the agent is not installed, or if it is installed\ - \ but the COM object AgentConfigManager.MgmtSvcCfg returns that it is registered\ - \ to a workspace other than the ID specified in the policy parameter.\",\"\ - metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"WindowsLogAnalyticsAgentConnection\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"WorkspaceId\":\"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"WorkspaceId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Connected workspace\ - \ IDs\",\"description\":\"A semicolon-separated list of the workspace IDs\ - \ that the Log Analytics agent should be connected to\"}}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsLogAnalyticsAgentConnection\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId',\ - \ '=', parameters('WorkspaceId')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6265018c-d7e2-432f-a75d-094d5f6f4465\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6265018c-d7e2-432f-a75d-094d5f6f4465\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1682 - Malicious\ - \ Code Protection | Nonsignature-Based Detection\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1682\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/62b638c5-29d7-404b-8d93-f21e4b1ce198\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"62b638c5-29d7-404b-8d93-f21e4b1ce198\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1660 - Session\ - \ Authenticity\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1660\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/63096613-ce83-43e5-96f4-e588e8813554\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"63096613-ce83-43e5-96f4-e588e8813554\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines network connectivity\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Requires\ - \ that prerequisites are deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol. Machines are non-compliant if a network connection\ - \ status to an IP and TCP port does not match the policy parameter.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"WindowsRemoteConnection\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"host\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;host\"\ - ,\"port\":\"[WindowsRemoteConnection]WindowsRemoteConnection1;port\",\"shouldConnect\"\ - :\"[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"host\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Remote Host Name\",\"\ - description\":\"Specifies the Domain Name System (DNS) name or IP address\ - \ of the remote host machine.\"}},\"port\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Port\",\"description\":\"The TCP port number on the remote\ - \ host name.\"}},\"shouldConnect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Should connect to remote host\",\"description\":\"The machine will be non-compliant\ - \ if it can't establish a connection.\"},\"allowedValues\":[\"True\",\"False\"\ - ],\"defaultValue\":\"False\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsRemoteConnection\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsRemoteConnection]WindowsRemoteConnection1;host',\ - \ '=', parameters('host'), ',', '[WindowsRemoteConnection]WindowsRemoteConnection1;port',\ - \ '=', parameters('port'), ',', '[WindowsRemoteConnection]WindowsRemoteConnection1;shouldConnect',\ - \ '=', parameters('shouldConnect')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/630ac30f-a234-4533-ac2d-e0df77acda51\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"630ac30f-a234-4533-ac2d-e0df77acda51\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that are not using\ - \ SSH key for authentication\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if Non-compliant if the machine allows passwords for authenticating\ - \ through SSH\",\"metadata\":{\"category\":\"Guest Configuration\",\"version\"\ - :\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"LinuxNoPasswordForSSH\",\"version\":\"1.*\"}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"LinuxNoPasswordForSSH\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/630c64f9-8b6b-4c64-b511-6544ceff6fd6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"630c64f9-8b6b-4c64-b511-6544ceff6fd6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1002 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1002\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/632024c2-8079-439d-a7f6-90af1d78cc65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"632024c2-8079-439d-a7f6-90af1d78cc65\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1498 - Rules\ - \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1498\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/633988b9-cf2f-4323-8394-f0d2af9cd6e1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"633988b9-cf2f-4323-8394-f0d2af9cd6e1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1177 - Baseline\ - \ Configuration | Reviews And Updates\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1177\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/63dbc7a8-e20b-4d38-b857-a7f6c0cd94bc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"63dbc7a8-e20b-4d38-b857-a7f6c0cd94bc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1185 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1185\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6420cd73-b939-43b7-9d99-e8688fea053c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6420cd73-b939-43b7-9d99-e8688fea053c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Devices'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Security Options - Devices'. It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"DevicesAllowedToFormatAndEjectRemovableMedia\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Devices: Allowed to\ - \ format and eject removable media\",\"description\":\"Specifies who is allowed\ - \ to format and eject removable NTFS media. You can use this policy setting\ - \ to prevent unauthorized users from removing data on one computer to access\ - \ it on another computer on which they have local administrator privileges.\"\ - },\"defaultValue\":\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsDevices\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Devices: Allowed to format and eject removable\ - \ media;ExpectedValue', '=', parameters('DevicesAllowedToFormatAndEjectRemovableMedia')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsDevices\"},\"DevicesAllowedToFormatAndEjectRemovableMedia\"\ - :{\"value\":\"[parameters('DevicesAllowedToFormatAndEjectRemovableMedia')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"DevicesAllowedToFormatAndEjectRemovableMedia\":{\"\ - type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Devices: Allowed\ - \ to format and eject removable media;ExpectedValue\",\"value\":\"[parameters('DevicesAllowedToFormatAndEjectRemovableMedia')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Devices: Allowed\ - \ to format and eject removable media;ExpectedValue\",\"value\":\"[parameters('DevicesAllowedToFormatAndEjectRemovableMedia')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6481cc21-ed6e-4480-99dd-ea7c5222e897\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6481cc21-ed6e-4480-99dd-ea7c5222e897\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1441 - Media\ - \ Sanitization | Equipment Testing\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1441\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6519d7f3-e8a2-4ff3-a935-9a9497152ad7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6519d7f3-e8a2-4ff3-a935-9a9497152ad7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1558 - Vulnerability\ - \ Scanning | Correlate Scanning Information\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1558\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/65592b16-4367-42c5-a26e-d371be450e17\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"65592b16-4367-42c5-a26e-d371be450e17\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit missing blob encryption\ - \ for storage accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"This policy is no longer necessary because storage blob encryption is enabled\ - \ by default and cannot be turned off.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"\ - },{\"not\":{\"field\":\"Microsoft.Storage/storageAccounts/enableBlobEncryption\"\ - ,\"equals\":\"True\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/655cb504-bcee-4362-bd4c-402e6aa38759\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"655cb504-bcee-4362-bd4c-402e6aa38759\"\ - },{\"properties\":{\"displayName\":\"Advanced data security should be enabled\ - \ on SQL servers on machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Advanced data security provides functionality for surfacing\ - \ and mitigating potential database vulnerabilities, detecting anomalous activities\ - \ that could indicate a threat to SQL database and discovering and classifying\ - \ sensitive data.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Security\ - \ Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/pricings\"\ - ,\"name\":\"SqlServerVirtualMachines\",\"existenceScope\":\"subscription\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/pricings/pricingTier\"\ - ,\"equals\":\"Standard\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6581d072-105e-4418-827f-bd446d56421b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6581d072-105e-4418-827f-bd446d56421b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1261 - Contingency\ - \ Plan Testing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1261\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/65aeceb5-a59c-4cb1-8d82-9c474be5d431\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"65aeceb5-a59c-4cb1-8d82-9c474be5d431\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit IP restrictions configuration\ - \ for a Function App\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"IP Restrictions allow you to define a list of IP addresses that are allowed\ - \ to access your app. Use of IP Restrictions protects a Function app from\ - \ common attacks.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"Security Center\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ + },\"location\":{\"type\":\"string\"}},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ + ,\"name\":\"[concat(parameters('vmName'), '/AzureMonitorLinuxAgent')]\",\"\ + apiVersion\":\"2019-07-01\",\"location\":\"[parameters('location')]\",\"properties\"\ + :{\"publisher\":\"Microsoft.Azure.Monitor\",\"type\":\"AzureMonitorLinuxAgent\"\ + ,\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ + :{},\"protectedSettings\":{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a4034bc6-ae50-406d-bf76-50f4ee5a7811\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a4034bc6-ae50-406d-bf76-50f4ee5a7811\"\ + },{\"properties\":{\"displayName\":\"Service Bus Premium namespaces should\ + \ use a customer-managed key for encryption\",\"policyType\":\"BuiltIn\",\"\ + mode\":\"Indexed\",\"description\":\"Azure Service Bus supports the option\ + \ of encrypting data at rest with either Microsoft-managed keys (default)\ + \ or customer-managed keys. Choosing to encrypt data using customer-managed\ + \ keys enables you to assign, rotate, disable, and revoke access to the keys\ + \ that Service Bus will use to encrypt data in your namespace. Note that Service\ + \ Bus only supports encryption with customer-managed keys for premium namespaces.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Service Bus\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ + if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ServiceBus/namespaces\"\ + },{\"field\":\"Microsoft.ServiceBus/namespaces/sku.tier\",\"equals\":\"Premium\"\ + },{\"not\":{\"field\":\"Microsoft.ServiceBus/namespaces/encryption.keySource\"\ + ,\"equals\":\"Microsoft.Keyvault\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/295fc8b1-dc9f-4f53-9c61-3f313ceab40a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"295fc8b1-dc9f-4f53-9c61-3f313ceab40a\"\ + },{\"properties\":{\"displayName\":\"Public network access should be disabled\ + \ for Batch accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"Disabling public network access on a Batch account improves\ + \ security by ensuring your Batch account can only be accessed from a private\ + \ endpoint. Learn more about disabling public network access at https://docs.microsoft.com/azure/batch/private-connectivity.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Batch\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The desired effect of the policy\"},\"allowedValues\":[\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"\ + },{\"field\":\"Microsoft.Batch/batchAccounts/publicNetworkAccess\",\"notEquals\"\ + :\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/74c5a0ae-5e48-4738-b093-65e23a060488\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74c5a0ae-5e48-4738-b093-65e23a060488\"\ + },{\"properties\":{\"displayName\":\"Event Hub namespaces should use a customer-managed\ + \ key for encryption\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"Azure Event Hubs supports the option of encrypting data at\ + \ rest with either Microsoft-managed keys (default) or customer-managed keys.\ + \ Choosing to encrypt data using customer-managed keys enables you to assign,\ + \ rotate, disable, and revoke access to the keys that Event Hub will use to\ + \ encrypt data in your namespace. Note that Event Hub only supports encryption\ + \ with customer-managed keys for namespaces in dedicated clusters.\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Event Hub\"},\"parameters\":{\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"\ - },{\"anyof\":[{\"field\":\"kind\",\"equals\":\"functionapp\"},{\"field\":\"\ - kind\",\"equals\":\"functionapp,linux\"},{\"field\":\"kind\",\"equals\":\"\ - functionapp,linux,container\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - ConfigureIPRestrictions\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/664346d9-be92-43fb-a219-d595eeb76a90\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"664346d9-be92-43fb-a219-d595eeb76a90\"\ - },{\"properties\":{\"displayName\":\"Service principals should be used to\ - \ protect your subscriptions instead of management certificates\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"Management certificates allow\ - \ anyone who authenticates with them to manage the subscription(s) they are\ - \ associated with. To manage subscriptions more securely, use of service principals\ - \ with Resource Manager is recommended to limit the impact of a certificate\ - \ compromise.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security\ - \ Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces\"\ + },{\"field\":\"Microsoft.EventHub/namespaces/clusterArmId\",\"exists\":\"\ + true\"},{\"not\":{\"field\":\"Microsoft.EventHub/namespaces/encryption.keySource\"\ + ,\"equals\":\"Microsoft.Keyvault\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a1ad735a-e96f-45d2-a7b2-9a4932cab7ec\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a1ad735a-e96f-45d2-a7b2-9a4932cab7ec\"\ + },{\"properties\":{\"displayName\":\"Azure Attestation providers should use\ + \ private endpoints\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Private endpoints provide a way to connect Azure Attestation providers\ + \ to your Azure resources without sending traffic over the public internet.\ + \ By preventing public access, private endpoints help protect against undesired\ + \ anonymous access.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ + Attestation\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.Resources/subscriptions\"]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"2acd365d-e8b5-4094-bce4-244b7c51d67c\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"NotApplicable\"\ - ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6646a0bd-e110-40ca-bb97-84fcee63c414\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6646a0bd-e110-40ca-bb97-84fcee63c414\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1444 - Media\ - \ Use | Prohibit Use Without Owner\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1444\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/666143df-f5e0-45bd-b554-135f0f93e44e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"666143df-f5e0-45bd-b554-135f0f93e44e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1319 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1319\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/66f7ae57-5560-4fc5-85c9-659f204e7a42\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"66f7ae57-5560-4fc5-85c9-659f204e7a42\"\ - },{\"properties\":{\"displayName\":\"Cognitive Services accounts should enable\ - \ data encryption with customer-managed key\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Customer-managed keys provide enhanced\ - \ data protection by allowing you to manage your encryption keys for data\ - \ stored in Cognitive Services. This is often required to meet compliance\ - \ requirements.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Cognitive\ - \ Services\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"The effect determines what\ - \ happens when the policy rule is evaluated to match\"},\"allowedValues\"\ + type\",\"equals\":\"Microsoft.Attestation/attestationProviders\"},\"then\"\ + :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Attestation/attestationProviders/privateEndpointConnections\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Attestation/attestationProviders/privateEndpointConnections/privateEndpoint\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Attestation/attestationProviders/privateEndpointConnections/provisioningState\"\ + ,\"equals\":\"Succeeded\"},{\"field\":\"Microsoft.Attestation/attestationProviders/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ + ,\"equals\":\"Approved\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7b256a2d-058b-41f8-bed9-3f870541c40a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7b256a2d-058b-41f8-bed9-3f870541c40a\"\ + },{\"properties\":{\"displayName\":\"Bot Service should be encrypted with\ + \ a customer-managed key\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Azure Bot Service automatically encrypts your resource\ + \ to protect your data and meet organizational security and compliance commitments.\ + \ By default, Microsoft-managed encryption keys are used. For greater flexibility\ + \ in managing keys or controlling access to your subscription, select customer-managed\ + \ keys, also known as bring your own key (BYOK). Learn more about Azure Bot\ + \ Service encryption: https://docs.microsoft.com/azure/bot-service/bot-service-encryption.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Bot Service\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The desired effect of the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.BotService/botServices\"\ + },{\"field\":\"Microsoft.BotService/botServices/isCmekEnabled\",\"notEquals\"\ + :\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ + /providers/Microsoft.Authorization/policyDefinitions/51522a96-0869-4791-82f3-981000c2c67f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"51522a96-0869-4791-82f3-981000c2c67f\"\ + },{\"properties\":{\"displayName\":\"Azure Automation accounts should use\ + \ customer-managed keys to encrypt data at rest\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Use customer-managed keys to manage\ + \ the encryption at rest of your Azure Automation Accounts. By default, customer\ + \ data is encrypted with service-managed keys, but customer-managed keys are\ + \ commonly required to meet regulatory compliance standards. Customer-managed\ + \ keys enable the data to be encrypted with an Azure Key Vault key created\ + \ and owned by you. You have full control and responsibility for the key lifecycle,\ + \ including rotation and management. Learn more at https://aka.ms/automation-cmk.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Automation\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.CognitiveServices/accounts\"\ - },{\"field\":\"Microsoft.CognitiveServices/accounts/encryption.keySource\"\ - ,\"notEquals\":\"Microsoft.KeyVault\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/67121cc7-ff39-4ab8-b7e3-95b84dab487d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"67121cc7-ff39-4ab8-b7e3-95b84dab487d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1628 - Boundary\ - \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1628\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/67de62b4-a737-4781-8861-3baed3c35069\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"67de62b4-a737-4781-8861-3baed3c35069\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Administrative Templates - Network'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Administrative Templates - Network'\ - \ for guest logons, simultaneous connections, network bridge, ICS, and multicast\ - \ name resolution. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_AdministrativeTemplatesNetwork\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"EnableInsecureGuestLogons\":\"Enable insecure\ - \ guest logons;ExpectedValue\",\"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain\"\ - :\"Minimize the number of simultaneous connections to the Internet or a Windows\ - \ Domain;ExpectedValue\",\"TurnOffMulticastNameResolution\":\"Turn off multicast\ - \ name resolution;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"EnableInsecureGuestLogons\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Enable insecure guest logons\",\"description\"\ - :\"Specifies whether the SMB client will allow insecure guest logons to an\ - \ SMB server.\"},\"defaultValue\":\"0\"},\"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Allow simultaneous connections\ - \ to the Internet or a Windows Domain\",\"description\":\"Specify whether\ - \ to prevent computers from connecting to both a domain based network and\ - \ a non-domain based network at the same time. A value of 0 allows simultaneous\ - \ connections, and a value of 1 blocks them.\"},\"defaultValue\":\"1\"},\"\ - TurnOffMulticastNameResolution\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Turn off multicast name resolution\",\"description\":\"Specifies whether\ - \ LLMNR, a secondary name resolution protocol that transmits using multicast\ - \ over a local subnet link on a single subnet, is enabled.\"},\"defaultValue\"\ - :\"1\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_AdministrativeTemplatesNetwork\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Enable insecure guest logons;ExpectedValue',\ - \ '=', parameters('EnableInsecureGuestLogons'), ',', 'Minimize the number\ - \ of simultaneous connections to the Internet or a Windows Domain;ExpectedValue',\ - \ '=', parameters('AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain'),\ - \ ',', 'Turn off multicast name resolution;ExpectedValue', '=', parameters('TurnOffMulticastNameResolution')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/67e010c1-640d-438e-a3a5-feaccb533a98\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"67e010c1-640d-438e-a3a5-feaccb533a98\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1377 - Incident\ - \ Response Assistance | Coordination With External Providers\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Incident Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1377\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68434bd1-e14b-4031-9edb-a4adf5f84a67\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68434bd1-e14b-4031-9edb-a4adf5f84a67\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs on which the Log Analytics agent is not connected as expected\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ on which the Log Analytics agent is not connected to the specified workspaces.\ - \ It also creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"WorkspaceId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Connected workspace IDs\",\"description\":\"A semicolon-separated\ - \ list of the workspace IDs that the Log Analytics agent should be connected\ - \ to\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsLogAnalyticsAgentConnection\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId',\ - \ '=', parameters('WorkspaceId')))]\"},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsLogAnalyticsAgentConnection\"\ - },\"WorkspaceId\":{\"value\":\"[parameters('WorkspaceId')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"WorkspaceId\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId\"\ - ,\"value\":\"[parameters('WorkspaceId')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LogAnalyticsAgent]LogAnalyticsAgent1;WorkspaceId\"\ - ,\"value\":\"[parameters('WorkspaceId')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68511db2-bd02-41c4-ae6b-1900a012968a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68511db2-bd02-41c4-ae6b-1900a012968a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1597 - Developer\ - \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1597\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68b250ec-2e4f-4eee-898a-117a9fda7016\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68b250ec-2e4f-4eee-898a-117a9fda7016\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1588 - External\ - \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1588\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68ebae26-e0e0-4ecb-8379-aabf633b51e9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68ebae26-e0e0-4ecb-8379-aabf633b51e9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1070 - Wireless\ - \ Access | Disable Wireless Networking\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1070\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/68f837d0-8942-4b1e-9b31-be78b247bda8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"68f837d0-8942-4b1e-9b31-be78b247bda8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1727 - Memory\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1727\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/697175a7-9715-4e89-b98b-c6f605888fa3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"697175a7-9715-4e89-b98b-c6f605888fa3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1652 - Mobile\ - \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this System and Communications Protection control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1652\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6998e84a-2d29-4e10-8962-76754d4f772d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6998e84a-2d29-4e10-8962-76754d4f772d\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy Log Analytics agent\ - \ to Windows Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy deploys the Log Analytics agent to Windows\ - \ Azure Arc machines if the agent isn't installed.\",\"metadata\":{\"version\"\ - :\"1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"parameters\"\ - :{\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Log Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ - \ the agent should be connected to. If this workspace is outside of the scope\ - \ of the assignment you must manually grant 'Log Analytics Contributor' permissions\ - \ (or similar) to the policy assignment's principal ID.\",\"strongType\":\"\ - omsWorkspace\",\"assignPermissions\":true}}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"},{\"\ - field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"variables\":{\"vmExtensionName\":\"MicrosoftMonitoringAgent\",\"vmExtensionPublisher\"\ - :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"MicrosoftMonitoringAgent\"\ - },\"resources\":[{\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"\ - [parameters('location')]\",\"apiVersion\":\"2019-12-12\",\"properties\":{\"\ - publisher\":\"[variables('vmExtensionPublisher')]\",\"type\":\"[variables('vmExtensionType')]\"\ - ,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'), '2015-03-20').customerId]\"\ - ,\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\":{\"workspaceKey\"\ - :\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ - }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ - vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/69af7d4a-7b18-4044-93a9-2651498ef203\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69af7d4a-7b18-4044-93a9-2651498ef203\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that have the\ - \ specified members in the Administrators group\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the local Administrators group contains one\ - \ or more of the members listed in the policy parameter.\",\"metadata\":{\"\ - category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AdministratorsGroupMembersToExclude\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"MembersToExclude\":\"[LocalGroup]AdministratorsGroup;MembersToExclude\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"MembersToExclude\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Members to exclude\"\ - ,\"description\":\"A semicolon-separated list of members that should be excluded\ - \ in the Administrators local group. Ex: Administrator; myUser1; myUser2\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToExclude\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;MembersToExclude',\ - \ '=', parameters('MembersToExclude')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/69bf4abd-ca1e-4cf6-8b5a-762d42e61d4f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69bf4abd-ca1e-4cf6-8b5a-762d42e61d4f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1699 - Information\ - \ System Monitoring | Privileged Users\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1699\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/69c7bee8-bc19-4129-a51e-65a7b39d3e7c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69c7bee8-bc19-4129-a51e-65a7b39d3e7c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1696 - Information\ - \ System Monitoring | Correlate Monitoring Information\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1696\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/69d2a238-20ab-4206-a6dc-f302bf88b1b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"69d2a238-20ab-4206-a6dc-f302bf88b1b8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1244 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1244\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a13a8f8-c163-4b1b-8554-d63569dab937\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a13a8f8-c163-4b1b-8554-d63569dab937\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1019 - Account\ - \ Management | Role-Based Schemes\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1019\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a3ee9b2-3977-459c-b8ce-2db583abd9f7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a3ee9b2-3977-459c-b8ce-2db583abd9f7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs on which Windows Defender Exploit Guard is not enabled\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ on which Windows Defender Exploit Guard is not enabled. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.1.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - NotAvailableMachineState\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: State in which to show VMs on which Windows Defender Exploit\ - \ Guard is not available\",\"description\":\"Windows Defender Exploit Guard\ - \ is only available starting with Windows 10/Windows Server with update 1709.\ - \ Setting this value to 'Non-Compliant' will make machines with older versions\ - \ on which Windows Defender Exploit Guard is not available (such as Windows\ - \ Server 2012 R2) non-compliant. Setting this value to 'Compliant' will make\ - \ these machines compliant.\"},\"allowedValues\":[\"Compliant\",\"Non-Compliant\"\ - ],\"defaultValue\":\"Non-Compliant\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDefenderExploitGuard\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState',\ - \ '=', parameters('NotAvailableMachineState')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsDefenderExploitGuard\"\ - },\"NotAvailableMachineState\":{\"value\":\"[parameters('NotAvailableMachineState')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"NotAvailableMachineState\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState\"\ - ,\"value\":\"[parameters('NotAvailableMachineState')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState\"\ - ,\"value\":\"[parameters('NotAvailableMachineState')]\"}]}}},{\"condition\"\ - :\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2015-05-01-preview\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a7a2bcf-f9be-4e35-9734-4f9657a70f1d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a7a2bcf-f9be-4e35-9734-4f9657a70f1d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit IP restrictions configuration\ - \ for a Web Application\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"IP Restrictions allow you to define a list of IP addresses that are allowed\ - \ to access your app. Use of IP Restrictions protects a web application from\ - \ common attacks.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"Security Center\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"\ - },{\"anyof\":[{\"field\":\"kind\",\"equals\":\"app\"},{\"field\":\"kind\"\ - ,\"equals\":\"WebApp\"},{\"field\":\"kind\",\"equals\":\"app,linux\"},{\"\ - field\":\"kind\",\"equals\":\"app,linux,container\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"ConfigureIPRestrictions\",\"existenceCondition\":{\"field\":\"\ - Microsoft.Security/complianceResults/resourceStatus\",\"in\":[\"OffByPolicy\"\ - ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a8450e2-6c61-43b4-be65-62e3a197bffe\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a8450e2-6c61-43b4-be65-62e3a197bffe\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1211 - Configuration\ - \ Settings\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1211\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a8b9dc8-6b00-4701-aa96-bba3277ebf50\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a8b9dc8-6b00-4701-aa96-bba3277ebf50\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure WEB app is using\ - \ the latest version of TLS encryption \",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Please use /providers/Microsoft.Authorization/policyDefinitions/f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b\ - \ instead. The TLS(Transport Layer Security) protocol secures transmission\ - \ of data over the internet using standard encryption technology. Encryption\ - \ should be set with the latest version of TLS. App service allows TLS 1.2\ - \ by default, which is the recommended TLS level by industry standards, such\ - \ as PCI DSS.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.minTlsVersion\"\ - ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6ad61431-88ce-4357-a0e1-6da43f292bd7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6ad61431-88ce-4357-a0e1-6da43f292bd7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1653 - Mobile\ - \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this System and Communications Protection control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1653\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6b1c00a7-7fd0-42b0-8c5b-c45f6fa1f71b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6b1c00a7-7fd0-42b0-8c5b-c45f6fa1f71b\"\ - },{\"properties\":{\"displayName\":\"Deprecated accounts should be removed\ - \ from your subscription\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Deprecated accounts should be removed from your subscriptions.\ - \ Deprecated accounts are accounts that have been blocked from signing in.\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Automation/automationAccounts\"\ + },{\"field\":\"Microsoft.Automation/automationAccounts/encryption.keySource\"\ + ,\"notEquals\":\"Microsoft.Keyvault\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/56a5ee18-2ae6-4810-86f7-18e39ce5629b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"56a5ee18-2ae6-4810-86f7-18e39ce5629b\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ for SQL Databases to Log Analytics workspace\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic settings for\ + \ SQL Databases to stream diagnostics logs to a Log Analytics workspace when\ + \ any SQL Database which is missing this diagnostic settings is created or\ + \ updated.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"\ parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"00c6d40b-e990-6acf-d4f3-471e747a27c4\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6b1cbf55-e8b6-442f-ba4c-7246b6381474\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6b1cbf55-e8b6-442f-ba4c-7246b6381474\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Service\ - \ Bus to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploys the diagnostic settings for Service Bus to stream to a regional\ - \ Event Hub when any Service Bus which is missing this diagnostic settings\ - \ is created or updated.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Profile name\",\"description\":\"The diagnostic\ - \ settings profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"},\"eventHubRuleId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Event Hub Authorization\ - \ Rule Id\",\"description\":\"The Event Hub authorization rule Id for Azure\ - \ Diagnostics. The authorization rule needs to be at Event Hub namespace level.\ - \ e.g. /subscriptions/{subscription Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ - \ in. Only Service Bus in this location will be linked to this Event Hub.\"\ - ,\"strongType\":\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Event Hub - True or False\"},\"\ - allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ - :\"Whether to enable logs stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ServiceBus/namespaces\"\ - },{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\ - \"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.ServiceBus/namespaces/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"OperationalLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6b51af03-9277-49a9-a3f8-1c69c9ff7403\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6b51af03-9277-49a9-a3f8-1c69c9ff7403\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1031 - Separation\ - \ Of Duties\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1031\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6b93a801-fe25-4574-a60d-cb22acffae00\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6b93a801-fe25-4574-a60d-cb22acffae00\"\ - },{\"properties\":{\"displayName\":\"Not allowed resource types\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy enables you to\ - \ specify the resource types that your organization cannot deploy.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"General\"},\"parameters\":{\"listOfResourceTypesNotAllowed\"\ - :{\"type\":\"Array\",\"metadata\":{\"description\":\"The list of resource\ - \ types that cannot be deployed.\",\"displayName\":\"Not allowed resource\ - \ types\",\"strongType\":\"resourceTypes\"}}},\"policyRule\":{\"if\":{\"field\"\ - :\"type\",\"in\":\"[parameters('listOfResourceTypesNotAllowed')]\"},\"then\"\ - :{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6c112d4e-5bc7-47ae-a041-ea2d9dccd749\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6c112d4e-5bc7-47ae-a041-ea2d9dccd749\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1338 - Authenticator\ - \ Management | Automated Support For Password Strength Determination\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Identification and Authentication control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1338\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6c59a207-6aed-41dc-83a2-e1ff66e4a4db\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6c59a207-6aed-41dc-83a2-e1ff66e4a4db\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1304 - Identification\ - \ And Authentication (Org. Users) | Local Access To Non-Privileged Accounts\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1304\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6ca71be3-16cb-4d39-8b50-7f8fd5e2f11b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6ca71be3-16cb-4d39-8b50-7f8fd5e2f11b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1437 - Media\ - \ Transport | Cryptographic Protection\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Media Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1437\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d1eb6ed-bf13-4046-b993-b9e2aef0f76c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d1eb6ed-bf13-4046-b993-b9e2aef0f76c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1171 - Penetration\ - \ Testing | Independent Penetration Agent Or Team\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Security\ - \ Assessment and Authorization control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1171\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d4820bc-8b61-4982-9501-2123cb776c00\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d4820bc-8b61-4982-9501-2123cb776c00\"\ - },{\"properties\":{\"displayName\":\"Function App should only be accessible\ - \ over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use of HTTPS ensures server/service authentication and protects data in\ - \ transit from network layer eavesdropping attacks.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"functionapp*\"},{\"field\":\"Microsoft.Web/sites/httpsOnly\",\"\ - equals\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d555dd1-86f2-4f1c-8ed7-5abae7c6cbab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d555dd1-86f2-4f1c-8ed7-5abae7c6cbab\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1643 - Cryptographic\ - \ Key Establishment And Management\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Communications\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1643\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d8d492c-dd7a-46f7-a723-fa66a425b87c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d8d492c-dd7a-46f7-a723-fa66a425b87c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1291 - Information\ - \ System Backup | Testing For Reliability / Integrity\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1291\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6d8fd073-9c85-4ee2-a9d0-2e4ec9eb8912\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6d8fd073-9c85-4ee2-a9d0-2e4ec9eb8912\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1175 - Configuration\ - \ Management Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1175\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6dab4254-c30d-4bb7-ae99-1d21586c063c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6dab4254-c30d-4bb7-ae99-1d21586c063c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1651 - Mobile\ - \ Code\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this System and Communications Protection control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1651\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6db63528-c9ba-491c-8a80-83e1e6977a50\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6db63528-c9ba-491c-8a80-83e1e6977a50\"\ - },{\"properties\":{\"displayName\":\"Enable Security Center's auto provisioning\ - \ of the Log Analytics agent on your subscriptions with default workspace.\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Allow Security\ - \ Center to auto provision the Log Analytics agent on your subscriptions to\ - \ monitor and collect security data using ASC default workspace.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/autoProvisioningSettings\",\"deploymentScope\":\"Subscription\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"existenceCondition\":{\"field\":\"Microsoft.Security/autoProvisioningSettings/autoProvision\"\ - ,\"equals\":\"On\"},\"deployment\":{\"location\":\"westus\",\"properties\"\ - :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"DeployIfNotExists\"},\"diagnosticsSettingNameToUse\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Setting name\",\"description\":\"Name of\ + \ the diagnostics settings.\"},\"defaultValue\":\"SQLDatabaseDiagnosticsLogsToWorkspace\"\ + },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ + \ Analytics workspace\",\"description\":\"Select the Log Analytics workspace\ + \ from dropdown list\",\"strongType\":\"omsWorkspace\",\"assignPermissions\"\ + :true}},\"QueryStoreRuntimeStatisticsEnabled\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"QueryStoreRuntimeStatistics - Enabled\",\"description\"\ + :\"Whether to stream QueryStoreRuntimeStatistics logs to the Log Analytics\ + \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"QueryStoreWaitStatisticsEnabled\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"QueryStoreWaitStatistics - Enabled\",\"description\":\"\ + Whether to stream QueryStoreWaitStatistics logs to the Log Analytics workspace\ + \ - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"ErrorsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Errors - Enabled\",\"description\":\"Whether to stream Errors logs to the\ + \ Log Analytics workspace - True or False\"},\"allowedValues\":[\"True\",\"\ + False\"],\"defaultValue\":\"True\"},\"DatabaseWaitStatisticsEnabled\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"DatabaseWaitStatistics -\ + \ Enabled\",\"description\":\"Whether to stream DatabaseWaitStatistics logs\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"},\"BlocksEnabled\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Blocks - Enabled\",\"description\"\ + :\"Whether to stream Blocks logs to the Log Analytics workspace - True or\ + \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + },\"SQLInsightsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"SQLInsights - Enabled\",\"description\":\"Whether to stream SQLInsights\ + \ logs to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"True\"},\"SQLSecurityAuditEventsEnabled\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"SQLSecurityAuditEvents\ + \ - Enabled\",\"description\":\"Whether to stream SQLSecurityAuditEvents logs\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"},\"TimeoutsEnabled\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Timeouts - Enabled\",\"description\"\ + :\"Whether to stream Timeouts logs to the Log Analytics workspace - True or\ + \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + },\"AutomaticTuningEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"AutomaticTuning - Enabled\",\"description\":\"Whether to stream AutomaticTuning\ + \ logs to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"True\"},\"DeadlocksEnabled\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Deadlocks - Enabled\",\"\ + description\":\"Whether to stream Deadlocks logs to the Log Analytics workspace\ + \ - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"Basic\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + Basic (metric) - Enabled\",\"description\":\"Whether to stream Basic metrics\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"},\"InstanceAndAppAdvanced\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"InstanceAndAppAdvanced (metric)\ + \ - Enabled\",\"description\":\"Whether to stream InstanceAndAppAdvanced metrics\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"},\"WorkloadManagement\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"WorkloadManagement (metric) -\ + \ Enabled\",\"description\":\"Whether to stream WorkloadManagement metrics\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"},\"then\":{\"effect\"\ + :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ + ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ + ,\"matchInsensitively\":\"[parameters('logAnalytics')]\"}]},\"deployment\"\ + :{\"properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"diagnosticsSettingNameToUse\"\ + :{\"type\":\"string\"},\"resourceName\":{\"type\":\"string\"},\"logAnalytics\"\ + :{\"type\":\"string\"},\"location\":{\"type\":\"string\"},\"Basic\":{\"type\"\ + :\"string\"},\"InstanceAndAppAdvanced\":{\"type\":\"string\"},\"WorkloadManagement\"\ + :{\"type\":\"string\"},\"QueryStoreRuntimeStatisticsEnabled\":{\"type\":\"\ + string\"},\"QueryStoreWaitStatisticsEnabled\":{\"type\":\"string\"},\"ErrorsEnabled\"\ + :{\"type\":\"string\"},\"DatabaseWaitStatisticsEnabled\":{\"type\":\"string\"\ + },\"BlocksEnabled\":{\"type\":\"string\"},\"SQLInsightsEnabled\":{\"type\"\ + :\"string\"},\"SQLSecurityAuditEventsEnabled\":{\"type\":\"string\"},\"TimeoutsEnabled\"\ + :{\"type\":\"string\"},\"AutomaticTuningEnabled\":{\"type\":\"string\"},\"\ + DeadlocksEnabled\":{\"type\":\"string\"}},\"variables\":{},\"resources\":[{\"\ + type\":\"Microsoft.Sql/servers/databases/providers/diagnosticSettings\",\"\ + apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Basic\",\"enabled\":\"[parameters('Basic')]\"},{\"category\":\"InstanceAndAppAdvanced\"\ + ,\"enabled\":\"[parameters('InstanceAndAppAdvanced')]\"},{\"category\":\"\ + WorkloadManagement\",\"enabled\":\"[parameters('WorkloadManagement')]\"}],\"\ + logs\":[{\"category\":\"SQLInsights\",\"enabled\":\"[parameters('SQLInsightsEnabled')]\"\ + },{\"category\":\"AutomaticTuning\",\"enabled\":\"[parameters('AutomaticTuningEnabled')]\"\ + },{\"category\":\"QueryStoreRuntimeStatistics\",\"enabled\":\"[parameters('QueryStoreRuntimeStatisticsEnabled')]\"\ + },{\"category\":\"QueryStoreWaitStatistics\",\"enabled\":\"[parameters('QueryStoreWaitStatisticsEnabled')]\"\ + },{\"category\":\"Errors\",\"enabled\":\"[parameters('ErrorsEnabled')]\"},{\"\ + category\":\"DatabaseWaitStatistics\",\"enabled\":\"[parameters('DatabaseWaitStatisticsEnabled')]\"\ + },{\"category\":\"Timeouts\",\"enabled\":\"[parameters('TimeoutsEnabled')]\"\ + },{\"category\":\"Blocks\",\"enabled\":\"[parameters('BlocksEnabled')]\"},{\"\ + category\":\"Deadlocks\",\"enabled\":\"[parameters('DeadlocksEnabled')]\"\ + }]}}],\"outputs\":{}},\"parameters\":{\"Basic\":{\"value\":\"[parameters('Basic')]\"\ + },\"InstanceAndAppAdvanced\":{\"value\":\"[parameters('InstanceAndAppAdvanced')]\"\ + },\"diagnosticsSettingNameToUse\":{\"value\":\"[parameters('diagnosticsSettingNameToUse')]\"\ + },\"WorkloadManagement\":{\"value\":\"[parameters('WorkloadManagement')]\"\ + },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"location\"\ + :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('fullName')]\"\ + },\"QueryStoreRuntimeStatisticsEnabled\":{\"value\":\"[parameters('QueryStoreRuntimeStatisticsEnabled')]\"\ + },\"QueryStoreWaitStatisticsEnabled\":{\"value\":\"[parameters('QueryStoreWaitStatisticsEnabled')]\"\ + },\"ErrorsEnabled\":{\"value\":\"[parameters('ErrorsEnabled')]\"},\"DatabaseWaitStatisticsEnabled\"\ + :{\"value\":\"[parameters('DatabaseWaitStatisticsEnabled')]\"},\"BlocksEnabled\"\ + :{\"value\":\"[parameters('BlocksEnabled')]\"},\"SQLInsightsEnabled\":{\"\ + value\":\"[parameters('SQLInsightsEnabled')]\"},\"SQLSecurityAuditEventsEnabled\"\ + :{\"value\":\"[parameters('SQLSecurityAuditEventsEnabled')]\"},\"TimeoutsEnabled\"\ + :{\"value\":\"[parameters('TimeoutsEnabled')]\"},\"AutomaticTuningEnabled\"\ + :{\"value\":\"[parameters('AutomaticTuningEnabled')]\"},\"DeadlocksEnabled\"\ + :{\"value\":\"[parameters('DeadlocksEnabled')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b79fa14e-238a-4c2d-b376-442ce508fc84\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b79fa14e-238a-4c2d-b376-442ce508fc84\"\ + },{\"properties\":{\"displayName\":\"Temp disks and cache for agent node pools\ + \ in Azure Kubernetes Service clusters should be encrypted at host\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"To enhance data security,\ + \ the data stored on the virtual machine (VM) host of your Azure Kubernetes\ + \ Service nodes VMs should be encrypted at rest. This is a common requirement\ + \ in many regulatory and industry compliance standards.\",\"metadata\":{\"\ + version\":\"1.0.0\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ + \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ + \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"Audit\"\ + ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },{\"count\":{\"field\":\"Microsoft.ContainerService/managedClusters/agentPoolProfiles[*]\"\ + ,\"where\":{\"anyOf\":[{\"field\":\"Microsoft.ContainerService/managedClusters/agentPoolProfiles[*].enableEncryptionAtHost\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.ContainerService/managedClusters/agentPoolProfiles[*].enableEncryptionAtHost\"\ + ,\"equals\":\"\"},{\"field\":\"Microsoft.ContainerService/managedClusters/agentPoolProfiles[*].enableEncryptionAtHost\"\ + ,\"equals\":\"false\"}]}},\"greater\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/41425d9f-d1a5-499a-9932-f8ed8453932c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"41425d9f-d1a5-499a-9932-f8ed8453932c\"\ + },{\"properties\":{\"displayName\":\"Public network access on Azure Data Factory\ + \ should be disabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ + description\":\"Disabling the public network access property improves security\ + \ by ensuring your Azure Data Factory can only be accessed from a private\ + \ endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Data Factory\"\ + },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.DataFactory/factories\"},{\"field\":\"Microsoft.DataFactory/factories/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1cf164be-6819-4a50-b8fa-4bcaa4f98fb6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1cf164be-6819-4a50-b8fa-4bcaa4f98fb6\"\ + },{\"properties\":{\"displayName\":\"Deploy Workflow Automation for Azure\ + \ Security Center regulatory compliance\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"All\",\"description\":\"Enable automation of Azure Security Center regulatory\ + \ compliance. This policy deploys a workflow automation with your conditions\ + \ and triggers on the assigned scope. To deploy this policy on newly created\ + \ subscriptions, open the Compliance tab, select the relevant non-compliant\ + \ assignment and create a remediation task.\",\"metadata\":{\"version\":\"\ + 3.0.0\",\"category\":\"Security Center\",\"preview \":true},\"parameters\"\ + :{\"automationName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + Automation name\",\"description\":\"This is the automation name.\"}},\"resourceGroupName\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Resource group name\"\ + ,\"description\":\"The resource group name where the workflow automation is\ + \ created. If you enter a name for a resource group that doesn't exist, it'll\ + \ be created in the subscription.\"}},\"resourceGroupLocation\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Resource group location\",\"description\"\ + :\"The location where the resource group and the workflow automation are created.\"\ + ,\"strongType\":\"location\"}},\"regulatoryComplianceStandards\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Compliance standards names\",\"\ + description\":\"For all compliance standards, leave it empty. For specific\ + \ compliance standards, enter a list of standards names separated by semicolons\ + \ (';'). Compliance standards names are available through the regulatory compliance\ + \ standards API (https://docs.microsoft.com/rest/api/securitycenter/regulatorycompliancestandards),\ + \ or Azure Resource Graph Explorer, choose securityresources and microsoft.security/regulatorycompliancestandards.\"\ + },\"defaultValue\":[]},\"regulatoryComplianceControlStates\":{\"type\":\"\ + Array\",\"metadata\":{\"displayName\":\"Compliance control states\",\"description\"\ + :\"Determines compliance control states.\"},\"allowedValues\":[\"Failed\"\ + ,\"Passed\",\"Skipped\",\"Unsupported\"],\"defaultValue\":[\"Failed\",\"Passed\"\ + ,\"Skipped\",\"Unsupported\"]},\"logicAppResourceId\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Logic App\",\"description\":\"The Logic App\ + \ that is triggered.\",\"strongType\":\"Microsoft.Logic/workflows\",\"assignPermissions\"\ + :true}},\"logicAppTrigger\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Logic app trigger\",\"description\":\"The trigger connector of the logic\ + \ app that is triggered. Possible values: 'Manual (Incoming HTTP request)',\ + \ 'When an Azure Security Center regulatory compliance assessment is created\ + \ or triggered'.\"},\"allowedValues\":[\"Manual (Incoming HTTP request)\"\ + ,\"When an Azure Security Center regulatory compliance assessment is created\ + \ or triggered\"]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Security/automations\",\"name\":\"[parameters('automationName')]\"\ + ,\"existenceScope\":\"resourcegroup\",\"ResourceGroupName\":\"[parameters('resourceGroupName')]\"\ + ,\"deploymentScope\":\"subscription\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Security/automations/isEnabled\"\ + ,\"equals\":true},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets\"\ + ,\"exists\":false},{\"value\":\"[length(parameters('regulatoryComplianceStandards'))]\"\ + ,\"equals\":0},{\"value\":\"[length(parameters('regulatoryComplianceControlStates'))]\"\ + ,\"equals\":4}]},{\"allOf\":[{\"value\":\"[length(parameters('regulatoryComplianceStandards'))]\"\ + ,\"equals\":0},{\"value\":\"[length(parameters('regulatoryComplianceControlStates'))]\"\ + ,\"less\":4},{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue\"\ + ,\"in\":\"[parameters('regulatoryComplianceControlStates')]\"},{\"count\"\ + :{\"value\":\"[parameters('regulatoryComplianceControlStates')]\",\"name\"\ + :\"regulatoryComplianceControlState\",\"where\":{\"count\":{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]\"\ + ,\"where\":{\"allOf\":[{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath\"\ + ,\"equals\":\"properties.state\"},{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue\"\ + ,\"equals\":\"[current('regulatoryComplianceControlState')]\"}]}},\"equals\"\ + :1}},\"equals\":\"[length(parameters('regulatoryComplianceControlStates'))]\"\ + }]},{\"allOf\":[{\"value\":\"[length(parameters('regulatoryComplianceStandards'))]\"\ + ,\"notEquals\":0},{\"value\":\"[length(parameters('regulatoryComplianceControlStates'))]\"\ + ,\"equals\":4},{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue\"\ + ,\"in\":\"[parameters('regulatoryComplianceStandards')]\"},{\"count\":{\"\ + value\":\"[parameters('regulatoryComplianceStandards')]\",\"name\":\"regulatoryComplianceStandard\"\ + ,\"where\":{\"count\":{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]\"\ + ,\"where\":{\"allOf\":[{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].propertyJPath\"\ + ,\"equals\":\"id\"},{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue\"\ + ,\"equals\":\"[current('regulatoryComplianceStandard')]\"}]}},\"equals\":1}},\"\ + equals\":\"[length(parameters('regulatoryComplianceStandards'))]\"}]},{\"\ + allOf\":[{\"value\":\"[length(parameters('regulatoryComplianceStandards'))]\"\ + ,\"notEquals\":0},{\"value\":\"[length(parameters('regulatoryComplianceControlStates'))]\"\ + ,\"notEquals\":4},{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*].expectedValue\"\ + ,\"in\":\"[union(parameters('regulatoryComplianceStandards'),parameters('regulatoryComplianceControlStates'))]\"\ + },{\"count\":{\"field\":\"Microsoft.Security/automations/sources[*].ruleSets[*].rules[*]\"\ + },\"equals\":\"[mul(2,mul(length(parameters('regulatoryComplianceStandards')),length(parameters('regulatoryComplianceControlStates'))))]\"\ + }]}]}]},\"deployment\":{\"location\":\"westeurope\",\"properties\":{\"mode\"\ + :\"incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"automationName\":{\"type\"\ + :\"string\"},\"resourceGroupName\":{\"type\":\"string\"},\"resourceGroupLocation\"\ + :{\"type\":\"string\"},\"regulatoryComplianceStandards\":{\"type\":\"array\"\ + },\"regulatoryComplianceControlStates\":{\"type\":\"array\"},\"logicAppResourceId\"\ + :{\"type\":\"string\"},\"logicAppTrigger\":{\"type\":\"string\"},\"guidValue\"\ + :{\"type\":\"string\",\"defaultValue\":\"[newGuid()]\"}},\"variables\":{\"\ + scopeDescription\":\"scope for subscription {0}\",\"regulatoryComplianceStandardsLength\"\ + :\"[length(parameters('regulatoryComplianceStandards'))]\",\"regulatoryComplianceControlStatesLength\"\ + :\"[length(parameters('regulatoryComplianceControlStates'))]\",\"regulatoryComplianceStandardsLengthIfEmpty\"\ + :\"[if(equals(variables('regulatoryComplianceStandardsLength'), 0), 1, variables('regulatoryComplianceStandardsLength'))]\"\ + ,\"regulatoryComplianceControlStatesLengthIfEmpty\":\"[if(equals(variables('regulatoryComplianceControlStatesLength'),\ + \ 0), 1, variables('regulatoryComplianceControlStatesLength'))]\",\"stateMap\"\ + :{\"Failed\":\"failed\",\"Passed\":\"passed\",\"Skipped\":\"skipped\",\"Unsupported\"\ + :\"unsupported\"},\"triggerMap\":{\"Manual (Incoming HTTP request)\":\"manual\"\ + ,\"When an Azure Security Center regulatory compliance assessment is created\ + \ or triggered\":\"When_a_Security_Center_Regulatory_Compliance_Assessment_is_created_or_triggered\"\ + },\"doesAllStatesSelected\":\"[if(equals(length(parameters('regulatoryComplianceControlStates')),length(variables('stateMap'))),bool('true'),bool('false'))]\"\ + ,\"doesAllStandardsSelected\":\"[if(equals(variables('regulatoryComplianceStandardsLength'),0),bool('true'),bool('false'))]\"\ + ,\"allRegulatoryComplianceRuleSets\":[],\"customStandardsOrCustomStateRuleSets\"\ + :{\"copy\":[{\"name\":\"customStandardsOrCustomStateRuleSetsArr\",\"count\"\ + :\"[if(not(variables('doesAllStandardsSelected')),variables('regulatoryComplianceStandardsLength'),if(not(variables('doesAllStatesSelected')),variables('regulatoryComplianceControlStatesLength'),1))]\"\ + ,\"input\":{\"rules\":[{\"propertyJPath\":\"[if(not(variables('doesAllStandardsSelected')),'id',if(not(variables('doesAllStatesSelected')),'properties.state',json('null')))]\"\ + ,\"propertyType\":\"string\",\"expectedValue\":\"[if(not(variables('doesAllStandardsSelected')),parameters('regulatoryComplianceStandards')[copyIndex('customStandardsOrCustomStateRuleSetsArr')],if(not(variables('doesAllStatesSelected')),parameters('regulatoryComplianceControlStates')[copyIndex('customStandardsOrCustomStateRuleSetsArr')],json('null')))]\"\ + ,\"operator\":\"[if(not(variables('doesAllStandardsSelected')),'Contains',if(not(variables('doesAllStatesSelected')),'Equals',json('null')))]\"\ + }]}}]},\"customStandardsAndCustomStateRuleSets\":{\"copy\":[{\"name\":\"customStandardsAndCustomStateRuleSetsArr\"\ + ,\"count\":\"[if(and(not(variables('doesAllStandardsSelected')),not(variables('doesAllStatesSelected'))),mul(variables('regulatoryComplianceStandardsLength'),variables('regulatoryComplianceControlStatesLength')),1)]\"\ + ,\"input\":{\"rules\":[{\"propertyJPath\":\"id\",\"propertyType\":\"string\"\ + ,\"expectedValue\":\"[if(not(variables('doesAllStandardsSelected')),parameters('regulatoryComplianceStandards')[mod(div(copyIndex('customStandardsAndCustomStateRuleSetsArr'),\ + \ variables('regulatoryComplianceControlStatesLength')), variables('regulatoryComplianceStandardsLength'))],json('null'))]\"\ + ,\"operator\":\"Contains\"},{\"propertyJPath\":\"properties.state\",\"propertyType\"\ + :\"string\",\"expectedValue\":\"[if(not(variables('doesAllStatesSelected')),parameters('regulatoryComplianceControlStates')[mod(copyIndex('customStandardsAndCustomStateRuleSetsArr'),\ + \ variables('regulatoryComplianceControlStatesLength'))],json('null'))]\"\ + ,\"operator\":\"Equals\"}]}}]},\"sourceRuleSets\":\"[if(and(variables('doesAllStandardsSelected'),variables('doesAllStatesSelected')),variables('allRegulatoryComplianceRuleSets'),if(and(not(variables('doesAllStandardsSelected')),not(variables('doesAllStatesSelected'))),variables('customStandardsAndCustomStateRuleSets').customStandardsAndCustomStateRuleSetsArr,variables('customStandardsOrCustomStateRuleSets').customStandardsOrCustomStateRuleSetsArr))]\"\ + },\"resources\":[{\"name\":\"[parameters('resourceGroupName')]\",\"type\"\ + :\"Microsoft.Resources/resourceGroups\",\"apiVersion\":\"2019-10-01\",\"location\"\ + :\"[parameters('resourceGroupLocation')]\",\"tags\":{},\"properties\":{}},{\"\ + type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2019-10-01\",\"\ + name\":\"[concat('nestedAutomationDeployment', '_', parameters('guidValue'))]\"\ + ,\"resourceGroup\":\"[parameters('resourceGroupName')]\",\"dependsOn\":[\"\ + [resourceId('Microsoft.Resources/resourceGroups/', parameters('resourceGroupName'))]\"\ + ],\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ - :[{\"type\":\"Microsoft.Security/autoProvisioningSettings\",\"name\":\"default\"\ - ,\"apiVersion\":\"2017-08-01-preview\",\"properties\":{\"autoProvision\":\"\ - On\"}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6df2fee6-a9ed-4fef-bced-e13be1b25f1c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6df2fee6-a9ed-4fef-bced-e13be1b25f1c\"\ - },{\"properties\":{\"displayName\":\"Email notification for high severity\ - \ alerts should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Enable emailing security alerts to the security contact, in\ - \ order to have them receive security alert emails from Microsoft. This ensures\ - \ that the right people are aware of any potential security issues and are\ - \ able to mitigate the risks\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/securityContacts\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/securityContacts/alertNotifications\"\ - ,\"notEquals\":\"Off\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e2593d9-add6-4083-9c9b-4b7d2188c899\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e2593d9-add6-4083-9c9b-4b7d2188c899\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1586 - External\ - \ Information System Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1586\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e3b2fbd-8f37-4766-a64d-3f37703dcb51\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e3b2fbd-8f37-4766-a64d-3f37703dcb51\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1536 - Risk\ - \ Assessment Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1536\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e40d9de-2ad4-4cb5-8945-23143326a502\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e40d9de-2ad4-4cb5-8945-23143326a502\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1530 - Third-Party\ - \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1530\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6e8f9566-29f1-49cd-b61f-f8628a3cf993\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e8f9566-29f1-49cd-b61f-f8628a3cf993\"\ - },{\"properties\":{\"displayName\":\"Storage account should use a private\ - \ link connection\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Private links enforce secure communication, by providing private connectivity\ - \ to the storage account\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Storage\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :[{\"tags\":{},\"apiVersion\":\"2019-01-01-preview\",\"location\":\"[parameters('resourceGroupLocation')]\"\ + ,\"name\":\"[parameters('automationName')]\",\"type\":\"Microsoft.Security/automations\"\ + ,\"dependsOn\":[],\"properties\":{\"description\":\"Workflow Automation for\ + \ Azure Security Center recommendations via policy\",\"isEnabled\":true,\"\ + scopes\":[{\"description\":\"[replace(variables('scopeDescription'),'{0}',\ + \ subscription().subscriptionId)]\",\"scopePath\":\"[subscription().id]\"\ + }],\"sources\":[{\"eventSource\":\"RegulatoryComplianceAssessment\",\"ruleSets\"\ + :\"[variables('sourceRuleSets')]\"}],\"actions\":[{\"actionType\":\"LogicApp\"\ + ,\"logicAppResourceId\":\"[parameters('logicAppResourceId')]\",\"uri\":\"\ + [listCallbackUrl(concat(parameters('logicAppResourceId'), '/triggers/', variables('triggerMap')[parameters('logicAppTrigger')]),'2016-06-01').value]\"\ + }]}}]}}}]},\"parameters\":{\"automationName\":{\"value\":\"[parameters('automationName')]\"\ + },\"resourceGroupName\":{\"value\":\"[parameters('resourceGroupName')]\"},\"\ + resourceGroupLocation\":{\"value\":\"[parameters('resourceGroupLocation')]\"\ + },\"regulatoryComplianceStandards\":{\"value\":\"[parameters('regulatoryComplianceStandards')]\"\ + },\"regulatoryComplianceControlStates\":{\"value\":\"[parameters('regulatoryComplianceControlStates')]\"\ + },\"logicAppResourceId\":{\"value\":\"[parameters('logicAppResourceId')]\"\ + },\"logicAppTrigger\":{\"value\":\"[parameters('logicAppTrigger')]\"}}}}}}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/509122b9-ddd9-47ba-a5f1-d0dac20be63c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"509122b9-ddd9-47ba-a5f1-d0dac20be63c\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Azure Data Factory linked\ + \ services should use Key Vault for storing secrets\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"All\",\"description\":\"To ensure secrets (such as connection\ + \ strings) are managed securely, require users to provide secrets using an\ + \ Azure Key Vault instead of specifying them inline in linked services.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Data Factory\"\ + ,\"preview\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Storage/storageAccounts\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Storage/storageAccounts/privateEndpointConnections\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateEndpoint\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Storage/storageAccounts/privateEndpointConnections/provisioningState\"\ - ,\"equals\":\"Succeeded\"},{\"field\":\"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateLinkServiceConnectionState\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Storage/storageAccounts/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6edd7eda-6dd8-40f7-810d-67160c639cd9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6edd7eda-6dd8-40f7-810d-67160c639cd9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1460 - Access\ - \ Control For Output Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1460\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6f3ce1bb-4f77-4695-8355-70b08d54fdda\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6f3ce1bb-4f77-4695-8355-70b08d54fdda\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1320 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1320\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6f54c732-71d4-4f93-a696-4e373eca3a77\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6f54c732-71d4-4f93-a696-4e373eca3a77\"\ - },{\"properties\":{\"displayName\":\"Storage account should use customer-managed\ - \ key for encryption\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Secure your storage account with greater flexibility using\ - \ customer-managed keys (CMKs). When you specify a CMK, that key is used to\ - \ protect and control access to the key that encrypts your data. Using CMKs\ - \ provides additional capabilities to control rotation of the key encryption\ - \ key or cryptographically erase data.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Storage\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ + defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ + type\",\"equals\":\"Microsoft.DataFactory/factories/linkedservices\"},{\"\ + anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"exists\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"AccountKey=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"PWD=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"Password=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"CredString=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"pwd=\"}]}]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/SqlServer.typeProperties.password.type\"\ + ,\"equals\":\"SecureString\"},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/SqlServer.typeProperties.password\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/SqlServer.typeProperties.password.type\"\ + ,\"exists\":\"false\"}]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureSqlDW.typeProperties.servicePrincipalKey.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureSearch.typeProperties.key.type\"\ + ,\"equals\":\"SecureString\"},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureStorage.typeProperties.sasUri\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureStorage.typeProperties.sasUri.type\"\ + ,\"notEquals\":\"AzureKeyVaultSecret\"}]},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureBlobStorage.typeProperties.servicePrincipalKey\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureBlobStorage.typeProperties.servicePrincipalKey.type\"\ + ,\"notEquals\":\"AzureKeyVaultSecret\"}]},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureStorage.typeProperties.accountKey\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/CosmosDb.typeProperties.accountKey.type\"\ + ,\"notEquals\":\"AzureKeyVaultSecret\"}]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.encryptedCredential\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AmazonMWS.typeProperties.mwsAuthToken.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AmazonMWS.typeProperties.secretKey.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AmazonS3.typeProperties.secretAccessKey.type\"\ + ,\"equals\":\"SecureString\"},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Dynamics.typeProperties.servicePrincipalCredential\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Dynamics.typeProperties.servicePrincipalCredential.type\"\ + ,\"equals\":\"SecureString\"}]},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Hubspot.typeProperties.accessToken\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Hubspot.typeProperties.accessToken.type\"\ + ,\"equals\":\"SecureString\"}]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Odbc.typeProperties.credential.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/GoogleAdWords.typeProperties.developerToken.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/GoogleBigQuery.typeProperties.clientSecret.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/GoogleBigQuery.typeProperties.refreshToken.type\"\ + ,\"equals\":\"SecureString\"},{\"allOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/type\"\ + ,\"in\":[\"MongoDbAtlas\",\"MongoDbV2\"]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString.type\"\ + ,\"notEquals\":\"AzureKeyVaultSecret\"}]},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/OData.typeProperties.servicePrincipalEmbeddedCert.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/OData.typeProperties.servicePrincipalEmbeddedCertPassword.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Sftp.typeProperties.privateKeyContent.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Sftp.typeProperties.passPhrase.type\"\ + ,\"equals\":\"SecureString\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Salesforce.typeProperties.securityToken.type\"\ + ,\"equals\":\"SecureString\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/127ef6d7-242f-43b3-9eef-947faf1725d0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"127ef6d7-242f-43b3-9eef-947faf1725d0\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Azure Data Factory should\ + \ use a Git repository for source control\",\"policyType\":\"BuiltIn\",\"\ + mode\":\"Indexed\",\"description\":\"Enable source control on data factories,\ + \ to gain capabilities such as change tracking, collaboration, continuous\ + \ integration, and deployment.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ + ,\"category\":\"Data Factory\",\"preview\":true},\"parameters\":{\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataFactory/factories\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.DataFactory/factories/repoConfiguration.repositoryName\"\ + ,\"exists\":\"false\"},{\"field\":\"Microsoft.DataFactory/factories/repoConfiguration.repositoryName\"\ + ,\"equals\":\"\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/77d40665-3120-4348-b539-3192ec808307\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"77d40665-3120-4348-b539-3192ec808307\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Azure Data Factory integration\ + \ runtime should have a limit for number of cores\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"All\",\"description\":\"To manage your resources and costs, limit\ + \ the number of cores for an integration runtime.\",\"metadata\":{\"version\"\ + :\"1.0.0-preview\",\"category\":\"Data Factory\",\"preview\":true},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"maxCores\"\ + :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"Allowed max number\ + \ of cores\",\"description\":\"The max number of cores allowed for dataflow.\"\ + },\"defaultValue\":32}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.DataFactory/factories/integrationRuntimes\"},{\"field\"\ + :\"Microsoft.DataFactory/factories/integrationruntimes/type\",\"equals\":\"\ + Managed\"},{\"field\":\"Microsoft.DataFactory/factories/integrationRuntimes/Managed.typeProperties.computeProperties.dataFlowProperties.coreCount\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/integrationRuntimes/Managed.typeProperties.computeProperties.dataFlowProperties.coreCount\"\ + ,\"greater\":\"[parameters('maxCores')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/85bb39b5-2f66-49f8-9306-77da3ac5130f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"85bb39b5-2f66-49f8-9306-77da3ac5130f\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Azure Data Factory linked\ + \ services should use system-assigned managed identity authentication when\ + \ it is supported\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ + :\"Using system-assigned managed identity when communicating with data stores\ + \ via linked services avoids the use of less secured credentials such as passwords\ + \ or connection strings.\",\"metadata\":{\"version\":\"1.0.0-preview\",\"\ + category\":\"Data Factory\",\"preview\":true},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataFactory/factories/linkedservices\"\ + },{\"field\":\"Microsoft.DataFactory/factories/linkedservices/type\",\"in\"\ + :[\"AzureSqlDatabase\",\"AzureSqlMI\",\"AzureSqlDW\",\"AzureBlobFS\",\"AdlsGen2CosmosStructuredStream\"\ + ,\"AzureDataLakeStore\",\"AzureDataLakeStoreCosmosStructuredStream\",\"AzureBlobStorage\"\ + ,\"AzureDatabricks\"]},{\"anyOf\":[{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"User ID=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/typeProperties.connectionString\"\ + ,\"contains\":\"AccountKey=\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureSqlDW.typeProperties.servicePrincipalKey\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureStorage.typeProperties.accountKey\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/AzureStorage.typeProperties.sasUri\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.DataFactory/factories/linkedservices/Hubspot.typeProperties.accessToken\"\ + ,\"exists\":\"true\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f78ccdb4-7bf4-4106-8647-270491d2978a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f78ccdb4-7bf4-4106-8647-270491d2978a\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Azure Data Factory linked\ + \ service resource type should be in allow list\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"All\",\"description\":\"Define the allow list of Azure Data Factory\ + \ linked service types. Restricting allowed resource types enables control\ + \ over the boundary of data movement. For example, restrict a scope to only\ + \ allow blob storage with Data Lake Storage Gen1 and Gen2 for analytics or\ + \ a scope to only allow SQL and Kusto access for real-time queries.\",\"metadata\"\ + :{\"version\":\"1.0.0-preview\",\"category\":\"Data Factory\",\"preview\"\ + :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"},\"allowedLinkedServiceResourceTypes\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed linked service resource types\",\"description\"\ + :\"The list of allowed linked service resource types.\"},\"allowedValues\"\ + :[\"AdlsGen2CosmosStructuredStream\",\"AdobeExperiencePlatform\",\"AdobeIntegration\"\ + ,\"AmazonRedshift\",\"AmazonS3\",\"AzureBlobFS\",\"AzureBlobStorage\",\"AzureDataExplorer\"\ + ,\"AzureDataLakeStore\",\"AzureDataLakeStoreCosmosStructuredStream\",\"AzureDataShare\"\ + ,\"AzureFileStorage\",\"AzureKeyVault\",\"AzureMariaDB\",\"AzureMySql\",\"\ + AzurePostgreSql\",\"AzureSearch\",\"AzureSqlDatabase\",\"AzureSqlDW\",\"AzureSqlMI\"\ + ,\"AzureTableStorage\",\"Cassandra\",\"CommonDataServiceForApps\",\"CosmosDb\"\ + ,\"CosmosDbMongoDbApi\",\"Db2\",\"DynamicsCrm\",\"FileServer\",\"FtpServer\"\ + ,\"GitHub\",\"GoogleCloudStorage\",\"Hdfs\",\"Hive\",\"HttpServer\",\"Informix\"\ + ,\"Kusto\",\"MicrosoftAccess\",\"MySql\",\"Netezza\",\"Odata\",\"Odbc\",\"\ + Office365\",\"Oracle\",\"PostgreSql\",\"Salesforce\",\"SalesforceServiceCloud\"\ + ,\"SapBw\",\"SapHana\",\"SapOpenHub\",\"SapTable\",\"Sftp\",\"SharePointOnlineList\"\ + ,\"Snowflake\",\"SqlServer\",\"Sybase\",\"Teradata\",\"HDInsightOnDemand\"\ + ,\"HDInsight\",\"AzureDataLakeAnalytics\",\"AzureBatch\",\"AzureFunction\"\ + ,\"AzureML\",\"AzureMLService\",\"MongoDb\",\"GoogleBigQuery\",\"Impala\"\ + ,\"ServiceNow\",\"Dynamics\",\"AzureDatabricks\",\"AmazonMWS\",\"SapCloudForCustomer\"\ + ,\"SapEcc\",\"Web\",\"MongoDbAtlas\",\"HBase\",\"Spark\",\"Phoenix\",\"PayPal\"\ + ,\"Marketo\",\"Responsys\",\"SalesforceMarketingCloud\",\"Presto\",\"Square\"\ + ,\"Xero\",\"Jira\",\"Magento\",\"Shopify\",\"Concur\",\"Hubspot\",\"Zoho\"\ + ,\"Eloqua\",\"QuickBooks\",\"Couchbase\",\"Drill\",\"Greenplum\",\"MariaDB\"\ + ,\"Vertica\",\"MongoDbV2\",\"OracleServiceCloud\",\"GoogleAdWords\",\"RestService\"\ + ,\"DynamicsAX\",\"AzureDataCatalog\",\"AzureDatabricksDeltaLake\"]}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataFactory/factories/linkedservices\"\ + },{\"field\":\"Microsoft.DataFactory/factories/linkedservices/type\",\"notIn\"\ + :\"[parameters('allowedLinkedServiceResourceTypes')]\"}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6809a3d0-d354-42fb-b955-783d207c62a8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6809a3d0-d354-42fb-b955-783d207c62a8\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ for Azure SQL Database server to Log Analytics workspace\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic\ + \ settings for Azure SQL Database server to stream resource logs to a Log\ + \ Analytics workspace when any SQL Server which is missing this diagnostic\ + \ settings is created or updated.\",\"metadata\":{\"version\":\"1.0.1\",\"\ + category\":\"SQL\"},\"parameters\":{\"logAnalyticsWorkspaceId\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\",\"description\"\ + :\"Specify the Log Analytics workspace the server should be connected to.\"\ + ,\"strongType\":\"omsWorkspace\",\"assignPermissions\":true}},\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ + DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"}},\"\ + policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Sql/servers/auditingSettings\",\"name\":\"Default\",\"existenceCondition\"\ + :{\"field\":\"Microsoft.Sql/auditingSettings.state\",\"equals\":\"Enabled\"\ + },\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3\"\ + ,\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"serverName\":{\"type\":\"\ + string\"},\"logAnalyticsWorkspaceId\":{\"type\":\"string\"}},\"variables\"\ + :{\"diagnosticSettingsName\":\"SQLSecurityAuditEvents_3d229c42-c7e7-4c97-9a99-ec0d0d8b86c1\"\ + },\"resources\":[{\"type\":\"Microsoft.Sql/servers/databases/providers/diagnosticSettings\"\ + ,\"name\":\"[concat(parameters('serverName'),'/master/microsoft.insights/',variables('diagnosticSettingsName'))]\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"properties\":{\"name\":\"[variables('diagnosticSettingsName')]\"\ + ,\"workspaceId\":\"[parameters('logAnalyticsWorkspaceId')]\",\"logs\":[{\"\ + category\":\"SQLSecurityAuditEvents\",\"enabled\":true,\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false}}]}},{\"name\":\"[concat(parameters('serverName'),\ + \ '/Default')]\",\"type\":\"Microsoft.Sql/servers/auditingSettings\",\"apiVersion\"\ + :\"2017-03-01-preview\",\"dependsOn\":[\"[concat('Microsoft.Sql/servers/',\ + \ parameters('serverName'),'/databases/master/providers/microsoft.insights/diagnosticSettings/',\ + \ variables('diagnosticSettingsName'))]\"],\"properties\":{\"state\":\"Enabled\"\ + ,\"isAzureMonitorTargetEnabled\":true}}]},\"parameters\":{\"serverName\":{\"\ + value\":\"[field('name')]\"},\"logAnalyticsWorkspaceId\":{\"value\":\"[parameters('logAnalyticsWorkspaceId')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ea8a143-05e3-4553-abfe-f56bef8b0b70\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ea8a143-05e3-4553-abfe-f56bef8b0b70\"\ + },{\"properties\":{\"displayName\":\"Modify - Configure Azure Event Grid topics\ + \ to disable public network access\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Indexed\",\"description\":\"Disable public network access for Azure Event\ + \ Grid resource so that it isn't accessible over the public internet. This\ + \ will help protect them against data leakage risks. You can limit exposure\ + \ of the your resources by creating private endpoints instead. Learn more\ + \ at: https://aka.ms/privateendpoints.\",\"metadata\":{\"category\":\"Event\ + \ Grid\",\"version\":\"1.0.0\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"},{\"not\":{\"field\"\ - :\"Microsoft.Storage/storageAccounts/encryption.keySource\",\"equals\":\"\ - Microsoft.Keyvault\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/6fac406b-40ca-413b-bf8e-0bf964659c25\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6fac406b-40ca-413b-bf8e-0bf964659c25\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ only in Japan data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Allows resource creation in the following locations only:\ - \ Japan East, Japan West\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"General\",\"deprecated\":true},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"not\":{\"field\":\"location\",\"in\":[\"japaneast\",\"japanwest\"\ - ]}},\"then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6fdb9205-3462-4cfc-87d8-16c7860b53f4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6fdb9205-3462-4cfc-87d8-16c7860b53f4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1141 - Audit\ - \ Generation | Changes By Authorized Individuals\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and\ - \ Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1141\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6fdefbf4-93e7-4513-bc95-c1858b7093e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6fdefbf4-93e7-4513-bc95-c1858b7093e0\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Microsoft Network Server'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Microsoft Network Server'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkServer\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6fe4ef56-7576-4dc4-8e9c-26bad4b087ce\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6fe4ef56-7576-4dc4-8e9c-26bad4b087ce\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Python version' is the latest,\ - \ if used as a part of the Web app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Python software either due to security flaws or to include additional functionality.\ - \ Using the latest Python version for web apps is recommended in order to\ - \ take advantage of security fixes, if any, and/or new functionalities of\ - \ the latest version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"WindowsPythonLatestVersion\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Windows Latest Python version\"\ - ,\"description\":\"Latest supported Python version for App Services\"},\"\ - defaultValue\":\"3.6\"},\"LinuxPythonLatestVersion\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Linux Latest Python version\",\"description\"\ - :\"Latest supported Python version for App Services\"},\"defaultValue\":\"\ - 3.8\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"notContains\":\"PYTHON\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PYTHON|', parameters('LinuxPythonLatestVersion'))]\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"\"},{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\"\ - ,\"equals\":\"[parameters('WindowsPythonLatestVersion')]\"}]}]}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/7008174a-fd10-4ef0-817e-fc820a951d73\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7008174a-fd10-4ef0-817e-fc820a951d73\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Windows Components'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Windows Components'. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - SendFileSamplesWhenFurtherAnalysisIsRequired\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Send file samples when further analysis\ - \ is required\",\"description\":\"Specifies whether and how Windows Defender\ - \ will submit samples of suspected malware to Microsoft for further analysis\ - \ when opt-in for MAPS telemetry is set.\"},\"defaultValue\":\"1\"},\"AllowIndexingOfEncryptedFiles\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allow\ - \ indexing of encrypted files\",\"description\":\"Specifies whether encrypted\ - \ items are allowed to be indexed.\"},\"defaultValue\":\"0\"},\"AllowTelemetry\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allow\ - \ Telemetry\",\"description\":\"Specifies configuration of the amount of diagnostic\ - \ and usage data reported to Microsoft. The data is transmitted securely and\ - \ sensitive data is not sent.\"},\"defaultValue\":\"2\"},\"AllowUnencryptedTraffic\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allow\ - \ unencrypted traffic\",\"description\":\"Specifies whether the Windows Remote\ - \ Management (WinRM) service sends and receives unencrypted messages over\ - \ the network.\"},\"defaultValue\":\"0\"},\"AlwaysInstallWithElevatedPrivileges\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Always\ - \ install with elevated privileges\",\"description\":\"Specifies whether Windows\ - \ Installer should use system permissions when it installs any program on\ - \ the system.\"},\"defaultValue\":\"0\"},\"AlwaysPromptForPasswordUponConnection\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Always\ - \ prompt for password upon connection\",\"description\":\"Specifies whether\ - \ Terminal Services/Remote Desktop Connection always prompts the client computer\ - \ for a password upon connection.\"},\"defaultValue\":\"1\"},\"ApplicationSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Application:\ - \ Specify the maximum log file size (KB)\",\"description\":\"Specifies the\ - \ maximum size for the Application event log in kilobytes.\"},\"defaultValue\"\ - :\"32768\"},\"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Automatically\ - \ send memory dumps for OS-generated error reports\",\"description\":\"Specifies\ - \ if memory dumps in support of OS-generated error reports can be sent to\ - \ Microsoft automatically.\"},\"defaultValue\":\"1\"},\"ConfigureDefaultConsent\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Configure\ - \ Default consent\",\"description\":\"Specifies setting of the default consent\ - \ handling for error reports sent to Microsoft.\"},\"defaultValue\":\"4\"\ - },\"ConfigureWindowsSmartScreen\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Configure Windows SmartScreen\",\"description\":\"Specifies\ - \ how to manage the behavior of Windows SmartScreen. Windows SmartScreen helps\ - \ keep PCs safer by warning users before running unrecognized programs downloaded\ - \ from the Internet. Some information is sent to Microsoft about files and\ - \ programs run on PCs with this feature enabled.\"},\"defaultValue\":\"1\"\ - },\"DisallowDigestAuthentication\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Disallow Digest authentication\",\"description\":\"Specifies\ - \ whether the Windows Remote Management (WinRM) client will not use Digest\ - \ authentication.\"},\"defaultValue\":\"0\"},\"DisallowWinRMFromStoringRunAsCredentials\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Disallow\ - \ WinRM from storing RunAs credentials\",\"description\":\"Specifies whether\ - \ the Windows Remote Management (WinRM) service will not allow RunAs credentials\ - \ to be stored for any plug-ins.\"},\"defaultValue\":\"1\"},\"DoNotAllowPasswordsToBeSaved\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Do not\ - \ allow passwords to be saved\",\"description\":\"Specifies whether to prevent\ - \ Remote Desktop Services - Terminal Services clients from saving passwords\ - \ on a computer.\"},\"defaultValue\":\"1\"},\"SecuritySpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Security:\ - \ Specify the maximum log file size (KB)\",\"description\":\"Specifies the\ - \ maximum size for the Security event log in kilobytes.\"},\"defaultValue\"\ - :\"196608\"},\"SetClientConnectionEncryptionLevel\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Deprecated]: Set client connection encryption\ - \ level\",\"description\":\"Specifies whether to require the use of a specific\ - \ encryption level to secure communications between client computers and RD\ - \ Session Host servers during Remote Desktop Protocol (RDP) connections. This\ - \ policy only applies when you are using native RDP encryption.\"},\"defaultValue\"\ - :\"3\"},\"SetTheDefaultBehaviorForAutoRun\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Set the default behavior for AutoRun\",\"\ - description\":\"Specifies the default behavior for Autorun commands. Autorun\ - \ commands are generally stored in autorun.inf files. They often launch the\ - \ installation program or other routines.\"},\"defaultValue\":\"1\"},\"SetupSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Setup:\ - \ Specify the maximum log file size (KB)\",\"description\":\"Specifies the\ - \ maximum size for the Setup event log in kilobytes.\"},\"defaultValue\":\"\ - 32768\"},\"SystemSpecifyTheMaximumLogFileSizeKB\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Deprecated]: System: Specify the maximum log\ - \ file size (KB)\",\"description\":\"Specifies the maximum size for the System\ - \ event log in kilobytes.\"},\"defaultValue\":\"32768\"},\"TurnOffDataExecutionPreventionForExplorer\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Turn off\ - \ Data Execution Prevention for Explorer\",\"description\":\"Specifies whether\ - \ to turn off Data Execution Prevention for Windows File Explorer. Disabling\ - \ data execution prevention can allow certain legacy plug-in applications\ - \ to function without terminating Explorer.\"},\"defaultValue\":\"0\"},\"\ - SpecifyTheIntervalToCheckForDefinitionUpdates\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Specify the interval to check for definition\ - \ updates\",\"description\":\"Specifies an interval at which to check for\ - \ Windows Defender definition updates. The time value is represented as the\ - \ number of hours between update checks.\"},\"defaultValue\":\"8\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_WindowsComponents\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Send file samples when further analysis is required;ExpectedValue',\ - \ '=', parameters('SendFileSamplesWhenFurtherAnalysisIsRequired'), ',', 'Allow\ - \ indexing of encrypted files;ExpectedValue', '=', parameters('AllowIndexingOfEncryptedFiles'),\ - \ ',', 'Allow Telemetry;ExpectedValue', '=', parameters('AllowTelemetry'),\ - \ ',', 'Allow unencrypted traffic;ExpectedValue', '=', parameters('AllowUnencryptedTraffic'),\ - \ ',', 'Always install with elevated privileges;ExpectedValue', '=', parameters('AlwaysInstallWithElevatedPrivileges'),\ - \ ',', 'Always prompt for password upon connection;ExpectedValue', '=', parameters('AlwaysPromptForPasswordUponConnection'),\ - \ ',', 'Application: Specify the maximum log file size (KB);ExpectedValue',\ - \ '=', parameters('ApplicationSpecifyTheMaximumLogFileSizeKB'), ',', 'Automatically\ - \ send memory dumps for OS-generated error reports;ExpectedValue', '=', parameters('AutomaticallySendMemoryDumpsForOSgeneratedErrorReports'),\ - \ ',', 'Configure Default consent;ExpectedValue', '=', parameters('ConfigureDefaultConsent'),\ - \ ',', 'Configure Windows SmartScreen;ExpectedValue', '=', parameters('ConfigureWindowsSmartScreen'),\ - \ ',', 'Disallow Digest authentication;ExpectedValue', '=', parameters('DisallowDigestAuthentication'),\ - \ ',', 'Disallow WinRM from storing RunAs credentials;ExpectedValue', '=',\ - \ parameters('DisallowWinRMFromStoringRunAsCredentials'), ',', 'Do not allow\ - \ passwords to be saved;ExpectedValue', '=', parameters('DoNotAllowPasswordsToBeSaved'),\ - \ ',', 'Security: Specify the maximum log file size (KB);ExpectedValue', '=',\ - \ parameters('SecuritySpecifyTheMaximumLogFileSizeKB'), ',', 'Set client connection\ - \ encryption level;ExpectedValue', '=', parameters('SetClientConnectionEncryptionLevel'),\ - \ ',', 'Set the default behavior for AutoRun;ExpectedValue', '=', parameters('SetTheDefaultBehaviorForAutoRun'),\ - \ ',', 'Setup: Specify the maximum log file size (KB);ExpectedValue', '=',\ - \ parameters('SetupSpecifyTheMaximumLogFileSizeKB'), ',', 'System: Specify\ - \ the maximum log file size (KB);ExpectedValue', '=', parameters('SystemSpecifyTheMaximumLogFileSizeKB'),\ - \ ',', 'Turn off Data Execution Prevention for Explorer;ExpectedValue', '=',\ - \ parameters('TurnOffDataExecutionPreventionForExplorer'), ',', 'Specify the\ - \ interval to check for definition updates;ExpectedValue', '=', parameters('SpecifyTheIntervalToCheckForDefinitionUpdates')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_WindowsComponents\"},\"SendFileSamplesWhenFurtherAnalysisIsRequired\"\ - :{\"value\":\"[parameters('SendFileSamplesWhenFurtherAnalysisIsRequired')]\"\ - },\"AllowIndexingOfEncryptedFiles\":{\"value\":\"[parameters('AllowIndexingOfEncryptedFiles')]\"\ - },\"AllowTelemetry\":{\"value\":\"[parameters('AllowTelemetry')]\"},\"AllowUnencryptedTraffic\"\ - :{\"value\":\"[parameters('AllowUnencryptedTraffic')]\"},\"AlwaysInstallWithElevatedPrivileges\"\ - :{\"value\":\"[parameters('AlwaysInstallWithElevatedPrivileges')]\"},\"AlwaysPromptForPasswordUponConnection\"\ - :{\"value\":\"[parameters('AlwaysPromptForPasswordUponConnection')]\"},\"\ - ApplicationSpecifyTheMaximumLogFileSizeKB\":{\"value\":\"[parameters('ApplicationSpecifyTheMaximumLogFileSizeKB')]\"\ - },\"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports\":{\"value\":\"\ - [parameters('AutomaticallySendMemoryDumpsForOSgeneratedErrorReports')]\"},\"\ - ConfigureDefaultConsent\":{\"value\":\"[parameters('ConfigureDefaultConsent')]\"\ - },\"ConfigureWindowsSmartScreen\":{\"value\":\"[parameters('ConfigureWindowsSmartScreen')]\"\ - },\"DisallowDigestAuthentication\":{\"value\":\"[parameters('DisallowDigestAuthentication')]\"\ - },\"DisallowWinRMFromStoringRunAsCredentials\":{\"value\":\"[parameters('DisallowWinRMFromStoringRunAsCredentials')]\"\ - },\"DoNotAllowPasswordsToBeSaved\":{\"value\":\"[parameters('DoNotAllowPasswordsToBeSaved')]\"\ - },\"SecuritySpecifyTheMaximumLogFileSizeKB\":{\"value\":\"[parameters('SecuritySpecifyTheMaximumLogFileSizeKB')]\"\ - },\"SetClientConnectionEncryptionLevel\":{\"value\":\"[parameters('SetClientConnectionEncryptionLevel')]\"\ - },\"SetTheDefaultBehaviorForAutoRun\":{\"value\":\"[parameters('SetTheDefaultBehaviorForAutoRun')]\"\ - },\"SetupSpecifyTheMaximumLogFileSizeKB\":{\"value\":\"[parameters('SetupSpecifyTheMaximumLogFileSizeKB')]\"\ - },\"SystemSpecifyTheMaximumLogFileSizeKB\":{\"value\":\"[parameters('SystemSpecifyTheMaximumLogFileSizeKB')]\"\ - },\"TurnOffDataExecutionPreventionForExplorer\":{\"value\":\"[parameters('TurnOffDataExecutionPreventionForExplorer')]\"\ - },\"SpecifyTheIntervalToCheckForDefinitionUpdates\":{\"value\":\"[parameters('SpecifyTheIntervalToCheckForDefinitionUpdates')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"SendFileSamplesWhenFurtherAnalysisIsRequired\":{\"\ - type\":\"string\"},\"AllowIndexingOfEncryptedFiles\":{\"type\":\"string\"\ - },\"AllowTelemetry\":{\"type\":\"string\"},\"AllowUnencryptedTraffic\":{\"\ - type\":\"string\"},\"AlwaysInstallWithElevatedPrivileges\":{\"type\":\"string\"\ - },\"AlwaysPromptForPasswordUponConnection\":{\"type\":\"string\"},\"ApplicationSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"string\"},\"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports\"\ - :{\"type\":\"string\"},\"ConfigureDefaultConsent\":{\"type\":\"string\"},\"\ - ConfigureWindowsSmartScreen\":{\"type\":\"string\"},\"DisallowDigestAuthentication\"\ - :{\"type\":\"string\"},\"DisallowWinRMFromStoringRunAsCredentials\":{\"type\"\ - :\"string\"},\"DoNotAllowPasswordsToBeSaved\":{\"type\":\"string\"},\"SecuritySpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"string\"},\"SetClientConnectionEncryptionLevel\":{\"type\":\"\ - string\"},\"SetTheDefaultBehaviorForAutoRun\":{\"type\":\"string\"},\"SetupSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"string\"},\"SystemSpecifyTheMaximumLogFileSizeKB\":{\"type\"\ - :\"string\"},\"TurnOffDataExecutionPreventionForExplorer\":{\"type\":\"string\"\ - },\"SpecifyTheIntervalToCheckForDefinitionUpdates\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Send file samples\ - \ when further analysis is required;ExpectedValue\",\"value\":\"[parameters('SendFileSamplesWhenFurtherAnalysisIsRequired')]\"\ - },{\"name\":\"Allow indexing of encrypted files;ExpectedValue\",\"value\"\ - :\"[parameters('AllowIndexingOfEncryptedFiles')]\"},{\"name\":\"Allow Telemetry;ExpectedValue\"\ - ,\"value\":\"[parameters('AllowTelemetry')]\"},{\"name\":\"Allow unencrypted\ - \ traffic;ExpectedValue\",\"value\":\"[parameters('AllowUnencryptedTraffic')]\"\ - },{\"name\":\"Always install with elevated privileges;ExpectedValue\",\"value\"\ - :\"[parameters('AlwaysInstallWithElevatedPrivileges')]\"},{\"name\":\"Always\ - \ prompt for password upon connection;ExpectedValue\",\"value\":\"[parameters('AlwaysPromptForPasswordUponConnection')]\"\ - },{\"name\":\"Application: Specify the maximum log file size (KB);ExpectedValue\"\ - ,\"value\":\"[parameters('ApplicationSpecifyTheMaximumLogFileSizeKB')]\"},{\"\ - name\":\"Automatically send memory dumps for OS-generated error reports;ExpectedValue\"\ - ,\"value\":\"[parameters('AutomaticallySendMemoryDumpsForOSgeneratedErrorReports')]\"\ - },{\"name\":\"Configure Default consent;ExpectedValue\",\"value\":\"[parameters('ConfigureDefaultConsent')]\"\ - },{\"name\":\"Configure Windows SmartScreen;ExpectedValue\",\"value\":\"[parameters('ConfigureWindowsSmartScreen')]\"\ - },{\"name\":\"Disallow Digest authentication;ExpectedValue\",\"value\":\"\ - [parameters('DisallowDigestAuthentication')]\"},{\"name\":\"Disallow WinRM\ - \ from storing RunAs credentials;ExpectedValue\",\"value\":\"[parameters('DisallowWinRMFromStoringRunAsCredentials')]\"\ - },{\"name\":\"Do not allow passwords to be saved;ExpectedValue\",\"value\"\ - :\"[parameters('DoNotAllowPasswordsToBeSaved')]\"},{\"name\":\"Security: Specify\ - \ the maximum log file size (KB);ExpectedValue\",\"value\":\"[parameters('SecuritySpecifyTheMaximumLogFileSizeKB')]\"\ - },{\"name\":\"Set client connection encryption level;ExpectedValue\",\"value\"\ - :\"[parameters('SetClientConnectionEncryptionLevel')]\"},{\"name\":\"Set the\ - \ default behavior for AutoRun;ExpectedValue\",\"value\":\"[parameters('SetTheDefaultBehaviorForAutoRun')]\"\ - },{\"name\":\"Setup: Specify the maximum log file size (KB);ExpectedValue\"\ - ,\"value\":\"[parameters('SetupSpecifyTheMaximumLogFileSizeKB')]\"},{\"name\"\ - :\"System: Specify the maximum log file size (KB);ExpectedValue\",\"value\"\ - :\"[parameters('SystemSpecifyTheMaximumLogFileSizeKB')]\"},{\"name\":\"Turn\ - \ off Data Execution Prevention for Explorer;ExpectedValue\",\"value\":\"\ - [parameters('TurnOffDataExecutionPreventionForExplorer')]\"},{\"name\":\"\ - Specify the interval to check for definition updates;ExpectedValue\",\"value\"\ - :\"[parameters('SpecifyTheIntervalToCheckForDefinitionUpdates')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Send file samples\ - \ when further analysis is required;ExpectedValue\",\"value\":\"[parameters('SendFileSamplesWhenFurtherAnalysisIsRequired')]\"\ - },{\"name\":\"Allow indexing of encrypted files;ExpectedValue\",\"value\"\ - :\"[parameters('AllowIndexingOfEncryptedFiles')]\"},{\"name\":\"Allow Telemetry;ExpectedValue\"\ - ,\"value\":\"[parameters('AllowTelemetry')]\"},{\"name\":\"Allow unencrypted\ - \ traffic;ExpectedValue\",\"value\":\"[parameters('AllowUnencryptedTraffic')]\"\ - },{\"name\":\"Always install with elevated privileges;ExpectedValue\",\"value\"\ - :\"[parameters('AlwaysInstallWithElevatedPrivileges')]\"},{\"name\":\"Always\ - \ prompt for password upon connection;ExpectedValue\",\"value\":\"[parameters('AlwaysPromptForPasswordUponConnection')]\"\ - },{\"name\":\"Application: Specify the maximum log file size (KB);ExpectedValue\"\ - ,\"value\":\"[parameters('ApplicationSpecifyTheMaximumLogFileSizeKB')]\"},{\"\ - name\":\"Automatically send memory dumps for OS-generated error reports;ExpectedValue\"\ - ,\"value\":\"[parameters('AutomaticallySendMemoryDumpsForOSgeneratedErrorReports')]\"\ - },{\"name\":\"Configure Default consent;ExpectedValue\",\"value\":\"[parameters('ConfigureDefaultConsent')]\"\ - },{\"name\":\"Configure Windows SmartScreen;ExpectedValue\",\"value\":\"[parameters('ConfigureWindowsSmartScreen')]\"\ - },{\"name\":\"Disallow Digest authentication;ExpectedValue\",\"value\":\"\ - [parameters('DisallowDigestAuthentication')]\"},{\"name\":\"Disallow WinRM\ - \ from storing RunAs credentials;ExpectedValue\",\"value\":\"[parameters('DisallowWinRMFromStoringRunAsCredentials')]\"\ - },{\"name\":\"Do not allow passwords to be saved;ExpectedValue\",\"value\"\ - :\"[parameters('DoNotAllowPasswordsToBeSaved')]\"},{\"name\":\"Security: Specify\ - \ the maximum log file size (KB);ExpectedValue\",\"value\":\"[parameters('SecuritySpecifyTheMaximumLogFileSizeKB')]\"\ - },{\"name\":\"Set client connection encryption level;ExpectedValue\",\"value\"\ - :\"[parameters('SetClientConnectionEncryptionLevel')]\"},{\"name\":\"Set the\ - \ default behavior for AutoRun;ExpectedValue\",\"value\":\"[parameters('SetTheDefaultBehaviorForAutoRun')]\"\ - },{\"name\":\"Setup: Specify the maximum log file size (KB);ExpectedValue\"\ - ,\"value\":\"[parameters('SetupSpecifyTheMaximumLogFileSizeKB')]\"},{\"name\"\ - :\"System: Specify the maximum log file size (KB);ExpectedValue\",\"value\"\ - :\"[parameters('SystemSpecifyTheMaximumLogFileSizeKB')]\"},{\"name\":\"Turn\ - \ off Data Execution Prevention for Explorer;ExpectedValue\",\"value\":\"\ - [parameters('TurnOffDataExecutionPreventionForExplorer')]\"},{\"name\":\"\ - Specify the interval to check for definition updates;ExpectedValue\",\"value\"\ - :\"[parameters('SpecifyTheIntervalToCheckForDefinitionUpdates')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7040a231-fb65-4412-8c0a-b365f4866c24\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7040a231-fb65-4412-8c0a-b365f4866c24\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1254 - Contingency\ - \ Plan | Resume All Missions / Business Functions\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1254\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/704e136a-4fe0-427c-b829-cd69957f5d2b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"704e136a-4fe0-427c-b829-cd69957f5d2b\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - System'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - System'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesSystem\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7066131b-61a6-4917-a7e4-72e8983f0aa6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7066131b-61a6-4917-a7e4-72e8983f0aa6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1509 - Position\ - \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1509\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/70792197-9bfc-4813-905a-bd33993e327f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"70792197-9bfc-4813-905a-bd33993e327f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1541 - Risk\ - \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1541\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/70f6af82-7be6-44aa-9b15-8b9231b2e434\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"70f6af82-7be6-44aa-9b15-8b9231b2e434\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1691 - Information\ - \ System Monitoring | Automated Tools For Real-Time Analysis\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1691\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/71475fb4-49bd-450b-a1a5-f63894c24725\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"71475fb4-49bd-450b-a1a5-f63894c24725\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1481 - Temperature\ - \ And Humidity Controls\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1481\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/717a1c78-a267-4f56-ac58-ee6c54dc4339\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"717a1c78-a267-4f56-ac58-ee6c54dc4339\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1129 - Time\ - \ Stamps | Synchronization With Authoritative Time Source\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1129\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/71bb965d-4047-4623-afd4-b8189a58df5d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"71bb965d-4047-4623-afd4-b8189a58df5d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1395 - System\ - \ Maintenance Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1395\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7207a023-a517-41c5-9df2-09d4c6845a05\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7207a023-a517-41c5-9df2-09d4c6845a05\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs on which the DSC configuration is not compliant\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows VMs on which\ - \ the Desired State Configuration (DSC) configuration is not compliant. This\ - \ policy is only applicable to machines with WMF 4 and above. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDscConfiguration\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7227ebe5-9ff7-47ab-b823-171cd02fb90f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7227ebe5-9ff7-47ab-b823-171cd02fb90f\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Administrative Templates - Network'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Administrative\ - \ Templates - Network'. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesNetwork\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7229bd6a-693d-478a-87f0-1dc1af06f3b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7229bd6a-693d-478a-87f0-1dc1af06f3b8\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Python version' is the latest,\ - \ if used as a part of the Function app\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Python software either due to security flaws or to include additional functionality.\ - \ Using the latest Python version for Function apps is recommended in order\ - \ to take advantage of security fixes, if any, and/or new functionalities\ - \ of the latest version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"WindowsPythonLatestVersion\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Windows Latest Python version\"\ - ,\"description\":\"Latest supported Python version for App Services\"},\"\ - defaultValue\":\"3.6\"},\"LinuxPythonLatestVersion\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Linux Latest Python version\",\"description\"\ - :\"Latest supported Python version for App Services\"},\"defaultValue\":\"\ - 3.8\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"notContains\":\"PYTHON\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PYTHON|', parameters('LinuxPythonLatestVersion'))]\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"\"},{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\"\ - ,\"equals\":\"[parameters('WindowsPythonLatestVersion')]\"}]}]}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/7238174a-fd10-4ef0-817e-fc820a951d73\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7238174a-fd10-4ef0-817e-fc820a951d73\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'PHP version' is the latest,\ - \ if used as a part of the WEB app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ PHP software either due to security flaws or to include additional functionality.\ - \ Using the latest PHP version for web apps is recommended in order to take\ - \ advantage of security fixes, if any, and/or new functionalities of the latest\ - \ version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"App Service\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"PHPLatestVersion\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Latest PHP version\",\"description\":\"Latest supported\ - \ PHP version for App Services\"},\"defaultValue\":\"7.3\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"notContains\":\"PHP\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\"\ - ,\"equals\":\"\"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PHP|', parameters('PHPLatestVersion'))]\"},{\"field\"\ - :\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\"\ - :\"[parameters('PHPLatestVersion')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7261b898-8a84-4db8-9e04-18527132abb3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7261b898-8a84-4db8-9e04-18527132abb3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that allow re-use of the previous 24 passwords\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines that allow\ - \ re-use of the previous 24 passwords. It also creates a system-assigned managed\ - \ identity and deploys the VM extension for Guest Configuration. This policy\ - \ should only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"2.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"EnforcePasswordHistory\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"EnforcePasswordHistory\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/726671ac-c4de-4908-8c7d-6043ae62e3b6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"726671ac-c4de-4908-8c7d-6043ae62e3b6\"\ - },{\"properties\":{\"displayName\":\"Add a tag to resource groups\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"Adds the specified tag and\ - \ value when any resource group missing this tag is created or updated. Existing\ - \ resource groups can be remediated by triggering a remediation task. If the\ - \ tag exists with a different value it will not be changed.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Tags\"},\"parameters\":{\"tagName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\",\"description\"\ - :\"Name of the tag, such as 'environment'\"}},\"tagValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Value\",\"description\":\"Value of the\ - \ tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\"\ - :\"false\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"add\",\"field\":\"[concat('tags[', parameters('tagName'),\ - \ ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/726aca4c-86e9-4b04-b0c5-073027359532\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"726aca4c-86e9-4b04-b0c5-073027359532\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1524 - Personnel\ - \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1524\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/72f1cb4e-2439-4fe8-88ea-b8671ce3c268\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"72f1cb4e-2439-4fe8-88ea-b8671ce3c268\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1393 - Information\ - \ Spillage Response | Exposure To Unauthorized Personnel\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Incident Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1393\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/731856d8-1598-4b75-92de-7d46235747c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"731856d8-1598-4b75-92de-7d46235747c0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1101 - Audit\ - \ And Accountability Policy And Procedures\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1101\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7327b708-f0e0-457d-9d2a-527fcc9c9a65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7327b708-f0e0-457d-9d2a-527fcc9c9a65\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1456 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1456\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/733ba9e3-9e7c-440a-a7aa-6196a90a2870\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"733ba9e3-9e7c-440a-a7aa-6196a90a2870\"\ - },{\"properties\":{\"displayName\":\"Deploy Workflow Automation for Azure\ - \ Security Center recommendations\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - All\",\"description\":\"Enable automation of Azure Security Center recommendations.\ - \ This policy deploys a workflow automation with your conditions and triggers\ - \ on the assigned scope. To deploy this policy on newly created subscriptions,\ - \ open the Compliance tab, select the relevant non-compliant assignment and\ - \ create a remediation task.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"automationName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Automation name\",\"description\":\"This\ - \ is the automation name.\"}},\"resourceGroupName\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Resource group name\",\"description\":\"The\ - \ resource group name where the workflow automation is created. If you enter\ - \ a name for a resource group that doesn't exist, it'll be created in the\ - \ subscription.\"}},\"resourceGroupLocation\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Resource group location\",\"description\":\"The location\ - \ where the resource group and the workflow automation are created.\",\"strongType\"\ - :\"location\"}},\"recommendationNames\":{\"type\":\"Array\",\"metadata\":{\"\ - displayName\":\"Recommendation IDs\",\"description\":\"For all recommendations,\ - \ leave empty. For specific recommendations, enter a list of recommendation\ - \ IDs separated by semicolons (';'). Recommendation IDs are available through\ - \ the Assessments API (https://docs.microsoft.com/en-us/rest/api/securitycenter/assessments),\ - \ or Azure Resource Graph Explorer (https://portal.azure.com/#blade/HubsExtension/ArgQueryBlade),\ - \ choose securityresources and microsoft.security/assessments.\"},\"defaultValue\"\ - :[]},\"recommendationSeverities\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Recommendation severities\",\"description\":\"Determines recommendation\ - \ severities. Example: High;Medium;Low;\"},\"allowedValues\":[\"High\",\"\ - Medium\",\"Low\"],\"defaultValue\":[\"High\",\"Medium\",\"Low\"]},\"recommendationStates\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Recommendation states\"\ - ,\"description\":\"Determines recommendation states. Recommendations with\ - \ unhealthy state require your attention to resolve. When a recommendation\ - \ state is healthy, it no longer applies to the resource as Security Center\ - \ detects it as healthy. A recommendation is not-applicable if, for example,\ - \ it was disabled in the Security Policy. Example: Healthy;Unhealthy;Not Applicable;\"\ - },\"allowedValues\":[\"Healthy\",\"Unhealthy\",\"Not Applicable\"],\"defaultValue\"\ - :[\"Healthy\",\"Unhealthy\",\"Not Applicable\"]},\"logicAppResourceId\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Logic App\",\"description\"\ - :\"The Logic App that is triggered. If you do not already have a logic app,\ - \ visit Logic Apps to create one (https://portal.azure.com/#blade/HubsExtension/BrowseResourceBlade/resourceType/Microsoft.Logic%2Fworkflows).\"\ - ,\"strongType\":\"Microsoft.Logic/workflows\",\"assignPermissions\":true}},\"\ - logicAppTrigger\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Logic\ - \ app trigger\",\"description\":\"The trigger connector of the logic app that\ - \ is triggered. Possible values: 'Manual (Incoming HTTP request)', 'When an\ - \ Azure Security Center Recommendation is created or triggered'.\"},\"allowedValues\"\ - :[\"Manual (Incoming HTTP request)\",\"When an Azure Security Center Recommendation\ - \ is created or triggered\"]}},\"policyRule\":{\"if\":{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"\ - deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Security/automations\"\ - ,\"name\":\"[parameters('automationName')]\",\"existenceScope\":\"resourcegroup\"\ - ,\"ResourceGroupName\":\"[parameters('resourceGroupName')]\",\"deploymentScope\"\ - :\"subscription\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"location\":\"westeurope\",\"properties\":{\"mode\":\"\ - incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"automationName\":{\"type\"\ - :\"string\"},\"resourceGroupName\":{\"type\":\"string\"},\"resourceGroupLocation\"\ - :{\"type\":\"string\"},\"recommendationNames\":{\"type\":\"array\"},\"recommendationSeverities\"\ - :{\"type\":\"array\"},\"recommendationStates\":{\"type\":\"array\"},\"logicAppResourceId\"\ - :{\"type\":\"string\"},\"logicAppTrigger\":{\"type\":\"string\"},\"guidValue\"\ - :{\"type\":\"string\",\"defaultValue\":\"[newGuid()]\"}},\"variables\":{\"\ - scopeDescription\":\"scope for subscription {0}\",\"recommendationNamesLength\"\ - :\"[length(parameters('recommendationNames'))]\",\"recommendationSeveritiesLength\"\ - :\"[length(parameters('recommendationSeverities'))]\",\"recommendationStatesLength\"\ - :\"[length(parameters('recommendationStates'))]\",\"recommendationNamesLengthIfEmpty\"\ - :\"[if(equals(variables('recommendationNamesLength'), 0), 1, variables('recommendationNamesLength'))]\"\ - ,\"recommendationSeveritiesLengthIfEmpty\":\"[if(equals(variables('recommendationSeveritiesLength'),\ - \ 0), 1, variables('recommendationSeveritiesLength'))]\",\"recommendationStatesLengthIfEmpty\"\ - :\"[if(equals(variables('recommendationStatesLength'), 0), 1, variables('recommendationStatesLength'))]\"\ - ,\"totalRuleCombinationsForOneRecommendationName\":\"[mul(variables('recommendationSeveritiesLengthIfEmpty'),variables('recommendationStatesLengthIfEmpty'))]\"\ - ,\"totalRuleCombinationsForOneRecommendationSeverity\":\"[variables('recommendationStatesLengthIfEmpty')]\"\ - ,\"totalRuleCombinationsForOneRecommendationState\":1,\"stateMap\":{\"Healthy\"\ - :\"healthy\",\"Unhealthy\":\"unhealthy\",\"Not Applicable\":\"notapplicable\"\ - },\"triggerMap\":{\"Manual (Incoming HTTP request)\":\"manual\",\"When an\ - \ Azure Security Center Recommendation is created or triggered\":\"When_an_Azure_Security_Center_Recommendation_is_created_or_triggered\"\ - }},\"resources\":[{\"name\":\"[parameters('resourceGroupName')]\",\"type\"\ - :\"Microsoft.Resources/resourceGroups\",\"apiVersion\":\"2019-10-01\",\"location\"\ - :\"[parameters('resourceGroupLocation')]\",\"tags\":{},\"properties\":{}},{\"\ - type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2019-10-01\",\"\ - name\":\"[concat('nestedAutomationDeployment', '_', parameters('guidValue'))]\"\ - ,\"resourceGroup\":\"[parameters('resourceGroupName')]\",\"dependsOn\":[\"\ - [resourceId('Microsoft.Resources/resourceGroups/', parameters('resourceGroupName'))]\"\ - ],\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ - :[{\"tags\":{},\"apiVersion\":\"2019-01-01-preview\",\"location\":\"[parameters('resourceGroupLocation')]\"\ - ,\"name\":\"[parameters('automationName')]\",\"type\":\"Microsoft.Security/automations\"\ - ,\"dependsOn\":[],\"properties\":{\"description\":\"Workflow Automation for\ - \ Azure Security Center recommendations via policy\",\"isEnabled\":true,\"\ - scopes\":[{\"description\":\"[replace(variables('scopeDescription'),'{0}',\ - \ subscription().subscriptionId)]\",\"scopePath\":\"[subscription().id]\"\ - }],\"sources\":[{\"eventSource\":\"Assessments\",\"copy\":[{\"name\":\"ruleSets\"\ - ,\"count\":\"[mul(variables('recommendationNamesLengthIfEmpty'), mul(variables('recommendationSeveritiesLengthIfEmpty'),variables('recommendationStatesLengthIfEmpty')))]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"[if(equals(variables('recommendationNamesLength'),\ - \ 0), 'type', 'name')]\",\"propertyType\":\"string\",\"expectedValue\":\"\ - [if(equals(variables('recommendationNamesLength'), 0), 'Microsoft.Security/assessments',\ - \ parameters('recommendationNames')[mod(div(copyIndex('ruleSets'), variables('totalRuleCombinationsForOneRecommendationName')),\ - \ variables('recommendationNamesLength'))])]\",\"operator\":\"Contains\"},{\"\ - propertyJPath\":\"properties.metadata.severity\",\"propertyType\":\"string\"\ - ,\"expectedValue\":\"[parameters('recommendationSeverities')[mod(div(copyIndex('ruleSets'),\ - \ variables('totalRuleCombinationsForOneRecommendationSeverity')), variables('recommendationSeveritiesLength'))]]\"\ - ,\"operator\":\"Equals\"},{\"propertyJPath\":\"properties.status.code\",\"\ - propertyType\":\"string\",\"expectedValue\":\"[variables('stateMap')[parameters('recommendationStates')[mod(div(copyIndex('ruleSets'),\ - \ variables('totalRuleCombinationsForOneRecommendationState')), variables('recommendationStatesLength'))]]]\"\ - ,\"operator\":\"Contains\"}]}}]}],\"actions\":[{\"actionType\":\"LogicApp\"\ - ,\"logicAppResourceId\":\"[parameters('logicAppResourceId')]\",\"uri\":\"\ - [listCallbackUrl(concat(parameters('logicAppResourceId'), '/triggers/', variables('triggerMap')[parameters('logicAppTrigger')]),'2016-06-01').value]\"\ - }]}}]}}}]},\"parameters\":{\"automationName\":{\"value\":\"[parameters('automationName')]\"\ - },\"resourceGroupName\":{\"value\":\"[parameters('resourceGroupName')]\"},\"\ - resourceGroupLocation\":{\"value\":\"[parameters('resourceGroupLocation')]\"\ - },\"recommendationNames\":{\"value\":\"[parameters('recommendationNames')]\"\ - },\"recommendationSeverities\":{\"value\":\"[parameters('recommendationSeverities')]\"\ - },\"recommendationStates\":{\"value\":\"[parameters('recommendationStates')]\"\ - },\"logicAppResourceId\":{\"value\":\"[parameters('logicAppResourceId')]\"\ - },\"logicAppTrigger\":{\"value\":\"[parameters('logicAppTrigger')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/73d6ab6c-2475-4850-afd6-43795f3492ef\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"73d6ab6c-2475-4850-afd6-43795f3492ef\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1581 - Information\ - \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1581\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/742b549b-7a25-465f-b83c-ea1ffb4f4e0e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"742b549b-7a25-465f-b83c-ea1ffb4f4e0e\"\ - },{\"properties\":{\"displayName\":\"Allowed storage account SKUs\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy enables you\ - \ to specify a set of storage account SKUs that your organization can deploy.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Storage\"},\"parameters\"\ - :{\"listOfAllowedSKUs\":{\"type\":\"Array\",\"metadata\":{\"description\"\ - :\"The list of SKUs that can be specified for storage accounts.\",\"displayName\"\ - :\"Allowed SKUs\",\"strongType\":\"StorageSKUs\"}}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Storage/storageAccounts\"\ - },{\"not\":{\"field\":\"Microsoft.Storage/storageAccounts/sku.name\",\"in\"\ - :\"[parameters('listOfAllowedSKUs')]\"}}]},\"then\":{\"effect\":\"Deny\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/7433c107-6db4-4ad1-b57a-a76dce0154a1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7433c107-6db4-4ad1-b57a-a76dce0154a1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1631 - Boundary\ - \ Protection | Deny By Default / Allow By Exception\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1631\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/74ae9b8e-e7bb-4c9c-992f-c535282f7a2c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74ae9b8e-e7bb-4c9c-992f-c535282f7a2c\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Python version' is the latest,\ - \ if used as a part of the Api app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Python software either due to security flaws or to include additional functionality.\ - \ Using the latest Python version for Api apps is recommended in order to\ - \ take advantage of security fixes, if any, and/or new functionalities of\ - \ the latest version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"WindowsPythonLatestVersion\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Windows Latest Python version\"\ - ,\"description\":\"Latest supported Python version for App Services\"},\"\ - defaultValue\":\"3.6\"},\"LinuxPythonLatestVersion\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Linux Latest Python version\",\"description\"\ - :\"Latest supported Python version for App Services\"},\"defaultValue\":\"\ - 3.8\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"notContains\":\"PYTHON\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PYTHON|', parameters('LinuxPythonLatestVersion'))]\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\",\"equals\":\"\ - \"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"\"},{\"field\":\"Microsoft.Web/sites/config/web.pythonVersion\"\ - ,\"equals\":\"[parameters('WindowsPythonLatestVersion')]\"}]}]}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/74c3584d-afae-46f7-a20a-6f8adba71a16\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74c3584d-afae-46f7-a20a-6f8adba71a16\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1417 - Nonlocal\ - \ Maintenance | Comparable Security / Sanitization\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1417\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7522ed84-70d5-4181-afc0-21e50b1b6d0e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7522ed84-70d5-4181-afc0-21e50b1b6d0e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit enabling of diagnostic\ - \ logs in App Services\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Audit enabling of diagnostic logs on the app. This enables you to recreate\ - \ activity trails for investigation purposes if a security incident occurs\ - \ or your network is compromised\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites/config\"\ - },{\"field\":\"name\",\"equals\":\"web\"},{\"anyOf\":[{\"field\":\"Microsoft.Web/sites/config/detailedErrorLoggingEnabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Web/sites/config/httpLoggingEnabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Web/sites/config/requestTracingEnabled\"\ - ,\"notEquals\":\"true\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/752c6934-9bcc-4749-b004-655e676ae2ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"752c6934-9bcc-4749-b004-655e676ae2ac\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1468 - Visitor\ - \ Access Records | Automated Records Maintenance / Review\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1468\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75603f96-80a1-4757-991d-5a1221765ddd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75603f96-80a1-4757-991d-5a1221765ddd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1053 - Session\ - \ Lock | Pattern-Hiding Displays\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1053\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7582b19c-9dba-438e-aed8-ede59ac35ba3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7582b19c-9dba-438e-aed8-ede59ac35ba3\"\ - },{\"properties\":{\"displayName\":\"Private endpoint should be enabled for\ - \ MySQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits MySQL servers not configured to use a private endpoint.\ - \ For more details, visit https://aka.ms/mysqlprivatelink.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + \ the execution of the policy\"},\"allowedValues\":[\"Modify\",\"Disabled\"\ + ],\"defaultValue\":\"Modify\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.EventGrid/topics\"},{\"field\":\"kind\",\"\ + notEquals\":\"AzureArc\"},{\"field\":\"Microsoft.EventGrid/topics/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/1e241071-0855-49ea-94dc-649edcd759de\"\ + ],\"conflictEffect\":\"audit\",\"operations\":[{\"condition\":\"[greaterOrEquals(requestContext().apiVersion,\ + \ '2020-04-01-preview')]\",\"operation\":\"addOrReplace\",\"field\":\"Microsoft.EventGrid/topics/publicNetworkAccess\"\ + ,\"value\":\"Disabled\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/36ea4b4b-0f7f-4a54-89fa-ab18f555a172\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"36ea4b4b-0f7f-4a54-89fa-ab18f555a172\"\ + },{\"properties\":{\"displayName\":\"Azure Event Grid domains should disable\ + \ public network access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Disabling public network access improves security by ensuring\ + \ that the resource isn't exposed on the public internet. You can limit exposure\ + \ of your resources by creating private endpoints instead. Learn more at:\ + \ https://aka.ms/privateendpoints.\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"Event Grid\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"\ + Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.EventGrid/domains\"},{\"field\"\ + :\"Microsoft.EventGrid/domains/publicNetworkAccess\",\"notEquals\":\"Disabled\"\ + }]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f8f774be-6aee-492a-9e29-486ef81f3a68\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f8f774be-6aee-492a-9e29-486ef81f3a68\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure Azure Event Grid domains\ + \ to use private DNS zones\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Use private DNS zones to override the DNS resolution for\ + \ a private endpoint. Learn more at: https://aka.ms/privatednszone.\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Event Grid\"},\"parameters\":{\"privateDnsZoneId\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Private DNS Zone ID\"\ + ,\"description\":\"Specifies the private DNS zone to use to configure private\ + \ endpoint\",\"strongType\":\"Microsoft.Network/privateDnsZones\"}},\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforMySQL/servers/privateEndpointConnections\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforMySQL/servers/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7595c971-233d-4bcf-bd18-596129188c49\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7595c971-233d-4bcf-bd18-596129188c49\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1459 - Access\ - \ Control For Transmission Medium\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1459\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75cc73c7-5cdb-479d-a06f-7b4d0dbb1da0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75cc73c7-5cdb-479d-a06f-7b4d0dbb1da0\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities should be remediated\ - \ by a Vulnerability Assessment solution\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Monitors vulnerabilities detected by Vulnerability\ - \ Assessment solution and VMs without a Vulnerability Assessment solution\ - \ in Azure Security Center as recommendations.\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + deployIfNotExists\",\"Disabled\"],\"defaultValue\":\"deployIfNotExists\"}},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/privateEndpoints\"\ + },{\"count\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"where\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"equals\":\"domain\"}},\"greaterOrEquals\":1}]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"privateDnsZoneId\":{\"type\"\ + :\"string\"},\"privateEndpointName\":{\"type\":\"string\"},\"location\":{\"\ + type\":\"string\"}},\"resources\":[{\"name\":\"[concat(parameters('privateEndpointName'),\ + \ '/deployedByPolicy')]\",\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"apiVersion\":\"2020-03-01\",\"location\":\"[parameters('location')]\",\"\ + properties\":{\"privateDnsZoneConfigs\":[{\"name\":\"domain-privateDnsZone\"\ + ,\"properties\":{\"privateDnsZoneId\":\"[parameters('privateDnsZoneId')]\"\ + }}]}}]},\"parameters\":{\"privateDnsZoneId\":{\"value\":\"[parameters('privateDnsZoneId')]\"\ + },\"privateEndpointName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ + value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d389df0a-e0d7-4607-833c-75a6fdac2c2d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d389df0a-e0d7-4607-833c-75a6fdac2c2d\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure Azure Event Grid topics\ + \ to use private DNS zones\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Use private DNS zones to override the DNS resolution for\ + \ a private endpoint. Learn more at: https://aka.ms/privatednszone.\",\"metadata\"\ + :{\"version\":\"1.0.0\",\"category\":\"Event Grid\"},\"parameters\":{\"privateDnsZoneId\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Private DNS Zone ID\"\ + ,\"description\":\"Specifies the private DNS zone to use to configure private\ + \ endpoint\",\"strongType\":\"Microsoft.Network/privateDnsZones\"}},\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"71992a2a-d168-42e0-b10e-6b45fa2ecddb\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/760a85ff-6162-42b3-8d70-698e268f648c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"760a85ff-6162-42b3-8d70-698e268f648c\"\ - },{\"properties\":{\"displayName\":\"Deploy Dependency agent for Linux virtual\ - \ machine scale sets\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Deploy Dependency agent for Linux virtual machine scale sets\ - \ if the VM Image (OS) is in the list defined and the agent is not installed.\ - \ Note: if your scale set upgradePolicy is set to Manual, you need to apply\ - \ the extension to the all virtual machines in the set by calling upgrade\ - \ on them. In CLI this would be az vmss update-instances.\",\"metadata\":{\"\ - version\":\"1.3.0\",\"category\":\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM\ - \ images that have supported Linux OS to add to scope\",\"description\":\"\ - Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude')]\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"\ - Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"14.04.0-LTS\"\ - ,\"14.04.1-LTS\",\"14.04.5-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"16.04-LTS\",\"16.04.0-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"18.04-LTS\"]}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"in\":[\"12-SP2\",\"12-SP3\",\"12-SP4\"]}]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"CentOS\",\"Centos-LVM\"\ - ,\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"cloudera-centos-os\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"}]}]}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"DependencyAgentLinux\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"}]},\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ - DependencyAgentLinux\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"vmExtensionType\":\"DependencyAgentLinux\",\"vmExtensionTypeHandlerVersion\"\ - :\"9.7\"},\"resources\":[{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"apiVersion\":\"2018-06-01\",\"location\":\"[parameters('location')]\",\"\ - properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\",\"type\"\ - :\"[variables('vmExtensionType')]\",\"typeHandlerVersion\":\"[variables('vmExtensionTypeHandlerVersion')]\"\ - ,\"autoUpgradeMinorVersion\":true}}],\"outputs\":{\"policy\":{\"type\":\"\ - string\",\"value\":\"[concat('Enabled extension for: ', parameters('vmName'))]\"\ - }}},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/765266ab-e40e-4c61-bcb2-5a5275d0b7c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"765266ab-e40e-4c61-bcb2-5a5275d0b7c0\"\ - },{\"properties\":{\"displayName\":\"Private endpoint connections on Azure\ - \ SQL Database should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Private endpoint connections enforce secure communication\ - \ by enabling private connectivity to Azure SQL Database.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },{\"count\":{\"field\":\"Microsoft.Sql/servers/privateEndpointConnections[*]\"\ - ,\"where\":{\"field\":\"Microsoft.Sql/servers/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/7698e800-9299-47a6-b3b6-5a0fee576eed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7698e800-9299-47a6-b3b6-5a0fee576eed\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1055 - Session\ - \ Termination| User-Initiated Logouts / Message Displays\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1055\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/769efd9b-3587-4e22-90ce-65ddcd5bd969\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"769efd9b-3587-4e22-90ce-65ddcd5bd969\"\ - },{\"properties\":{\"displayName\":\"Audit delegation of scopes to a managing\ - \ tenant\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - Audit delegation of scopes to a managing tenant via Azure Lighthouse.\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Lighthouse\"},\"parameters\"\ + deployIfNotExists\",\"Disabled\"],\"defaultValue\":\"deployIfNotExists\"}},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/privateEndpoints\"\ + },{\"count\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"where\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"equals\":\"topic\"}},\"greaterOrEquals\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"privateDnsZoneId\":{\"type\"\ + :\"string\"},\"privateEndpointName\":{\"type\":\"string\"},\"location\":{\"\ + type\":\"string\"}},\"resources\":[{\"name\":\"[concat(parameters('privateEndpointName'),\ + \ '/deployedByPolicy')]\",\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"apiVersion\":\"2020-03-01\",\"location\":\"[parameters('location')]\",\"\ + properties\":{\"privateDnsZoneConfigs\":[{\"name\":\"topic-privateDnsZone\"\ + ,\"properties\":{\"privateDnsZoneId\":\"[parameters('privateDnsZoneId')]\"\ + }}]}}]},\"parameters\":{\"privateDnsZoneId\":{\"value\":\"[parameters('privateDnsZoneId')]\"\ + },\"privateEndpointName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ + value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/baf19753-7502-405f-8745-370519b20483\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"baf19753-7502-405f-8745-370519b20483\"\ + },{\"properties\":{\"displayName\":\"Modify - Configure Azure Event Grid domains\ + \ to disable public network access\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Indexed\",\"description\":\"Disable public network access for Azure Event\ + \ Grid resource so that it isn't accessible over the public internet. This\ + \ will help protect them against data leakage risks. You can limit exposure\ + \ of the your resources by creating private endpoints instead. Learn more\ + \ at: https://aka.ms/privateendpoints.\",\"metadata\":{\"category\":\"Event\ + \ Grid\",\"version\":\"1.0.0\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"Modify\",\"Disabled\"\ + ],\"defaultValue\":\"Modify\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.EventGrid/domains\"},{\"field\":\"Microsoft.EventGrid/domains/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/1e241071-0855-49ea-94dc-649edcd759de\"\ + ],\"conflictEffect\":\"audit\",\"operations\":[{\"condition\":\"[greaterOrEquals(requestContext().apiVersion,\ + \ '2020-04-01-preview')]\",\"operation\":\"addOrReplace\",\"field\":\"Microsoft.EventGrid/domains/publicNetworkAccess\"\ + ,\"value\":\"Disabled\"}]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/898e9824-104c-4965-8e0e-5197588fa5d4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"898e9824-104c-4965-8e0e-5197588fa5d4\"\ + },{\"properties\":{\"displayName\":\"Azure Event Grid topics should disable\ + \ public network access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Disabling public network access improves security by ensuring\ + \ that the resource isn't exposed on the public internet. You can limit exposure\ + \ of your resources by creating private endpoints instead. Learn more at:\ + \ https://aka.ms/privateendpoints.\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"Event Grid\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"\ + Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.EventGrid/topics\"},{\"field\"\ + :\"kind\",\"notEquals\":\"AzureArc\"},{\"field\":\"Microsoft.EventGrid/topics/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1adadefe-5f21-44f7-b931-a59b54ccdb45\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1adadefe-5f21-44f7-b931-a59b54ccdb45\"\ + },{\"properties\":{\"displayName\":\"Azure Monitor Logs for Application Insights\ + \ should be linked to a Log Analytics workspace\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Link the Application Insights component\ + \ to a Log Analytics workspace for logs encryption. Customer-managed keys\ + \ are commonly required to meet regulatory compliance and for more control\ + \ over the access to your data in Azure Monitor. Linking your component to\ + \ a Log Analytics workspace that's enabled with a customer-managed key, ensures\ + \ that your Application Insights logs meet this compliance requirement, see\ + \ https://docs.microsoft.com/azure/azure-monitor/platform/customer-managed-keys.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ManagedServices/registrationAssignments\"\ - },{\"value\":\"true\",\"equals\":\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/76bed37b-484f-430f-a009-fd7592dff818\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"76bed37b-484f-430f-a009-fd7592dff818\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1058 - Permitted\ - \ Actions Without Identification Or Authentication\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1058\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/76e85d08-8fbb-4112-a1c1-93521e6a9254\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"76e85d08-8fbb-4112-a1c1-93521e6a9254\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1508 - Position\ - \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1508\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/76f500cc-4bca-4583-bda1-6d084dc21086\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"76f500cc-4bca-4583-bda1-6d084dc21086\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1423 - Maintenance\ - \ Personnel | Individuals Without Appropriate Access\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1423\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7741669e-d4f6-485a-83cb-e70ce7cbbc20\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7741669e-d4f6-485a-83cb-e70ce7cbbc20\"\ - },{\"properties\":{\"displayName\":\"Azure subscriptions should have a log\ - \ profile for Activity Log\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"This policy ensures if a log profile is enabled for exporting\ - \ activity logs. It audits if there is no log profile created to export the\ - \ logs either to a storage account or to an event hub.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ + ,\"description\":\"The effect determines what happens when the policy rule\ + \ is evaluated to match\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Insights/components\"},{\"anyOf\":[{\"field\"\ + :\"Microsoft.Insights/components/WorkspaceResourceId\",\"equals\":\"\"},{\"\ + field\":\"Microsoft.Insights/components/WorkspaceResourceId\",\"exists\":\"\ + false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ + /providers/Microsoft.Authorization/policyDefinitions/d550e854-df1a-4de9-bf44-cd894b39a95e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d550e854-df1a-4de9-bf44-cd894b39a95e\"\ + },{\"properties\":{\"displayName\":\"Resource logs in App Services should\ + \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Audit enabling of resource logs on the app. This enables you to recreate\ + \ activity trails for investigation purposes if a security incident occurs\ + \ or your network is compromised.\",\"metadata\":{\"version\":\"1.0.0\",\"\ + category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ + Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ + ,\"description\":\"The required resource logs retention in days\"},\"defaultValue\"\ + :\"365\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"notContains\":\"functionapp\"\ + }]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ + :\"Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ + :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ + anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"greaterOrEquals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\"\ + :\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\":\"true\"\ + }]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ + ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/91a78b24-f231-4a8a-8da9-02c35b2b6510\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"91a78b24-f231-4a8a-8da9-02c35b2b6510\"\ + },{\"properties\":{\"displayName\":\"Azure Monitor Logs clusters should be\ + \ encrypted with customer-managed key\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Indexed\",\"description\":\"Create Azure Monitor logs cluster with customer-managed\ + \ keys encryption. By default, the log data is encrypted with service-managed\ + \ keys, but customer-managed keys are commonly required to meet regulatory\ + \ compliance. Customer-managed key in Azure Monitor gives you more control\ + \ over the access to you data, see https://docs.microsoft.com/azure/azure-monitor/platform/customer-managed-keys.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The effect determines what happens when the policy rule\ + \ is evaluated to match\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.OperationalInsights/clusters\"},{\"anyOf\"\ + :[{\"anyOf\":[{\"field\":\"Microsoft.OperationalInsights/clusters/keyVaultProperties.keyVaultUri\"\ + ,\"equals\":\"\"},{\"field\":\"Microsoft.OperationalInsights/clusters/keyVaultProperties.keyVaultUri\"\ + ,\"exists\":\"false\"}]},{\"anyOf\":[{\"field\":\"Microsoft.OperationalInsights/clusters/keyVaultProperties.keyName\"\ + ,\"equals\":\"\"},{\"field\":\"Microsoft.OperationalInsights/clusters/keyVaultProperties.keyName\"\ + ,\"exists\":\"false\"}]},{\"not\":{\"field\":\"Microsoft.OperationalInsights/clusters/keyVaultProperties.keyVersion\"\ + ,\"exists\":\"true\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1f68a601-6e6d-4e42-babf-3f643a047ea2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1f68a601-6e6d-4e42-babf-3f643a047ea2\"\ + },{\"properties\":{\"displayName\":\"Saved-queries in Azure Monitor should\ + \ be saved in customer storage account for logs encryption\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Link storage account to\ + \ Log Analytics workspace to protect saved-queries with storage account encryption.\ + \ Customer-managed keys are commonly required to meet regulatory compliance\ + \ and for more control over the access to your saved-queries in Azure Monitor.\ + \ For more details on the above, see https://docs.microsoft.com/azure/azure-monitor/platform/customer-managed-keys?tabs=portal#customer-managed-key-for-saved-queries.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The effect determines what happens when the policy rule\ + \ is evaluated to match\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.OperationalInsights/workspaces\"},{\"not\"\ + :{\"field\":\"Microsoft.OperationalInsights/workspaces/forceCmkForQuery\"\ + ,\"equals\":\"true\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/fa298e57-9444-42ba-bf04-86e8470e32c7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fa298e57-9444-42ba-bf04-86e8470e32c7\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ to a Log Analytics workspace to be enabled on Azure Key Vault Managed HSM\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys\ + \ the diagnostic settings for Azure Key Vault Managed HSM to stream to a regional\ + \ Log Analytics workspace when any Azure Key Vault Managed HSM which is missing\ + \ this diagnostic settings is created or updated.\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ + ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ + :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_logAnalytics\"\ + },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ + \ Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ + \ to send log to. If this workspace is outside of the scope of the assignment\ + \ you must manually grant 'Log Analytics Contributor' permissions (or similar)\ + \ to the policy assignment's principal ID.\",\"strongType\":\"omsWorkspace\"\ + ,\"assignPermissions\":true}},\"metricsEnabled\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Enable metrics\",\"description\":\"Whether to enable metrics\ + \ stream to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ + :\"Whether to enable logs stream to the Log Analytics workspace - True or\ + \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/managedHsms\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"allOf\"\ + :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ + :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ + /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ + :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ + :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ + type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ + resources\":[{\"type\":\"Microsoft.KeyVault/managedHsms/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ + [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ + :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ + ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ + :false,\"days\":0}}],\"logs\":[{\"category\":\"AuditEvent\",\"enabled\":\"\ + [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ + :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ + },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ + :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ + :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b3884c81-31aa-473d-a9bb-9466fe0ec2a0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b3884c81-31aa-473d-a9bb-9466fe0ec2a0\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ to an Event Hub to be enabled on Azure Key Vault Managed HSM\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic\ + \ settings for Azure Key Vault Managed HSM to stream to a regional Event Hub\ + \ when any Azure Key Vault Managed HSM which is missing this diagnostic settings\ + \ is created or updated.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ + :\"Key Vault\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"\ + defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Profile name\",\"description\":\"The diagnostic\ + \ settings profile name\"},\"defaultValue\":\"setbypolicy\"},\"eventHubRuleId\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Event Hub Authorization\ + \ Rule Id\",\"description\":\"The Event Hub authorization rule Id for Azure\ + \ Diagnostics. The authorization rule needs to be at Event Hub namespace level.\ + \ e.g. /subscriptions/{subscription Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ + \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ + :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ + :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ + \ in. Only Azure Key Vault Managed HSMs in this location will be linked to\ + \ this Event Hub.\",\"strongType\":\"location\"},\"defaultValue\":\"\"},\"\ + metricsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ + \ metrics\",\"description\":\"Whether to enable metrics stream to the Event\ + \ Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"False\"},\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Enable logs\",\"description\":\"Whether to enable logs stream to the Event\ + \ Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.KeyVault/managedHsms\"},{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\"\ + ,\"equals\":\"\"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ + }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ + :\"Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"allOf\"\ + :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ + :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ + /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"hsmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\":\"string\"\ + },\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"type\":\"string\"\ + },\"profileName\":{\"type\":\"string\"}},\"resources\":[{\"type\":\"Microsoft.KeyVault/managedHsms/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('hsmName'),\ + \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ + [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ + :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ + ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ + :false,\"days\":0}}],\"logs\":[{\"category\":\"AuditEvent\",\"enabled\":\"\ + [parameters('logsEnabled')]\"}]}}],\"outputs\":{\"policy\":{\"type\":\"string\"\ + ,\"value\":\"[concat('Enabled diagnostic settings for ', parameters('hsmName'))]\"\ + }}},\"parameters\":{\"location\":{\"value\":\"[field('location')]\"},\"hsmName\"\ + :{\"value\":\"[field('name')]\"},\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"\ + },\"metricsEnabled\":{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\"\ + :{\"value\":\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"\ + [parameters('profileName')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a6d2c800-5230-4a40-bff3-8268b4987d42\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a6d2c800-5230-4a40-bff3-8268b4987d42\"\ + },{\"properties\":{\"displayName\":\"Azure Monitor Logs clusters should be\ + \ created with infrastructure-encryption enabled (double encryption)\",\"\ + policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"To ensure\ + \ secure data encryption is enabled at the service level and the infrastructure\ + \ level with two different encryption algorithms and two different keys, use\ + \ an Azure Monitor dedicated cluster. This option is enabled by default when\ + \ supported at the region, see https://docs.microsoft.com/azure/azure-monitor/platform/customer-managed-keys#customer-managed-key-overview.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"The effect determines what happens when the policy rule\ + \ is evaluated to match\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.OperationalInsights/clusters\"},{\"not\"\ + :{\"field\":\"Microsoft.OperationalInsights/clusters/isDoubleEncryptionEnabled\"\ + ,\"equals\":\"true\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea0dfaed-95fb-448c-934e-d6e713ce393d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea0dfaed-95fb-448c-934e-d6e713ce393d\"\ + },{\"properties\":{\"displayName\":\"Resource logs in Azure Key Vault Managed\ + \ HSM should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"To recreate activity trails for investigation purposes\ + \ when a security incident occurs or when your network is compromised, you\ + \ may want to audit by enabling resource logs on Managed HSMs. Please follow\ + \ the instructions here: https://docs.microsoft.com/azure/key-vault/managed-hsm/logging.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Key Vault\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ + },\"requiredRetentionDays\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Required retention (days)\",\"description\":\"The required resource logs\ + \ retention in days\"},\"defaultValue\":\"365\"}},\"policyRule\":{\"if\":{\"\ + field\":\"type\",\"equals\":\"Microsoft.KeyVault/managedHsms\"},\"then\":{\"\ + effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ + ,\"existenceCondition\":{\"count\":{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\"\ + ,\"where\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ + ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ + ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ + ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2a5b911-5617-447e-a49e-59dbe0e0434b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2a5b911-5617-447e-a49e-59dbe0e0434b\"\ + },{\"properties\":{\"displayName\":\"Azure Key Vault Managed HSM should have\ + \ purge protection enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Malicious deletion of an Azure Key Vault Managed HSM can\ + \ lead to permanent data loss. A malicious insider in your organization can\ + \ potentially delete and purge Azure Key Vault Managed HSM. Purge protection\ + \ protects you from insider attacks by enforcing a mandatory retention period\ + \ for soft deleted Azure Key Vault Managed HSM. No one inside your organization\ + \ or Microsoft will be able to purge your Azure Key Vault Managed HSM during\ + \ the soft delete retention period.\",\"metadata\":{\"version\":\"1.0.0\"\ + ,\"category\":\"Key Vault\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"\ + Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/managedHsms\"},{\"anyOf\"\ + :[{\"field\":\"Microsoft.KeyVault/managedHsms/enableSoftDelete\",\"notEquals\"\ + :\"true\"},{\"field\":\"Microsoft.KeyVault/managedHsms/enablePurgeProtection\"\ + ,\"notEquals\":\"true\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c39ba22d-4428-4149-b981-70acb31fc383\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c39ba22d-4428-4149-b981-70acb31fc383\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ for storage accounts to Log Analytics workspace\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic settings for\ + \ storage accounts to stream resource logs to a Log Analytics workspace when\ + \ any storage account which is missing this diagnostic settings is created\ + \ or updated.\",\"metadata\":{\"category\":\"Storage\",\"version\":\"1.0.0\"\ + },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"DeployIfNotExists\"},\"diagnosticsSettingNameToUse\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Setting name\",\"description\":\"Name of\ + \ the diagnostic settings.\"},\"defaultValue\":\"storageAccountsDiagnosticsLogsToWorkspace\"\ + },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ + \ Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ + \ the storage account should be connected to.\",\"strongType\":\"omsWorkspace\"\ + ,\"assignPermissions\":true}},\"StorageDelete\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"StorageDelete - Enabled\",\"description\":\"Whether to\ + \ stream StorageDelete logs to the Log Analytics workspace - True or False\"\ + },\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"},\"StorageWrite\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"StorageWrite - Enabled\"\ + ,\"description\":\"Whether to stream StorageWrite logs to the Log Analytics\ + \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"StorageRead\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"StorageRead - Enabled\",\"description\":\"Whether to stream StorageRead\ + \ logs to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"True\"},\"Transaction\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Transaction - Enabled\",\"description\"\ + :\"Whether to stream Transaction logs to the Log Analytics workspace - True\ + \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Storage/storageAccounts\"\ + ,\"Microsoft.Storage/storageAccounts/blobServices\",\"Microsoft.Storage/storageAccounts/fileServices\"\ + ,\"Microsoft.Storage/storageAccounts/tableServices\",\"Microsoft.Storage/storageAccounts/queueServices\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Insights/diagnosticSettings\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"anyof\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"True\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ + ,\"equals\":\"[parameters('logAnalytics')]\"}]},\"deployment\":{\"properties\"\ + :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"diagnosticsSettingNameToUse\"\ + :{\"type\":\"string\"},\"resourceName\":{\"type\":\"string\"},\"logAnalytics\"\ + :{\"type\":\"string\"},\"location\":{\"type\":\"string\"},\"Transaction\"\ + :{\"type\":\"string\"},\"StorageRead\":{\"type\":\"string\"},\"StorageWrite\"\ + :{\"type\":\"string\"},\"StorageDelete\":{\"type\":\"string\"}},\"variables\"\ + :{},\"resources\":[{\"type\":\"Microsoft.storage/storageAccounts/blobServices/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/default/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Transaction\",\"enabled\":\"[parameters('Transaction')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"StorageRead\",\"enabled\":\"[parameters('StorageRead')]\"},{\"category\"\ + :\"StorageWrite\",\"enabled\":\"[parameters('StorageWrite')]\"},{\"category\"\ + :\"StorageDelete\",\"enabled\":\"[parameters('StorageDelete')]\"}]}},{\"type\"\ + :\"Microsoft.storage/storageAccounts/fileServices/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/default/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Transaction\",\"enabled\":\"[parameters('Transaction')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"StorageRead\",\"enabled\":\"[parameters('StorageRead')]\"},{\"category\"\ + :\"StorageWrite\",\"enabled\":\"[parameters('StorageWrite')]\"},{\"category\"\ + :\"StorageDelete\",\"enabled\":\"[parameters('StorageDelete')]\"}]}},{\"type\"\ + :\"Microsoft.storage/storageAccounts/tableServices/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/default/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Transaction\",\"enabled\":\"[parameters('Transaction')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"StorageRead\",\"enabled\":\"[parameters('StorageRead')]\"},{\"category\"\ + :\"StorageWrite\",\"enabled\":\"[parameters('StorageWrite')]\"},{\"category\"\ + :\"StorageDelete\",\"enabled\":\"[parameters('StorageDelete')]\"}]}},{\"type\"\ + :\"Microsoft.storage/storageAccounts/queueServices/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/default/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Transaction\",\"enabled\":\"[parameters('Transaction')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"StorageRead\",\"enabled\":\"[parameters('StorageRead')]\"},{\"category\"\ + :\"StorageWrite\",\"enabled\":\"[parameters('StorageWrite')]\"},{\"category\"\ + :\"StorageDelete\",\"enabled\":\"[parameters('StorageDelete')]\"}]}},{\"type\"\ + :\"Microsoft.storage/storageAccounts/providers/diagnosticSettings\",\"apiVersion\"\ + :\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'), '/',\ + \ 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\",\"\ + location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\":{\"\ + workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"Transaction\",\"enabled\":\"[parameters('Transaction')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"StorageRead\",\"enabled\":\"[parameters('StorageRead')]\"},{\"category\"\ + :\"StorageWrite\",\"enabled\":\"[parameters('StorageWrite')]\"},{\"category\"\ + :\"StorageDelete\",\"enabled\":\"[parameters('StorageDelete')]\"}]}}],\"outputs\"\ + :{}},\"parameters\":{\"diagnosticsSettingNameToUse\":{\"value\":\"[parameters('diagnosticsSettingNameToUse')]\"\ + },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"location\"\ + :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ + },\"Transaction\":{\"value\":\"[parameters('Transaction')]\"},\"StorageDelete\"\ + :{\"value\":\"[parameters('StorageDelete')]\"},\"StorageWrite\":{\"value\"\ + :\"[parameters('StorageWrite')]\"},\"StorageRead\":{\"value\":\"[parameters('StorageRead')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6f8f98a4-f108-47cb-8e98-91a0d85cd474\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6f8f98a4-f108-47cb-8e98-91a0d85cd474\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ for Azure Kubernetes Service to Log Analytics workspace\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic\ + \ settings for Azure Kubernetes Service to stream resource logs to a Log Analytics\ + \ workspace.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Kubernetes\"\ + },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ + :\"DeployIfNotExists\"},\"diagnosticsSettingNameToUse\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Setting name\",\"description\":\"Name of\ + \ the diagnostic settings.\"},\"defaultValue\":\"AzureKubernetesDiagnosticsLogsToWorkspace\"\ + },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ + \ Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ + \ the Azure Kubernetes Service should be connected to\",\"strongType\":\"\ + omsWorkspace\",\"assignPermissions\":true}},\"AllMetrics\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"AllMetrics - Enabled\",\"description\":\"\ + Whether to stream AllMetrics logs to the Log Analytics workspace - True or\ + \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + },\"kube-apiserver\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + kube-apiserver - Enabled\",\"description\":\"Whether to stream kube-apiserver\ + \ logs to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"True\"},\"kube-audit\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"kube-audit - Enabled\",\"description\"\ + :\"Whether to stream kube-audit logs to the Log Analytics workspace - True\ + \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + },\"kube-controller-manager\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"kube-controller-manager - Enabled\",\"description\":\"Whether to stream\ + \ kube-controller-manager logs to the Log Analytics workspace - True or False\"\ + },\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"},\"kube-scheduler\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"kube-scheduler - Enabled\"\ + ,\"description\":\"Whether to stream kube-scheduler logs to the Log Analytics\ + \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"cluster-autoscaler\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"cluster-autoscaler - Enabled\",\"description\":\"Whether to stream cluster-autoscaler\ + \ logs to the Log Analytics workspace - True or False\"},\"allowedValues\"\ + :[\"True\",\"False\"],\"defaultValue\":\"True\"},\"kube-audit-admin\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"kube-audit-admin - Enabled\"\ + ,\"description\":\"Whether to stream kube-audit-admin logs to the Log Analytics\ + \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ + :\"True\"},\"guard\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + guard - Enabled\",\"description\":\"Whether to stream guard logs to the Log\ + \ Analytics workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"\ + ],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"\ + equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\":{\"effect\"\ + :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ + ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ + ,\"equals\":\"[parameters('logAnalytics')]\"}]},\"deployment\":{\"properties\"\ + :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"diagnosticsSettingNameToUse\"\ + :{\"type\":\"string\"},\"resourceName\":{\"type\":\"string\"},\"logAnalytics\"\ + :{\"type\":\"string\"},\"location\":{\"type\":\"string\"},\"AllMetrics\":{\"\ + type\":\"string\"},\"kube-apiserver\":{\"type\":\"string\"},\"kube-audit\"\ + :{\"type\":\"string\"},\"kube-controller-manager\":{\"type\":\"string\"},\"\ + kube-scheduler\":{\"type\":\"string\"},\"cluster-autoscaler\":{\"type\":\"\ + string\"},\"kube-audit-admin\":{\"type\":\"string\"},\"guard\":{\"type\":\"\ + string\"}},\"variables\":{},\"resources\":[{\"type\":\"Microsoft.ContainerService/managedClusters/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"AllMetrics\",\"enabled\":\"[parameters('AllMetrics')]\"}],\"logs\":[{\"\ + category\":\"kube-apiserver\",\"enabled\":\"[parameters('kube-apiserver')]\"\ + },{\"category\":\"kube-audit\",\"enabled\":\"[parameters('kube-audit')]\"\ + },{\"category\":\"kube-controller-manager\",\"enabled\":\"[parameters('kube-controller-manager')]\"\ + },{\"category\":\"kube-scheduler\",\"enabled\":\"[parameters('kube-scheduler')]\"\ + },{\"category\":\"cluster-autoscaler\",\"enabled\":\"[parameters('cluster-autoscaler')]\"\ + },{\"category\":\"kube-audit-admin\",\"enabled\":\"[parameters('kube-audit-admin')]\"\ + },{\"category\":\"guard\",\"enabled\":\"[parameters('guard')]\"}]}}],\"outputs\"\ + :{}},\"parameters\":{\"diagnosticsSettingNameToUse\":{\"value\":\"[parameters('diagnosticsSettingNameToUse')]\"\ + },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"location\"\ + :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ + },\"guard\":{\"value\":\"[parameters('guard')]\"},\"AllMetrics\":{\"value\"\ + :\"[parameters('AllMetrics')]\"},\"kube-apiserver\":{\"value\":\"[parameters('kube-apiserver')]\"\ + },\"kube-audit\":{\"value\":\"[parameters('kube-audit')]\"},\"kube-scheduler\"\ + :{\"value\":\"[parameters('kube-scheduler')]\"},\"kube-controller-manager\"\ + :{\"value\":\"[parameters('kube-controller-manager')]\"},\"cluster-autoscaler\"\ + :{\"value\":\"[parameters('cluster-autoscaler')]\"},\"kube-audit-admin\":{\"\ + value\":\"[parameters('kube-audit-admin')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6c66c325-74c8-42fd-a286-a74b0e2939d8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6c66c325-74c8-42fd-a286-a74b0e2939d8\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure private DNS zones\ + \ for private endpoints that connect to Batch accounts\",\"policyType\":\"\ + BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Private DNS records allow\ + \ private connections to private endpoints. Private endpoint connections allow\ + \ secure communication by enabling private connectivity to Batch accounts\ + \ without a need for public IP addresses at the source or destination. For\ + \ more information on private endpoints and DNS zones in Batch, see https://docs.microsoft.com/azure/batch/private-connectivity.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Batch\"},\"parameters\"\ + :{\"privateDnsZoneId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Private DNS Zone\",\"strongType\":\"Microsoft.Network/privateDnsZones\"\ + ,\"description\":\"The private DNS zone to deploy in a new private DNS zone\ + \ group and link to the private endpoint\"}},\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ + ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"}},\"policyRule\":{\"\ + if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/privateEndpoints\"\ + },{\"count\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"where\":{\"field\":\"Microsoft.Network/privateEndpoints/privateLinkServiceConnections[*].groupIds[*]\"\ + ,\"equals\":\"batchAccount\"}},\"greaterOrEquals\":1}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"privateDnsZoneId\":{\"type\"\ + :\"string\"},\"privateEndpointName\":{\"type\":\"string\"},\"location\":{\"\ + type\":\"string\"}},\"resources\":[{\"name\":\"[concat(parameters('privateEndpointName'),\ + \ '/deployedByPolicy')]\",\"type\":\"Microsoft.Network/privateEndpoints/privateDnsZoneGroups\"\ + ,\"apiVersion\":\"2020-03-01\",\"location\":\"[parameters('location')]\",\"\ + properties\":{\"privateDnsZoneConfigs\":[{\"name\":\"batchAccount-privateDnsZone\"\ + ,\"properties\":{\"privateDnsZoneId\":\"[parameters('privateDnsZoneId')]\"\ + }}]}}]},\"parameters\":{\"privateDnsZoneId\":{\"value\":\"[parameters('privateDnsZoneId')]\"\ + },\"privateEndpointName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ + value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/4ec38ebc-381f-45ee-81a4-acbc4be878f8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"4ec38ebc-381f-45ee-81a4-acbc4be878f8\"\ + },{\"properties\":{\"displayName\":\"App Configuration should disable public\ + \ network access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ + :\"Disabling public network access improves security by ensuring that the\ + \ resource isn't exposed on the public internet. You can limit exposure of\ + \ your resources by creating private endpoints instead. Learn more at: https://aka.ms/appconfig/private-endpoint.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"App Configuration\"},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.AppConfiguration/configurationStores\"},{\"field\":\"Microsoft.AppConfiguration/configurationStores/publicNetworkAccess\"\ + ,\"notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3d9f5e4c-9947-4579-9539-2a7695fbc187\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3d9f5e4c-9947-4579-9539-2a7695fbc187\"\ + },{\"properties\":{\"displayName\":\"Deploy - Configure diagnostic settings\ + \ for Azure Key Vault to Log Analytics workspace\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Indexed\",\"description\":\"Deploys the diagnostic settings for\ + \ Azure Key Vault to stream resource logs to a Log Analytics workspace when\ + \ any Key Vault which is missing this diagnostic settings is created or updated.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Key Vault\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ + },\"diagnosticsSettingNameToUse\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Setting name\",\"description\":\"Name of the diagnostic settings.\"},\"\ + defaultValue\":\"AzureKeyVaultDiagnosticsLogsToWorkspace\"},\"logAnalytics\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log Analytics workspace\"\ + ,\"description\":\"Specify the Log Analytics workspace the Key Vault should\ + \ be connected to.\",\"strongType\":\"omsWorkspace\",\"assignPermissions\"\ + :true}},\"AuditEventEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"AuditEvent - Enabled\",\"description\":\"Whether to stream AuditEvent logs\ + \ to the Log Analytics workspace - True or False\"},\"allowedValues\":[\"\ + True\",\"False\"],\"defaultValue\":\"True\"},\"AllMetricsEnabled\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"AllMetrics - Enabled\",\"description\"\ + :\"Whether to stream AllMetrics logs to the Log Analytics workspace - True\ + \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ + Microsoft.Insights/diagnosticSettings\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ + ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ + ],\"existenceCondition\":{\"allOf\":[{\"anyof\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ + ,\"equals\":\"True\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ + ,\"equals\":\"True\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ + ,\"equals\":\"[parameters('logAnalytics')]\"}]},\"deployment\":{\"properties\"\ + :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"diagnosticsSettingNameToUse\"\ + :{\"type\":\"string\"},\"resourceName\":{\"type\":\"string\"},\"logAnalytics\"\ + :{\"type\":\"string\"},\"location\":{\"type\":\"string\"},\"AuditEventEnabled\"\ + :{\"type\":\"string\"},\"AllMetricsEnabled\":{\"type\":\"string\"}},\"variables\"\ + :{},\"resources\":[{\"type\":\"Microsoft.KeyVault/vaults/providers/diagnosticSettings\"\ + ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ + \ '/', 'Microsoft.Insights/', parameters('diagnosticsSettingNameToUse'))]\"\ + ,\"location\":\"[parameters('location')]\",\"dependsOn\":[],\"properties\"\ + :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\"\ + :\"AllMetrics\",\"enabled\":\"[parameters('AllMetricsEnabled')]\",\"retentionPolicy\"\ + :{\"days\":0,\"enabled\":false},\"timeGrain\":null}],\"logs\":[{\"category\"\ + :\"AuditEvent\",\"enabled\":\"[parameters('AuditEventEnabled')]\"}]}}],\"\ + outputs\":{}},\"parameters\":{\"diagnosticsSettingNameToUse\":{\"value\":\"\ + [parameters('diagnosticsSettingNameToUse')]\"},\"logAnalytics\":{\"value\"\ + :\"[parameters('logAnalytics')]\"},\"location\":{\"value\":\"[field('location')]\"\ + },\"resourceName\":{\"value\":\"[field('name')]\"},\"AuditEventEnabled\":{\"\ + value\":\"[parameters('AllMetricsEnabled')]\"},\"AllMetricsEnabled\":{\"value\"\ + :\"[parameters('AuditEventEnabled')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/951af2fa-529b-416e-ab6e-066fd85ac459\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"951af2fa-529b-416e-ab6e-066fd85ac459\"\ + },{\"properties\":{\"displayName\":\"App Configuration should use a SKU that\ + \ supports private link\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"When using a supported SKU, Azure Private Link lets you\ + \ connect your virtual network to Azure services without a public IP address\ + \ at the source or destination. The private link platform handles the connectivity\ + \ between the consumer and services over the Azure backbone network. By mapping\ + \ private endpoints to your app configuration instances instead of the entire\ + \ service, you'll also be protected against data leakage risks. Learn more\ + \ at: https://aka.ms/appconfig/private-endpoint.\",\"metadata\":{\"version\"\ + :\"1.0.0\",\"category\":\"App Configuration\"},\"parameters\":{\"effect\"\ :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ + Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.AppConfiguration/configurationStores\"\ + },{\"field\":\"Microsoft.AppConfiguration/configurationStores/sku.name\",\"\ + equals\":\"Free\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/89c8a434-18f0-402c-8147-630a8dea54e0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"89c8a434-18f0-402c-8147-630a8dea54e0\"\ + },{\"properties\":{\"displayName\":\"Private endpoint connections on Batch\ + \ accounts should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ + ,\"description\":\"Private endpoint connections allow secure communication\ + \ by enabling private connectivity to Batch accounts without a need for public\ + \ IP addresses at the source or destination. Learn more about private endpoints\ + \ in Batch at https://docs.microsoft.com/azure/batch/private-connectivity.\"\ + ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Batch\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"\ },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/logProfiles\",\"existenceCondition\":{\"field\":\"Microsoft.Insights/logProfiles/categories\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7796937f-307b-4598-941c-67d3a05ebfe7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7796937f-307b-4598-941c-67d3a05ebfe7\"\ - },{\"properties\":{\"displayName\":\"Virtual network firewall rule on Azure\ - \ SQL Database should be enabled to allow traffic from the specified subnet\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Virtual\ - \ network based firewall rules are used to enable traffic from a specific\ - \ subnet to Azure SQL Database while ensuring the traffic stays within the\ - \ Azure boundary.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"\ - },\"parameters\":{\"subnetId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Subnet ID\",\"strongType\":\"Microsoft.Network/virtualNetworks/subnets\"\ - ,\"description\":\"The resource ID of the virtual network subnet that should\ - \ have a rule enabled. Example: /subscriptions/00000000-1111-2222-3333-444444444444/resourceGroups/Default/providers/Microsoft.Network/virtualNetworks/testvnet/subnets/testsubnet\"\ - }}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },\"then\":{\"effect\":\"AuditIfNotExists\",\"details\":{\"type\":\"Microsoft.Sql/servers/virtualNetworkRules\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"equals\":\"[parameters('subnetId')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/77e8b146-0078-4fb2-b002-e112381199f0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"77e8b146-0078-4fb2-b002-e112381199f0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1336 - Authenticator\ - \ Management | Pki-Based Authentication\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Identification and\ - \ Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1336\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/77f56280-e367-432a-a3b9-8ca2aa636a26\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"77f56280-e367-432a-a3b9-8ca2aa636a26\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1258 - Contingency\ - \ Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1258\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7814506c-382c-4d33-a142-249dd4a0dbff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7814506c-382c-4d33-a142-249dd4a0dbff\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1178 - Baseline\ - \ Configuration | Reviews And Updates\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1178\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7818b8f4-47c6-441a-90ae-12ce04e99893\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7818b8f4-47c6-441a-90ae-12ce04e99893\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1057 - Permitted\ - \ Actions Without Identification Or Authentication\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1057\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/78255758-6d45-4bf0-a005-7016bc03b13c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"78255758-6d45-4bf0-a005-7016bc03b13c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1700 - Information\ - \ System Monitoring | Unauthorized Network Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1700\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7831b4ba-c3f4-4cb1-8c11-ef8d59438cd5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7831b4ba-c3f4-4cb1-8c11-ef8d59438cd5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1010 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1010\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/784663a8-1eb0-418a-a98c-24d19bc1bb62\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"784663a8-1eb0-418a-a98c-24d19bc1bb62\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1216 - Least\ - \ Functionality | Periodic Review\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1216\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7894fe6a-f5cb-44c8-ba90-c3f254ff9484\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7894fe6a-f5cb-44c8-ba90-c3f254ff9484\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1639 - Boundary\ - \ Protection | Isolation Of Information System Components\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1639\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/78e8e649-50f6-4fe3-99ac-fedc2e63b03f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"78e8e649-50f6-4fe3-99ac-fedc2e63b03f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1647 - Cryptographic\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1647\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/791cfc15-6974-42a0-9f4c-2d4b82f4a78c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"791cfc15-6974-42a0-9f4c-2d4b82f4a78c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1510 - Position\ - \ Risk Designation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1510\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/79da5b09-0e7e-499e-adda-141b069c7998\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"79da5b09-0e7e-499e-adda-141b069c7998\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1384 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1384\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/79fbc228-461c-4a45-9004-a865ca0728a7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"79fbc228-461c-4a45-9004-a865ca0728a7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows Server VMs on which Windows Serial Console is not enabled\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows Server virtual\ - \ machines on which Windows Serial Console is not enabled. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - EMSPortNumber\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ EMS Port Number\",\"description\":\"An integer indicating the COM port to\ - \ be used for the Emergency Management Services (EMS) console redirection.\ - \ For more information on EMS settings, please visit https://aka.ms/gcpolwsc\"\ - },\"allowedValues\":[\"1\",\"2\",\"3\",\"4\"],\"defaultValue\":\"1\"},\"EMSBaudRate\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: EMS Baud\ - \ Rate\",\"description\":\"An integer indicating the baud rate to be used\ - \ for the Emergency Management Services (EMS) console redirection. For more\ - \ information on EMS settings, please visit https://aka.ms/gcpolwsc\"},\"\ - allowedValues\":[\"9600\",\"19200\",\"38400\",\"57600\",\"115200\"],\"defaultValue\"\ - :\"115200\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsSerialConsole\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber',\ - \ '=', parameters('EMSPortNumber'), ',', '[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate',\ - \ '=', parameters('EMSBaudRate')))]\"},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsSerialConsole\"\ - },\"EMSPortNumber\":{\"value\":\"[parameters('EMSPortNumber')]\"},\"EMSBaudRate\"\ - :{\"value\":\"[parameters('EMSBaudRate')]\"}},\"template\":{\"$schema\":\"\ - https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"EMSPortNumber\":{\"type\":\"string\"},\"EMSBaudRate\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber\"\ - ,\"value\":\"[parameters('EMSPortNumber')]\"},{\"name\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate\"\ - ,\"value\":\"[parameters('EMSBaudRate')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSPortNumber\"\ - ,\"value\":\"[parameters('EMSPortNumber')]\"},{\"name\":\"[WindowsSerialConsole]WindowsSerialConsole;EMSBaudRate\"\ - ,\"value\":\"[parameters('EMSBaudRate')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a031c68-d6ab-406e-a506-697a19c634b0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a031c68-d6ab-406e-a506-697a19c634b0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1093 - Role-Based\ - \ Security Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1093\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a0bdeeb-15f4-47e8-a1da-9f769f845fdf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a0bdeeb-15f4-47e8-a1da-9f769f845fdf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1708 - Security\ - \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1708\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a1e2c88-13de-4959-8ee7-47e3d74f1f48\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a1e2c88-13de-4959-8ee7-47e3d74f1f48\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1289 - Information\ - \ System Backup\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1289\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a724864-956a-496c-b778-637cb1d762cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a724864-956a-496c-b778-637cb1d762cf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1687 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1687\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7a87fc7f-301e-49f3-ba2a-4d74f424fa97\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7a87fc7f-301e-49f3-ba2a-4d74f424fa97\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1061 - Remote\ - \ Access | Automated Monitoring / Control\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1061\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ac22808-a2e8-41c4-9d46-429b50738914\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ac22808-a2e8-41c4-9d46-429b50738914\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1492 - System\ - \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1492\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ad5f307-e045-46f7-8214-5bdb7e973737\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ad5f307-e045-46f7-8214-5bdb7e973737\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1636 - Boundary\ - \ Protection | Isolation Of Security Tools / Mechanisms / Support Components\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Communications Protection control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1636\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7b694eed-7081-43c6-867c-41c76c961043\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7b694eed-7081-43c6-867c-41c76c961043\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Virtual Machine Scale\ - \ Sets should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"It is recommended to enable Logs so that activity trail\ - \ can be recreated when investigations are required in the event of an incident\ - \ or a compromise.\",\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Compute\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"includeAKSClusters\":{\"type\":\"Boolean\",\"metadata\"\ - :{\"displayName\":\"Include AKS Clusters\",\"description\":\"Whether to include\ - \ AKS Clusters to Diagnostic logs extension - True or False\"},\"defaultValue\"\ - :false}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"value\":\"[parameters('includeAKSClusters')]\"\ - ,\"equals\":true}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"value\":\"[parameters('includeAKSClusters')]\",\"equals\":false},{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"notEquals\":\"microsoft-aks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notEquals\":\"aks\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"aks*\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"IaaSDiagnostics\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Diagnostics\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"LinuxDiagnostic\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"in\":[\"Microsoft.OSTCExtensions\",\"Microsoft.Azure.Diagnostics\"]}]}]}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/7c1b1214-f927-48bf-8882-84f0af6588b1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7c1b1214-f927-48bf-8882-84f0af6588b1\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Require blob encryption\ - \ for storage accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy ensures blob encryption for storage accounts is\ - \ turned on. It only applies to Microsoft.Storage resource types, not other\ - \ storage providers. This policy is deprecated because storage blob encryption\ - \ is now enabled by default, and can no longer be disabled.\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Storage\",\"deprecated\"\ - :true},\"parameters\":{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.Storage/storageAccounts\"},{\"field\":\"Microsoft.Storage/storageAccounts/enableBlobEncryption\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7c5a74bf-ae94-4a74-8fcf-644d1e0e6e6f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7c5a74bf-ae94-4a74-8fcf-644d1e0e6e6f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1143 - Security\ - \ Assessment And Authorization Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Security\ - \ Assessment and Authorization control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1143\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7c6de11b-5f51-4f7c-8d83-d2467c8a816e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7c6de11b-5f51-4f7c-8d83-d2467c8a816e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1051 - Session\ - \ Lock\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1051\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7cac6ee9-b58b-40c8-a5ce-f0efc3d9b339\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7cac6ee9-b58b-40c8-a5ce-f0efc3d9b339\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1279 - Telecommunications\ - \ Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1279\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7d00bcd6-963d-4c02-ad8e-b45fa50bf3b0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7d00bcd6-963d-4c02-ad8e-b45fa50bf3b0\"\ - },{\"properties\":{\"displayName\":\"Azure Cache for Redis should reside within\ - \ a virtual network\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Azure Cache for Redis has the ability to reside within a virtual network,\ - \ which is a way for the resource to have a non-public endpoint controlled\ - \ and managed by the user.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"Cache\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"The effect determines what happens\ - \ when the policy rule is evaluated to match.\"},\"allowedValues\":[\"Audit\"\ - ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Cache/redis\"},{\"\ - field\":\"Microsoft.Cache/Redis/subnetId\",\"exists\":\"false\"}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7d092e0a-7acd-40d2-a975-dca21cae48c4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7d092e0a-7acd-40d2-a975-dca21cae48c4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1109 - Content\ - \ Of Audit Records | Centralized Management Of Planned Audit Record Content\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Audit and Accountability control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1109\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7d9ffa23-ad92-4d0d-b1f4-7db274cc2aec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7d9ffa23-ad92-4d0d-b1f4-7db274cc2aec\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1201 - Security\ - \ Impact Analysis | Separate Test Environments\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1201\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7daef997-fdd3-461b-8807-a608a6dd70f1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7daef997-fdd3-461b-8807-a608a6dd70f1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1471 - Emergency\ - \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1471\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7dd0e9ce-1772-41fb-a50a-99977071f916\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7dd0e9ce-1772-41fb-a50a-99977071f916\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that have the specified applications installed. For more information on\ - \ Guest Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"NotInstalledApplication\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7e56b49b-5990-4159-a734-511ea19b731c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7e56b49b-5990-4159-a734-511ea19b731c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1011 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1011\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7e6a54f3-883f-43d5-87c4-172dfd64a1f5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7e6a54f3-883f-43d5-87c4-172dfd64a1f5\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that have not restarted within the specified number of days\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines that have not restarted within the specified number of\ - \ days. For more information on Guest Configuration policies, please visit\ - \ https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"\ - category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MachineLastBootUpTime\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7e84ba44-6d03-46fd-950e-5efa5a1112fa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7e84ba44-6d03-46fd-950e-5efa5a1112fa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1692 - Information\ - \ System Monitoring | Inbound And Outbound Communications Traffic\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1692\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ecda928-9df4-4dd7-8f44-641a91e470e8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ecda928-9df4-4dd7-8f44-641a91e470e8\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have the password complexity setting enabled\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ that do not have the password complexity setting enabled. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"2.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordMustMeetComplexityRequirements\",\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"PasswordMustMeetComplexityRequirements\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ed40801-8a0f-4ceb-85c0-9fd25c1d61a8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ed40801-8a0f-4ceb-85c0-9fd25c1d61a8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1191 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1191\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f26a61b-a74d-467c-99cf-63644db144f7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f26a61b-a74d-467c-99cf-63644db144f7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1520 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1520\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f2c513b-eb16-463b-b469-c10e5fa94f0a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f2c513b-eb16-463b-b469-c10e5fa94f0a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1126 - Audit\ - \ Reduction And Report Generation | Automatic Processing\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1126\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f37f71b-420f-49bf-9477-9c0196974ecf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f37f71b-420f-49bf-9477-9c0196974ecf\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Privilege Use'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Privilege Use'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesPrivilegeUse\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f4e96d1-e4f3-4dbb-b767-33ca4df8df7c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f4e96d1-e4f3-4dbb-b767-33ca4df8df7c\"\ - },{\"properties\":{\"displayName\":\"Audit diagnostic setting\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"Audit diagnostic setting for\ - \ selected resource types\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"listOfResourceTypes\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"Resource Types\",\"strongType\":\"resourceTypes\"\ - }}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":\"[parameters('listOfResourceTypes')]\"\ - },\"then\":{\"effect\":\"AuditIfNotExists\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7f89b1eb-583c-429a-8828-af049802c1d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7f89b1eb-583c-429a-8828-af049802c1d9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1117 - Audit\ - \ Review, Analysis, And Reporting | Process Integration\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1117\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7fbfe680-6dbb-4037-963c-a621c5635902\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7fbfe680-6dbb-4037-963c-a621c5635902\"\ - },{\"properties\":{\"displayName\":\"Advanced data security should be enabled\ - \ on Azure SQL Database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Advanced data security provides functionality for surfacing\ - \ and mitigating potential database vulnerabilities, detecting anomalous activities\ - \ that could indicate a threat on SQL database and discovering and classifying\ - \ sensitive data.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Security\ - \ Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/pricings\"\ - ,\"name\":\"SqlServers\",\"existenceScope\":\"subscription\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/pricings/pricingTier\",\"equals\":\"Standard\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7fe3b40f-802b-4cdd-8bd4-fd799c948cc2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7fe3b40f-802b-4cdd-8bd4-fd799c948cc2\"\ - },{\"properties\":{\"displayName\":\"SQL Auditing settings should have Action-Groups\ - \ configured to capture critical activities\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"The AuditActionsAndGroups property should\ - \ contain at least SUCCESSFUL_DATABASE_AUTHENTICATION_GROUP, FAILED_DATABASE_AUTHENTICATION_GROUP,\ - \ BATCH_COMPLETED_GROUP to ensure a thorough audit logging\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/servers/auditingSettings\",\"name\":\"default\",\"existenceCondition\"\ - :{\"allOf\":[{\"not\":{\"field\":\"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]\"\ - ,\"notEquals\":\"SUCCESSFUL_DATABASE_AUTHENTICATION_GROUP\"}},{\"not\":{\"\ - field\":\"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]\"\ - ,\"notEquals\":\"FAILED_DATABASE_AUTHENTICATION_GROUP\"}},{\"not\":{\"field\"\ - :\"Microsoft.Sql/servers/auditingSettings/auditActionsAndGroups[*]\",\"notEquals\"\ - :\"BATCH_COMPLETED_GROUP\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ff426e2-515f-405a-91c8-4f2333442eb5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ff426e2-515f-405a-91c8-4f2333442eb5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1703 - Security\ - \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1703\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/804faf7d-b687-40f7-9f74-79e28adf4205\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"804faf7d-b687-40f7-9f74-79e28adf4205\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1303 - Identification\ - \ And Authentication (Org. Users) | Local Access To Privileged Accounts\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1303\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/80ca0a27-918a-4604-af9e-723a27ee51e8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"80ca0a27-918a-4604-af9e-723a27ee51e8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1505 - Information\ - \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Planning control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1505\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/813a10a7-3943-4fe3-8678-00dc52db5490\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"813a10a7-3943-4fe3-8678-00dc52db5490\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1614 - Developer\ - \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1614\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8154e3b3-cc52-40be-9407-7756581d71f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8154e3b3-cc52-40be-9407-7756581d71f6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'User Rights Assignment'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'User Rights Assignment'. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"parameters\":{\"\ - UsersOrGroupsThatMayAccessThisComputerFromTheNetwork\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Users or groups that may access\ - \ this computer from the network\",\"description\":\"Specifies which remote\ - \ users on the network are permitted to connect to the computer. This does\ - \ not include Remote Desktop Connection.\"},\"defaultValue\":\"Administrators,\ - \ Authenticated Users\"},\"UsersOrGroupsThatMayLogOnLocally\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users or groups that\ - \ may log on locally\",\"description\":\"Specifies which users or groups can\ - \ interactively log on to the computer. Users who attempt to log on via Remote\ - \ Desktop Connection or IIS also require this user right.\"},\"defaultValue\"\ - :\"Administrators\"},\"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ or groups that may log on through Remote Desktop Services\",\"description\"\ - :\"Specifies which users or groups are permitted to log on as a Terminal Services\ - \ client, Remote Desktop, or for Remote Assistance.\"},\"defaultValue\":\"\ - Administrators, Remote Desktop Users\"},\"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ and groups that are denied access to this computer from the network\",\"\ - description\":\"Specifies which users or groups are explicitly prohibited\ - \ from connecting to the computer across the network.\"},\"defaultValue\"\ - :\"Guests\"},\"UsersOrGroupsThatMayManageAuditingAndSecurityLog\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users or groups\ - \ that may manage auditing and security log\",\"description\":\"Specifies\ - \ users and groups permitted to change the auditing options for files and\ - \ directories and clear the Security log.\"},\"defaultValue\":\"Administrators\"\ - },\"UsersOrGroupsThatMayBackUpFilesAndDirectories\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Deprecated]: Users or groups that may back\ - \ up files and directories\",\"description\":\"Specifies users and groups\ - \ allowed to circumvent file and directory permissions to back up the system.\"\ - },\"defaultValue\":\"Administrators, Backup Operators\"},\"UsersOrGroupsThatMayChangeTheSystemTime\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ or groups that may change the system time\",\"description\":\"Specifies\ - \ which users and groups are permitted to change the time and date on the\ - \ internal clock of the computer.\"},\"defaultValue\":\"Administrators, LOCAL\ - \ SERVICE\"},\"UsersOrGroupsThatMayChangeTheTimeZone\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Users or groups that may change\ - \ the time zone\",\"description\":\"Specifies which users and groups are permitted\ - \ to change the time zone of the computer.\"},\"defaultValue\":\"Administrators,\ - \ LOCAL SERVICE\"},\"UsersOrGroupsThatMayCreateATokenObject\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users or groups that\ - \ may create a token object\",\"description\":\"Specifies which users and\ - \ groups are permitted to create an access token, which may provide elevated\ - \ rights to access sensitive data.\"},\"defaultValue\":\"No One\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ and groups that are denied logging on as a batch job\",\"description\":\"\ - Specifies which users and groups are explicitly not permitted to log on to\ - \ the computer as a batch job (i.e. scheduled task).\"},\"defaultValue\":\"\ - Guests\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsAService\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users and groups that\ - \ are denied logging on as a service\",\"description\":\"Specifies which service\ - \ accounts are explicitly not permitted to register a process as a service.\"\ - },\"defaultValue\":\"Guests\"},\"UsersAndGroupsThatAreDeniedLocalLogon\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users and\ - \ groups that are denied local logon\",\"description\":\"Specifies which users\ - \ and groups are explicitly not permitted to log on to the computer.\"},\"\ - defaultValue\":\"Guests\"},\"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ and groups that are denied log on through Remote Desktop Services\",\"description\"\ - :\"Specifies which users and groups are explicitly not permitted to log on\ - \ to the computer via Terminal Services/Remote Desktop Client.\"},\"defaultValue\"\ - :\"Guests\"},\"UserAndGroupsThatMayForceShutdownFromARemoteSystem\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: User and groups\ - \ that may force shutdown from a remote system\",\"description\":\"Specifies\ - \ which users and groups are permitted to shut down the computer from a remote\ - \ location on the network.\"},\"defaultValue\":\"Administrators\"},\"UsersAndGroupsThatMayRestoreFilesAndDirectories\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ and groups that may restore files and directories\",\"description\":\"Specifies\ - \ which users and groups are permitted to bypass file, directory, registry,\ - \ and other persistent object permissions when restoring backed up files and\ - \ directories.\"},\"defaultValue\":\"Administrators, Backup Operators\"},\"\ - UsersAndGroupsThatMayShutDownTheSystem\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Users and groups that may shut down the\ - \ system\",\"description\":\"Specifies which users and groups who are logged\ - \ on locally to the computers in your environment are permitted to shut down\ - \ the operating system with the Shut Down command.\"},\"defaultValue\":\"\ - Administrators\"},\"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Users\ - \ or groups that may take ownership of files or other objects\",\"description\"\ - :\"Specifies which users and groups are permitted to take ownership of files,\ - \ folders, registry keys, processes, or threads. This user right bypasses\ - \ any permissions that are in place to protect objects to give ownership to\ - \ the specified user.\"},\"defaultValue\":\"Administrators\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_UserRightsAssignment\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Access this computer from the network;ExpectedValue',\ - \ '=', parameters('UsersOrGroupsThatMayAccessThisComputerFromTheNetwork'),\ - \ ',', 'Allow log on locally;ExpectedValue', '=', parameters('UsersOrGroupsThatMayLogOnLocally'),\ - \ ',', 'Allow log on through Remote Desktop Services;ExpectedValue', '=',\ - \ parameters('UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices'), ',',\ - \ 'Deny access to this computer from the network;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork'),\ - \ ',', 'Manage auditing and security log;ExpectedValue', '=', parameters('UsersOrGroupsThatMayManageAuditingAndSecurityLog'),\ - \ ',', 'Back up files and directories;ExpectedValue', '=', parameters('UsersOrGroupsThatMayBackUpFilesAndDirectories'),\ - \ ',', 'Change the system time;ExpectedValue', '=', parameters('UsersOrGroupsThatMayChangeTheSystemTime'),\ - \ ',', 'Change the time zone;ExpectedValue', '=', parameters('UsersOrGroupsThatMayChangeTheTimeZone'),\ - \ ',', 'Create a token object;ExpectedValue', '=', parameters('UsersOrGroupsThatMayCreateATokenObject'),\ - \ ',', 'Deny log on as a batch job;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob'),\ - \ ',', 'Deny log on as a service;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLoggingOnAsAService'),\ - \ ',', 'Deny log on locally;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLocalLogon'),\ - \ ',', 'Deny log on through Remote Desktop Services;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices'),\ - \ ',', 'Force shutdown from a remote system;ExpectedValue', '=', parameters('UserAndGroupsThatMayForceShutdownFromARemoteSystem'),\ - \ ',', 'Restore files and directories;ExpectedValue', '=', parameters('UsersAndGroupsThatMayRestoreFilesAndDirectories'),\ - \ ',', 'Shut down the system;ExpectedValue', '=', parameters('UsersAndGroupsThatMayShutDownTheSystem'),\ - \ ',', 'Take ownership of files or other objects;ExpectedValue', '=', parameters('UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_UserRightsAssignment\"},\"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork\"\ - :{\"value\":\"[parameters('UsersOrGroupsThatMayAccessThisComputerFromTheNetwork')]\"\ - },\"UsersOrGroupsThatMayLogOnLocally\":{\"value\":\"[parameters('UsersOrGroupsThatMayLogOnLocally')]\"\ - },\"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices\":{\"value\":\"\ - [parameters('UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices')]\"},\"\ - UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork\":{\"value\"\ - :\"[parameters('UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork')]\"\ - },\"UsersOrGroupsThatMayManageAuditingAndSecurityLog\":{\"value\":\"[parameters('UsersOrGroupsThatMayManageAuditingAndSecurityLog')]\"\ - },\"UsersOrGroupsThatMayBackUpFilesAndDirectories\":{\"value\":\"[parameters('UsersOrGroupsThatMayBackUpFilesAndDirectories')]\"\ - },\"UsersOrGroupsThatMayChangeTheSystemTime\":{\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheSystemTime')]\"\ - },\"UsersOrGroupsThatMayChangeTheTimeZone\":{\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheTimeZone')]\"\ - },\"UsersOrGroupsThatMayCreateATokenObject\":{\"value\":\"[parameters('UsersOrGroupsThatMayCreateATokenObject')]\"\ - },\"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob\":{\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob')]\"\ - },\"UsersAndGroupsThatAreDeniedLoggingOnAsAService\":{\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsAService')]\"\ - },\"UsersAndGroupsThatAreDeniedLocalLogon\":{\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLocalLogon')]\"\ - },\"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices\":{\"value\"\ - :\"[parameters('UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices')]\"\ - },\"UserAndGroupsThatMayForceShutdownFromARemoteSystem\":{\"value\":\"[parameters('UserAndGroupsThatMayForceShutdownFromARemoteSystem')]\"\ - },\"UsersAndGroupsThatMayRestoreFilesAndDirectories\":{\"value\":\"[parameters('UsersAndGroupsThatMayRestoreFilesAndDirectories')]\"\ - },\"UsersAndGroupsThatMayShutDownTheSystem\":{\"value\":\"[parameters('UsersAndGroupsThatMayShutDownTheSystem')]\"\ - },\"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects\":{\"value\":\"\ - [parameters('UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork\"\ - :{\"type\":\"string\"},\"UsersOrGroupsThatMayLogOnLocally\":{\"type\":\"string\"\ - },\"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices\":{\"type\":\"string\"\ - },\"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork\":{\"type\"\ - :\"string\"},\"UsersOrGroupsThatMayManageAuditingAndSecurityLog\":{\"type\"\ - :\"string\"},\"UsersOrGroupsThatMayBackUpFilesAndDirectories\":{\"type\":\"\ - string\"},\"UsersOrGroupsThatMayChangeTheSystemTime\":{\"type\":\"string\"\ - },\"UsersOrGroupsThatMayChangeTheTimeZone\":{\"type\":\"string\"},\"UsersOrGroupsThatMayCreateATokenObject\"\ - :{\"type\":\"string\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob\"\ - :{\"type\":\"string\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsAService\"\ - :{\"type\":\"string\"},\"UsersAndGroupsThatAreDeniedLocalLogon\":{\"type\"\ - :\"string\"},\"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices\"\ - :{\"type\":\"string\"},\"UserAndGroupsThatMayForceShutdownFromARemoteSystem\"\ - :{\"type\":\"string\"},\"UsersAndGroupsThatMayRestoreFilesAndDirectories\"\ - :{\"type\":\"string\"},\"UsersAndGroupsThatMayShutDownTheSystem\":{\"type\"\ - :\"string\"},\"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects\":{\"\ - type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Access this computer\ - \ from the network;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayAccessThisComputerFromTheNetwork')]\"\ - },{\"name\":\"Allow log on locally;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayLogOnLocally')]\"\ - },{\"name\":\"Allow log on through Remote Desktop Services;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices')]\"\ - },{\"name\":\"Deny access to this computer from the network;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork')]\"\ - },{\"name\":\"Manage auditing and security log;ExpectedValue\",\"value\":\"\ - [parameters('UsersOrGroupsThatMayManageAuditingAndSecurityLog')]\"},{\"name\"\ - :\"Back up files and directories;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayBackUpFilesAndDirectories')]\"\ - },{\"name\":\"Change the system time;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheSystemTime')]\"\ - },{\"name\":\"Change the time zone;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheTimeZone')]\"\ - },{\"name\":\"Create a token object;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayCreateATokenObject')]\"\ - },{\"name\":\"Deny log on as a batch job;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob')]\"\ - },{\"name\":\"Deny log on as a service;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsAService')]\"\ - },{\"name\":\"Deny log on locally;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLocalLogon')]\"\ - },{\"name\":\"Deny log on through Remote Desktop Services;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices')]\"\ - },{\"name\":\"Force shutdown from a remote system;ExpectedValue\",\"value\"\ - :\"[parameters('UserAndGroupsThatMayForceShutdownFromARemoteSystem')]\"},{\"\ - name\":\"Restore files and directories;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatMayRestoreFilesAndDirectories')]\"\ - },{\"name\":\"Shut down the system;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatMayShutDownTheSystem')]\"\ - },{\"name\":\"Take ownership of files or other objects;ExpectedValue\",\"\ - value\":\"[parameters('UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Access this computer\ - \ from the network;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayAccessThisComputerFromTheNetwork')]\"\ - },{\"name\":\"Allow log on locally;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayLogOnLocally')]\"\ - },{\"name\":\"Allow log on through Remote Desktop Services;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices')]\"\ - },{\"name\":\"Deny access to this computer from the network;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork')]\"\ - },{\"name\":\"Manage auditing and security log;ExpectedValue\",\"value\":\"\ - [parameters('UsersOrGroupsThatMayManageAuditingAndSecurityLog')]\"},{\"name\"\ - :\"Back up files and directories;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayBackUpFilesAndDirectories')]\"\ - },{\"name\":\"Change the system time;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheSystemTime')]\"\ - },{\"name\":\"Change the time zone;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayChangeTheTimeZone')]\"\ - },{\"name\":\"Create a token object;ExpectedValue\",\"value\":\"[parameters('UsersOrGroupsThatMayCreateATokenObject')]\"\ - },{\"name\":\"Deny log on as a batch job;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob')]\"\ - },{\"name\":\"Deny log on as a service;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLoggingOnAsAService')]\"\ - },{\"name\":\"Deny log on locally;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLocalLogon')]\"\ - },{\"name\":\"Deny log on through Remote Desktop Services;ExpectedValue\"\ - ,\"value\":\"[parameters('UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices')]\"\ - },{\"name\":\"Force shutdown from a remote system;ExpectedValue\",\"value\"\ - :\"[parameters('UserAndGroupsThatMayForceShutdownFromARemoteSystem')]\"},{\"\ - name\":\"Restore files and directories;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatMayRestoreFilesAndDirectories')]\"\ - },{\"name\":\"Shut down the system;ExpectedValue\",\"value\":\"[parameters('UsersAndGroupsThatMayShutDownTheSystem')]\"\ - },{\"name\":\"Take ownership of files or other objects;ExpectedValue\",\"\ - value\":\"[parameters('UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/815dcc9f-6662-43f2-9a03-1b83e9876f24\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"815dcc9f-6662-43f2-9a03-1b83e9876f24\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1308 - Identification\ - \ And Authentication (Org. Users) | Remote Access - Separate Device\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Identification and Authentication control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1308\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/81817e1c-5347-48dd-965a-40159d008229\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"81817e1c-5347-48dd-965a-40159d008229\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1287 - Information\ - \ System Backup\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1287\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/819dc6da-289d-476e-8500-7e341ef8677d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"819dc6da-289d-476e-8500-7e341ef8677d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1213 - Configuration\ - \ Settings | Respond To Unauthorized Changes\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1213\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/81f11e32-a293-4a58-82cd-134af52e2318\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"81f11e32-a293-4a58-82cd-134af52e2318\"\ - },{\"properties\":{\"displayName\":\"Geo-redundant backup should be enabled\ - \ for Azure Database for MySQL\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any Azure Database for MySQL with geo-redundant\ - \ backup not enabled.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },{\"field\":\"Microsoft.DBforMySQL/servers/storageProfile.geoRedundantBackup\"\ - ,\"notEquals\":\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/82339799-d096-41ae-8538-b108becf0970\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82339799-d096-41ae-8538-b108becf0970\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1168 - Continuous\ - \ Monitoring | Independent Assessment\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Security Assessment\ - \ and Authorization control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1168\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/82409f9e-1f32-4775-bf07-b99d53a91b06\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82409f9e-1f32-4775-bf07-b99d53a91b06\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1448 - Physical\ - \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1448\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/825d6494-e583-42f2-a3f2-6458e6f0004f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"825d6494-e583-42f2-a3f2-6458e6f0004f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1452 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1452\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/82c76455-4d3f-4e09-a654-22e592107e74\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82c76455-4d3f-4e09-a654-22e592107e74\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - System'\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - System' for\ - \ auditing IPsec driver, system integrity, system extension, state change,\ - \ and other system events. This policy requires that the Guest Configuration\ - \ prerequisites have been deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SystemAuditPoliciesSystem\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"AuditOtherSystemEvents\"\ - :\"Audit Other System Events;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"AuditOtherSystemEvents\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Audit Other System Events\",\"description\"\ - :\"Specifies whether audit events are generated for Windows Firewall Service\ - \ and Windows Firewall driver start and stop events, failure events for these\ - \ services and Windows Firewall Service policy processing failures.\"},\"\ - allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"\ - ],\"defaultValue\":\"No Auditing\"},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesSystem\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Other System Events;ExpectedValue', '=',\ - \ parameters('AuditOtherSystemEvents')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8316fa92-d69c-4810-8124-62414f560dcf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8316fa92-d69c-4810-8124-62414f560dcf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1262 - Contingency\ - \ Plan Testing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1262\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/831e510e-db41-4c72-888e-a0621ab62265\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"831e510e-db41-4c72-888e-a0621ab62265\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1008 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1008\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8356cfc6-507a-4d20-b818-08038011cd07\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8356cfc6-507a-4d20-b818-08038011cd07\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Event Hub should be\ - \ enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Event Hub\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/83a214f7-d01a-484b-91a9-ed54470c9a6a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"83a214f7-d01a-484b-91a9-ed54470c9a6a\"\ - },{\"properties\":{\"displayName\":\"Network interfaces should not have public\ - \ IPs\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - This policy denies the network interfaces which are configured with any public\ - \ IP. Public IP addresses allow internet resources to communicate inbound\ - \ to Azure resources, and Azure resources to communicate outbound to the internet.\ - \ This should be reviewed by the network security team.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkInterfaces\"\ - },{\"not\":{\"field\":\"Microsoft.Network/networkInterfaces/ipconfigurations[*].publicIpAddress.id\"\ - ,\"notLike\":\"*\"}}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/83a86a26-fd1f-447c-b59d-e51f44264114\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"83a86a26-fd1f-447c-b59d-e51f44264114\"\ - },{\"properties\":{\"displayName\":\"Bring your own key data protection should\ - \ be enabled for MySQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits MySQL servers in your environment without\ - \ bring your own key data protection enabled. For more details, visit https://aka.ms/mysqlbyok.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforMySQL/servers/keys\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.DBforMySQL/servers/keys/serverKeyType\",\"equals\":\"\ - AzureKeyVault\"},{\"field\":\"Microsoft.DBforMySQL/servers/keys/uri\",\"notEquals\"\ - :\"\"},{\"field\":\"Microsoft.DBforMySQL/servers/keys/uri\",\"exists\":\"\ - true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/83cef61d-dbd1-4b20-a4fc-5fbc7da10833\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"83cef61d-dbd1-4b20-a4fc-5fbc7da10833\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1382 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1382\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/841392b3-40da-4473-b328-4cde49db67b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"841392b3-40da-4473-b328-4cde49db67b3\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Log Analytics agent should\ - \ be installed on your Linux Azure Arc machines\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy audits Linux Azure Arc\ - \ machines if the Log Analytics agent is not installed.\",\"metadata\":{\"\ - version\":\"1.0.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\"\ - :\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.HybridCompute/machines\"},{\"field\":\"Microsoft.HybridCompute/imageOffer\"\ - ,\"like\":\"linux*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"\ - details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/842c54e8-c2f9-4d79-ae8d-38d8b8019373\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"842c54e8-c2f9-4d79-ae8d-38d8b8019373\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1098 - Security\ - \ Training Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1098\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/84363adb-dde3-411a-9fc1-36b56737f822\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"84363adb-dde3-411a-9fc1-36b56737f822\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that '.NET Framework'\ - \ version is the latest, if used as a part of the Web app\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy is not required\ - \ since Azure App Service automatically updates and maintains the .NET Framework\ - \ versions installed on the platform.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/config/web.netFrameworkVersion\",\"in\"\ - :[\"v3.0\",\"v4.0\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/843664e0-7563-41ee-a9cb-7522c382d2c4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"843664e0-7563-41ee-a9cb-7522c382d2c4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1119 - Audit\ - \ Review, Analysis, And Reporting | Central Review And Analysis\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1119\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/845f6359-b764-4b40-b579-657aefe23c44\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"845f6359-b764-4b40-b579-657aefe23c44\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that are not joined\ - \ to the specified domain\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if the value of the Domain property in WMI class win32_computersystem\ - \ does not match the value in the policy parameter.\",\"metadata\":{\"category\"\ - :\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"WindowsDomainMembership\",\"version\"\ - :\"1.*\",\"configurationParameter\":{\"DomainName\":\"[DomainMembership]WindowsDomainMembership;DomainName\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"DomainName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Domain Name (FQDN)\"\ - ,\"description\":\"The fully qualified domain name (FQDN) that the Windows\ - \ machines should be joined to\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDomainMembership\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[DomainMembership]WindowsDomainMembership;DomainName',\ - \ '=', parameters('DomainName')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/84662df4-0e37-44a6-9ce1-c9d2150db18c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"84662df4-0e37-44a6-9ce1-c9d2150db18c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1024 - Account\ - \ Management | Account Monitoring / Atypical Usage\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1024\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/84914fb4-12da-4c53-a341-a9fd463bed10\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"84914fb4-12da-4c53-a341-a9fd463bed10\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1307 - Identification\ - \ And Authentication (Org. Users) | Net. Access To Non-Priv. Accts. - Replay\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1307\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/84e622c8-4bed-417c-84c6-b2fb0dd73682\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"84e622c8-4bed-417c-84c6-b2fb0dd73682\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1080 - Use\ - \ Of External Information Systems | Portable Storage Devices\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1080\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/852981b4-a380-4704-aa1e-2e52d63445e5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"852981b4-a380-4704-aa1e-2e52d63445e5\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Windows Components'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Windows machines should have the specified Group Policy\ - \ settings in the category 'Windows Components' for basic authentication,\ - \ unencrypted traffic, Microsoft accounts, telemetry, Cortana, and other Windows\ - \ behaviors. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_WindowsComponents\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"SendFileSamplesWhenFurtherAnalysisIsRequired\":\"Send file samples when\ - \ further analysis is required;ExpectedValue\",\"AllowIndexingOfEncryptedFiles\"\ - :\"Allow indexing of encrypted files;ExpectedValue\",\"AllowTelemetry\":\"\ - Allow Telemetry;ExpectedValue\",\"AllowUnencryptedTraffic\":\"Allow unencrypted\ - \ traffic;ExpectedValue\",\"AlwaysInstallWithElevatedPrivileges\":\"Always\ - \ install with elevated privileges;ExpectedValue\",\"AlwaysPromptForPasswordUponConnection\"\ - :\"Always prompt for password upon connection;ExpectedValue\",\"ApplicationSpecifyTheMaximumLogFileSizeKB\"\ - :\"Application: Specify the maximum log file size (KB);ExpectedValue\",\"\ - AutomaticallySendMemoryDumpsForOSgeneratedErrorReports\":\"Automatically send\ - \ memory dumps for OS-generated error reports;ExpectedValue\",\"ConfigureDefaultConsent\"\ - :\"Configure Default consent;ExpectedValue\",\"ConfigureWindowsSmartScreen\"\ - :\"Configure Windows SmartScreen;ExpectedValue\",\"DisallowDigestAuthentication\"\ - :\"Disallow Digest authentication;ExpectedValue\",\"DisallowWinRMFromStoringRunAsCredentials\"\ - :\"Disallow WinRM from storing RunAs credentials;ExpectedValue\",\"DoNotAllowPasswordsToBeSaved\"\ - :\"Do not allow passwords to be saved;ExpectedValue\",\"SecuritySpecifyTheMaximumLogFileSizeKB\"\ - :\"Security: Specify the maximum log file size (KB);ExpectedValue\",\"SetClientConnectionEncryptionLevel\"\ - :\"Set client connection encryption level;ExpectedValue\",\"SetTheDefaultBehaviorForAutoRun\"\ - :\"Set the default behavior for AutoRun;ExpectedValue\",\"SetupSpecifyTheMaximumLogFileSizeKB\"\ - :\"Setup: Specify the maximum log file size (KB);ExpectedValue\",\"SystemSpecifyTheMaximumLogFileSizeKB\"\ - :\"System: Specify the maximum log file size (KB);ExpectedValue\",\"TurnOffDataExecutionPreventionForExplorer\"\ - :\"Turn off Data Execution Prevention for Explorer;ExpectedValue\",\"SpecifyTheIntervalToCheckForDefinitionUpdates\"\ - :\"Specify the interval to check for definition updates;ExpectedValue\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"SendFileSamplesWhenFurtherAnalysisIsRequired\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Send file samples when\ - \ further analysis is required\",\"description\":\"Specifies whether and how\ - \ Windows Defender will submit samples of suspected malware to Microsoft\ - \ for further analysis when opt-in for MAPS telemetry is set.\"},\"defaultValue\"\ - :\"1\"},\"AllowIndexingOfEncryptedFiles\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Allow indexing of encrypted files\",\"description\":\"\ - Specifies whether encrypted items are allowed to be indexed.\"},\"defaultValue\"\ - :\"0\"},\"AllowTelemetry\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Allow Telemetry\",\"description\":\"Specifies configuration of the amount\ - \ of diagnostic and usage data reported to Microsoft. The data is transmitted\ - \ securely and sensitive data is not sent.\"},\"defaultValue\":\"2\"},\"AllowUnencryptedTraffic\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Allow unencrypted traffic\"\ - ,\"description\":\"Specifies whether the Windows Remote Management (WinRM)\ - \ service sends and receives unencrypted messages over the network.\"},\"\ - defaultValue\":\"0\"},\"AlwaysInstallWithElevatedPrivileges\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Always install with elevated privileges\"\ - ,\"description\":\"Specifies whether Windows Installer should use system permissions\ - \ when it installs any program on the system.\"},\"defaultValue\":\"0\"},\"\ - AlwaysPromptForPasswordUponConnection\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Always prompt for password upon connection\",\"description\"\ - :\"Specifies whether Terminal Services/Remote Desktop Connection always prompts\ - \ the client computer for a password upon connection.\"},\"defaultValue\"\ - :\"1\"},\"ApplicationSpecifyTheMaximumLogFileSizeKB\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Application: Specify the maximum log file\ - \ size (KB)\",\"description\":\"Specifies the maximum size for the Application\ - \ event log in kilobytes.\"},\"defaultValue\":\"32768\"},\"AutomaticallySendMemoryDumpsForOSgeneratedErrorReports\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Automatically send memory\ - \ dumps for OS-generated error reports\",\"description\":\"Specifies if memory\ - \ dumps in support of OS-generated error reports can be sent to Microsoft\ - \ automatically.\"},\"defaultValue\":\"1\"},\"ConfigureDefaultConsent\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Configure Default consent\"\ - ,\"description\":\"Specifies setting of the default consent handling for error\ - \ reports sent to Microsoft.\"},\"defaultValue\":\"4\"},\"ConfigureWindowsSmartScreen\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Configure Windows SmartScreen\"\ - ,\"description\":\"Specifies how to manage the behavior of Windows SmartScreen.\ - \ Windows SmartScreen helps keep PCs safer by warning users before running\ - \ unrecognized programs downloaded from the Internet. Some information is\ - \ sent to Microsoft about files and programs run on PCs with this feature\ - \ enabled.\"},\"defaultValue\":\"1\"},\"DisallowDigestAuthentication\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Disallow Digest authentication\"\ - ,\"description\":\"Specifies whether the Windows Remote Management (WinRM)\ - \ client will not use Digest authentication.\"},\"defaultValue\":\"0\"},\"\ - DisallowWinRMFromStoringRunAsCredentials\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Disallow WinRM from storing RunAs credentials\",\"description\"\ - :\"Specifies whether the Windows Remote Management (WinRM) service will not\ - \ allow RunAs credentials to be stored for any plug-ins.\"},\"defaultValue\"\ - :\"1\"},\"DoNotAllowPasswordsToBeSaved\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Do not allow passwords to be saved\",\"description\":\"\ - Specifies whether to prevent Remote Desktop Services - Terminal Services clients\ - \ from saving passwords on a computer.\"},\"defaultValue\":\"1\"},\"SecuritySpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Security: Specify the\ - \ maximum log file size (KB)\",\"description\":\"Specifies the maximum size\ - \ for the Security event log in kilobytes.\"},\"defaultValue\":\"196608\"\ - },\"SetClientConnectionEncryptionLevel\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Set client connection encryption level\",\"description\"\ - :\"Specifies whether to require the use of a specific encryption level to\ - \ secure communications between client computers and RD Session Host servers\ - \ during Remote Desktop Protocol (RDP) connections. This policy only applies\ - \ when you are using native RDP encryption.\"},\"defaultValue\":\"3\"},\"\ - SetTheDefaultBehaviorForAutoRun\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Set the default behavior for AutoRun\",\"description\":\"Specifies the\ - \ default behavior for Autorun commands. Autorun commands are generally stored\ - \ in autorun.inf files. They often launch the installation program or other\ - \ routines.\"},\"defaultValue\":\"1\"},\"SetupSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Setup: Specify the maximum\ - \ log file size (KB)\",\"description\":\"Specifies the maximum size for the\ - \ Setup event log in kilobytes.\"},\"defaultValue\":\"32768\"},\"SystemSpecifyTheMaximumLogFileSizeKB\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"System: Specify the\ - \ maximum log file size (KB)\",\"description\":\"Specifies the maximum size\ - \ for the System event log in kilobytes.\"},\"defaultValue\":\"32768\"},\"\ - TurnOffDataExecutionPreventionForExplorer\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Turn off Data Execution Prevention for Explorer\",\"description\"\ - :\"Specifies whether to turn off Data Execution Prevention for Windows File\ - \ Explorer. Disabling data execution prevention can allow certain legacy plug-in\ - \ applications to function without terminating Explorer.\"},\"defaultValue\"\ - :\"0\"},\"SpecifyTheIntervalToCheckForDefinitionUpdates\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Specify the interval to check for definition\ - \ updates\",\"description\":\"Specifies an interval at which to check for\ - \ Windows Defender definition updates. The time value is represented as the\ - \ number of hours between update checks.\"},\"defaultValue\":\"8\"},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of this policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_WindowsComponents\",\"existenceCondition\":{\"allOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Send file samples when further analysis is required;ExpectedValue',\ - \ '=', parameters('SendFileSamplesWhenFurtherAnalysisIsRequired'), ',', 'Allow\ - \ indexing of encrypted files;ExpectedValue', '=', parameters('AllowIndexingOfEncryptedFiles'),\ - \ ',', 'Allow Telemetry;ExpectedValue', '=', parameters('AllowTelemetry'),\ - \ ',', 'Allow unencrypted traffic;ExpectedValue', '=', parameters('AllowUnencryptedTraffic'),\ - \ ',', 'Always install with elevated privileges;ExpectedValue', '=', parameters('AlwaysInstallWithElevatedPrivileges'),\ - \ ',', 'Always prompt for password upon connection;ExpectedValue', '=', parameters('AlwaysPromptForPasswordUponConnection'),\ - \ ',', 'Application: Specify the maximum log file size (KB);ExpectedValue',\ - \ '=', parameters('ApplicationSpecifyTheMaximumLogFileSizeKB'), ',', 'Automatically\ - \ send memory dumps for OS-generated error reports;ExpectedValue', '=', parameters('AutomaticallySendMemoryDumpsForOSgeneratedErrorReports'),\ - \ ',', 'Configure Default consent;ExpectedValue', '=', parameters('ConfigureDefaultConsent'),\ - \ ',', 'Configure Windows SmartScreen;ExpectedValue', '=', parameters('ConfigureWindowsSmartScreen'),\ - \ ',', 'Disallow Digest authentication;ExpectedValue', '=', parameters('DisallowDigestAuthentication'),\ - \ ',', 'Disallow WinRM from storing RunAs credentials;ExpectedValue', '=',\ - \ parameters('DisallowWinRMFromStoringRunAsCredentials'), ',', 'Do not allow\ - \ passwords to be saved;ExpectedValue', '=', parameters('DoNotAllowPasswordsToBeSaved'),\ - \ ',', 'Security: Specify the maximum log file size (KB);ExpectedValue', '=',\ - \ parameters('SecuritySpecifyTheMaximumLogFileSizeKB'), ',', 'Set client connection\ - \ encryption level;ExpectedValue', '=', parameters('SetClientConnectionEncryptionLevel'),\ - \ ',', 'Set the default behavior for AutoRun;ExpectedValue', '=', parameters('SetTheDefaultBehaviorForAutoRun'),\ - \ ',', 'Setup: Specify the maximum log file size (KB);ExpectedValue', '=',\ - \ parameters('SetupSpecifyTheMaximumLogFileSizeKB'), ',', 'System: Specify\ - \ the maximum log file size (KB);ExpectedValue', '=', parameters('SystemSpecifyTheMaximumLogFileSizeKB'),\ - \ ',', 'Turn off Data Execution Prevention for Explorer;ExpectedValue', '=',\ - \ parameters('TurnOffDataExecutionPreventionForExplorer'), ',', 'Specify the\ - \ interval to check for definition updates;ExpectedValue', '=', parameters('SpecifyTheIntervalToCheckForDefinitionUpdates')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8537fe96-8cbe-43de-b0ef-131bc72bc22a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8537fe96-8cbe-43de-b0ef-131bc72bc22a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1580 - Information\ - \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1580\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/854db8ac-6adf-42a0-bef3-b73f764f40b9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"854db8ac-6adf-42a0-bef3-b73f764f40b9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1348 - Identification\ - \ And Authentication (Non-Org. Users) | Acceptance Of Third-Party Credentials\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1348\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/855ced56-417b-4d74-9d5f-dd1bc81e22d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"855ced56-417b-4d74-9d5f-dd1bc81e22d6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1079 - Use\ - \ Of External Information Systems | Limits On Authorized Use\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1079\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/85c32733-7d23-4948-88da-058e2c56b60f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"85c32733-7d23-4948-88da-058e2c56b60f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1326 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1326\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8605fc00-1bf5-4fb3-984e-c95cec4f231d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8605fc00-1bf5-4fb3-984e-c95cec4f231d\"\ - },{\"properties\":{\"displayName\":\"Azure Cosmos DB accounts should have\ - \ firewall rules\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Audit or deny resources that do not have any IP rules configured and allow\ - \ all networks by default. Accounts that have at least one IP rule defined\ - \ with the virtual network filter enabled are deemed compliant. Accounts disabling\ - \ public access are also deemed compliant.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Cosmos DB\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Policy Effect\",\"description\":\"\ - The desired effect of the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\"\ - ,\"Disabled\"],\"defaultValue\":\"Deny\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.DocumentDB/databaseAccounts\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.DocumentDB/databaseAccounts/publicNetworkAccess\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/publicNetworkAccess\"\ - ,\"equals\":\"Enabled\"}]},{\"anyOf\":[{\"field\":\"Microsoft.DocumentDB/databaseAccounts/isVirtualNetworkFilterEnabled\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/isVirtualNetworkFilterEnabled\"\ - ,\"equals\":\"false\"},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.DocumentDB/databaseAccounts/ipRules\"\ - ,\"exists\":\"false\"},{\"count\":{\"field\":\"Microsoft.DocumentDB/databaseAccounts/ipRules[*]\"\ - },\"equals\":0}]},{\"anyOf\":[{\"field\":\"Microsoft.DocumentDB/databaseAccounts/ipRangeFilter\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/ipRangeFilter\"\ - ,\"equals\":\"\"}]}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/862e97cf-49fc-4a5c-9de4-40d4e2e7c8eb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"862e97cf-49fc-4a5c-9de4-40d4e2e7c8eb\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Microsoft Network\ - \ Server'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Microsoft Network Server'. It also creates a system-assigned managed\ - \ identity and deploys the VM extension for Guest Configuration. This policy\ - \ should only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkServer\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsMicrosoftNetworkServer\"}},\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86880e5c-df35-43c5-95ad-7e120635775e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86880e5c-df35-43c5-95ad-7e120635775e\"\ - },{\"properties\":{\"displayName\":\"Deploy SQL DB transparent data encryption\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Enables\ - \ transparent data encryption on SQL databases\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"\ - },{\"field\":\"name\",\"notEquals\":\"master\"}]},\"then\":{\"effect\":\"\ - DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.Sql/servers/databases/transparentDataEncryption\"\ - ,\"name\":\"current\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/transparentDataEncryption.status\"\ - ,\"equals\":\"Enabled\"},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9b7fa17d-e63e-47b0-bb0a-15c516ac86ec\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullDbName\":{\"type\":\"\ - string\"}},\"resources\":[{\"name\":\"[concat(parameters('fullDbName'), '/current')]\"\ - ,\"type\":\"Microsoft.Sql/servers/databases/transparentDataEncryption\",\"\ - apiVersion\":\"2014-04-01\",\"properties\":{\"status\":\"Enabled\"}}]},\"\ - parameters\":{\"fullDbName\":{\"value\":\"[field('fullName')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/86a912f6-9a06-4e26-b447-11b16ba8659f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86a912f6-9a06-4e26-b447-11b16ba8659f\"\ - },{\"properties\":{\"displayName\":\"System updates should be installed on\ - \ your machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Missing security system updates on your servers will be monitored by Azure\ - \ Security Center as recommendations\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"\ - Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"c0f5316d-5ac5-9218-b77a-b96e16ccfd66\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86b3d65f-7626-441e-b690-81a8b71cff60\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86b3d65f-7626-441e-b690-81a8b71cff60\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1507 - Personnel\ - \ Security Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Personnel Security control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1507\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86ccd1bf-e7ad-4851-93ce-6ec817469c1e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86ccd1bf-e7ad-4851-93ce-6ec817469c1e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that Register with\ - \ Azure Active Directory is enabled on API app\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy is a duplicate of the\ - \ respective Managed Identity policies. Please use /providers/Microsoft.Authorization/policyDefinitions/c4d441f8-f9d9-4a9e-9cef-e82117cb3ee\ - \ instead.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ - App Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86d97760-d216-4d81-a3ad-163087b2b6c3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86d97760-d216-4d81-a3ad-163087b2b6c3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1392 - Information\ - \ Spillage Response | Post-Spill Operations\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1392\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86dc819f-15e1-43f9-a271-41ae58d4cecc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86dc819f-15e1-43f9-a271-41ae58d4cecc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1589 - External\ - \ Information System Services | Risk Assessments / Organizational Approvals\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Services Acquisition control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1589\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/86ec7f9b-9478-40ff-8cfd-6a0d510081a8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"86ec7f9b-9478-40ff-8cfd-6a0d510081a8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1207 - Access\ - \ Restrictions For Change | Limit Production / Operational Privileges\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1207\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8713a0ed-0d1e-4d10-be82-83dffb39830e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8713a0ed-0d1e-4d10-be82-83dffb39830e\"\ - },{\"properties\":{\"displayName\":\"Require a tag on resources\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Enforces existence of\ - \ a tag. Does not apply to resource groups.\",\"metadata\":{\"version\":\"\ - 1.0.1\",\"category\":\"Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Name of the\ - \ tag, such as 'environment'\"}}},\"policyRule\":{\"if\":{\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"exists\":\"false\"},\"then\":{\"effect\"\ - :\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/871b6d14-10aa-478d-b590-94f262ecfa99\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"871b6d14-10aa-478d-b590-94f262ecfa99\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1180 - Baseline\ - \ Configuration | Automation Support For Accuracy / Currency\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1180\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/874e7880-a067-42a7-bcbe-1a340f54c8cc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"874e7880-a067-42a7-bcbe-1a340f54c8cc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1635 - Boundary\ - \ Protection | Host-Based Protection\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Communications\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1635\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/87551b5d-1deb-4d0f-86cc-9dc14cb4bf7e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"87551b5d-1deb-4d0f-86cc-9dc14cb4bf7e\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Privilege Use'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Privilege\ - \ Use' for auditing nonsensitive and other privilege use. This policy requires\ - \ that the Guest Configuration prerequisites have been deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AzureBaseline_SystemAuditPoliciesPrivilegeUse\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\",\"\ - description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesPrivilegeUse\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/87845465-c458-45f3-af66-dcd62176f397\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"87845465-c458-45f3-af66-dcd62176f397\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Devices'\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Windows machines should have the specified Group\ - \ Policy settings in the category 'Security Options - Devices' for undocking\ - \ without logging on, installing print drivers, and formatting/ejecting media.\ - \ This policy requires that the Guest Configuration prerequisites have been\ - \ deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsDevices\",\"version\":\"1.*\",\"\ - configurationParameter\":{\"DevicesAllowedToFormatAndEjectRemovableMedia\"\ - :\"Devices: Allowed to format and eject removable media;ExpectedValue\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"DevicesAllowedToFormatAndEjectRemovableMedia\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Devices: Allowed to\ - \ format and eject removable media\",\"description\":\"Specifies who is allowed\ - \ to format and eject removable NTFS media. You can use this policy setting\ - \ to prevent unauthorized users from removing data on one computer to access\ - \ it on another computer on which they have local administrator privileges.\"\ - },\"defaultValue\":\"0\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsDevices\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Devices: Allowed to format and eject removable\ - \ media;ExpectedValue', '=', parameters('DevicesAllowedToFormatAndEjectRemovableMedia')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8794ff4f-1a35-4e18-938f-0b22055067cd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8794ff4f-1a35-4e18-938f-0b22055067cd\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Administrative Templates - Control Panel'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Administrative\ - \ Templates - Control Panel'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesControlPanel\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/87b590fe-4a1d-4697-ae74-d4fe72ab786c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"87b590fe-4a1d-4697-ae74-d4fe72ab786c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1293 - Information\ - \ System Backup | Separate Storage For Critical Information\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1293\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/87f7cd82-2e45-4d0f-9e2f-586b0962d142\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"87f7cd82-2e45-4d0f-9e2f-586b0962d142\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1440 - Media\ - \ Sanitization | Review / Approve / Track / Document / Verify\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Media Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1440\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/881299bf-2a5b-4686-a1b2-321d33679953\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"881299bf-2a5b-4686-a1b2-321d33679953\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1356 - Incident\ - \ Response Training | Simulated Events\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1356\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8829f8f5-e8be-441e-85c9-85b72a5d0ef3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8829f8f5-e8be-441e-85c9-85b72a5d0ef3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Linux VMs that have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Linux virtual machines that have\ - \ the specified applications installed. It also creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration. This\ - \ policy should only be used along with its corresponding audit policy in\ - \ an initiative. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"3.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"deprecated\":true},\"parameters\":{\"ApplicationName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Application names\",\"description\"\ - :\"A semicolon-separated list of the names of the applications that should\ - \ not be installed. e.g. 'python; powershell'\"}}},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"not_installed_application_linux\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent',\ - \ '=', concat('packages: [', replace(parameters('ApplicationName'), ';', ','),\ - \ ']')))]\"},\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"not_installed_application_linux\"},\"ApplicationName\":{\"value\":\"[parameters('ApplicationName')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ApplicationName\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent\"\ - ,\"value\":\"[concat('packages: [', replace(parameters('ApplicationName'),\ - \ ';', ','), ']')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[ChefInSpec]NotInstalledApplicationLinuxResource1;AttributesYmlContent\"\ - ,\"value\":\"[concat('packages: [', replace(parameters('ApplicationName'),\ - \ ';', ','), ']')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/884b209a-963b-4520-8006-d20cb3c213e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"884b209a-963b-4520-8006-d20cb3c213e0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1317 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1317\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8877f519-c166-47b7-81b7-8a8eb4ff3775\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8877f519-c166-47b7-81b7-8a8eb4ff3775\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1501 - Rules\ - \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1501\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/88817b58-8472-4f6c-81fa-58ce42b67f51\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88817b58-8472-4f6c-81fa-58ce42b67f51\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Java version' is the latest,\ - \ if used as a part of the Api app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Java either due to security flaws or to include additional functionality.\ - \ Using the latest Python version for Api apps is recommended in order to\ - \ take advantage of security fixes, if any, and/or new functionalities of\ - \ the latest version.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"JavaLatestVersion\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Latest Java version\",\"description\":\"\ - Latest supported Java version for App Services\"},\"defaultValue\":\"11\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"notContains\":\"JAVA\"},{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\"\ - ,\"equals\":\"\"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"like\":\"[concat('*', parameters('JavaLatestVersion'))]\"},{\"field\":\"\ - Microsoft.Web/sites/config/web.javaVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\",\"like\"\ - :\"[concat(parameters('JavaLatestVersion'), '*')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/88999f4c-376a-45c8-bcb3-4058f713cf39\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88999f4c-376a-45c8-bcb3-4058f713cf39\"\ - },{\"properties\":{\"displayName\":\"Network interfaces should disable IP\ - \ forwarding\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy denies the network interfaces which enabled IP forwarding.\ - \ The setting of IP forwarding disables Azure's check of the source and destination\ - \ for a network interface. This should be reviewed by the network security\ - \ team.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Network\"},\"\ - parameters\":{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Network/networkInterfaces\"},{\"field\":\"Microsoft.Network/networkInterfaces/enableIpForwarding\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/88c0b9da-ce96-4b03-9635-f29a937e2900\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88c0b9da-ce96-4b03-9635-f29a937e2900\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1215 - Least\ - \ Functionality\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1215\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/88fc93e8-4745-4785-b5a5-b44bb92c44ff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88fc93e8-4745-4785-b5a5-b44bb92c44ff\"\ - },{\"properties\":{\"displayName\":\"SQL servers should be configured with\ - \ auditing retention days greater than 90 days.\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Audit SQL servers configured with\ - \ an auditing retention period of less than 90 days.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/auditingSettings\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/auditingSettings/retentionDays\"\ - ,\"greater\":90}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/89099bee-89e0-4b26-a5f4-165451757743\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"89099bee-89e0-4b26-a5f4-165451757743\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1411 - Nonlocal\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1411\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/898d4fe8-f743-4333-86b7-0c9245d93e7d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"898d4fe8-f743-4333-86b7-0c9245d93e7d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1092 - Security\ - \ Awareness Training | Insider Threat\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Awareness and Training\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1092\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8a29d47b-8604-4667-84ef-90d203fcb305\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8a29d47b-8604-4667-84ef-90d203fcb305\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - System settings'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - System settings'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsSystemsettings\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8a39d1f1-5513-4628-b261-f469a5a3341b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8a39d1f1-5513-4628-b261-f469a5a3341b\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs with a pending reboot\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"This policy should only be used along with its\ - \ corresponding deploy policy in an initiative. This definition allows Azure\ - \ Policy to process the results of auditing Windows virtual machines with\ - \ a pending reboot. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPendingReboot\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8b0de57a-f511-4d45-a277-17cb79cb163b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8b0de57a-f511-4d45-a277-17cb79cb163b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1534 - Personnel\ - \ Sanctions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1534\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8b2b263e-cd05-4488-bcbf-4debec7a17d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8b2b263e-cd05-4488-bcbf-4debec7a17d9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1170 - Penetration\ - \ Testing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1170\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8b78b9b3-ee3c-48e0-a243-ed6dba5b7a12\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8b78b9b3-ee3c-48e0-a243-ed6dba5b7a12\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Windows Firewall Properties'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Windows Firewall\ - \ Properties'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_WindowsFirewallProperties\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8bbd627e-4d25-4906-9a6e-3789780af3ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8bbd627e-4d25-4906-9a6e-3789780af3ec\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'HTTP Version' is the latest,\ - \ if used to run the Web app\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Periodically, newer versions are released for HTTP either\ - \ due to security flaws or to include additional functionality. Using the\ - \ latest HTTP version for web apps to take advantage of security fixes, if\ - \ any, and/or new functionalities of the newer version.\",\"metadata\":{\"\ - version\":\"1.1.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.http20Enabled\"\ - ,\"Equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8c122334-9d20-4eb8-89ea-ac9a705b74ae\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8c122334-9d20-4eb8-89ea-ac9a705b74ae\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1458 - Physical\ - \ Access Control | Information System Access\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ - \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1458\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8c19ceb7-56e9-4488-8ddb-b1eb3aa6d203\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8c19ceb7-56e9-4488-8ddb-b1eb3aa6d203\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1683 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1683\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8c79fee4-88dd-44ce-bbd4-4de88948c4f8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8c79fee4-88dd-44ce-bbd4-4de88948c4f8\"\ - },{\"properties\":{\"displayName\":\"Latest TLS version should be used in\ - \ your API App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Upgrade to the latest TLS version\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/minTlsVersion\"\ - ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8cb6aa8b-9e41-4f4e-aa25-089a7ac2581e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8cb6aa8b-9e41-4f4e-aa25-089a7ac2581e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1316 - Identifier\ - \ Management | Identify User Status\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Identification and Authentication\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1316\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8ce14753-66e5-465d-9841-26ef55c09c0d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8ce14753-66e5-465d-9841-26ef55c09c0d\"\ - },{\"properties\":{\"displayName\":\"Require a tag and its value on resource\ - \ groups\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - Enforces a required tag and its value on resource groups.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Tags\"},\"parameters\":{\"tagName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\",\"description\"\ - :\"Name of the tag, such as 'environment'\"}},\"tagValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Value\",\"description\":\"Value of the\ - \ tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"notEquals\"\ - :\"[parameters('tagValue')]\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/8ce3da23-7156-49e4-b145-24f95f9dcb46\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8ce3da23-7156-49e4-b145-24f95f9dcb46\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1324 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1324\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8cfea2b3-7f77-497e-ac20-0752f2ff6eee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8cfea2b3-7f77-497e-ac20-0752f2ff6eee\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1225 - Information\ - \ System Component Inventory | Automated Maintenance\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1225\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8d096fe0-f510-4486-8b4d-d17dc230980b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8d096fe0-f510-4486-8b4d-d17dc230980b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1288 - Information\ - \ System Backup\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1288\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8d854c3b-a3e6-4ec9-9f0c-c7274dbaeb2f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8d854c3b-a3e6-4ec9-9f0c-c7274dbaeb2f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1281 - Telecommunications\ - \ Services | Priority Of Service Provisions\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1281\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8dc459b3-0e77-45af-8d71-cfd8c9654fe2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8dc459b3-0e77-45af-8d71-cfd8c9654fe2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1250 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1250\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8de614d8-a8b7-4f70-a62a-6d37089a002c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8de614d8-a8b7-4f70-a62a-6d37089a002c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Object Access'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Object Access'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditDetailedFileShare\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Audit Detailed File Share\",\"description\"\ - :\"If this policy setting is enabled, access to all shared files and folders\ - \ on the system is audited. Auditing for Success can lead to very high volumes\ - \ of events.\"},\"allowedValues\":[\"No Auditing\",\"Success\",\"Failure\"\ - ,\"Success and Failure\"],\"defaultValue\":\"No Auditing\"},\"AuditFileShare\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Audit\ - \ File Share\",\"description\":\"Specifies whether to audit events related\ - \ to file shares: creation, deletion, modification, and access attempts. Also,\ - \ it shows failed SMB SPN checks. Event volumes can be high on DCs and File\ - \ Servers.\"},\"allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"\ - Success and Failure\"],\"defaultValue\":\"No Auditing\"},\"AuditFileSystem\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Audit\ - \ File System\",\"description\":\"Specifies whether audit events are generated\ - \ when users attempt to access file system objects. Audit events are generated\ - \ only for objects that have configured system access control lists (SACLs).\"\ - },\"allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and\ - \ Failure\"],\"defaultValue\":\"No Auditing\"}},\"policyRule\":{\"if\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesObjectAccess\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Detailed File Share;ExpectedValue', '=',\ - \ parameters('AuditDetailedFileShare'), ',', 'Audit File Share;ExpectedValue',\ - \ '=', parameters('AuditFileShare'), ',', 'Audit File System;ExpectedValue',\ - \ '=', parameters('AuditFileSystem')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SystemAuditPoliciesObjectAccess\"\ - },\"AuditDetailedFileShare\":{\"value\":\"[parameters('AuditDetailedFileShare')]\"\ - },\"AuditFileShare\":{\"value\":\"[parameters('AuditFileShare')]\"},\"AuditFileSystem\"\ - :{\"value\":\"[parameters('AuditFileSystem')]\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditDetailedFileShare\":{\"type\":\"string\"},\"\ - AuditFileShare\":{\"type\":\"string\"},\"AuditFileSystem\":{\"type\":\"string\"\ - }},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Detailed\ - \ File Share;ExpectedValue\",\"value\":\"[parameters('AuditDetailedFileShare')]\"\ - },{\"name\":\"Audit File Share;ExpectedValue\",\"value\":\"[parameters('AuditFileShare')]\"\ - },{\"name\":\"Audit File System;ExpectedValue\",\"value\":\"[parameters('AuditFileSystem')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Detailed\ - \ File Share;ExpectedValue\",\"value\":\"[parameters('AuditDetailedFileShare')]\"\ - },{\"name\":\"Audit File Share;ExpectedValue\",\"value\":\"[parameters('AuditFileShare')]\"\ - },{\"name\":\"Audit File System;ExpectedValue\",\"value\":\"[parameters('AuditFileSystem')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8e170edb-e0f5-497a-bb36-48b3280cec6a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8e170edb-e0f5-497a-bb36-48b3280cec6a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1278 - Alternate\ - \ Processing Site | Preparation For Use\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1278\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8e5ef485-9e16-4c53-a475-fbb8107eac59\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8e5ef485-9e16-4c53-a475-fbb8107eac59\"\ - },{\"properties\":{\"displayName\":\"Enable Security Center's auto provisioning\ - \ of the Log Analytics agent on your subscriptions with custom workspace.\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Allow Security\ - \ Center to auto provision the Log Analytics agent on your subscriptions to\ - \ monitor and collect security data using a custom workspace.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ - \ Analytics workspace\",\"description\":\"Auto provision the Log Analytics\ - \ agent on your subscriptions to monitor and collect security data using a\ - \ custom workspace.\",\"strongType\":\"omsWorkspace\"}}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/autoProvisioningSettings\",\"deploymentScope\":\"Subscription\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"existenceCondition\":{\"field\":\"Microsoft.Security/autoProvisioningSettings/autoProvision\"\ - ,\"equals\":\"On\"},\"deployment\":{\"location\":\"westus\",\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"logAnalytics\":{\"value\":\"\ - [parameters('logAnalytics')]\"}},\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"logAnalytics\":{\"type\"\ - :\"string\"}},\"variables\":{},\"resources\":[{\"type\":\"Microsoft.Security/autoProvisioningSettings\"\ - ,\"name\":\"default\",\"apiVersion\":\"2017-08-01-preview\",\"properties\"\ - :{\"autoProvision\":\"On\"}},{\"type\":\"Microsoft.Security/workspaceSettings\"\ - ,\"apiVersion\":\"2017-08-01-preview\",\"name\":\"default\",\"properties\"\ - :{\"workspaceId\":\"[parameters('logAnalytics')]\",\"scope\":\"[subscription().id]\"\ - }}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8e7da0a5-0a0e-4bbc-bfc0-7773c018b616\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8e7da0a5-0a0e-4bbc-bfc0-7773c018b616\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1517 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1517\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8f5ad423-50d6-4617-b058-69908f5586c9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8f5ad423-50d6-4617-b058-69908f5586c9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1668 - Flaw\ - \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1668\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8fb0966e-be1d-42c3-baca-60df5c0bcc61\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fb0966e-be1d-42c3-baca-60df5c0bcc61\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1013 - Account\ - \ Management | Automated System Account Management\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1013\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8fd7b917-d83b-4379-af60-51e14e316c61\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fd7b917-d83b-4379-af60-51e14e316c61\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1147 - Security\ - \ Assessments\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1147\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8fef824a-29a8-4a4c-88fc-420a39c0d541\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fef824a-29a8-4a4c-88fc-420a39c0d541\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not store passwords using reversible encryption\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ that do not store passwords using reversible encryption. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"2.2.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"StorePasswordsUsingReversibleEncryption\",\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"StorePasswordsUsingReversibleEncryption\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8ff0b18b-262e-4512-857a-48ad0aeb9a78\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8ff0b18b-262e-4512-857a-48ad0aeb9a78\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1550 - Vulnerability\ - \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1550\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/902908fb-25a8-4225-a3a5-5603c80066c9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"902908fb-25a8-4225-a3a5-5603c80066c9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Windows Firewall Properties'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Windows Firewall Properties'. It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"WindowsFirewallDomainUseProfileSettings\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Windows Firewall (Domain):\ - \ Use profile settings\",\"description\":\"Specifies whether Windows Firewall\ - \ with Advanced Security uses the settings for the Domain profile to filter\ - \ network traffic. If you select Off, Windows Firewall with Advanced Security\ - \ will not use any of the firewall rules or connection security rules for\ - \ this profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainBehaviorForOutboundConnections\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Domain): Behavior for outbound connections\",\"description\":\"\ - Specifies the behavior for outbound connections for the Domain profile that\ - \ do not match an outbound firewall rule. The default value of 0 means to\ - \ allow connections, and a value of 1 means to block connections.\"},\"defaultValue\"\ - :\"0\"},\"WindowsFirewallDomainApplyLocalConnectionSecurityRules\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows Firewall\ - \ (Domain): Apply local connection security rules\",\"description\":\"Specifies\ - \ whether local administrators are allowed to create connection security rules\ - \ that apply together with connection security rules configured by Group Policy\ - \ for the Domain profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Domain): Apply local firewall rules\",\"description\":\"Specifies\ - \ whether local administrators are allowed to create local firewall rules\ - \ that apply together with firewall rules configured by Group Policy for the\ - \ Domain profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainDisplayNotifications\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Domain): Display notifications\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security displays notifications to the user\ - \ when a program is blocked from receiving inbound connections, for the Domain\ - \ profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPrivateUseProfileSettings\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Private): Use profile settings\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security uses the settings for the Private\ - \ profile to filter network traffic. If you select Off, Windows Firewall with\ - \ Advanced Security will not use any of the firewall rules or connection security\ - \ rules for this profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPrivateBehaviorForOutboundConnections\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Private): Behavior for outbound connections\",\"description\"\ - :\"Specifies the behavior for outbound connections for the Private profile\ - \ that do not match an outbound firewall rule. The default value of 0 means\ - \ to allow connections, and a value of 1 means to block connections.\"},\"\ - defaultValue\":\"0\"},\"WindowsFirewallPrivateApplyLocalConnectionSecurityRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Private): Apply local connection security rules\",\"description\"\ - :\"Specifies whether local administrators are allowed to create connection\ - \ security rules that apply together with connection security rules configured\ - \ by Group Policy for the Private profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPrivateApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Private): Apply local firewall rules\",\"description\":\"Specifies\ - \ whether local administrators are allowed to create local firewall rules\ - \ that apply together with firewall rules configured by Group Policy for the\ - \ Private profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPrivateDisplayNotifications\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Private): Display notifications\",\"description\":\"Specifies\ - \ whether Windows Firewall with Advanced Security displays notifications to\ - \ the user when a program is blocked from receiving inbound connections, for\ - \ the Private profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPublicUseProfileSettings\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Public): Use profile settings\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security uses the settings for the Public\ - \ profile to filter network traffic. If you select Off, Windows Firewall with\ - \ Advanced Security will not use any of the firewall rules or connection security\ - \ rules for this profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPublicBehaviorForOutboundConnections\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Public): Behavior for outbound connections\",\"description\":\"\ - Specifies the behavior for outbound connections for the Public profile that\ - \ do not match an outbound firewall rule. The default value of 0 means to\ - \ allow connections, and a value of 1 means to block connections.\"},\"defaultValue\"\ - :\"0\"},\"WindowsFirewallPublicApplyLocalConnectionSecurityRules\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows Firewall\ - \ (Public): Apply local connection security rules\",\"description\":\"Specifies\ - \ whether local administrators are allowed to create connection security rules\ - \ that apply together with connection security rules configured by Group Policy\ - \ for the Public profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPublicApplyLocalFirewallRules\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Public): Apply local firewall rules\",\"description\":\"Specifies\ - \ whether local administrators are allowed to create local firewall rules\ - \ that apply together with firewall rules configured by Group Policy for the\ - \ Public profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallPublicDisplayNotifications\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall (Public): Display notifications\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security displays notifications to the user\ - \ when a program is blocked from receiving inbound connections, for the Public\ - \ profile.\"},\"defaultValue\":\"1\"},\"WindowsFirewallDomainAllowUnicastResponse\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall: Domain: Allow unicast response\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security permits the local computer to receive\ - \ unicast responses to its outgoing multicast or broadcast messages; for the\ - \ Domain profile.\"},\"defaultValue\":\"0\"},\"WindowsFirewallPrivateAllowUnicastResponse\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall: Private: Allow unicast response\",\"description\":\"Specifies\ - \ whether Windows Firewall with Advanced Security permits the local computer\ - \ to receive unicast responses to its outgoing multicast or broadcast messages;\ - \ for the Private profile.\"},\"defaultValue\":\"0\"},\"WindowsFirewallPublicAllowUnicastResponse\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Windows\ - \ Firewall: Public: Allow unicast response\",\"description\":\"Specifies whether\ - \ Windows Firewall with Advanced Security permits the local computer to receive\ - \ unicast responses to its outgoing multicast or broadcast messages; for the\ - \ Public profile.\"},\"defaultValue\":\"1\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_WindowsFirewallProperties\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Windows Firewall: Domain: Firewall state;ExpectedValue',\ - \ '=', parameters('WindowsFirewallDomainUseProfileSettings'), ',', 'Windows\ - \ Firewall: Domain: Outbound connections;ExpectedValue', '=', parameters('WindowsFirewallDomainBehaviorForOutboundConnections'),\ - \ ',', 'Windows Firewall: Domain: Settings: Apply local connection security\ - \ rules;ExpectedValue', '=', parameters('WindowsFirewallDomainApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallDomainApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Domain: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallDomainDisplayNotifications'), ',', 'Windows Firewall:\ - \ Private: Firewall state;ExpectedValue', '=', parameters('WindowsFirewallPrivateUseProfileSettings'),\ - \ ',', 'Windows Firewall: Private: Outbound connections;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPrivateBehaviorForOutboundConnections'), ',',\ - \ 'Windows Firewall: Private: Settings: Apply local connection security rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Private: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPrivateDisplayNotifications'), ',', 'Windows\ - \ Firewall: Public: Firewall state;ExpectedValue', '=', parameters('WindowsFirewallPublicUseProfileSettings'),\ - \ ',', 'Windows Firewall: Public: Outbound connections;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPublicBehaviorForOutboundConnections'), ',',\ - \ 'Windows Firewall: Public: Settings: Apply local connection security rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPublicApplyLocalConnectionSecurityRules'),\ - \ ',', 'Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPublicApplyLocalFirewallRules'), ',', 'Windows\ - \ Firewall: Public: Settings: Display a notification;ExpectedValue', '=',\ - \ parameters('WindowsFirewallPublicDisplayNotifications'), ',', 'Windows Firewall:\ - \ Domain: Allow unicast response;ExpectedValue', '=', parameters('WindowsFirewallDomainAllowUnicastResponse'),\ - \ ',', 'Windows Firewall: Private: Allow unicast response;ExpectedValue',\ - \ '=', parameters('WindowsFirewallPrivateAllowUnicastResponse'), ',', 'Windows\ - \ Firewall: Public: Allow unicast response;ExpectedValue', '=', parameters('WindowsFirewallPublicAllowUnicastResponse')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_WindowsFirewallProperties\"},\"WindowsFirewallDomainUseProfileSettings\"\ - :{\"value\":\"[parameters('WindowsFirewallDomainUseProfileSettings')]\"},\"\ - WindowsFirewallDomainBehaviorForOutboundConnections\":{\"value\":\"[parameters('WindowsFirewallDomainBehaviorForOutboundConnections')]\"\ - },\"WindowsFirewallDomainApplyLocalConnectionSecurityRules\":{\"value\":\"\ - [parameters('WindowsFirewallDomainApplyLocalConnectionSecurityRules')]\"},\"\ - WindowsFirewallDomainApplyLocalFirewallRules\":{\"value\":\"[parameters('WindowsFirewallDomainApplyLocalFirewallRules')]\"\ - },\"WindowsFirewallDomainDisplayNotifications\":{\"value\":\"[parameters('WindowsFirewallDomainDisplayNotifications')]\"\ - },\"WindowsFirewallPrivateUseProfileSettings\":{\"value\":\"[parameters('WindowsFirewallPrivateUseProfileSettings')]\"\ - },\"WindowsFirewallPrivateBehaviorForOutboundConnections\":{\"value\":\"[parameters('WindowsFirewallPrivateBehaviorForOutboundConnections')]\"\ - },\"WindowsFirewallPrivateApplyLocalConnectionSecurityRules\":{\"value\":\"\ - [parameters('WindowsFirewallPrivateApplyLocalConnectionSecurityRules')]\"\ - },\"WindowsFirewallPrivateApplyLocalFirewallRules\":{\"value\":\"[parameters('WindowsFirewallPrivateApplyLocalFirewallRules')]\"\ - },\"WindowsFirewallPrivateDisplayNotifications\":{\"value\":\"[parameters('WindowsFirewallPrivateDisplayNotifications')]\"\ - },\"WindowsFirewallPublicUseProfileSettings\":{\"value\":\"[parameters('WindowsFirewallPublicUseProfileSettings')]\"\ - },\"WindowsFirewallPublicBehaviorForOutboundConnections\":{\"value\":\"[parameters('WindowsFirewallPublicBehaviorForOutboundConnections')]\"\ - },\"WindowsFirewallPublicApplyLocalConnectionSecurityRules\":{\"value\":\"\ - [parameters('WindowsFirewallPublicApplyLocalConnectionSecurityRules')]\"},\"\ - WindowsFirewallPublicApplyLocalFirewallRules\":{\"value\":\"[parameters('WindowsFirewallPublicApplyLocalFirewallRules')]\"\ - },\"WindowsFirewallPublicDisplayNotifications\":{\"value\":\"[parameters('WindowsFirewallPublicDisplayNotifications')]\"\ - },\"WindowsFirewallDomainAllowUnicastResponse\":{\"value\":\"[parameters('WindowsFirewallDomainAllowUnicastResponse')]\"\ - },\"WindowsFirewallPrivateAllowUnicastResponse\":{\"value\":\"[parameters('WindowsFirewallPrivateAllowUnicastResponse')]\"\ - },\"WindowsFirewallPublicAllowUnicastResponse\":{\"value\":\"[parameters('WindowsFirewallPublicAllowUnicastResponse')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"WindowsFirewallDomainUseProfileSettings\":{\"type\"\ - :\"string\"},\"WindowsFirewallDomainBehaviorForOutboundConnections\":{\"type\"\ - :\"string\"},\"WindowsFirewallDomainApplyLocalConnectionSecurityRules\":{\"\ - type\":\"string\"},\"WindowsFirewallDomainApplyLocalFirewallRules\":{\"type\"\ - :\"string\"},\"WindowsFirewallDomainDisplayNotifications\":{\"type\":\"string\"\ - },\"WindowsFirewallPrivateUseProfileSettings\":{\"type\":\"string\"},\"WindowsFirewallPrivateBehaviorForOutboundConnections\"\ - :{\"type\":\"string\"},\"WindowsFirewallPrivateApplyLocalConnectionSecurityRules\"\ - :{\"type\":\"string\"},\"WindowsFirewallPrivateApplyLocalFirewallRules\":{\"\ - type\":\"string\"},\"WindowsFirewallPrivateDisplayNotifications\":{\"type\"\ - :\"string\"},\"WindowsFirewallPublicUseProfileSettings\":{\"type\":\"string\"\ - },\"WindowsFirewallPublicBehaviorForOutboundConnections\":{\"type\":\"string\"\ - },\"WindowsFirewallPublicApplyLocalConnectionSecurityRules\":{\"type\":\"\ - string\"},\"WindowsFirewallPublicApplyLocalFirewallRules\":{\"type\":\"string\"\ - },\"WindowsFirewallPublicDisplayNotifications\":{\"type\":\"string\"},\"WindowsFirewallDomainAllowUnicastResponse\"\ - :{\"type\":\"string\"},\"WindowsFirewallPrivateAllowUnicastResponse\":{\"\ - type\":\"string\"},\"WindowsFirewallPublicAllowUnicastResponse\":{\"type\"\ - :\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Windows Firewall:\ - \ Domain: Firewall state;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallDomainUseProfileSettings')]\"\ - },{\"name\":\"Windows Firewall: Domain: Outbound connections;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainBehaviorForOutboundConnections')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Apply local connection security\ - \ rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallDomainApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainDisplayNotifications')]\"},{\"\ - name\":\"Windows Firewall: Private: Firewall state;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPrivateUseProfileSettings')]\"},{\"name\":\"\ - Windows Firewall: Private: Outbound connections;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPrivateBehaviorForOutboundConnections')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Apply local connection\ - \ security rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallPrivateApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateDisplayNotifications')]\"\ - },{\"name\":\"Windows Firewall: Public: Firewall state;ExpectedValue\",\"\ - value\":\"[parameters('WindowsFirewallPublicUseProfileSettings')]\"},{\"name\"\ - :\"Windows Firewall: Public: Outbound connections;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPublicBehaviorForOutboundConnections')]\"},{\"\ - name\":\"Windows Firewall: Public: Settings: Apply local connection security\ - \ rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallPublicApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Public: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicDisplayNotifications')]\"},{\"\ - name\":\"Windows Firewall: Domain: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainAllowUnicastResponse')]\"},{\"\ - name\":\"Windows Firewall: Private: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateAllowUnicastResponse')]\"\ - },{\"name\":\"Windows Firewall: Public: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicAllowUnicastResponse')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Windows Firewall:\ - \ Domain: Firewall state;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallDomainUseProfileSettings')]\"\ - },{\"name\":\"Windows Firewall: Domain: Outbound connections;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainBehaviorForOutboundConnections')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Apply local connection security\ - \ rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallDomainApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Domain: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainDisplayNotifications')]\"},{\"\ - name\":\"Windows Firewall: Private: Firewall state;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPrivateUseProfileSettings')]\"},{\"name\":\"\ - Windows Firewall: Private: Outbound connections;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPrivateBehaviorForOutboundConnections')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Apply local connection\ - \ security rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallPrivateApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Private: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateDisplayNotifications')]\"\ - },{\"name\":\"Windows Firewall: Public: Firewall state;ExpectedValue\",\"\ - value\":\"[parameters('WindowsFirewallPublicUseProfileSettings')]\"},{\"name\"\ - :\"Windows Firewall: Public: Outbound connections;ExpectedValue\",\"value\"\ - :\"[parameters('WindowsFirewallPublicBehaviorForOutboundConnections')]\"},{\"\ - name\":\"Windows Firewall: Public: Settings: Apply local connection security\ - \ rules;ExpectedValue\",\"value\":\"[parameters('WindowsFirewallPublicApplyLocalConnectionSecurityRules')]\"\ - },{\"name\":\"Windows Firewall: Public: Settings: Apply local firewall rules;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicApplyLocalFirewallRules')]\"\ - },{\"name\":\"Windows Firewall: Public: Settings: Display a notification;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicDisplayNotifications')]\"},{\"\ - name\":\"Windows Firewall: Domain: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallDomainAllowUnicastResponse')]\"},{\"\ - name\":\"Windows Firewall: Private: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPrivateAllowUnicastResponse')]\"\ - },{\"name\":\"Windows Firewall: Public: Allow unicast response;ExpectedValue\"\ - ,\"value\":\"[parameters('WindowsFirewallPublicAllowUnicastResponse')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/909c958d-1b99-4c74-b88f-46a5c5bc34f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"909c958d-1b99-4c74-b88f-46a5c5bc34f9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1133 - Protection\ - \ Of Audit Information | Cryptographic Protection\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and\ - \ Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1133\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90b60a09-133d-45bc-86ef-b206a6134bbe\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90b60a09-133d-45bc-86ef-b206a6134bbe\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have the specified Windows PowerShell modules\ - \ installed\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines that do not have the specified Windows PowerShell modules installed.\ - \ It also creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"Modules\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: PowerShell Modules\",\"description\":\"A semicolon-separated\ - \ list of the names of the PowerShell modules that should be installed. You\ - \ may also specify a specific version of a module that should be installed\ - \ by including a comma after the module name, followed by the desired version.\ - \ e.g. PSDscResources; SqlServerDsc, 12.0.0.0; ComputerManagementDsc, 6.1.0.0\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPowerShellModules\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[PowerShellModules]PowerShellModules1;Modules',\ - \ '=', parameters('Modules')))]\"},\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsPowerShellModules\"\ - },\"Modules\":{\"value\":\"[parameters('Modules')]\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"Modules\":{\"type\":\"string\"}},\"resources\":[{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[PowerShellModules]PowerShellModules1;Modules\"\ - ,\"value\":\"[parameters('Modules')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[PowerShellModules]PowerShellModules1;Modules\"\ - ,\"value\":\"[parameters('Modules')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90ba2ee7-4ca8-4673-84d1-c851c50d3baf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90ba2ee7-4ca8-4673-84d1-c851c50d3baf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1140 - Audit\ - \ Generation | System-Wide / Time-Correlated Audit Trail\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1140\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90d8b8ad-8ee3-4db7-913f-2a53fcff5316\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90d8b8ad-8ee3-4db7-913f-2a53fcff5316\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1355 - Incident\ - \ Response Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1355\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90e01f69-3074-4de8-ade7-0fef3e7d83e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90e01f69-3074-4de8-ade7-0fef3e7d83e0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1657 - Secure\ - \ Name / Address Resolution Service (Authoritative Source)\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1657\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/90f01329-a100-43c2-af31-098996135d2b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"90f01329-a100-43c2-af31-098996135d2b\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Windows Components'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"This policy should only be used along\ - \ with its corresponding deploy policy in an initiative. This definition allows\ - \ Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Windows Components'.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_WindowsComponents\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9178b430-2295-406e-bb28-f6a7a2a2f897\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9178b430-2295-406e-bb28-f6a7a2a2f897\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1069 - Wireless\ - \ Access | Authentication And Encryption\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1069\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/91c97b44-791e-46e9-bad7-ab7c4949edbb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"91c97b44-791e-46e9-bad7-ab7c4949edbb\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy Dependency agent to\ - \ Windows Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy deploys the Dependency agent to Windows Azure\ - \ Arc machines if the agent isn't installed.\",\"metadata\":{\"version\":\"\ - 1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"DependencyAgentWindows\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.HybridCompute/machines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"DaExtensionName\":\"\ - DependencyAgentWindows\",\"DaExtensionType\":\"DependencyAgentWindows\"},\"\ - resources\":[{\"type\":\"Microsoft.HybridCompute/machines\",\"apiVersion\"\ - :\"2020-03-11-preview\",\"name\":\"[parameters('vmName')]\",\"location\":\"\ - [parameters('location')]\",\"resources\":[{\"type\":\"extensions\",\"apiVersion\"\ - :\"2020-03-11-preview\",\"name\":\"[variables('DaExtensionName')]\",\"location\"\ - :\"[parameters('location')]\",\"dependsOn\":[\"[concat('Microsoft.HybridCompute/machines/',\ - \ parameters('vmName'))]\"],\"properties\":{\"publisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"type\":\"[variables('DaExtensionType')]\",\"autoUpgradeMinorVersion\":true,\"\ - settings\":{}}}]}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\"\ - :\"[concat('Enabled DA extension for VM', ': ', parameters('vmName'))]\"}}},\"\ - parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/91cb9edd-cd92-4d2f-b2f2-bdd8d065a3d4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"91cb9edd-cd92-4d2f-b2f2-bdd8d065a3d4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1370 - Incident\ - \ Monitoring | Automated Tracking / Data Collection / Analysis\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Incident Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1370\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/924e1b2d-c502-478f-bfdb-a7e09a0d5c01\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"924e1b2d-c502-478f-bfdb-a7e09a0d5c01\"\ - },{\"properties\":{\"displayName\":\"MFA should be enabled accounts with write\ - \ permissions on your subscription\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - All\",\"description\":\"Multi-Factor Authentication (MFA) should be enabled\ - \ for all subscription accounts with write privileges to prevent a breach\ - \ of accounts or resources.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"57e98606-6b1e-6193-0e3d-fe621387c16b\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"Healthy\"\ - ]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9297c21d-2ed6-4474-b48f-163f75654ce3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9297c21d-2ed6-4474-b48f-163f75654ce3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1290 - Information\ - \ System Backup\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1290\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/92f85ce9-17b7-49ea-85ee-ea7271ea6b82\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"92f85ce9-17b7-49ea-85ee-ea7271ea6b82\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that contain certificates expiring within the specified number\ - \ of days\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy should only be used along with its corresponding deploy policy\ - \ in an initiative. This definition allows Azure Policy to process the results\ - \ of auditing Windows virtual machines that contain certificates expiring\ - \ within the specified number of days. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"CertificateExpiration\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9328f27e-611e-44a7-a244-39109d7d35ab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9328f27e-611e-44a7-a244-39109d7d35ab\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not contain\ - \ the specified certificates in Trusted Root\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the machine Trusted Root certificate store\ - \ (Cert:\\\\LocalMachine\\\\Root) does not contain one or more of the certificates\ - \ listed by the policy paramter.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.1\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"WindowsCertificateInTrustedRoot\",\"\ - version\":\"1.*\",\"configurationParameter\":{\"CertificateThumbprints\":\"\ - [CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"}}},\"\ - parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"CertificateThumbprints\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Certificate thumbprints\"\ - ,\"description\":\"A semicolon-separated list of certificate thumbprints that\ - \ should exist under the Trusted Root certificate store (Cert:\\\\LocalMachine\\\ - \\Root). e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"}}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsCertificateInTrustedRoot\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude',\ - \ '=', parameters('CertificateThumbprints')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/934345e1-4dfb-4c70-90d7-41990dc9608b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"934345e1-4dfb-4c70-90d7-41990dc9608b\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs if the Administrators group doesn't contain all the specified\ - \ members\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines in which the Administrators group does not contain all of the specified\ - \ members. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"MembersToInclude\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Members to include\",\"description\":\"A semicolon-separated\ - \ list of members that should be included in the Administrators local group.\ - \ Ex: Administrator; myUser1; myUser2\"}}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToInclude\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;MembersToInclude',\ - \ '=', parameters('MembersToInclude')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AdministratorsGroupMembersToInclude\"\ - },\"MembersToInclude\":{\"value\":\"[parameters('MembersToInclude')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"MembersToInclude\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;MembersToInclude\"\ - ,\"value\":\"[parameters('MembersToInclude')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;MembersToInclude\"\ - ,\"value\":\"[parameters('MembersToInclude')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93507a81-10a4-4af0-9ee2-34cf25a96e98\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93507a81-10a4-4af0-9ee2-34cf25a96e98\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1575 - Acquisition\ - \ Process | Functional Properties Of Security Controls\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1575\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93e1bb73-1b08-4dbe-9c62-8e2e92e7ec41\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93e1bb73-1b08-4dbe-9c62-8e2e92e7ec41\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1674 - Flaw\ - \ Remediation | Time To Remediate Flaws / Benchmarks For Corrective Actions\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1674\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93e9e233-dd0a-4bde-aea5-1371bce0e002\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93e9e233-dd0a-4bde-aea5-1371bce0e002\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1297 - Information\ - \ System Recovery And Reconstitution | Restore Within Time Period\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1297\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/93fd8af1-c161-4bae-9ba9-f62731f76439\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"93fd8af1-c161-4bae-9ba9-f62731f76439\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1284 - Telecommunications\ - \ Services | Provider Contingency Plan\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1284\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/942b3e97-6ae3-410e-a794-c9c999b97c0b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"942b3e97-6ae3-410e-a794-c9c999b97c0b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1379 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1379\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9442dd2c-a07f-46cd-b55a-553b66ba47ca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9442dd2c-a07f-46cd-b55a-553b66ba47ca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1371 - Incident\ - \ Reporting\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1371\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9447f354-2c85-4700-93b3-ecdc6cb6a417\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9447f354-2c85-4700-93b3-ecdc6cb6a417\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ only in European data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Allows resource creation in the following locations only:\ - \ North Europe, West Europe\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"General\",\"deprecated\":true},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"not\":{\"field\":\"location\",\"in\":[\"northeurope\",\"westeurope\"\ - ]}},\"then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/94c19f19-8192-48cd-a11b-e37099d3e36b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"94c19f19-8192-48cd-a11b-e37099d3e36b\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'System Audit Policies - Account Management'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'System Audit Policies - Account Management'\ - \ for auditing application, security, and user group management, and other\ - \ management events. This policy requires that the Guest Configuration prerequisites\ - \ have been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SystemAuditPoliciesAccountManagement\",\"version\"\ - :\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Include Arc connected servers\",\"description\"\ - :\"By selecting this option, you agree to be charged monthly per Arc connected\ - \ machine.\"},\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SystemAuditPoliciesAccountManagement\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/94d9aca8-3757-46df-aa51-f218c5f11954\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"94d9aca8-3757-46df-aa51-f218c5f11954\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1526 - Access\ - \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1526\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/953e6261-a05a-44fd-8246-000e1a3edbb9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"953e6261-a05a-44fd-8246-000e1a3edbb9\"\ - },{\"properties\":{\"displayName\":\"Authentication should be enabled on your\ - \ web app\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Azure App Service Authentication is a feature that can prevent anonymous\ - \ HTTP requests from reaching the web app, or authenticate those that have\ - \ tokens before they reach the web app\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/siteAuthEnabled\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/95bccee9-a7f8-4bec-9ee9-62c3473701fc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"95bccee9-a7f8-4bec-9ee9-62c3473701fc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1163 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1163\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/961663a1-8a91-4e59-b6f5-1eee57c0f49c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"961663a1-8a91-4e59-b6f5-1eee57c0f49c\"\ - },{\"properties\":{\"displayName\":\"Require a tag on resource groups\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Enforces existence\ - \ of a tag on resource groups.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Tag Name\",\"description\":\"Name of the tag, such as 'environment'\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\"\ - :\"false\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/96670d01-0a4d-4649-9c89-2d3abc0a5025\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"96670d01-0a4d-4649-9c89-2d3abc0a5025\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1717 - Software,\ - \ Firmware, And Information Integrity | Binary Or Machine Executable Code\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1717\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/967773fc-d9ab-4a4e-8ff6-f5e9e3f5dbef\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"967773fc-d9ab-4a4e-8ff6-f5e9e3f5dbef\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Advanced data security\ - \ settings for SQL server should contain an email address to receive security\ - \ alerts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Ensure that an email address is provided for the 'Send alerts to' field\ - \ in the Advanced Data Security server settings. This email address receives\ - \ alert notifications when anomalous activities are detected on SQL servers.\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"SQL\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"\ - equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\",\"\ - name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/emailAddresses[*]\"\ - ,\"notEquals\":\"\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9677b740-f641-4f3c-b9c5-466005c85278\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9677b740-f641-4f3c-b9c5-466005c85278\"\ - },{\"properties\":{\"displayName\":\"App Configuration should use a customer-managed\ - \ key\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - Customer-managed keys provide enhanced data protection by allowing you to\ - \ manage your encryption keys. This is often required to meet compliance requirements.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"App Configuration\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.AppConfiguration/configurationStores\"\ - },{\"field\":\"Microsoft.AppConfiguration/configurationStores/encryption.keyVaultProperties.keyIdentifier\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/967a4b4b-2da9-43c1-b7d0-f98d0d74d0b1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"967a4b4b-2da9-43c1-b7d0-f98d0d74d0b1\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Administrative Templates - System'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Administrative Templates - System'\ - \ for settings that control the administrative experience and Remote Assistance.\ - \ This policy requires that the Guest Configuration prerequisites have been\ - \ deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_AdministrativeTemplatesSystem\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"AlwaysUseClassicLogon\":\"Always use classic\ - \ logon;ExpectedValue\",\"BootStartDriverInitializationPolicy\":\"Boot-Start\ - \ Driver Initialization Policy;ExpectedValue\",\"EnableWindowsNTPClient\"\ - :\"Enable Windows NTP Client;ExpectedValue\",\"TurnOnConveniencePINSignin\"\ - :\"Turn on convenience PIN sign-in;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"AlwaysUseClassicLogon\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Always use classic logon\",\"description\"\ - :\"Specifies whether to force the user to log on to the computer using the\ - \ classic logon screen. This setting only works when the computer is not on\ - \ a domain.\"},\"defaultValue\":\"0\"},\"BootStartDriverInitializationPolicy\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Boot-Start Driver Initialization\ - \ Policy\",\"description\":\"Specifies which boot-start drivers are initialized\ - \ based on a classification determined by an Early Launch Antimalware boot-start\ - \ driver.\"},\"defaultValue\":\"3\"},\"EnableWindowsNTPClient\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable Windows NTP Client\",\"\ - description\":\"Specifies whether the Windows NTP Client is enabled. Enabling\ - \ the Windows NTP Client allows your computer to synchronize its computer\ - \ clock with other NTP servers.\"},\"defaultValue\":\"1\"},\"TurnOnConveniencePINSignin\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Turn on convenience\ - \ PIN sign-in\",\"description\":\"Specifies whether a domain user can sign\ - \ in using a convenience PIN.\"},\"defaultValue\":\"0\"},\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_AdministrativeTemplatesSystem\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Always use classic logon;ExpectedValue', '=',\ - \ parameters('AlwaysUseClassicLogon'), ',', 'Boot-Start Driver Initialization\ - \ Policy;ExpectedValue', '=', parameters('BootStartDriverInitializationPolicy'),\ - \ ',', 'Enable Windows NTP Client;ExpectedValue', '=', parameters('EnableWindowsNTPClient'),\ - \ ',', 'Turn on convenience PIN sign-in;ExpectedValue', '=', parameters('TurnOnConveniencePINSignin')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/968410dc-5ca0-4518-8a5b-7b55f0530ea9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"968410dc-5ca0-4518-8a5b-7b55f0530ea9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1453 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1453\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9693b564-3008-42bc-9d5d-9c7fe198c011\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9693b564-3008-42bc-9d5d-9c7fe198c011\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Administrative Templates - MSS (Legacy)'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Administrative\ - \ Templates - MSS (Legacy)'. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.1-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdminstrativeTemplatesMSSLegacy\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/97646672-5efa-4622-9b54-740270ad60bf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"97646672-5efa-4622-9b54-740270ad60bf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1607 - Developer\ - \ Security Testing And Evaluation | Dynamic Code Analysis\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1607\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/976a74cf-b192-4d35-8cab-2068f272addb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"976a74cf-b192-4d35-8cab-2068f272addb\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Policy Change'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Policy Change'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditAuthenticationPolicyChange\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Deprecated]: Audit Authentication Policy Change\"\ - ,\"description\":\"Specifies whether audit events are generated when changes\ - \ are made to authentication policy. This setting is useful for tracking changes\ - \ in domain-level and forest-level trust and privileges that are granted to\ - \ user accounts or groups.\"},\"allowedValues\":[\"No Auditing\",\"Success\"\ - ,\"Failure\",\"Success and Failure\"],\"defaultValue\":\"Success\"},\"AuditAuthorizationPolicyChange\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Audit\ - \ Authorization Policy Change\",\"description\":\"Specifies whether audit\ - \ events are generated for assignment and removal of user rights in user right\ - \ policies, changes in security token object permission, resource attributes\ - \ changes and Central Access Policy changes for file system objects.\"},\"\ - allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"\ - ],\"defaultValue\":\"No Auditing\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesPolicyChange\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Authentication Policy Change;ExpectedValue',\ - \ '=', parameters('AuditAuthenticationPolicyChange'), ',', 'Audit Authorization\ - \ Policy Change;ExpectedValue', '=', parameters('AuditAuthorizationPolicyChange')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SystemAuditPoliciesPolicyChange\"},\"AuditAuthenticationPolicyChange\"\ - :{\"value\":\"[parameters('AuditAuthenticationPolicyChange')]\"},\"AuditAuthorizationPolicyChange\"\ - :{\"value\":\"[parameters('AuditAuthorizationPolicyChange')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditAuthenticationPolicyChange\":{\"type\":\"string\"\ - },\"AuditAuthorizationPolicyChange\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Authentication\ - \ Policy Change;ExpectedValue\",\"value\":\"[parameters('AuditAuthenticationPolicyChange')]\"\ - },{\"name\":\"Audit Authorization Policy Change;ExpectedValue\",\"value\"\ - :\"[parameters('AuditAuthorizationPolicyChange')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Authentication\ - \ Policy Change;ExpectedValue\",\"value\":\"[parameters('AuditAuthenticationPolicyChange')]\"\ - },{\"name\":\"Audit Authorization Policy Change;ExpectedValue\",\"value\"\ - :\"[parameters('AuditAuthorizationPolicyChange')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/97b595c8-fd10-400e-8543-28e2b9138b13\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"97b595c8-fd10-400e-8543-28e2b9138b13\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1136 - Audit\ - \ Record Retention\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1136\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/97ed5bac-a92f-4f6d-a8ed-dc094723597c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"97ed5bac-a92f-4f6d-a8ed-dc094723597c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1378 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1378\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/97fceb70-6983-42d0-9331-18ad8253184d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"97fceb70-6983-42d0-9331-18ad8253184d\"\ - },{\"properties\":{\"displayName\":\"Azure Event Grid domains should use private\ - \ links\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit Azure Event Grid domains that do not have at least one approved private\ - \ endpoint connection. Clients in a virtual network can securely access resources\ - \ that have private endpoint connections via private links. For more information,\ - \ visit https://aka.ms/privateendpoints.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Event Grid\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.EventGrid/domains\"},{\"count\":{\"field\"\ - :\"Microsoft.EventGrid/domains/privateEndpointConnections[*]\",\"where\":{\"\ - field\":\"Microsoft.EventGrid/domains/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9830b652-8523-49cc-b1b3-e17dce1127ca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9830b652-8523-49cc-b1b3-e17dce1127ca\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ only in United States data centers\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Allows resource creation in the following locations\ - \ only: Central US, East US, East US2, North Central US, South Central US,\ - \ West US\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ - General\",\"deprecated\":true},\"parameters\":{},\"policyRule\":{\"if\":{\"\ - not\":{\"field\":\"location\",\"in\":[\"centralus\",\"eastus\",\"eastus2\"\ - ,\"northcentralus\",\"southcentralus\",\"westus\"]}},\"then\":{\"effect\"\ - :\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/983211ba-f348-4758-983b-21fa29294869\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"983211ba-f348-4758-983b-21fa29294869\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Administrative Templates - Network'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Administrative Templates\ - \ - Network'. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.1.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"EnableInsecureGuestLogons\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Enable insecure guest logons\",\"description\"\ - :\"Specifies whether the SMB client will allow insecure guest logons to an\ - \ SMB server.\"},\"defaultValue\":\"0\"},\"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allow\ - \ simultaneous connections to the Internet or a Windows Domain\",\"description\"\ - :\"Specify whether to prevent computers from connecting to both a domain based\ - \ network and a non-domain based network at the same time. A value of 0 allows\ - \ simultaneous connections, and a value of 1 blocks them.\"},\"defaultValue\"\ - :\"1\"},\"TurnOffMulticastNameResolution\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Turn off multicast name resolution\",\"\ - description\":\"Specifies whether LLMNR, a secondary name resolution protocol\ - \ that transmits using multicast over a local subnet link on a single subnet,\ - \ is enabled.\"},\"defaultValue\":\"1\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesNetwork\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Enable insecure guest logons;ExpectedValue',\ - \ '=', parameters('EnableInsecureGuestLogons'), ',', 'Minimize the number\ - \ of simultaneous connections to the Internet or a Windows Domain;ExpectedValue',\ - \ '=', parameters('AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain'),\ - \ ',', 'Turn off multicast name resolution;ExpectedValue', '=', parameters('TurnOffMulticastNameResolution')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_AdministrativeTemplatesNetwork\"},\"EnableInsecureGuestLogons\"\ - :{\"value\":\"[parameters('EnableInsecureGuestLogons')]\"},\"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain\"\ - :{\"value\":\"[parameters('AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain')]\"\ - },\"TurnOffMulticastNameResolution\":{\"value\":\"[parameters('TurnOffMulticastNameResolution')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"EnableInsecureGuestLogons\":{\"type\":\"string\"\ - },\"AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain\":{\"type\"\ - :\"string\"},\"TurnOffMulticastNameResolution\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Enable insecure\ - \ guest logons;ExpectedValue\",\"value\":\"[parameters('EnableInsecureGuestLogons')]\"\ - },{\"name\":\"Minimize the number of simultaneous connections to the Internet\ - \ or a Windows Domain;ExpectedValue\",\"value\":\"[parameters('AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain')]\"\ - },{\"name\":\"Turn off multicast name resolution;ExpectedValue\",\"value\"\ - :\"[parameters('TurnOffMulticastNameResolution')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Enable insecure\ - \ guest logons;ExpectedValue\",\"value\":\"[parameters('EnableInsecureGuestLogons')]\"\ - },{\"name\":\"Minimize the number of simultaneous connections to the Internet\ - \ or a Windows Domain;ExpectedValue\",\"value\":\"[parameters('AllowSimultaneousConnectionsToTheInternetOrAWindowsDomain')]\"\ - },{\"name\":\"Turn off multicast name resolution;ExpectedValue\",\"value\"\ - :\"[parameters('TurnOffMulticastNameResolution')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/985285b7-b97a-419c-8d48-c88cc934c8d8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"985285b7-b97a-419c-8d48-c88cc934c8d8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1076 - Use\ - \ Of External Information Systems\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1076\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/98a4bd5f-6436-46d4-ad00-930b5b1dfed4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"98a4bd5f-6436-46d4-ad00-930b5b1dfed4\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'HTTP Version' is the latest,\ - \ if used to run the Api app\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Periodically, newer versions are released for HTTP either\ - \ due to security flaws or to include additional functionality. Using the\ - \ latest HTTP version for web apps to take advantage of security fixes, if\ - \ any, and/or new functionalities of the newer version.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.http20Enabled\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/991310cd-e9f3-47bc-b7b6-f57b557d07db\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"991310cd-e9f3-47bc-b7b6-f57b557d07db\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1102 - Audit\ - \ Events\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1102\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9943c16a-c54c-4b4a-ad28-bfd938cdbf57\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9943c16a-c54c-4b4a-ad28-bfd938cdbf57\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1300 - Identification\ - \ And Authentication (Organizational Users)\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1300\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/99deec7d-5526-472e-b07c-3645a792026a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"99deec7d-5526-472e-b07c-3645a792026a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1036 - Least\ - \ Privilege | Non-Privileged Access For Nonsecurity Functions\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1036\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9a16d673-8cf0-4dcf-b1d5-9b3e114fef71\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9a16d673-8cf0-4dcf-b1d5-9b3e114fef71\"\ - },{\"properties\":{\"displayName\":\"FTPS only should be required in your\ - \ API App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Enable FTPS enforcement for enhanced security\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"\ - field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/ftpsState\",\"\ - in\":[\"FtpsOnly\",\"Disabled\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9a1b8c48-453a-4044-86c3-d8bfd823e4f5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9a1b8c48-453a-4044-86c3-d8bfd823e4f5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1021 - Account\ - \ Management | Restrictions On Use Of Shared / Group Accounts\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1021\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9a3eb0a3-428d-4669-baff-20a14eb4b551\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9a3eb0a3-428d-4669-baff-20a14eb4b551\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Azure\ - \ SQL Database to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Azure SQL Database\ - \ to stream to a regional Event Hub on any Azure SQL Database which is missing\ - \ this diagnostic settings is created or updated.\",\"metadata\":{\"version\"\ - :\"1.1.0\",\"category\":\"SQL\"},\"parameters\":{\"profileName\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ - :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy\"\ - },\"eventHubRuleId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Event Hub Authorization Rule Id\",\"description\":\"The Event Hub authorization\ - \ rule Id for Azure Diagnostics. The authorization rule needs to be at Event\ - \ Hub namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource\ - \ group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization\ - \ rule}\",\"strongType\":\"Microsoft.EventHub/Namespaces/AuthorizationRules\"\ - ,\"assignPermissions\":true}},\"metricsEnabled\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Enable metrics\",\"description\":\"Whether to enable metrics\ - \ stream to the Event Hub - True or False\"},\"allowedValues\":[\"True\",\"\ - False\"],\"defaultValue\":\"False\"},\"logsEnabled\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Enable logs\",\"description\":\"Whether to\ - \ enable logs stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"},\"then\"\ - :{\"effect\":\"DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"[parameters('profileName')]\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ - :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"resources\":[{\"\ - type\":\"Microsoft.Sql/servers/databases/providers/diagnosticSettings\",\"\ - apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('fullName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"QueryStoreRuntimeStatistics\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"QueryStoreWaitStatistics\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"Errors\",\"\ - enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"DatabaseWaitStatistics\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"Blocks\",\"\ - enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"SQLInsights\",\"\ - enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"SQLSecurityAuditEvents\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"Timeouts\",\"\ - enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"AutomaticTuning\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"Deadlocks\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{\"policy\"\ - :{\"type\":\"string\",\"value\":\"[concat('Enabled diagnostic settings for\ - \ ', parameters('fullName'))]\"}}},\"parameters\":{\"location\":{\"value\"\ - :\"[field('location')]\"},\"fullName\":{\"value\":\"[field('fullName')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9a7c7a7d-49e5-4213-bea8-6a502b6272e0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9a7c7a7d-49e5-4213-bea8-6a502b6272e0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1049 - System\ - \ Use Notification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1049\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9adf7ba7-900a-4f35-8d57-9f34aafc405c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9adf7ba7-900a-4f35-8d57-9f34aafc405c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1563 - Allocation\ - \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1563\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9afe2edf-232c-4fdf-8e6a-e867a5c525fd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9afe2edf-232c-4fdf-8e6a-e867a5c525fd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1462 - Monitoring\ - \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1462\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9b1f3a9a-13a1-4b40-8420-36bca6fd8c02\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9b1f3a9a-13a1-4b40-8420-36bca6fd8c02\"\ - },{\"properties\":{\"displayName\":\"Microsoft IaaSAntimalware extension should\ - \ be deployed on Windows servers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy audits any Windows server VM without\ - \ Microsoft IaaSAntimalware extension deployed.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Compute\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\"\ - ,\"2012-Datacenter\",\"2012-Datacenter-smalldisk\",\"2012-R2-Datacenter\"\ - ,\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\",\"2016-Datacenter-Server-Core\"\ - ,\"2016-Datacenter-Server-Core-smalldisk\",\"2016-Datacenter-smalldisk\",\"\ - 2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\",\"2019-Datacenter\"\ - ,\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\",\"2019-Datacenter-Core-with-Containers\"\ - ,\"2019-Datacenter-Core-with-Containers-smalldisk\",\"2019-Datacenter-smalldisk\"\ - ,\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Compute/virtualMachines/extensions\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"IaaSAntimalware\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Security\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9b597639-28e4-48eb-b506-56b05d366257\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9b597639-28e4-48eb-b506-56b05d366257\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1236 - Software\ - \ Usage Restrictions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1236\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ba3ed84-c768-4e18-b87c-34ef1aff1b57\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ba3ed84-c768-4e18-b87c-34ef1aff1b57\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1525 - Personnel\ - \ Transfer\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1525\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9be2f688-7a61-45e3-8230-e1ec93893f66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9be2f688-7a61-45e3-8230-e1ec93893f66\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit API Applications\ - \ that are not using latest supported Java Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported Java version\ - \ for the latest security classes. Using older classes and types can make\ - \ your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestJava\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9bfe3727-0a17-471f-a2fe-eddd6b668745\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9bfe3727-0a17-471f-a2fe-eddd6b668745\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1138 - Audit\ - \ Generation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1138\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9c284fc0-268a-4f29-af44-3c126674edb4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9c284fc0-268a-4f29-af44-3c126674edb4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1135 - Non-Repudiation\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Audit and Accountability control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1135\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9c308b6b-2429-4b97-86cf-081b8e737b04\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9c308b6b-2429-4b97-86cf-081b8e737b04\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1489 - Location\ - \ Of Information System Components\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1489\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d0a794f-1444-4c96-9534-e35fc8c39c91\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d0a794f-1444-4c96-9534-e35fc8c39c91\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'Java version' is the latest,\ - \ if used as a part of the Function app\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ Java software either due to security flaws or to include additional functionality.\ - \ Using the latest Java version for Function apps is recommended in order\ - \ to take advantage of security fixes, if any, and/or new functionalities\ - \ of the latest version.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"JavaLatestVersion\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Latest Java version\",\"description\":\"\ - Latest supported Java version for App Services\"},\"defaultValue\":\"11\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"notContains\":\"JAVA\"\ - },{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\",\"equals\":\"\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"like\":\"[concat('*', parameters('JavaLatestVersion'))]\"},{\"field\":\"\ - Microsoft.Web/sites/config/web.javaVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.javaVersion\",\"like\"\ - :\"[concat(parameters('JavaLatestVersion'), '*')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d0b6ea4-93e2-4578-bf2f-6bb17d22b4bc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d0b6ea4-93e2-4578-bf2f-6bb17d22b4bc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1322 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1322\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d1d971e-467e-4278-9633-c74c3d4fecc4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d1d971e-467e-4278-9633-c74c3d4fecc4\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy Log Analytics agent\ - \ to Linux Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy deploys the Log Analytics agent to Linux Azure\ - \ Arc machines if the agent isn't installed.\",\"metadata\":{\"version\":\"\ - 1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"parameters\"\ - :{\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Log Analytics workspace\",\"description\":\"Specify the Log Analytics workspace\ - \ the agent should be connected to. If this workspace is outside of the scope\ - \ of the assignment you must manually grant 'Log Analytics Contributor' permissions\ - \ (or similar) to the policy assignment's principal ID.\",\"strongType\":\"\ - omsWorkspace\",\"assignPermissions\":true}}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"},{\"\ - field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]},\"then\"\ - :{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"OmsAgentForLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\":\"string\"\ - }},\"variables\":{\"vmExtensionName\":\"OMSAgentForLinux\",\"vmExtensionPublisher\"\ - :\"Microsoft.EnterpriseCloud.Monitoring\",\"vmExtensionType\":\"OmsAgentForLinux\"\ - },\"resources\":[{\"name\":\"[concat(parameters('vmName'), '/', variables('vmExtensionName'))]\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"\ - [parameters('location')]\",\"apiVersion\":\"2019-12-12\",\"properties\":{\"\ - publisher\":\"[variables('vmExtensionPublisher')]\",\"type\":\"[variables('vmExtensionType')]\"\ - ,\"settings\":{\"workspaceId\":\"[reference(parameters('logAnalytics'), '2015-03-20').customerId]\"\ - ,\"stopOnMultipleConnections\":\"true\"},\"protectedSettings\":{\"workspaceKey\"\ - :\"[listKeys(parameters('logAnalytics'), '2015-03-20').primarySharedKey]\"\ - }}}],\"outputs\":{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled\ - \ extension for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"\ - vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"}}}}}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d2b61b4-1d14-4a63-be30-d4498e7ad2cf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d2b61b4-1d14-4a63-be30-d4498e7ad2cf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1233 - Configuration\ - \ Management Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1233\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d79001f-95fe-45d0-8736-f217e78c1f57\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d79001f-95fe-45d0-8736-f217e78c1f57\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1305 - Identification\ - \ And Authentication (Org. Users) | Group Authentication\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Identification and Authentication control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1305\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d9166a8-1722-4b8f-847c-2cf3f2618b3d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d9166a8-1722-4b8f-847c-2cf3f2618b3d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1259 - Contingency\ - \ Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1259\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9d9e18f7-bad9-4d30-8806-a0c9d5e26208\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d9e18f7-bad9-4d30-8806-a0c9d5e26208\"\ - },{\"properties\":{\"displayName\":\"Access through Internet facing endpoint\ - \ should be restricted\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Azure Security center has identified some of your Network Security Groups'\ - \ inbound rules to be too permissive. Inbound rules should not allow access\ - \ from 'Any' or 'Internet' ranges. This can potentially enable attackers to\ - \ easily target your resources.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"3b20e985-f71f-483b-b078-f30d73936d43\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9daedab3-fb2d-461e-b861-71790eead4f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9daedab3-fb2d-461e-b861-71790eead4f6\"\ - },{\"properties\":{\"displayName\":\"Application definition for Managed Application\ - \ should use customer provided storage account\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Use your own storage account to control\ - \ the application definition data when this is a regulatory or compliance\ - \ requirement. You can choose to store your managed application definition\ - \ within a storage account provided by you during creation, so that its location\ - \ and access can be fully managed by you to fulfill regulatory compliance\ - \ requirements.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Managed\ - \ Application\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"\ - defaultValue\":\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.Solutions/applicationDefinitions\"},{\"field\"\ - :\"Microsoft.Solutions/applicationDefinitions/storageAccountId\",\"exists\"\ - :\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/9db7917b-1607-4e7d-a689-bca978dd0633\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9db7917b-1607-4e7d-a689-bca978dd0633\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1500 - Rules\ - \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1500\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9dd5b241-03cb-47d3-a5cd-4b89f9c53c92\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9dd5b241-03cb-47d3-a5cd-4b89f9c53c92\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1482 - Temperature\ - \ And Humidity Controls | Monitoring With Alarms / Notifications\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Physical and Environmental Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1482\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9df4277e-8c88-4d5c-9b1a-541d53d15d7b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9df4277e-8c88-4d5c-9b1a-541d53d15d7b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1553 - Vulnerability\ - \ Scanning | Breadth / Depth Of Coverage\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1553\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e5225fe-cdfb-4fce-9aec-0fe20dd53b62\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e5225fe-cdfb-4fce-9aec-0fe20dd53b62\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1490 - Security\ - \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Planning control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1490\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e61da80-0957-4892-b70c-609d5eaafb6b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e61da80-0957-4892-b70c-609d5eaafb6b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1504 - Information\ - \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Planning control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1504\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e7c35d0-12d4-4e0c-80a2-8a352537aefd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e7c35d0-12d4-4e0c-80a2-8a352537aefd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1609 - Development\ - \ Process, Standards, And Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1609\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9e93fa71-42ac-41a7-b177-efbfdc53c69f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9e93fa71-42ac-41a7-b177-efbfdc53c69f\"\ - },{\"properties\":{\"displayName\":\"Append a tag and its value from the resource\ - \ group\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Appends the specified tag with its value from the resource group when any\ - \ resource which is missing this tag is created or updated. Does not modify\ - \ the tags of resources created before this policy was applied until those\ - \ resources are changed. New 'modify' effect policies are available that support\ - \ remediation of tags on existing resources (see https://aka.ms/modifydoc).\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Tags\"},\"parameters\"\ - :{\"tagName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\"\ - ,\"description\":\"Name of the tag, such as 'environment'\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"[concat('tags[', parameters('tagName'),\ - \ ']')]\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('tagName')]]\"\ - ,\"notEquals\":\"\"}]},\"then\":{\"effect\":\"append\",\"details\":[{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"value\":\"[resourceGroup().tags[parameters('tagName')]]\"\ - }]}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ea02ca2-71db-412d-8b00-7c7ca9fcd32d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ea02ca2-71db-412d-8b00-7c7ca9fcd32d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1494 - System\ - \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1494\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ed09d84-3311-4853-8b67-2b55dfa33d09\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ed09d84-3311-4853-8b67-2b55dfa33d09\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1514 - Personnel\ - \ Screening | Information With Special Protection Measures\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Personnel Security control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1514\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9ed5ca00-0e43-434e-a018-7aab91461ba7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9ed5ca00-0e43-434e-a018-7aab91461ba7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1187 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1187\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9f2b2f9e-4ba6-46c3-907f-66db138b6f85\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9f2b2f9e-4ba6-46c3-907f-66db138b6f85\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that are not set to the specified time zone\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that are not set to the specified time zone. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsTimeZone\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9f658460-46b7-43af-8565-94fc0662be38\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9f658460-46b7-43af-8565-94fc0662be38\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1354 - Incident\ - \ Response Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1354\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9fd92c17-163a-4511-bb96-bbb476449796\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9fd92c17-163a-4511-bb96-bbb476449796\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs on which the Log Analytics agent is not connected as expected\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines on which the Log Analytics agent is not connected to the\ - \ specified workspaces. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsLogAnalyticsAgentConnection\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a030a57e-4639-4e8f-ade9-a92f33afe7ee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a030a57e-4639-4e8f-ade9-a92f33afe7ee\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1145 - Security\ - \ Assessments\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1145\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a0724970-9c75-4a64-a225-a28002953f28\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a0724970-9c75-4a64-a225-a28002953f28\"\ - },{\"properties\":{\"displayName\":\"Allowed resource types\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy enables you\ - \ to specify the resource types that your organization can deploy. Only resource\ - \ types that support 'tags' and 'location' will be affected by this policy.\ - \ To restrict all resources please duplicate this policy and change the 'mode'\ - \ to 'All'.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"General\"\ - },\"parameters\":{\"listOfResourceTypesAllowed\":{\"type\":\"Array\",\"metadata\"\ - :{\"description\":\"The list of resource types that can be deployed.\",\"\ - displayName\":\"Allowed resource types\",\"strongType\":\"resourceTypes\"\ - }}},\"policyRule\":{\"if\":{\"not\":{\"field\":\"type\",\"in\":\"[parameters('listOfResourceTypesAllowed')]\"\ - }},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a08ec900-254a-4555-9bf5-e42af04b5c5c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a08ec900-254a-4555-9bf5-e42af04b5c5c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1245 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1245\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a0e45314-57b8-4623-80cd-bbb561f59516\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a0e45314-57b8-4623-80cd-bbb561f59516\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1406 - Maintenance\ - \ Tools | Inspect Media\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Maintenance control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1406\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a0f5339c-9292-43aa-a0bc-d27c6b8e30aa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a0f5339c-9292-43aa-a0bc-d27c6b8e30aa\"\ - },{\"properties\":{\"displayName\":\"Security Center standard pricing tier\ - \ should be selected\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"The standard pricing tier enables threat detection for networks and virtual\ - \ machines, providing threat intelligence, anomaly detection, and behavior\ - \ analytics in Azure Security Center\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Security/pricings\"},{\"field\"\ - :\"Microsoft.Security/pricings/pricingTier\",\"exists\":\"true\"},{\"field\"\ - :\"Microsoft.Security/pricings/pricingTier\",\"notEquals\":\"Standard\"}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a1181c5f-672a-477a-979a-7d58aa086233\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a1181c5f-672a-477a-979a-7d58aa086233\"\ - },{\"properties\":{\"displayName\":\"All authorization rules except RootManageSharedAccessKey\ - \ should be removed from Service Bus namespace\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Service Bus clients should not use a namespace\ - \ level access policy that provides access to all queues and topics in a namespace.\ - \ To align with the least privilege security model, you should create access\ - \ policies at the entity level for queues and topics to provide access to\ - \ only the specific entity\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"Service Bus\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"The effect determines what\ - \ happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ServiceBus/namespaces/authorizationRules\"\ - },{\"field\":\"name\",\"notEquals\":\"RootManageSharedAccessKey\"}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a1817ec0-a368-432a-8057-8371e17ac6ee\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a1817ec0-a368-432a-8057-8371e17ac6ee\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1265 - Contingency\ - \ Plan Testing | Alternate Processing Site\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1265\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a18adb5b-1db6-4a5b-901a-7d3797d12972\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a18adb5b-1db6-4a5b-901a-7d3797d12972\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Logic\ - \ Apps to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploys the diagnostic settings for Logic Apps to stream to a regional\ - \ Event Hub when any Logic Apps which is missing this diagnostic settings\ - \ is created or updated.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Profile name\",\"description\":\"The diagnostic\ - \ settings profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"},\"eventHubRuleId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Event Hub Authorization\ - \ Rule Id\",\"description\":\"The Event Hub authorization rule Id for Azure\ - \ Diagnostics. The authorization rule needs to be at Event Hub namespace level.\ - \ e.g. /subscriptions/{subscription Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ - \ in. Only Logic Apps in this location will be linked to this Event Hub.\"\ - ,\"strongType\":\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Event Hub - True or False\"},\"\ - allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ - :\"Whether to enable logs stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Logic/workflows\"},{\"\ - anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\"},{\"\ - field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"[parameters('profileName')]\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ - :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Logic/workflows/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"WorkflowRuntime\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a1dae6c7-13f3-48ea-a149-ff8442661f60\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a1dae6c7-13f3-48ea-a149-ff8442661f60\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Administrative Templates - System'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Administrative Templates\ - \ - System'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesSystem\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a1e8dda3-9fd2-4835-aec3-0e55531fde33\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a1e8dda3-9fd2-4835-aec3-0e55531fde33\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1612 - Developer\ - \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1612\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2037b3d-8b04-4171-8610-e6d4f1d08db5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2037b3d-8b04-4171-8610-e6d4f1d08db5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1197 - Configuration\ - \ Change Control | Test / Validate / Document Changes\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1197\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a20d2eaa-88e2-4907-96a2-8f3a05797e5c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a20d2eaa-88e2-4907-96a2-8f3a05797e5c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1275 - Alternate\ - \ Processing Site | Separation From Primary Site\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1275\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a23d9d53-ad2e-45ef-afd5-e6d10900a737\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a23d9d53-ad2e-45ef-afd5-e6d10900a737\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1690 - Information\ - \ System Monitoring | System-Wide Intrusion Detection System\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1690\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2567a23-d1c3-4783-99f3-d471302a4d6b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2567a23-d1c3-4783-99f3-d471302a4d6b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1410 - Maintenance\ - \ Tools | Prevent Unauthorized Removal\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1410\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2596a9f-e59f-420d-9625-6e0b536348be\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2596a9f-e59f-420d-9625-6e0b536348be\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1059 - Remote\ - \ Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1059\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a29b5d9f-4953-4afe-b560-203a6410b6b4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a29b5d9f-4953-4afe-b560-203a6410b6b4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that are not joined to the specified domain\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that are not joined to the specified domain. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDomainMembership\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a29ee95c-0395-4515-9851-cc04ffe82a91\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a29ee95c-0395-4515-9851-cc04ffe82a91\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1532 - Third-Party\ - \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1532\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2c66299-9017-4d95-8040-8bdbf7901d52\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2c66299-9017-4d95-8040-8bdbf7901d52\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1664 - Protection\ - \ Of Information At Rest | Cryptographic Protection\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1664\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2cdf6b8-9505-4619-b579-309ba72037ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2cdf6b8-9505-4619-b579-309ba72037ac\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not restrict\ - \ the minimum password length to 14 characters\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if Windows machines that do not restrict the\ - \ minimum password length to 14 characters\",\"metadata\":{\"category\":\"\ - Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"MinimumPasswordLength\",\"version\":\"\ - 1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of this policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - MinimumPasswordLength\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2d0e922-65d0-40c4-8f87-ea6da2d307a2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2d0e922-65d0-40c4-8f87-ea6da2d307a2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1252 - Contingency\ - \ Plan | Capacity Planning\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Contingency Planning control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1252\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a328fd72-8ff5-4f96-8c9c-b30ed95db4ab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a328fd72-8ff5-4f96-8c9c-b30ed95db4ab\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1238 - User-Installed\ - \ Software\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1238\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a36cedd4-3ffd-4b1f-8b18-aa71d8d87ce1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a36cedd4-3ffd-4b1f-8b18-aa71d8d87ce1\"\ - },{\"properties\":{\"displayName\":\"Log Analytics agent should be installed\ - \ on your virtual machine scale sets for Azure Security Center monitoring\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Security Center\ - \ collects data from your Azure virtual machines (VMs) to monitor for security\ - \ vulnerabilities and threats.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.Compute/virtualMachineScaleSets\"]},\"then\":{\"\ - effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"45cfe080-ceb1-a91e-9743-71551ed24e94\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"NotApplicable\"\ - ,\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a3a6ea0c-e018-4933-9ef0-5aaa1501449b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a3a6ea0c-e018-4933-9ef0-5aaa1501449b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1693 - Information\ - \ System Monitoring | System-Generated Alerts\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1693\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a450eba6-2efc-4a00-846a-5804a93c6b77\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a450eba6-2efc-4a00-846a-5804a93c6b77\"\ - },{\"properties\":{\"displayName\":\"Audit usage of custom RBAC rules\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Audit built-in\ - \ roles such as 'Owner, Contributer, Reader' instead of custom RBAC roles,\ - \ which are error prone. Using custom roles is treated as an exception and\ - \ requires a rigorous review and threat modeling\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"General\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Authorization/roleDefinitions\"\ - },{\"field\":\"Microsoft.Authorization/roleDefinitions/type\",\"equals\":\"\ - CustomRole\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/a451c1ef-c6ca-483d-87ed-f49761e3ffb5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a451c1ef-c6ca-483d-87ed-f49761e3ffb5\"\ - },{\"properties\":{\"displayName\":\"Web Application should only be accessible\ - \ over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use of HTTPS ensures server/service authentication and protects data in\ - \ transit from network layer eavesdropping attacks.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"app*\"},{\"field\":\"Microsoft.Web/sites/httpsOnly\",\"equals\"\ - :\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/a4af4a39-4135-47fb-b175-47fbdf85311d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a4af4a39-4135-47fb-b175-47fbdf85311d\"\ - },{\"properties\":{\"displayName\":\"Log Analytics agent should be installed\ - \ on your virtual machine for Azure Security Center monitoring\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy audits any Windows/Linux\ - \ virtual machines (VMs) if the Log Analytics agent is not installed which\ - \ Security Center uses to monitor for security vulnerabilities and threats\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.ClassicCompute/virtualMachines\",\"Microsoft.Compute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"d1db3318-01ff-16de-29eb-28b344515626\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"NotApplicable\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a4fe33eb-e377-4efb-ab31-0784311bc499\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a4fe33eb-e377-4efb-ab31-0784311bc499\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1617 - Application\ - \ Partitioning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1617\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a631d8f5-eb81-4f9d-9ee1-74431371e4a3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a631d8f5-eb81-4f9d-9ee1-74431371e4a3\"\ - },{\"properties\":{\"displayName\":\"Auditing on SQL server should be enabled\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Auditing\ - \ on your SQL Server should be enabled to track database activities across\ - \ all databases on the server and save them in an audit log.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"\ - setting\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Desired Auditing\ - \ setting\"},\"allowedValues\":[\"enabled\",\"disabled\"],\"defaultValue\"\ - :\"enabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/servers/auditingSettings\",\"name\":\"default\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Sql/auditingSettings.state\",\"equals\":\"[parameters('setting')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a6fb4358-5bf4-4ad7-ba82-2cd2f41ce5e9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a6fb4358-5bf4-4ad7-ba82-2cd2f41ce5e9\"\ - },{\"properties\":{\"displayName\":\"The Log Analytics agent should be installed\ - \ on virtual machines\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy audits any Windows/Linux virtual machines if the\ - \ Log Analytics agent is not installed.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"in\":[\"MicrosoftMonitoringAgent\",\"OmsAgentForLinux\"]},{\"field\":\"\ - Microsoft.Compute/virtualMachines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/settings.workspaceId\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a70ca396-0a34-413a-88e1-b956c1e683be\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a70ca396-0a34-413a-88e1-b956c1e683be\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1431 - Media\ - \ Storage\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1431\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7173c52-2b99-4696-a576-63dd5f970ef4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7173c52-2b99-4696-a576-63dd5f970ef4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1644 - Cryptographic\ - \ Key Establishment And Management | Availability\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1644\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7211477-c970-446b-b4af-062f37461147\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7211477-c970-446b-b4af-062f37461147\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1027 - Access\ - \ Enforcement\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1027\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a76ca9b0-3f4a-4192-9a38-b25e4f8ae48c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a76ca9b0-3f4a-4192-9a38-b25e4f8ae48c\"\ - },{\"properties\":{\"displayName\":\"Azure DDoS Protection Standard should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"DDoS protection standard should be enabled for all virtual networks with\ - \ a subnet that is part of an application gateway with a public IP.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"microsoft.network/virtualNetworks\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"e3de1cc0-f4dd-3b34-e496-8b5381ba2d70\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7aca53f-2ed4-4466-a25e-0b45ade68efd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7aca53f-2ed4-4466-a25e-0b45ade68efd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1570 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1570\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7fcf38d-bb09-4600-be7d-825046eb162a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7fcf38d-bb09-4600-be7d-825046eb162a\"\ - },{\"properties\":{\"displayName\":\"Require encryption on Data Lake Store\ - \ accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy ensures encryption is enabled on all Data Lake Store accounts\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Data Lake\"},\"parameters\"\ - :{},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DataLakeStore/accounts\"\ - },{\"field\":\"Microsoft.DataLakeStore/accounts/encryptionState\",\"equals\"\ - :\"Disabled\"}]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a7ff3161-0087-490a-9ad9-ad6217f4f43a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a7ff3161-0087-490a-9ad9-ad6217f4f43a\"\ - },{\"properties\":{\"displayName\":\"SQL Managed Instance should have the\ - \ minimal TLS version of 1.2\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Setting minimal TLS version to 1.2 improves security by\ - \ ensuring your SQL Managed Instance can only be accessed from clients using\ - \ TLS 1.2. Using versions of TLS less than 1.2 is not reccomended since they\ - \ have well documented security vunerabilities.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Sql/managedInstances\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Sql/managedInstances/minimalTlsVersion\",\"exists\":false},{\"\ - field\":\"Microsoft.Sql/managedInstances/minimalTlsVersion\",\"notEquals\"\ - :\"1.2\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/a8793640-60f7-487c-b5c3-1d37215905c4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a8793640-60f7-487c-b5c3-1d37215905c4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1295 - Information\ - \ System Recovery And Reconstitution\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1295\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a895fbdb-204d-4302-9689-0a59dc42b3d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a895fbdb-204d-4302-9689-0a59dc42b3d9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Monitor unencrypted SQL\ - \ databases in Azure Security Center\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Unencrypted SQL databases will be monitored by\ - \ Azure Security Center as recommendations. This policy is deprecated and\ - \ replaced by the following policy: Transparent Data Encryption on SQL databases\ - \ should be enabled'\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"Security Center\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.SQL/servers/databases\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/complianceResults\",\"name\":\"encryption\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\",\"in\"\ - :[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a8bef009-a5c9-4d0f-90d7-6018734e8a16\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a8bef009-a5c9-4d0f-90d7-6018734e8a16\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1283 - Telecommunications\ - \ Services | Separation Of Primary / Alternate Providers\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1283\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9172e76-7f56-46e9-93bf-75d69bdb5491\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9172e76-7f56-46e9-93bf-75d69bdb5491\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1400 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1400\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a96d5098-a604-4cdf-90b1-ef6449a27424\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a96d5098-a604-4cdf-90b1-ef6449a27424\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1118 - Audit\ - \ Review, Analysis, And Reporting | Correlate Audit Repositories\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1118\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a96f743d-a195-420d-983a-08aa06bc441e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a96f743d-a195-420d-983a-08aa06bc441e\"\ - },{\"properties\":{\"displayName\":\"SQL Managed Instances should avoid using\ - \ GRS backup redundancy\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Managed Instances should avoid using GRS storage for backups\ - \ if data residency rules require data to stay within a specific region.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Deny\",\"Disabled\"],\"defaultValue\":\"Deny\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/managedInstances\"\ - },{\"not\":{\"anyOf\":[{\"field\":\"Microsoft.Sql/managedInstances/storageAccountType\"\ - ,\"equals\":\"LRS\"},{\"field\":\"Microsoft.Sql/managedInstances/storageAccountType\"\ - ,\"equals\":\"ZRS\"}]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9934fd7-29f2-4e6d-ab3d-607ea38e9079\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9934fd7-29f2-4e6d-ab3d-607ea38e9079\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1199 - Configuration\ - \ Change Control | Cryptography Management\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1199\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9a08d1c-09b1-48f1-90ea-029bbdf7111e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9a08d1c-09b1-48f1-90ea-029bbdf7111e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Detailed Tracking'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Detailed Tracking'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesDetailedTracking\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9a33475-481d-4b81-9116-0bf02ffe67e8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9a33475-481d-4b81-9116-0bf02ffe67e8\"\ - },{\"properties\":{\"displayName\":\"Deploy network watcher when virtual networks\ - \ are created\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a network watcher resource in regions with virtual\ - \ networks. You need to ensure existence of a resource group named networkWatcherRG,\ - \ which will be used to deploy network watcher instances.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks\"\ - },\"then\":{\"effect\":\"DeployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkWatchers\"\ - ,\"resourceGroupName\":\"networkWatcherRG\",\"existenceCondition\":{\"field\"\ - :\"location\",\"equals\":\"[field('location')]\"},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ - string\"}},\"resources\":[{\"apiVersion\":\"2016-09-01\",\"type\":\"Microsoft.Network/networkWatchers\"\ - ,\"name\":\"[concat('networkWatcher_', parameters('location'))]\",\"location\"\ - :\"[parameters('location')]\"}]},\"parameters\":{\"location\":{\"value\":\"\ - [field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9b99dd8-06c5-4317-8629-9d86a3c6e7d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9b99dd8-06c5-4317-8629-9d86a3c6e7d9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1511 - Personnel\ - \ Screening\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1511\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a9eae324-d327-4539-9293-b48e122465f8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a9eae324-d327-4539-9293-b48e122465f8\"\ - },{\"properties\":{\"displayName\":\"MFA should be enabled on accounts with\ - \ owner permissions on your subscription\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Multi-Factor Authentication (MFA) should be enabled\ - \ for all subscription accounts with owner permissions to prevent a breach\ - \ of accounts or resources.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"94290b00-4d0c-d7b4-7cea-064a9554e681\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"Healthy\"\ - ]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aa633080-8b72-40c4-a2d7-d00c03e80bed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aa633080-8b72-40c4-a2d7-d00c03e80bed\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that Register with\ - \ Azure Active Directory is enabled on WEB App\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy is a duplicate of the\ - \ respective Managed Identity policies. Please use /providers/Microsoft.Authorization/policyDefinitions/2b9ad585-36bc-4615-b300-fd4435808332\ - \ instead.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ - App Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aa81768c-cb87-4ce2-bfaa-00baa10d760c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aa81768c-cb87-4ce2-bfaa-00baa10d760c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1539 - Security\ - \ Categorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1539\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aabb155f-e7a5-4896-a767-e918bfae2ee0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aabb155f-e7a5-4896-a767-e918bfae2ee0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1006 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1006\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aae8d54c-4bce-4c04-b3aa-5b65b67caac8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aae8d54c-4bce-4c04-b3aa-5b65b67caac8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1461 - Monitoring\ - \ Physical Access\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1461\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aafef03e-fea8-470b-88fa-54bd1fcd7064\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aafef03e-fea8-470b-88fa-54bd1fcd7064\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1073 - Access\ - \ Control For Mobile Devices\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1073\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ab55cdb0-c7dd-4bd8-ae22-a7cea7594e9c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ab55cdb0-c7dd-4bd8-ae22-a7cea7594e9c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that 'PHP version'\ - \ is the latest, if used as a part of the Function app\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"PHP cannot be used with Function\ - \ apps.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"App\ - \ Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"\ - Enable or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"PHPLatestVersion\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Latest\ - \ PHP version\",\"description\":\"Latest supported PHP version for App Services\"\ - },\"defaultValue\":\"7.3\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\",\"like\"\ - :\"functionapp*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"existenceCondition\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"notContains\":\"PHP\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\"\ - ,\"equals\":\"\"}]},{\"allOf\":[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\"\ - ,\"equals\":\"[concat('PHP|', parameters('PHPLatestVersion'))]\"},{\"field\"\ - :\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\":\"\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/web.linuxFxVersion\",\"equals\"\ - :\"\"},{\"field\":\"Microsoft.Web/sites/config/web.phpVersion\",\"equals\"\ - :\"[parameters('PHPLatestVersion')]\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ab965db2-d2bf-4b64-8b39-c38ec8179461\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ab965db2-d2bf-4b64-8b39-c38ec8179461\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Automatic provisioning\ - \ of security monitoring agent\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Installs security agent on VMs for advanced security alerts\ - \ and preventions in Azure Security Center. Applies only for subscriptions\ - \ that use Azure Security Center.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"AuditIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - securityAgent\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/abcc6037-1fc4-47f6-aac5-89706589be24\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"abcc6037-1fc4-47f6-aac5-89706589be24\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1323 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1323\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/abe8f70b-680f-470c-9b86-a7edfb664ecc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"abe8f70b-680f-470c-9b86-a7edfb664ecc\"\ - },{\"properties\":{\"displayName\":\"Advanced data security should be enabled\ - \ on your SQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Audit SQL servers without Advanced Data Security\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },{\"field\":\"kind\",\"notContains\":\"analytics\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"name\":\"Default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/state\"\ - ,\"equals\":\"Enabled\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/abfb4388-5bf4-4ad7-ba82-2cd2f41ceae9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"abfb4388-5bf4-4ad7-ba82-2cd2f41ceae9\"\ - },{\"properties\":{\"displayName\":\"Advanced data security should be enabled\ - \ on SQL Managed Instance\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Audit each SQL Managed Instance without advanced data security.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/managedInstances\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/managedInstances/securityAlertPolicies\",\"name\":\"Default\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/managedInstances/securityAlertPolicies/state\"\ - ,\"equals\":\"Enabled\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/abfb7388-5bf4-4ad7-ba99-2cd2f41cebb9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"abfb7388-5bf4-4ad7-ba99-2cd2f41cebb9\"\ - },{\"properties\":{\"displayName\":\"Enable Azure Security Center on your\ - \ subscription\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Identifies existing subscriptions that are not monitored by Azure Security\ - \ Center (ASC).\\r\\nSubscriptions not monitored by ASC will be registered\ - \ to the free pricing tier.\\r\\nSubscriptions already monitored by ASC (free\ - \ or standard), will be considered compliant.\\r\\nTo register newly created\ - \ subscriptions, open the compliance tab, select the relevant non-compliant\ - \ assignment and create a remediation task.\\r\\nRepeat this step when you\ - \ have one or more new subscriptions you want to monitor with Security Center.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Security/pricings\"\ - ,\"name\":\"VirtualMachines\",\"deploymentScope\":\"subscription\",\"existenceScope\"\ - :\"subscription\",\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd\"\ - ],\"existenceCondition\":{\"anyof\":[{\"field\":\"microsoft.security/pricings/pricingTier\"\ - ,\"equals\":\"standard\"},{\"field\":\"microsoft.security/pricings/pricingTier\"\ - ,\"equals\":\"free\"}]},\"deployment\":{\"location\":\"westeurope\",\"properties\"\ - :{\"mode\":\"incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"variables\":{},\"resources\":[{\"type\"\ - :\"Microsoft.Security/pricings\",\"apiVersion\":\"2018-06-01\",\"name\":\"\ - VirtualMachines\",\"properties\":{\"pricingTier\":\"free\"}}],\"outputs\"\ - :{}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ac076320-ddcf-4066-b451-6154267e8ad2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac076320-ddcf-4066-b451-6154267e8ad2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1056 - Session\ - \ Termination | User-Initiated Logouts / Message Displays\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1056\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ac43352f-df83-4694-8738-cfce549fd08d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac43352f-df83-4694-8738-cfce549fd08d\"\ - },{\"properties\":{\"displayName\":\"Role-Based Access Control (RBAC) should\ - \ be used on Kubernetes Services\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - All\",\"description\":\"To provide granular filtering on the actions that\ - \ users can perform, use Role-Based Access Control (RBAC) to manage permissions\ - \ in Kubernetes Service Clusters and configure relevant authorization policies.\"\ - ,\"metadata\":{\"version\":\"1.0.2\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.ContainerService/managedClusters/enableRBAC\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ContainerService/managedClusters/enableRBAC\"\ - ,\"equals\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ac4a19c2-fa67-49b4-8ae5-0b2e78c49457\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac4a19c2-fa67-49b4-8ae5-0b2e78c49457\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ if 'environment' tag value in allowed values\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Allows resource creation if the 'environment'\ - \ tag is set to one of the following values: production, dev, test, staging\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Tags\",\"deprecated\"\ - :true},\"parameters\":{},\"policyRule\":{\"if\":{\"not\":{\"field\":\"tags['environment']\"\ - ,\"in\":[\"production\",\"dev\",\"test\",\"staging\"]}},\"then\":{\"effect\"\ - :\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ac7e5fc0-c029-4b12-91d4-a8500ce697f9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac7e5fc0-c029-4b12-91d4-a8500ce697f9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1569 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1569\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ad2f8e61-a564-4dfd-8eaa-816f5be8cb34\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ad2f8e61-a564-4dfd-8eaa-816f5be8cb34\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1454 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1454\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ad58985d-ab32-4f99-8bd3-b7e134c90229\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ad58985d-ab32-4f99-8bd3-b7e134c90229\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1025 - Account\ - \ Management | Account Monitoring / Atypical Usage\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1025\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/adfe020d-0a97-45f4-a39c-696ef99f3a95\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"adfe020d-0a97-45f4-a39c-696ef99f3a95\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1272 - Alternate\ - \ Processing Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1272\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ae46cf7a-e3fd-427b-9b91-44bc78e2d9d8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ae46cf7a-e3fd-427b-9b91-44bc78e2d9d8\"\ - },{\"properties\":{\"displayName\":\"SQL Server should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any SQL Server not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/servers/virtualNetworkRules\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Sql/servers/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ae5d2f14-d830-42b6-9899-df6cfe9c71a3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ae5d2f14-d830-42b6-9899-df6cfe9c71a3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1598 - Developer\ - \ Configuration Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1598\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ae7e1f5e-2d63-4b38-91ef-bce14151cce3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ae7e1f5e-2d63-4b38-91ef-bce14151cce3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Email notifications to\ - \ admins should be enabled in SQL Managed Instance advanced data security\ - \ settings\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit that 'email notification to admins and subscription owners' is enabled\ - \ in SQL Managed Instance advanced threat protection settings. This setting\ - \ ensures that any detections of anomalous activities on SQL Managed Instance\ - \ are reported as soon as possible to the admins.\",\"metadata\":{\"version\"\ - :\"1.0.1-deprecated\",\"category\":\"SQL\",\"deprecated\":true},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/managedInstances\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Sql/managedInstances/securityAlertPolicies\",\"name\":\"default\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/managedInstances/securityAlertPolicies/emailAccountAdmins\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aeb23562-188d-47cb-80b8-551f16ef9fff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aeb23562-188d-47cb-80b8-551f16ef9fff\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1413 - Nonlocal\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1413\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/aeedddb6-6bc0-42d5-809b-80048033419d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"aeedddb6-6bc0-42d5-809b-80048033419d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1710 - Security\ - \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1710\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/af2a93c8-e6dd-4c94-acdd-4a2eedfc478e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"af2a93c8-e6dd-4c94-acdd-4a2eedfc478e\"\ - },{\"properties\":{\"displayName\":\"Azure Spring Cloud should use network\ - \ injection\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Azure Spring Cloud instances should use virtual network injection for the\ - \ following purposes: 1. Isolate Azure Spring Cloud from Internet. 2. Enable\ - \ Azure Spring Cloud to interact with systems in either on premises data centers\ - \ or Azure service in other virtual networks. 3. Empower customers to control\ - \ inbound and outbound network communications for Azure Spring Cloud.\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"App Platform\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\",\"Deny\"],\"defaultValue\":\"Audit\"},\"evaluatedSkuNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Azure Spring Cloud SKU\ - \ Names\",\"description\":\"List of Azure Spring Cloud SKUs against which\ - \ this policy will be evaluated.\"},\"allowedValues\":[\"Standard\"],\"defaultValue\"\ - :[\"Standard\"]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.AppPlatform/Spring\"},{\"field\":\"Microsoft.AppPlatform/Spring/sku.tier\"\ - ,\"in\":\"[parameters('evaluatedSkuNames')]\"},{\"field\":\"Microsoft.AppPlatform/Spring/networkProfile.serviceRuntimeSubnetId\"\ - ,\"exists\":false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/af35e2a4-ef96-44e7-a9ae-853dd97032c4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"af35e2a4-ef96-44e7-a9ae-853dd97032c4\"\ - },{\"properties\":{\"displayName\":\"Monitor missing Endpoint Protection in\ - \ Azure Security Center\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Servers without an installed Endpoint Protection agent will be monitored\ - \ by Azure Security Center as recommendations\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"3bcd234d-c9c7-c2a2-89e0-c01f419c1a8a\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/af6cd1bd-1635-48cb-bde7-5b15693900b9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"af6cd1bd-1635-48cb-bde7-5b15693900b9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Monitor unaudited SQL servers\ - \ in Azure Security Center\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"SQL servers which don't have SQL auditing turned on will be\ - \ monitored by Azure Security Center as recommendations. This policy is deprecated\ - \ and replaced by the following policy: 'Auditing should be enabled on advanced\ - \ data security settings on SQL Server'\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.SQL/servers\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - auditing\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/af8051bf-258b-44e2-a2bf-165330459f9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"af8051bf-258b-44e2-a2bf-165330459f9d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1645 - Cryptographic\ - \ Key Establishment And Management | Symmetric Keys\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1645\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/afbd0baf-ff1a-4447-a86f-088a97347c0c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"afbd0baf-ff1a-4447-a86f-088a97347c0c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1725 - Error\ - \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1725\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/afc234b5-456b-4aa5-b3e2-ce89108124cc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"afc234b5-456b-4aa5-b3e2-ce89108124cc\"\ - },{\"properties\":{\"displayName\":\"Activity log should be retained for at\ - \ least one year\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"This policy audits the activity log if the retention is not set for 365\ - \ days or forever (retention days set to 0).\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/logProfiles\",\"existenceCondition\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/logProfiles/retentionPolicy.enabled\",\"\ - equals\":\"true\"},{\"field\":\"Microsoft.Insights/logProfiles/retentionPolicy.days\"\ - ,\"equals\":\"365\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/logProfiles/retentionPolicy.enabled\"\ - ,\"equals\":\"false\"},{\"field\":\"Microsoft.Insights/logProfiles/retentionPolicy.days\"\ - ,\"equals\":\"0\"}]}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b02aacc0-b073-424e-8298-42b22829ee0a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b02aacc0-b073-424e-8298-42b22829ee0a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1429 - Media\ - \ Marking\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1429\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b07c9b24-729e-4e85-95fc-f224d2d08a80\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b07c9b24-729e-4e85-95fc-f224d2d08a80\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1711 - Security\ - \ Function Verification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1711\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b083a535-a66a-41ec-ba7f-f9498bf67cde\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b083a535-a66a-41ec-ba7f-f9498bf67cde\"\ - },{\"properties\":{\"displayName\":\"Management ports of virtual machines\ - \ should be protected with just-in-time network access control\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"Possible network Just In Time\ - \ (JIT) access will be monitored by Azure Security Center as recommendations\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"805651bc-6ecd-4c73-9b55-97a19d0582d0\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b0f33259-77d7-4c9e-aac6-3aabcfae693c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b0f33259-77d7-4c9e-aac6-3aabcfae693c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1571 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1571\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b11c985b-f2cd-4bd7-85f4-b52426edf905\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b11c985b-f2cd-4bd7-85f4-b52426edf905\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Linux VMs that do not have the passwd file permissions set to 0644\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Linux\ - \ virtual machines that do not have the passwd file permissions set to 0644.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"\ - qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid121\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b18175dd-c599-4c64-83ba-bb018a06d35b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b18175dd-c599-4c64-83ba-bb018a06d35b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1537 - Risk\ - \ Assessment Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Risk Assessment control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1537\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b19454ca-0d70-42c0-acf5-ea1c1e5726d1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b19454ca-0d70-42c0-acf5-ea1c1e5726d1\"\ - },{\"properties\":{\"displayName\":\"SQL Database should avoid using GRS backup\ - \ redundancy\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Databases should avoid using GRS storage for backups if data residency\ - \ rules require data to stay within a specific region.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Deny\",\"\ - Disabled\"],\"defaultValue\":\"Deny\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"},{\"\ - field\":\"Microsoft.Sql/servers/databases/edition\",\"notEquals\":\"DataWarehouse\"\ - },{\"not\":{\"anyOf\":[{\"field\":\"Microsoft.Sql/servers/databases/storageAccountType\"\ - ,\"equals\":\"LRS\"},{\"field\":\"Microsoft.Sql/servers/databases/storageAccountType\"\ - ,\"equals\":\"ZRS\"}]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b219b9cf-f672-4f96-9ab0-f5a3ac5e1c13\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b219b9cf-f672-4f96-9ab0-f5a3ac5e1c13\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1091 - Security\ - \ Awareness Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1091\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b23bd715-5d1c-4e5c-9759-9cbdf79ded9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b23bd715-5d1c-4e5c-9759-9cbdf79ded9d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1078 - Use\ - \ Of External Information Systems | Limits On Authorized Use\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Access Control control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1078\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b25faf85-8a16-4f28-8e15-d05c0072d64d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b25faf85-8a16-4f28-8e15-d05c0072d64d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1009 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1009\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b26f8610-e615-47c2-abd6-c00b2b0b503a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b26f8610-e615-47c2-abd6-c00b2b0b503a\"\ - },{\"properties\":{\"displayName\":\"All authorization rules except RootManageSharedAccessKey\ - \ should be removed from Event Hub namespace\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Event Hub clients should not use a namespace\ - \ level access policy that provides access to all queues and topics in a namespace.\ - \ To align with the least privilege security model, you should create access\ - \ policies at the entity level for queues and topics to provide access to\ - \ only the specific entity\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"Event Hub\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"The effect determines what\ - \ happens when the policy rule is evaluated to match\"},\"allowedValues\"\ - :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces/authorizationRules\"\ - },{\"field\":\"name\",\"notEquals\":\"RootManageSharedAccessKey\"}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b278e460-7cfc-4451-8294-cccc40a940d7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b278e460-7cfc-4451-8294-cccc40a940d7\"\ - },{\"properties\":{\"displayName\":\"Inherit a tag from the subscription\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Adds or\ - \ replaces the specified tag and value from the containing subscription when\ - \ any resource is created or updated. Existing resources can be remediated\ - \ by triggering a remediation task.\",\"metadata\":{\"category\":\"Tags\"\ - ,\"version\":\"1.0.0\"},\"parameters\":{\"tagName\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Name of the tag,\ - \ such as 'environment'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"notEquals\":\"[subscription().tags[parameters('tagName')]]\"\ - },{\"value\":\"[subscription().tags[parameters('tagName')]]\",\"notEquals\"\ - :\"\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[subscription().tags[parameters('tagName')]]\"\ - }]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b27a0cbd-a167-4dfa-ae64-4337be671140\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b27a0cbd-a167-4dfa-ae64-4337be671140\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1234 - Software\ - \ Usage Restrictions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1234\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b293f881-361c-47ed-b997-bc4e2296bc0b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b293f881-361c-47ed-b997-bc4e2296bc0b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1107 - Content\ - \ Of Audit Records\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1107\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b29ed931-8e21-4779-8458-27916122a904\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b29ed931-8e21-4779-8458-27916122a904\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows web servers that are not using secure communication protocols\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows web servers that\ - \ are not using secure communication protocols (TLS 1.1 or TLS 1.2). It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"MinimumTLSVersion\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Deprecated]: Minimum TLS version\",\"description\":\"The\ - \ minimum TLS protocol version that should be enabled. Windows web servers\ - \ with lower TLS versions will be marked as non-compliant.\"},\"allowedValues\"\ - :[\"1.1\",\"1.2\"],\"defaultValue\":\"1.1\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AuditSecureProtocol\",\"existenceCondition\":{\"anyOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[SecureWebServer]s1;MinimumTLSVersion', '=',\ - \ parameters('MinimumTLSVersion')))]\"},{\"allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"\"},{\"value\":\"[parameters('MinimumTLSVersion')]\",\"equals\"\ - :\"1.1\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"\ - parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"},\"type\":{\"value\":\"[field('type')]\"},\"\ - configurationName\":{\"value\":\"AuditSecureProtocol\"},\"MinimumTLSVersion\"\ - :{\"value\":\"[parameters('MinimumTLSVersion')]\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"MinimumTLSVersion\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[SecureWebServer]s1;MinimumTLSVersion\"\ - ,\"value\":\"[parameters('MinimumTLSVersion')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[SecureWebServer]s1;MinimumTLSVersion\"\ - ,\"value\":\"[parameters('MinimumTLSVersion')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b2fc8f91-866d-4434-9089-5ebfe38d6fd8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b2fc8f91-866d-4434-9089-5ebfe38d6fd8\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Logon-Logoff'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Logon-Logoff'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesLogonLogoff\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b3802d79-dd88-4bce-b81d-780218e48280\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b3802d79-dd88-4bce-b81d-780218e48280\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1041 - Least\ - \ Privilege | Privilege Levels For Code Execution\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1041\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b3d8d15b-627a-4219-8c96-4d16f788888b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b3d8d15b-627a-4219-8c96-4d16f788888b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1380 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1380\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b4319b7e-ea8d-42ff-8a67-ccd462972827\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4319b7e-ea8d-42ff-8a67-ccd462972827\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Search services should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Search\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Search/searchServices\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b4330a05-a843-4bc8-bf9a-cacce50c67f4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4330a05-a843-4bc8-bf9a-cacce50c67f4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1172 - Internal\ - \ System Connections\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1172\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b43e946e-a4c8-4b92-8201-4a39331db43c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b43e946e-a4c8-4b92-8201-4a39331db43c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1672 - Flaw\ - \ Remediation | Central Management\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1672\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b45fe972-904e-45a4-ac20-673ba027a301\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b45fe972-904e-45a4-ac20-673ba027a301\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1131 - Protection\ - \ Of Audit Information\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Audit and Accountability control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1131\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b472a17e-c2bc-493f-b50b-42d55a346962\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b472a17e-c2bc-493f-b50b-42d55a346962\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Sockets state\ - \ for an API App\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"The Web Sockets protocol is vulnerable to different types of security threats.\ - \ Use of Web Sockets within an API app must be carefully reviewed.\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"\ - field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\"\ - :\"kind\",\"equals\":\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"DisableWebSockets\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b48334a4-911b-4084-b1ab-3e6a4e50b951\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b48334a4-911b-4084-b1ab-3e6a4e50b951\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Shutdown'\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Shutdown' for\ - \ allowing shutdown without logon and clearing the virtual memory pagefile.\ - \ This policy requires that the Guest Configuration prerequisites have been\ - \ deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsShutdown\",\"version\":\"1.*\",\"\ - configurationParameter\":{\"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn\"\ - :\"Shutdown: Allow system to be shut down without having to log on;ExpectedValue\"\ - ,\"ShutdownClearVirtualMemoryPagefile\":\"Shutdown: Clear virtual memory pagefile;ExpectedValue\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Shutdown: Allow system\ - \ to be shut down without having to log on\",\"description\":\"Specifies whether\ - \ a computer can be shut down when a user is not logged on. If this policy\ - \ setting is enabled, the shutdown command is available on the Windows logon\ - \ screen.\"},\"defaultValue\":\"0\"},\"ShutdownClearVirtualMemoryPagefile\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Shutdown: Clear virtual\ - \ memory pagefile\",\"description\":\"Specifies whether the virtual memory\ - \ pagefile is cleared when the system is shut down. When this policy setting\ - \ is enabled, the system pagefile is cleared each time that the system shuts\ - \ down properly. For systems with large amounts of RAM, this could result\ - \ in substantial time needed to complete the shutdown.\"},\"defaultValue\"\ - :\"0\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsShutdown\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Shutdown: Allow system to be shut down without\ - \ having to log on;ExpectedValue', '=', parameters('ShutdownAllowSystemToBeShutDownWithoutHavingToLogOn'),\ - \ ',', 'Shutdown: Clear virtual memory pagefile;ExpectedValue', '=', parameters('ShutdownClearVirtualMemoryPagefile')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b4a4d1eb-0263-441b-84cb-a44073d8372d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4a4d1eb-0263-441b-84cb-a44073d8372d\"\ - },{\"properties\":{\"displayName\":\"A security contact phone number should\ - \ be provided for your subscription\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Enter a phone number to receive notifications when\ - \ Azure Security Center detects compromised resources\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/securityContacts\",\"existenceCondition\":{\"field\":\"\ - Microsoft.Security/securityContacts/phone\",\"notEquals\":\"\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/b4d66858-c922-44e3-9566-5cdb7a7be744\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4d66858-c922-44e3-9566-5cdb7a7be744\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1286 - Telecommunications\ - \ Services | Provider Contingency Plan\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1286\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b4f9b47a-2116-4e6f-88db-4edbf22753f1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4f9b47a-2116-4e6f-88db-4edbf22753f1\"\ - },{\"properties\":{\"displayName\":\"Public network access should be disabled\ - \ for PostgreSQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits PostgreSQL servers in your environment\ - \ with public network access enabled. For more details, visit https://go.microsoft.com/fwlink/?linkid=2120015.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },{\"field\":\"Microsoft.DBforPostgreSQL/servers/publicNetworkAccess\",\"\ - notEquals\":\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b52376f7-9612-48a1-81cd-1ffe4b61032c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b52376f7-9612-48a1-81cd-1ffe4b61032c\"\ - },{\"properties\":{\"displayName\":\"Service Fabric clusters should only use\ - \ Azure Active Directory for client authentication\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Audit usage of client authentication\ - \ only via Azure Active Directory in Service Fabric\",\"metadata\":{\"version\"\ - :\"1.1.0\",\"category\":\"Service Fabric\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"The effect determines what happens when the policy rule is evaluated to\ - \ match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ServiceFabric/clusters\"},{\"anyOf\":[{\"field\":\"Microsoft.ServiceFabric/clusters/azureActiveDirectory.tenantId\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ServiceFabric/clusters/azureActiveDirectory.tenantId\"\ - ,\"equals\":\"\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/b54ed75b-3e1a-44ac-a333-05ba39b99ff0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b54ed75b-3e1a-44ac-a333-05ba39b99ff0\"\ - },{\"properties\":{\"displayName\":\"Deploy Advanced Threat Protection for\ - \ Cosmos DB Accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy enables Advanced Threat Protection across Cosmos\ - \ DB accounts.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Cosmos\ - \ DB\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ - :\"DeployIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DocumentDB/databaseAccounts\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/advancedThreatProtectionSettings\"\ - ,\"name\":\"current\",\"existenceCondition\":{\"field\":\"Microsoft.Security/advancedThreatProtectionSettings/isEnabled\"\ - ,\"equals\":\"true\"},\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/fb1c8493-542b-48eb-b624-b4c8fea62acd\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"cosmosDbAccountName\":{\"\ - type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-01-01\",\"type\"\ - :\"Microsoft.DocumentDB/databaseAccounts/providers/advancedThreatProtectionSettings\"\ - ,\"name\":\"[concat(parameters('cosmosDbAccountName'), '/Microsoft.Security/current')]\"\ - ,\"properties\":{\"isEnabled\":true}}]},\"parameters\":{\"cosmosDbAccountName\"\ - :{\"value\":\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b5f04e03-92a3-4b09-9410-2cc5e5047656\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b5f04e03-92a3-4b09-9410-2cc5e5047656\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in App Services should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Audit enabling of diagnostic logs on the app. This enables you to recreate\ - \ activity trails for investigation purposes if a security incident occurs\ - \ or your network is compromised\",\"metadata\":{\"version\":\"2.0.0\",\"\ - category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"notContains\":\"functionapp\"},{\"field\":\"kind\",\"notContains\"\ - :\"linux\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Web/sites/config/detailedErrorLoggingEnabled\",\"\ - equals\":\"true\"},{\"field\":\"Microsoft.Web/sites/config/httpLoggingEnabled\"\ - ,\"equals\":\"true\"},{\"field\":\"Microsoft.Web/sites/config/requestTracingEnabled\"\ - ,\"equals\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b607c5de-e7d9-4eee-9e5c-83f1bcee4fa0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b607c5de-e7d9-4eee-9e5c-83f1bcee4fa0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1419 - Nonlocal\ - \ Maintenance | Cryptographic Protection\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1419\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b6747bf9-2b97-45b8-b162-3c8becb9937d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b6747bf9-2b97-45b8-b162-3c8becb9937d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1301 - Identification\ - \ And Authentication (Org. Users) | Network Access To Privileged Accounts\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1301\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b6a8e0cc-ac23-468b-abe4-a8a1cc6d7a08\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b6a8e0cc-ac23-468b-abe4-a8a1cc6d7a08\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1568 - Acquisition\ - \ Process\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1568\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b6a8eae8-9854-495a-ac82-d2cd3eac02a6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b6a8eae8-9854-495a-ac82-d2cd3eac02a6\"\ - },{\"properties\":{\"displayName\":\"Network Watcher should be enabled\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Network Watcher\ - \ is a regional service that enables you to monitor and diagnose conditions\ - \ at a network scenario level in, to, and from Azure. Scenario level monitoring\ - \ enables you to diagnose problems at an end to end network level view. Network\ - \ diagnostic and visualization tools available with Network Watcher help you\ - \ understand, diagnose, and gain insights to your network in Azure.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{\"listOfLocations\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Locations\",\"description\"\ - :\"Audit if Network Watcher is not enabled for region(s).\",\"strongType\"\ - :\"location\"}}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"\ - Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"auditIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkWatchers\",\"resourceGroupName\"\ - :\"NetworkWatcherRG\",\"existenceCondition\":{\"field\":\"location\",\"in\"\ - :\"[parameters('listOfLocations')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b6e2945c-0b7b-40f5-9233-7a5323b5cdc6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b6e2945c-0b7b-40f5-9233-7a5323b5cdc6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1608 - Supply\ - \ Chain Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1608\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b73b7b3b-677c-4a2a-b949-ad4dc4acd89f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b73b7b3b-677c-4a2a-b949-ad4dc4acd89f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1401 - Controlled\ - \ Maintenance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1401\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b78ee928-e3c1-4569-ad97-9f8c4b629847\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b78ee928-e3c1-4569-ad97-9f8c4b629847\"\ - },{\"properties\":{\"displayName\":\"API App should only be accessible over\ - \ HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use of HTTPS ensures server/service authentication and protects data in\ - \ transit from network layer eavesdropping attacks.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"*api\"},{\"field\":\"Microsoft.Web/sites/httpsOnly\",\"equals\"\ - :\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/b7ddfbdc-1260-477d-91fd-98bd9be789a6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b7ddfbdc-1260-477d-91fd-98bd9be789a6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs if the Administrators group doesn't contain only specified\ - \ members\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines in which the Administrators group does not contain only the specified\ - \ members. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"Members\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Members\",\"description\":\"A semicolon-separated list of\ - \ all the expected members of the Administrators local group. Ex: Administrator;\ - \ myUser1; myUser2\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembers\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[LocalGroup]AdministratorsGroup;Members', '=',\ - \ parameters('Members')))]\"},\"deployment\":{\"properties\":{\"mode\":\"\ - incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"\ - location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"[field('type')]\"\ - },\"configurationName\":{\"value\":\"AdministratorsGroupMembers\"},\"Members\"\ - :{\"value\":\"[parameters('Members')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"Members\":{\"type\":\"string\"}},\"resources\":[{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;Members\"\ - ,\"value\":\"[parameters('Members')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[LocalGroup]AdministratorsGroup;Members\"\ - ,\"value\":\"[parameters('Members')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b821191b-3a12-44bc-9c38-212138a29ff3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b821191b-3a12-44bc-9c38-212138a29ff3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Accounts'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Accounts'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsAccounts\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b872a447-cc6f-43b9-bccf-45703cd81607\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b872a447-cc6f-43b9-bccf-45703cd81607\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Logic\ - \ Apps to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Deploys the diagnostic settings for Logic Apps\ - \ to stream to a regional Log Analytics workspace when any Logic Apps which\ - \ is missing this diagnostic settings is created or updated.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Logic/workflows\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Logic/workflows/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"WorkflowRuntime\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b889a06c-ec72-4b03-910a-cb169ee18721\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b889a06c-ec72-4b03-910a-cb169ee18721\"\ - },{\"properties\":{\"displayName\":\"An activity log alert should exist for\ - \ specific Administrative operations\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"This policy audits specific Administrative operations\ - \ with no activity log alerts configured.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"operationName\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Operation Name\",\"description\"\ - :\"Administrative Operation name for which activity log alert should be configured\"\ - },\"allowedValues\":[\"Microsoft.Sql/servers/firewallRules/write\",\"Microsoft.Sql/servers/firewallRules/delete\"\ - ,\"Microsoft.Network/networkSecurityGroups/write\",\"Microsoft.Network/networkSecurityGroups/delete\"\ - ,\"Microsoft.ClassicNetwork/networkSecurityGroups/write\",\"Microsoft.ClassicNetwork/networkSecurityGroups/delete\"\ - ,\"Microsoft.Network/networkSecurityGroups/securityRules/write\",\"Microsoft.Network/networkSecurityGroups/securityRules/delete\"\ - ,\"Microsoft.ClassicNetwork/networkSecurityGroups/securityRules/write\",\"\ - Microsoft.ClassicNetwork/networkSecurityGroups/securityRules/delete\"]}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - }]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/ActivityLogAlerts\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/enabled\",\"equals\":\"\ - true\"},{\"count\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]\"\ - ,\"where\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"Administrative\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"[parameters('operationName')]\"}]}]}},\"equals\":2},{\"not\"\ - :{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"}},{\"not\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b954148f-4c11-4c38-8221-be76711e194a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b954148f-4c11-4c38-8221-be76711e194a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1257 - Contingency\ - \ Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1257\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b958b241-4245-4bd6-bd2d-b8f0779fb543\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b958b241-4245-4bd6-bd2d-b8f0779fb543\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1186 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1186\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b95ba3bd-4ded-49ea-9d10-c6f4b680813d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b95ba3bd-4ded-49ea-9d10-c6f4b680813d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1447 - Physical\ - \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1447\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9783a99-98fe-4a95-873f-29613309fe9a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9783a99-98fe-4a95-873f-29613309fe9a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1625 - Boundary\ - \ Protection | Access Points\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1625\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9b66a4d-70a1-4b47-8fa1-289cec68c605\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9b66a4d-70a1-4b47-8fa1-289cec68c605\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1610 - Development\ - \ Process, Standards, And Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1610\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b9f3fb54-4222-46a1-a308-4874061f8491\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9f3fb54-4222-46a1-a308-4874061f8491\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Recovery console'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Recovery console'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsRecoveryconsole\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ba12366f-f9a6-42b8-9d98-157d0b1a837b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ba12366f-f9a6-42b8-9d98-157d0b1a837b\"\ - },{\"properties\":{\"displayName\":\"Azure Machine Learning workspaces should\ - \ be encrypted with a customer-managed key (CMK)\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Evaluate Azure Machine Learning workspaces\ - \ that do not have encryption enabled with customer-managed keys (CMK). Customer-managed\ - \ keys add an aditional layer of security for workspaces. For more information,\ - \ visit https://aka.ms/azureml-workspaces-cmk.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Machine Learning\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.MachineLearningServices/workspaces\"\ - },{\"not\":{\"field\":\"Microsoft.MachineLearningServices/workspaces/encryption.status\"\ - ,\"equals\":\"enabled\"}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ba769a63-b8cc-4b2d-abf6-ac33c7204be8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ba769a63-b8cc-4b2d-abf6-ac33c7204be8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1606 - Developer\ - \ Security Testing And Evaluation | Threat And Vulnerability Analyses\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this System and Services Acquisition control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1606\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/baa8a9a4-5bbe-4c72-98f6-a3a47ae2b1ca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"baa8a9a4-5bbe-4c72-98f6-a3a47ae2b1ca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1726 - Information\ - \ Handling And Retention\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1726\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/baff1279-05e0-4463-9a70-8ba5de4c7aa4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"baff1279-05e0-4463-9a70-8ba5de4c7aa4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1166 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1166\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bb02733d-3cc5-4bb0-a6cd-695ba2c2272e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bb02733d-3cc5-4bb0-a6cd-695ba2c2272e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1188 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1188\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bb20548a-c926-4e4d-855c-bcddc6faf95e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bb20548a-c926-4e4d-855c-bcddc6faf95e\"\ - },{\"properties\":{\"displayName\":\"Non-internet-facing virtual machines\ - \ should be protected with network security groups\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Protect your non-internet-facing virtual\ - \ machines from potential threats by restricting access with network security\ - \ groups (NSG). Learn more about controlling traffic with NSGs at https://aka.ms/nsg-doc\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"a9341235-9389-42f0-a0bf-9bfb57960d44\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bb91dfba-c30d-4263-9add-9c2384e659a6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bb91dfba-c30d-4263-9add-9c2384e659a6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1533 - Third-Party\ - \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1533\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bba2a036-fb3b-4261-b1be-a13dfb5fbcaa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bba2a036-fb3b-4261-b1be-a13dfb5fbcaa\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Microsoft Network\ - \ Client'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Microsoft Network Client'. It also creates a system-assigned managed\ - \ identity and deploys the VM extension for Guest Configuration. This policy\ - \ should only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"MicrosoftNetworkClientDigitallySignCommunicationsAlways\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Microsoft\ - \ network client: Digitally sign communications (always)\",\"description\"\ - :\"Specifies whether packet signing is required by the SMB client component.\"\ - },\"defaultValue\":\"1\"},\"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Microsoft\ - \ network client: Send unencrypted password to third-party SMB servers\",\"\ - description\":\"Specifies whether the SMB redirector will send plaintext passwords\ - \ during authentication to third-party SMB servers that do not support password\ - \ encryption. It is recommended that you disable this policy setting unless\ - \ there is a strong business case to enable it.\"},\"defaultValue\":\"0\"\ - },\"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Microsoft\ - \ network server: Amount of idle time required before suspending session\"\ - ,\"description\":\"Specifies the amount of continuous idle time that must\ - \ pass in an SMB session before the session is suspended because of inactivity.\ - \ The format of the value is two integers separated by a comma, denoting an\ - \ inclusive range.\"},\"defaultValue\":\"1,15\"},\"MicrosoftNetworkServerDigitallySignCommunicationsAlways\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Microsoft\ - \ network server: Digitally sign communications (always)\",\"description\"\ - :\"Specifies whether packet signing is required by the SMB server component.\"\ - },\"defaultValue\":\"1\"},\"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Microsoft\ - \ network server: Disconnect clients when logon hours expire\",\"description\"\ - :\"Specifies whether to disconnect users who are connected to the local computer\ - \ outside their user account's valid logon hours. This setting affects the\ - \ Server Message Block (SMB) component. If you enable this policy setting\ - \ you should also enable 'Network security: Force logoff when logon hours\ - \ expire'\"},\"defaultValue\":\"1\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkClient\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Microsoft network client: Digitally sign communications\ - \ (always);ExpectedValue', '=', parameters('MicrosoftNetworkClientDigitallySignCommunicationsAlways'),\ - \ ',', 'Microsoft network client: Send unencrypted password to third-party\ - \ SMB servers;ExpectedValue', '=', parameters('MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers'),\ - \ ',', 'Microsoft network server: Amount of idle time required before suspending\ - \ session;ExpectedValue', '=', parameters('MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession'),\ - \ ',', 'Microsoft network server: Digitally sign communications (always);ExpectedValue',\ - \ '=', parameters('MicrosoftNetworkServerDigitallySignCommunicationsAlways'),\ - \ ',', 'Microsoft network server: Disconnect clients when logon hours expire;ExpectedValue',\ - \ '=', parameters('MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsMicrosoftNetworkClient\"},\"MicrosoftNetworkClientDigitallySignCommunicationsAlways\"\ - :{\"value\":\"[parameters('MicrosoftNetworkClientDigitallySignCommunicationsAlways')]\"\ - },\"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers\"\ - :{\"value\":\"[parameters('MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers')]\"\ - },\"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession\"\ - :{\"value\":\"[parameters('MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession')]\"\ - },\"MicrosoftNetworkServerDigitallySignCommunicationsAlways\":{\"value\":\"\ - [parameters('MicrosoftNetworkServerDigitallySignCommunicationsAlways')]\"\ - },\"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire\":{\"value\"\ - :\"[parameters('MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"MicrosoftNetworkClientDigitallySignCommunicationsAlways\"\ - :{\"type\":\"string\"},\"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers\"\ - :{\"type\":\"string\"},\"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession\"\ - :{\"type\":\"string\"},\"MicrosoftNetworkServerDigitallySignCommunicationsAlways\"\ - :{\"type\":\"string\"},\"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Microsoft network\ - \ client: Digitally sign communications (always);ExpectedValue\",\"value\"\ - :\"[parameters('MicrosoftNetworkClientDigitallySignCommunicationsAlways')]\"\ - },{\"name\":\"Microsoft network client: Send unencrypted password to third-party\ - \ SMB servers;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers')]\"\ - },{\"name\":\"Microsoft network server: Amount of idle time required before\ - \ suspending session;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession')]\"\ - },{\"name\":\"Microsoft network server: Digitally sign communications (always);ExpectedValue\"\ - ,\"value\":\"[parameters('MicrosoftNetworkServerDigitallySignCommunicationsAlways')]\"\ - },{\"name\":\"Microsoft network server: Disconnect clients when logon hours\ - \ expire;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Microsoft network\ - \ client: Digitally sign communications (always);ExpectedValue\",\"value\"\ - :\"[parameters('MicrosoftNetworkClientDigitallySignCommunicationsAlways')]\"\ - },{\"name\":\"Microsoft network client: Send unencrypted password to third-party\ - \ SMB servers;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers')]\"\ - },{\"name\":\"Microsoft network server: Amount of idle time required before\ - \ suspending session;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession')]\"\ - },{\"name\":\"Microsoft network server: Digitally sign communications (always);ExpectedValue\"\ - ,\"value\":\"[parameters('MicrosoftNetworkServerDigitallySignCommunicationsAlways')]\"\ - },{\"name\":\"Microsoft network server: Disconnect clients when logon hours\ - \ expire;ExpectedValue\",\"value\":\"[parameters('MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bbcdd8fa-b600-4ee3-85b8-d184e3339652\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bbcdd8fa-b600-4ee3-85b8-d184e3339652\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit API Applications\ - \ that are not using latest supported Python Framework\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"Use the latest supported Python\ - \ version for the latest security classes. Using older classes and types can\ - \ make your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestPython\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bc0378bb-d7ab-4614-a0f6-5a6e3f02d644\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bc0378bb-d7ab-4614-a0f6-5a6e3f02d644\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1194 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1194\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bc34667f-397e-4a65-9b72-d0358f0b6b09\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bc34667f-397e-4a65-9b72-d0358f0b6b09\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1095 - Role-Based\ - \ Security Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1095\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bc3f6f7a-057b-433e-9834-e8c97b0194f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bc3f6f7a-057b-433e-9834-e8c97b0194f6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Account Logon'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Account Logon'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesAccountLogon\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bc87d811-4a9b-47cc-ae54-0a41abda7768\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bc87d811-4a9b-47cc-ae54-0a41abda7768\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1427 - Media\ - \ Protection Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Media Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1427\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bc90e44f-d83f-4bdf-900f-3d5eb4111b31\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bc90e44f-d83f-4bdf-900f-3d5eb4111b31\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1351 - Incident\ - \ Response Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Incident Response control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1351\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bcfb6683-05e5-4ce6-9723-c3fbe9896bdd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bcfb6683-05e5-4ce6-9723-c3fbe9896bdd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1050 - Concurrent\ - \ Session Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1050\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bd20184c-b4ec-4ce5-8db6-6e86352d183f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bd20184c-b4ec-4ce5-8db6-6e86352d183f\"\ - },{\"properties\":{\"displayName\":\"IP Forwarding on your virtual machine\ - \ should be disabled\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Enabling IP forwarding on a virtual machine's NIC allows the machine to\ - \ receive traffic addressed to other destinations. IP forwarding is rarely\ - \ required (e.g., when using the VM as a network virtual appliance), and therefore,\ - \ this should be reviewed by the network security team.\",\"metadata\":{\"\ - version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"c3b51c94-588b-426b-a892-24696f9e54cc\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bd352bd5-2853-4985-bf0d-73806b4a5744\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bd352bd5-2853-4985-bf0d-73806b4a5744\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Advanced Threat Protection\ - \ types should be set to 'All' in SQL Managed Instance advanced data security\ - \ settings\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"It's recommended to enable all Advanced Threat Protection types on your\ - \ SQL Managed Instance. Enabling all types protects against SQL injection,\ - \ database vulnerabilities, and any other anomalous activities.\",\"metadata\"\ - :{\"version\":\"1.0.1-deprecated\",\"category\":\"SQL\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"Disabled\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"\ - equals\":\"Microsoft.Sql/managedInstances\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/managedInstances/securityAlertPolicies\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/managedInstances/securityAlertPolicies/disabledAlerts[*]\"\ - ,\"equals\":\"\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bda18df3-5e41-4709-add9-2554ce68c966\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bda18df3-5e41-4709-add9-2554ce68c966\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs if the Administrators group contains any of the specified members\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines in which the Administrators group contains any of the specified\ - \ members. For more information on Guest Configuration policies, please visit\ - \ https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"\ - category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToExclude\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bde62c94-ccca-4821-a815-92c1d31a76de\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bde62c94-ccca-4821-a815-92c1d31a76de\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using latest supported Java Framework\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Use the latest supported Java version\ - \ for the latest security classes. Using older classes and types can make\ - \ your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"app\"},{\"field\":\"kind\",\"equals\":\"WebApp\"},{\"field\":\"kind\",\"\ - equals\":\"app,linux\"},{\"field\":\"kind\",\"equals\":\"app,linux,container\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Security/complianceResults\",\"name\":\"UseLatestJava\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\",\"in\"\ - :[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/be0a7681-bed4-48dc-9ff3-f0171ee170b6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"be0a7681-bed4-48dc-9ff3-f0171ee170b6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1360 - Incident\ - \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1360\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/be5b05e7-0b82-4ebc-9eda-25e447b1a41e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"be5b05e7-0b82-4ebc-9eda-25e447b1a41e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Web Application Firewall\ - \ should be enabled for Azure Front Door Service or Application Gateway\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Requires\ - \ Web Application Firewall on any Azure Front Door Service or Application\ - \ Gateway. A Web Application Firewall provides greater security for your other\ - \ Azure resources.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"Network\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Deny\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/frontdoors\"\ - },{\"field\":\"Microsoft.Network/frontdoors/frontendEndpoints[*].webApplicationFirewallPolicyLink.id\"\ - ,\"exists\":\"false\"}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/applicationGateways\"\ - },{\"field\":\"Microsoft.Network/applicationGateways/webApplicationFirewallConfiguration\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/be7ed5c8-2660-4136-8216-e6f3412ba909\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"be7ed5c8-2660-4136-8216-e6f3412ba909\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that have not\ - \ restarted within the specified number of days\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the WMI property LastBootUpTime in class Win32_Operatingsystem\ - \ is outside the range of days provided by the policy parameter.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"MachineLastBootUpTime\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"NumberOfDays\":\"[MachineUpTime]MachineLastBootUpTime;NumberOfDays\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"NumberOfDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Number of days\",\"\ - description\":\"The number of days without restart until the machine is considered\ - \ non-compliant\"},\"defaultValue\":\"12\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MachineLastBootUpTime\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[MachineUpTime]MachineLastBootUpTime;NumberOfDays',\ - \ '=', parameters('NumberOfDays')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/beb6ccee-b6b8-4e91-9801-a5fa4260a104\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"beb6ccee-b6b8-4e91-9801-a5fa4260a104\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines on which Windows\ - \ Defender Exploit Guard is not enabled\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the PowerShell command Get-MPPreference returns configuration\ - \ details that does not match expected values. Windows Defender Exploit Guard\ - \ helps protect against malware that uses exploits to infect devices and spread.\ - \ Exploit Guard protection consists of a number of mitigations that can be\ - \ applied to either the operating system or individual apps.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.1.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"WindowsDefenderExploitGuard\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"NotAvailableMachineState\"\ - :\"[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"NotAvailableMachineState\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Status if Windows Defender\ - \ is not available on machine\",\"description\":\"Windows Defender Exploit\ - \ Guard is only available starting with Windows 10/Windows Server with update\ - \ 1709. Setting this value to 'Non-Compliant' shows machines with older versions\ - \ on which Windows Defender Exploit Guard is not available (such as Windows\ - \ Server 2012 R2) as non-compliant. Setting this value to 'Compliant' shows\ - \ these machines as compliant.\"},\"allowedValues\":[\"Compliant\",\"Non-Compliant\"\ - ],\"defaultValue\":\"Compliant\"},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - WindowsDefenderExploitGuard\",\"existenceCondition\":{\"allOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsDefenderExploitGuard]WindowsDefenderExploitGuard1;NotAvailableMachineState',\ - \ '=', parameters('NotAvailableMachineState')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bed48b13-6647-468e-aa2f-1af1d3f4dd40\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bed48b13-6647-468e-aa2f-1af1d3f4dd40\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Key Vault\ - \ to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Key Vault to stream\ - \ to a regional Log Analytics workspace when any Key Vault which is missing\ - \ this diagnostic settings is created or updated.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ - :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_logAnalytics\"\ - },\"logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log\ - \ Analytics workspace\",\"description\":\"Select Log Analytics workspace from\ - \ dropdown list. If this workspace is outside of the scope of the assignment\ - \ you must manually grant 'Log Analytics Contributor' permissions (or similar)\ - \ to the policy assignment's principal ID.\",\"strongType\":\"omsWorkspace\"\ - ,\"assignPermissions\":true}},\"metricsEnabled\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Enable metrics\",\"description\":\"Whether to enable metrics\ - \ stream to the Log Analytics workspace - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ - :\"Whether to enable logs stream to the Log Analytics workspace - True or\ - \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"True\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.KeyVault/vaults/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"AuditEvent\",\"enabled\":\"\ - [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bef3f64c-5290-43b7-85b0-9b254eef4c47\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bef3f64c-5290-43b7-85b0-9b254eef4c47\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1152 - System\ - \ Interconnections\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1152\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/beff0acf-7e67-40b2-b1ca-1a0e8205cf1b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"beff0acf-7e67-40b2-b1ca-1a0e8205cf1b\"\ - },{\"properties\":{\"displayName\":\"Geo-redundant storage should be enabled\ - \ for Storage Accounts\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy audits any Storage Account with geo-redundant\ - \ storage not enabled.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Storage\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Storage/storageAccounts\"},{\"not\":{\"field\":\"Microsoft.Storage/storageAccounts/sku.name\"\ - ,\"in\":[\"Standard_GRS\",\"Standard_RAGRS\",\"Standard_GZRS\",\"Standard_RAGZRS\"\ - ]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf045164-79ba-4215-8f95-f8048dc1780b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf045164-79ba-4215-8f95-f8048dc1780b\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not have\ - \ the password complexity setting enabled\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if Windows machines that do not have the password\ - \ complexity setting enabled\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"PasswordMustMeetComplexityRequirements\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\",\"\ - description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - PasswordMustMeetComplexityRequirements\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf16e0bb-31e1-4646-8202-60a235cc7e74\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf16e0bb-31e1-4646-8202-60a235cc7e74\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1590 - External\ - \ Information System Services | Risk Assessments / Organizational Approvals\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Services Acquisition control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1590\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf296b8c-f391-4ea4-9198-be3c9d39dd1f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf296b8c-f391-4ea4-9198-be3c9d39dd1f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1446 - Physical\ - \ And Environmental Protection Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical\ - \ and Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1446\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bf6850fe-abba-468e-9ef4-d09ec7d983cd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bf6850fe-abba-468e-9ef4-d09ec7d983cd\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Logon-Logoff'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Logon-Logoff'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditGroupMembership\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Deprecated]: Audit Group Membership\",\"description\":\"\ - Specifies whether audit events are generated when group memberships are enumerated\ - \ on the client computer.\"},\"allowedValues\":[\"No Auditing\",\"Success\"\ - ,\"Failure\",\"Success and Failure\"],\"defaultValue\":\"Success\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesLogonLogoff\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Group Membership;ExpectedValue', '=',\ - \ parameters('AuditGroupMembership')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SystemAuditPoliciesLogonLogoff\"\ - },\"AuditGroupMembership\":{\"value\":\"[parameters('AuditGroupMembership')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditGroupMembership\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Group Membership;ExpectedValue\"\ - ,\"value\":\"[parameters('AuditGroupMembership')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Group Membership;ExpectedValue\"\ - ,\"value\":\"[parameters('AuditGroupMembership')]\"}]}}},{\"condition\":\"\ - [equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c04255ee-1b9f-42c1-abaa-bf1553f79930\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c04255ee-1b9f-42c1-abaa-bf1553f79930\"\ - },{\"properties\":{\"displayName\":\"Only approved VM extensions should be\ - \ installed\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy governs the virtual machine extensions that are not approved.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Compute\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"The effect determines what happens when the policy rule\ - \ is evaluated to match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"},\"approvedExtensions\":{\"type\":\"Array\",\"\ - metadata\":{\"description\":\"The list of approved extension types that can\ - \ be installed. Example: AzureDiskEncryption\",\"displayName\":\"Approved\ - \ extensions\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines/extensions\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"notIn\":\"[parameters('approvedExtensions')]\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c0e996f8-39cf-4af9-9f45-83fbde810432\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c0e996f8-39cf-4af9-9f45-83fbde810432\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1124 - Audit\ - \ Reduction And Report Generation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1124\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c10152dd-78f8-4335-ae2d-ad92cc028da4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c10152dd-78f8-4335-ae2d-ad92cc028da4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1676 - Malicious\ - \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1676\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c10fb58b-56a8-489e-9ce3-7ffe24e78e4b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c10fb58b-56a8-489e-9ce3-7ffe24e78e4b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1719 - Spam\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1719\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c13da9b4-fe14-4fe2-853a-5997c9d4215a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c13da9b4-fe14-4fe2-853a-5997c9d4215a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1226 - Information\ - \ System Component Inventory | Automated Unauthorized Component Detection\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1226\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c158eb1c-ae7e-4081-8057-d527140c4e0c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c158eb1c-ae7e-4081-8057-d527140c4e0c\"\ - },{\"properties\":{\"displayName\":\"Deploy associations for a custom provider\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Deploys\ - \ an association resource that associates selected resource types to the specified\ - \ custom provider. This policy deployment does not support nested resource\ - \ types.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Custom Provider\"\ - },\"parameters\":{\"targetCustomProviderId\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Custom provider ID\",\"description\":\"Resource ID of\ - \ the Custom provider to which resources need to be associated.\"}},\"resourceTypesToAssociate\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Resource types to associate\"\ - ,\"description\":\"The list of resource types to be associated to the custom\ - \ provider.\",\"strongType\":\"resourceTypes\"}},\"associationNamePrefix\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Association name prefix\"\ - ,\"description\":\"Prefix to be added to the name of the association resource\ - \ being created.\"},\"defaultValue\":\"DeployedByPolicy\"}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"in\":\"[parameters('resourceTypesToAssociate')]\"\ - },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.CustomProviders/Associations\"\ - ,\"name\":\"[concat(parameters('associationNamePrefix'), '-', uniqueString(parameters('targetCustomProviderId')))]\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"associatedResourceName\"\ - :{\"type\":\"string\"},\"resourceTypesToAssociate\":{\"type\":\"string\"},\"\ - targetCustomProviderId\":{\"type\":\"string\"},\"associationNamePrefix\":{\"\ - type\":\"string\"}},\"variables\":{\"resourceType\":\"[concat(parameters('resourceTypesToAssociate'),\ - \ '/providers/associations')]\",\"resourceName\":\"[concat(parameters('associatedResourceName'),\ - \ '/microsoft.customproviders/', parameters('associationNamePrefix'), '-',\ - \ uniqueString(parameters('targetCustomProviderId')))]\"},\"resources\":[{\"\ - type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2017-05-10\",\"\ - name\":\"[concat(deployment().Name, '-2')]\",\"properties\":{\"mode\":\"Incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"type\":\"[variables('resourceType')]\"\ - ,\"name\":\"[variables('resourceName')]\",\"apiVersion\":\"2018-09-01-preview\"\ - ,\"properties\":{\"targetResourceId\":\"[parameters('targetCustomProviderId')]\"\ - }}]}}}]},\"parameters\":{\"resourceTypesToAssociate\":{\"value\":\"[field('type')]\"\ - },\"associatedResourceName\":{\"value\":\"[field('name')]\"},\"targetCustomProviderId\"\ - :{\"value\":\"[parameters('targetCustomProviderId')]\"},\"associationNamePrefix\"\ - :{\"value\":\"[parameters('associationNamePrefix')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c15c281f-ea5c-44cd-90b8-fc3c14d13f0c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c15c281f-ea5c-44cd-90b8-fc3c14d13f0c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1629 - Boundary\ - \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1629\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c171b095-7756-41de-8644-a062a96043f2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c171b095-7756-41de-8644-a062a96043f2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1004 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1004\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c17822dc-736f-4eb4-a97d-e6be662ff835\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c17822dc-736f-4eb4-a97d-e6be662ff835\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ only in Asia data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Allows resource creation in the following locations only:\ - \ East Asia, Southeast Asia, West India, South India, Central India, Japan\ - \ East, Japan West\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"General\",\"deprecated\":true},\"parameters\":{},\"policyRule\":{\"if\"\ - :{\"not\":{\"field\":\"location\",\"in\":[\"eastasia\",\"southeastasia\",\"\ - westindia\",\"southindia\",\"centralindia\",\"japaneast\",\"japanwest\"]}},\"\ - then\":{\"effect\":\"Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c1b9cbed-08e3-427d-b9ce-7c535b1e9b94\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c1b9cbed-08e3-427d-b9ce-7c535b1e9b94\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Account Logon'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Account Logon'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditCredentialValidation\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Audit Credential Validation\",\"description\"\ - :\"Specifies whether audit events are generated when credentials are submitted\ - \ for a user account logon request. This setting is especially useful for\ - \ monitoring unsuccessful attempts, to find brute-force attacks, account enumeration,\ - \ and potential account compromise events on domain controllers.\"},\"allowedValues\"\ - :[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"],\"defaultValue\"\ - :\"Success and Failure\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesAccountLogon\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Credential Validation;ExpectedValue',\ - \ '=', parameters('AuditCredentialValidation')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SystemAuditPoliciesAccountLogon\"\ - },\"AuditCredentialValidation\":{\"value\":\"[parameters('AuditCredentialValidation')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditCredentialValidation\":{\"type\":\"string\"\ - }},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Credential\ - \ Validation;ExpectedValue\",\"value\":\"[parameters('AuditCredentialValidation')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Credential\ - \ Validation;ExpectedValue\",\"value\":\"[parameters('AuditCredentialValidation')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c1e289c0-ffad-475d-a924-adc058765d65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c1e289c0-ffad-475d-a924-adc058765d65\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1503 - Information\ - \ Security Architecture\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Planning control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1503\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c1fa9c2f-d439-4ab9-8b83-81fb1934f81d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c1fa9c2f-d439-4ab9-8b83-81fb1934f81d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that are not set to the specified time zone\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines that are\ - \ not set to the specified time zone. It also creates a system-assigned managed\ - \ identity and deploys the VM extension for Guest Configuration. This policy\ - \ should only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"TimeZone\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Time zone\",\"description\":\"The expected time zone\"},\"\ - allowedValues\":[\"(UTC-12:00) International Date Line West\",\"(UTC-11:00)\ - \ Coordinated Universal Time-11\",\"(UTC-10:00) Aleutian Islands\",\"(UTC-10:00)\ - \ Hawaii\",\"(UTC-09:30) Marquesas Islands\",\"(UTC-09:00) Alaska\",\"(UTC-09:00)\ - \ Coordinated Universal Time-09\",\"(UTC-08:00) Baja California\",\"(UTC-08:00)\ - \ Coordinated Universal Time-08\",\"(UTC-08:00) Pacific Time (US & Canada)\"\ - ,\"(UTC-07:00) Arizona\",\"(UTC-07:00) Chihuahua, La Paz, Mazatlan\",\"(UTC-07:00)\ - \ Mountain Time (US & Canada)\",\"(UTC-06:00) Central America\",\"(UTC-06:00)\ - \ Central Time (US & Canada)\",\"(UTC-06:00) Easter Island\",\"(UTC-06:00)\ - \ Guadalajara, Mexico City, Monterrey\",\"(UTC-06:00) Saskatchewan\",\"(UTC-05:00)\ - \ Bogota, Lima, Quito, Rio Branco\",\"(UTC-05:00) Chetumal\",\"(UTC-05:00)\ - \ Eastern Time (US & Canada)\",\"(UTC-05:00) Haiti\",\"(UTC-05:00) Havana\"\ - ,\"(UTC-05:00) Indiana (East)\",\"(UTC-05:00) Turks and Caicos\",\"(UTC-04:00)\ - \ Asuncion\",\"(UTC-04:00) Atlantic Time (Canada)\",\"(UTC-04:00) Caracas\"\ - ,\"(UTC-04:00) Cuiaba\",\"(UTC-04:00) Georgetown, La Paz, Manaus, San Juan\"\ - ,\"(UTC-04:00) Santiago\",\"(UTC-03:30) Newfoundland\",\"(UTC-03:00) Araguaina\"\ - ,\"(UTC-03:00) Brasilia\",\"(UTC-03:00) Cayenne, Fortaleza\",\"(UTC-03:00)\ - \ City of Buenos Aires\",\"(UTC-03:00) Greenland\",\"(UTC-03:00) Montevideo\"\ - ,\"(UTC-03:00) Punta Arenas\",\"(UTC-03:00) Saint Pierre and Miquelon\",\"\ - (UTC-03:00) Salvador\",\"(UTC-02:00) Coordinated Universal Time-02\",\"(UTC-02:00)\ - \ Mid-Atlantic - Old\",\"(UTC-01:00) Azores\",\"(UTC-01:00) Cabo Verde Is.\"\ - ,\"(UTC) Coordinated Universal Time\",\"(UTC+00:00) Dublin, Edinburgh, Lisbon,\ - \ London\",\"(UTC+00:00) Monrovia, Reykjavik\",\"(UTC+00:00) Sao Tome\",\"\ - (UTC+01:00) Casablanca\",\"(UTC+01:00) Amsterdam, Berlin, Bern, Rome, Stockholm,\ - \ Vienna\",\"(UTC+01:00) Belgrade, Bratislava, Budapest, Ljubljana, Prague\"\ - ,\"(UTC+01:00) Brussels, Copenhagen, Madrid, Paris\",\"(UTC+01:00) Sarajevo,\ - \ Skopje, Warsaw, Zagreb\",\"(UTC+01:00) West Central Africa\",\"(UTC+02:00)\ - \ Amman\",\"(UTC+02:00) Athens, Bucharest\",\"(UTC+02:00) Beirut\",\"(UTC+02:00)\ - \ Cairo\",\"(UTC+02:00) Chisinau\",\"(UTC+02:00) Damascus\",\"(UTC+02:00)\ - \ Gaza, Hebron\",\"(UTC+02:00) Harare, Pretoria\",\"(UTC+02:00) Helsinki,\ - \ Kyiv, Riga, Sofia, Tallinn, Vilnius\",\"(UTC+02:00) Jerusalem\",\"(UTC+02:00)\ - \ Kaliningrad\",\"(UTC+02:00) Khartoum\",\"(UTC+02:00) Tripoli\",\"(UTC+02:00)\ - \ Windhoek\",\"(UTC+03:00) Baghdad\",\"(UTC+03:00) Istanbul\",\"(UTC+03:00)\ - \ Kuwait, Riyadh\",\"(UTC+03:00) Minsk\",\"(UTC+03:00) Moscow, St. Petersburg\"\ - ,\"(UTC+03:00) Nairobi\",\"(UTC+03:30) Tehran\",\"(UTC+04:00) Abu Dhabi, Muscat\"\ - ,\"(UTC+04:00) Astrakhan, Ulyanovsk\",\"(UTC+04:00) Baku\",\"(UTC+04:00) Izhevsk,\ - \ Samara\",\"(UTC+04:00) Port Louis\",\"(UTC+04:00) Saratov\",\"(UTC+04:00)\ - \ Tbilisi\",\"(UTC+04:00) Volgograd\",\"(UTC+04:00) Yerevan\",\"(UTC+04:30)\ - \ Kabul\",\"(UTC+05:00) Ashgabat, Tashkent\",\"(UTC+05:00) Ekaterinburg\"\ - ,\"(UTC+05:00) Islamabad, Karachi\",\"(UTC+05:00) Qyzylorda\",\"(UTC+05:30)\ - \ Chennai, Kolkata, Mumbai, New Delhi\",\"(UTC+05:30) Sri Jayawardenepura\"\ - ,\"(UTC+05:45) Kathmandu\",\"(UTC+06:00) Astana\",\"(UTC+06:00) Dhaka\",\"\ - (UTC+06:00) Omsk\",\"(UTC+06:30) Yangon (Rangoon)\",\"(UTC+07:00) Bangkok,\ - \ Hanoi, Jakarta\",\"(UTC+07:00) Barnaul, Gorno-Altaysk\",\"(UTC+07:00) Hovd\"\ - ,\"(UTC+07:00) Krasnoyarsk\",\"(UTC+07:00) Novosibirsk\",\"(UTC+07:00) Tomsk\"\ - ,\"(UTC+08:00) Beijing, Chongqing, Hong Kong, Urumqi\",\"(UTC+08:00) Irkutsk\"\ - ,\"(UTC+08:00) Kuala Lumpur, Singapore\",\"(UTC+08:00) Perth\",\"(UTC+08:00)\ - \ Taipei\",\"(UTC+08:00) Ulaanbaatar\",\"(UTC+08:45) Eucla\",\"(UTC+09:00)\ - \ Chita\",\"(UTC+09:00) Osaka, Sapporo, Tokyo\",\"(UTC+09:00) Pyongyang\"\ - ,\"(UTC+09:00) Seoul\",\"(UTC+09:00) Yakutsk\",\"(UTC+09:30) Adelaide\",\"\ - (UTC+09:30) Darwin\",\"(UTC+10:00) Brisbane\",\"(UTC+10:00) Canberra, Melbourne,\ - \ Sydney\",\"(UTC+10:00) Guam, Port Moresby\",\"(UTC+10:00) Hobart\",\"(UTC+10:00)\ - \ Vladivostok\",\"(UTC+10:30) Lord Howe Island\",\"(UTC+11:00) Bougainville\ - \ Island\",\"(UTC+11:00) Chokurdakh\",\"(UTC+11:00) Magadan\",\"(UTC+11:00)\ - \ Norfolk Island\",\"(UTC+11:00) Sakhalin\",\"(UTC+11:00) Solomon Is., New\ - \ Caledonia\",\"(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky\",\"(UTC+12:00)\ - \ Auckland, Wellington\",\"(UTC+12:00) Coordinated Universal Time+12\",\"\ - (UTC+12:00) Fiji\",\"(UTC+12:00) Petropavlovsk-Kamchatsky - Old\",\"(UTC+12:45)\ - \ Chatham Islands\",\"(UTC+13:00) Coordinated Universal Time+13\",\"(UTC+13:00)\ - \ Nuku'alofa\",\"(UTC+13:00) Samoa\",\"(UTC+14:00) Kiritimati Island\"]}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsTimeZone\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsTimeZone]WindowsTimeZone1;TimeZone',\ - \ '=', parameters('TimeZone')))]\"},\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsTimeZone\"},\"\ - TimeZone\":{\"value\":\"[parameters('TimeZone')]\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"TimeZone\":{\"type\":\"string\"}},\"resources\":[{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsTimeZone]WindowsTimeZone1;TimeZone\"\ - ,\"value\":\"[parameters('TimeZone')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[WindowsTimeZone]WindowsTimeZone1;TimeZone\"\ - ,\"value\":\"[parameters('TimeZone')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c21f7060-c148-41cf-a68b-0ab3e14c764c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c21f7060-c148-41cf-a68b-0ab3e14c764c\"\ - },{\"properties\":{\"displayName\":\"Flow log should be configured for every\ - \ network security group\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Audit for network security groups to verify if flow log\ - \ resource is configured. Flow log allows to log information about IP traffic\ - \ flowing through network security group. It can be used for optimizing network\ - \ flows, monitoring throughput, verifying compliance, detecting intrusions\ - \ and more.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Network\"\ - },\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"count\":{\"field\":\"Microsoft.Network/networkSecurityGroups/flowLogs[*]\"\ - },\"equals\":0}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c251913d-7d24-4958-af87-478ed3b9ba41\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c251913d-7d24-4958-af87-478ed3b9ba41\"\ - },{\"properties\":{\"displayName\":\"Advanced threat protection should be\ - \ enabled on Azure Container Registry registries\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Advanced threat protection provides scanning\ - \ of container registries for security vulnerabilities on each pushed container\ - \ image and exposes detailed findings per image.\",\"metadata\":{\"version\"\ - :\"1.0.2\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/pricings\",\"name\":\"ContainerRegistry\",\"existenceScope\"\ - :\"subscription\",\"existenceCondition\":{\"field\":\"Microsoft.Security/pricings/pricingTier\"\ - ,\"equals\":\"Standard\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c25d9a16-bc35-4e15-a7e5-9db606bf9ed4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c25d9a16-bc35-4e15-a7e5-9db606bf9ed4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs on which the specified services are not installed and 'Running'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines on which the specified services are not installed and 'Running'.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsServiceStatus\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c2dd2a9a-8a20-4a9c-b8d6-f17ccc26939a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c2dd2a9a-8a20-4a9c-b8d6-f17ccc26939a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that '.NET Framework'\ - \ version is the latest, if used as a part of the API app\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy is not required\ - \ since Azure App Service automatically updates and maintains the .NET Framework\ - \ versions installed on the platform.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"App Service\",\"deprecated\":true},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.netFrameworkVersion\"\ - ,\"in\":[\"v3.0\",\"v4.0\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c2e7ca55-f62c-49b2-89a4-d41eb661d2f0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c2e7ca55-f62c-49b2-89a4-d41eb661d2f0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1176 - Baseline\ - \ Configuration\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1176\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c30690a5-7bf3-467f-b0cd-ef5c7c7449cd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c30690a5-7bf3-467f-b0cd-ef5c7c7449cd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1389 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1389\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c39e6fda-ae70-4891-a739-be7bba6d1062\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c39e6fda-ae70-4891-a739-be7bba6d1062\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1390 - Information\ - \ Spillage Response | Responsible Personnel\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident Response\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1390\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c3b65b63-09ec-4cb5-8028-7dd324d10eb0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c3b65b63-09ec-4cb5-8028-7dd324d10eb0\"\ - },{\"properties\":{\"displayName\":\"System updates on virtual machine scale\ - \ sets should be installed\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Audit whether there are any missing system security updates\ - \ and critical updates that should be installed to ensure that your Windows\ - \ and Linux virtual machine scale sets are secure.\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"bd20bd91-aaf1-7f14-b6e4-866de2f43146\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c3f317a7-a95c-4547-b7e7-11017ebdf2fe\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c3f317a7-a95c-4547-b7e7-11017ebdf2fe\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Linux VMs that have accounts without passwords\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"This policy should only be used along\ - \ with its corresponding deploy policy in an initiative. This definition allows\ - \ Azure Policy to process the results of auditing Linux virtual machines that\ - \ have accounts without passwords. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"3.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"qubole-inc\"\ - ,\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid232\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c40c9087-1981-4e73-9f53-39743eda9d05\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c40c9087-1981-4e73-9f53-39743eda9d05\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1220 - Least\ - \ Functionality | Authorized Software / Whitelisting\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1220\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c40f31a7-81e1-4130-99e5-a02ceea2a1d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c40f31a7-81e1-4130-99e5-a02ceea2a1d6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1513 - Personnel\ - \ Screening | Information With Special Protection Measures\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Personnel Security control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1513\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c416970d-b12b-49eb-8af4-fb144cd7c290\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c416970d-b12b-49eb-8af4-fb144cd7c290\"\ - },{\"properties\":{\"displayName\":\"Microsoft Antimalware for Azure should\ - \ be configured to automatically update protection signatures\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy audits any\ - \ Windows virtual machine not configured with automatic update of Microsoft\ - \ Antimalware protection signatures.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Compute\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"equals\":\"Windows\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ - existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"IaaSAntimalware\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Security\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/autoUpgradeMinorVersion\"\ - ,\"equals\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c43e4a30-77cb-48ab-a4dd-93f175c63b57\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c43e4a30-77cb-48ab-a4dd-93f175c63b57\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Container Registry should\ - \ use a virtual network service endpoint\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"This policy audits any Container Registry not\ - \ configured to use a virtual network service endpoint.\",\"metadata\":{\"\ - version\":\"1.0.0-preview\",\"category\":\"Network\",\"preview\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerRegistry/registries\"},{\"anyOf\":[{\"field\":\"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction\"\ - ,\"notEquals\":\"Deny\"},{\"field\":\"Microsoft.ContainerRegistry/registries/networkRuleSet.virtualNetworkRules[*].action\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c4857be7-912a-4c75-87e6-e30292bcdf78\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c4857be7-912a-4c75-87e6-e30292bcdf78\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1235 - Software\ - \ Usage Restrictions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1235\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c49c610b-ece4-44b3-988c-2172b70d6e46\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c49c610b-ece4-44b3-988c-2172b70d6e46\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1173 - Internal\ - \ System Connections\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1173\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c4aff9e7-2e60-46fa-86be-506b79033fc5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c4aff9e7-2e60-46fa-86be-506b79033fc5\"\ - },{\"properties\":{\"displayName\":\"Managed identity should be used in your\ - \ API App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Use a managed identity for enhanced authentication security\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c4d441f8-f9d9-4a9e-9cef-e82117cb3eef\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c4d441f8-f9d9-4a9e-9cef-e82117cb3eef\"\ - },{\"properties\":{\"displayName\":\"Authentication should be enabled on your\ - \ API app\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Azure App Service Authentication is a feature that can prevent anonymous\ - \ HTTP requests from reaching the API app, or authenticate those that have\ - \ tokens before they reach the API app\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/siteAuthEnabled\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c4ebc54a-46e1-481a-bee2-d4411e95d828\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c4ebc54a-46e1-481a-bee2-d4411e95d828\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1600 - Developer\ - \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1600\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c53f3123-d233-44a7-930b-f40d3bfeb7d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c53f3123-d233-44a7-930b-f40d3bfeb7d6\"\ - },{\"properties\":{\"displayName\":\"An activity log alert should exist for\ - \ specific Policy operations\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"This policy audits specific Policy operations with no activity\ - \ log alerts configured.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"},\"operationName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Operation Name\",\"description\":\"Policy\ - \ Operation name for which activity log alert should exist\"},\"allowedValues\"\ - :[\"Microsoft.Authorization/policyAssignments/write\",\"Microsoft.Authorization/policyAssignments/delete\"\ - ]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - }]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/ActivityLogAlerts\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/enabled\",\"equals\":\"\ - true\"},{\"count\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*]\"\ - ,\"where\":{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"Policy\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"},{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].equals\"\ - ,\"equals\":\"[parameters('operationName')]\"}]}]}},\"equals\":2},{\"not\"\ - :{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"category\"}},{\"not\":{\"field\":\"Microsoft.Insights/ActivityLogAlerts/condition.allOf[*].field\"\ - ,\"equals\":\"operationName\"}}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c5447c04-a4d7-4ba8-a263-c9ee321a6858\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c5447c04-a4d7-4ba8-a263-c9ee321a6858\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that have the\ - \ specified applications installed\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Requires that prerequisites are deployed to the\ - \ policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the application name is found in any of the following\ - \ registry paths: HKLM:SOFTWARE\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\ - \\Uninstall, HKLM:SOFTWARE\\\\Wow6432node\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\ - \\Uninstall, HKCU:Software\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Uninstall.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"NotInstalledApplicationForWindows\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"ApplicationName\":\"[InstalledApplication]NotInstalledApplicationResource1;Name\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ApplicationName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Application names (supports\ - \ wildcards)\",\"description\":\"A semicolon-separated list of the names of\ - \ the applications that should not be installed. e.g. 'Microsoft SQL Server\ - \ 2014 (64-bit); Microsoft Visual Studio Code' or 'Microsoft SQL Server 2014*'\ - \ (to match any application starting with 'Microsoft SQL Server 2014')\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"NotInstalledApplicationForWindows\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[InstalledApplication]NotInstalledApplicationResource1;Name',\ - \ '=', parameters('ApplicationName')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c5b85cba-6e6f-4de4-95e1-f0233cd712ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c5b85cba-6e6f-4de4-95e1-f0233cd712ac\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1408 - Maintenance\ - \ Tools | Prevent Unauthorized Removal\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1408\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c5f56ac6-4bb2-4086-bc41-ad76344ba2c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c5f56ac6-4bb2-4086-bc41-ad76344ba2c2\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that contain certificates expiring within the specified\ - \ number of days\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines that contain certificates expiring within the specified number\ - \ of days. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"CertificateStorePath\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Deprecated]: Certificate store path\",\"description\":\"\ - The path to the certificate store containing the certificates to check the\ - \ expiration dates of. Default value is 'Cert:' which is the root certificate\ - \ store path, so all certificates on the machine will be checked. Other example\ - \ paths: 'Cert:\\\\LocalMachine', 'Cert:\\\\LocalMachine\\\\TrustedPublisher',\ - \ 'Cert:\\\\CurrentUser'\"},\"defaultValue\":\"Cert:\"},\"ExpirationLimitInDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Expiration\ - \ limit in days\",\"description\":\"An integer indicating the number of days\ - \ within which to check for certificates that are expiring. For example, if\ - \ this value is 30, any certificate expiring within the next 30 days will\ - \ cause this policy to be non-compliant.\"},\"defaultValue\":\"30\"},\"CertificateThumbprintsToInclude\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Certificate\ - \ thumbprints to include\",\"description\":\"A semicolon-separated list of\ - \ certificate thumbprints to check under the specified path. If a value is\ - \ not specified, all certificates under the certificate store path will be\ - \ checked. If a value is specified, no certificates other than those with\ - \ the thumbprints specified will be checked. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"\ - },\"defaultValue\":\"\"},\"CertificateThumbprintsToExclude\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Certificate thumbprints\ - \ to exclude\",\"description\":\"A semicolon-separated list of certificate\ - \ thumbprints to ignore. e.g. THUMBPRINT1;THUMBPRINT2;THUMBPRINT3\"},\"defaultValue\"\ - :\"\"},\"IncludeExpiredCertificates\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Deprecated]: Include expired certificates\",\"description\"\ - :\"Must be 'true' or 'false'. True indicates that any found certificates that\ - \ have already expired will also make this policy non-compliant. False indicates\ - \ that certificates that have expired will be be ignored.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"}},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"CertificateExpiration\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[CertificateStore]CertificateStore1;CertificateStorePath',\ - \ '=', parameters('CertificateStorePath'), ',', '[CertificateStore]CertificateStore1;ExpirationLimitInDays',\ - \ '=', parameters('ExpirationLimitInDays'), ',', '[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude',\ - \ '=', parameters('CertificateThumbprintsToInclude'), ',', '[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude',\ - \ '=', parameters('CertificateThumbprintsToExclude'), ',', '[CertificateStore]CertificateStore1;IncludeExpiredCertificates',\ - \ '=', parameters('IncludeExpiredCertificates')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"CertificateExpiration\"\ - },\"CertificateStorePath\":{\"value\":\"[parameters('CertificateStorePath')]\"\ - },\"ExpirationLimitInDays\":{\"value\":\"[parameters('ExpirationLimitInDays')]\"\ - },\"CertificateThumbprintsToInclude\":{\"value\":\"[parameters('CertificateThumbprintsToInclude')]\"\ - },\"CertificateThumbprintsToExclude\":{\"value\":\"[parameters('CertificateThumbprintsToExclude')]\"\ - },\"IncludeExpiredCertificates\":{\"value\":\"[parameters('IncludeExpiredCertificates')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"CertificateStorePath\":{\"type\":\"string\"},\"ExpirationLimitInDays\"\ - :{\"type\":\"string\"},\"CertificateThumbprintsToInclude\":{\"type\":\"string\"\ - },\"CertificateThumbprintsToExclude\":{\"type\":\"string\"},\"IncludeExpiredCertificates\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[CertificateStore]CertificateStore1;CertificateStorePath\"\ - ,\"value\":\"[parameters('CertificateStorePath')]\"},{\"name\":\"[CertificateStore]CertificateStore1;ExpirationLimitInDays\"\ - ,\"value\":\"[parameters('ExpirationLimitInDays')]\"},{\"name\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"\ - ,\"value\":\"[parameters('CertificateThumbprintsToInclude')]\"},{\"name\"\ - :\"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude\",\"\ - value\":\"[parameters('CertificateThumbprintsToExclude')]\"},{\"name\":\"\ - [CertificateStore]CertificateStore1;IncludeExpiredCertificates\",\"value\"\ - :\"[parameters('IncludeExpiredCertificates')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[CertificateStore]CertificateStore1;CertificateStorePath\"\ - ,\"value\":\"[parameters('CertificateStorePath')]\"},{\"name\":\"[CertificateStore]CertificateStore1;ExpirationLimitInDays\"\ - ,\"value\":\"[parameters('ExpirationLimitInDays')]\"},{\"name\":\"[CertificateStore]CertificateStore1;CertificateThumbprintsToInclude\"\ - ,\"value\":\"[parameters('CertificateThumbprintsToInclude')]\"},{\"name\"\ - :\"[CertificateStore]CertificateStore1;CertificateThumbprintsToExclude\",\"\ - value\":\"[parameters('CertificateThumbprintsToExclude')]\"},{\"name\":\"\ - [CertificateStore]CertificateStore1;IncludeExpiredCertificates\",\"value\"\ - :\"[parameters('IncludeExpiredCertificates')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c5fbc59e-fb6f-494f-81e2-d99a671bdaa8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c5fbc59e-fb6f-494f-81e2-d99a671bdaa8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1670 - Flaw\ - \ Remediation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1670\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c6108469-57ee-4666-af7e-79ba61c7ae0c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c6108469-57ee-4666-af7e-79ba61c7ae0c\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that are not set\ - \ to the specified time zone\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Requires that prerequisites are deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol. Machines are\ - \ non-compliant if the value of the property StandardName in WMI class Win32_TimeZone\ - \ does not match the selected time zone for the policy parameter.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"WindowsTimeZone\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"TimeZone\":\"[WindowsTimeZone]WindowsTimeZone1;TimeZone\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"TimeZone\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Time zone\",\"description\"\ - :\"The expected time zone\"},\"allowedValues\":[\"(UTC-12:00) International\ - \ Date Line West\",\"(UTC-11:00) Coordinated Universal Time-11\",\"(UTC-10:00)\ - \ Aleutian Islands\",\"(UTC-10:00) Hawaii\",\"(UTC-09:30) Marquesas Islands\"\ - ,\"(UTC-09:00) Alaska\",\"(UTC-09:00) Coordinated Universal Time-09\",\"(UTC-08:00)\ - \ Baja California\",\"(UTC-08:00) Coordinated Universal Time-08\",\"(UTC-08:00)\ - \ Pacific Time (US & Canada)\",\"(UTC-07:00) Arizona\",\"(UTC-07:00) Chihuahua,\ - \ La Paz, Mazatlan\",\"(UTC-07:00) Mountain Time (US & Canada)\",\"(UTC-06:00)\ - \ Central America\",\"(UTC-06:00) Central Time (US & Canada)\",\"(UTC-06:00)\ - \ Easter Island\",\"(UTC-06:00) Guadalajara, Mexico City, Monterrey\",\"(UTC-06:00)\ - \ Saskatchewan\",\"(UTC-05:00) Bogota, Lima, Quito, Rio Branco\",\"(UTC-05:00)\ - \ Chetumal\",\"(UTC-05:00) Eastern Time (US & Canada)\",\"(UTC-05:00) Haiti\"\ - ,\"(UTC-05:00) Havana\",\"(UTC-05:00) Indiana (East)\",\"(UTC-05:00) Turks\ - \ and Caicos\",\"(UTC-04:00) Asuncion\",\"(UTC-04:00) Atlantic Time (Canada)\"\ - ,\"(UTC-04:00) Caracas\",\"(UTC-04:00) Cuiaba\",\"(UTC-04:00) Georgetown,\ - \ La Paz, Manaus, San Juan\",\"(UTC-04:00) Santiago\",\"(UTC-03:30) Newfoundland\"\ - ,\"(UTC-03:00) Araguaina\",\"(UTC-03:00) Brasilia\",\"(UTC-03:00) Cayenne,\ - \ Fortaleza\",\"(UTC-03:00) City of Buenos Aires\",\"(UTC-03:00) Greenland\"\ - ,\"(UTC-03:00) Montevideo\",\"(UTC-03:00) Punta Arenas\",\"(UTC-03:00) Saint\ - \ Pierre and Miquelon\",\"(UTC-03:00) Salvador\",\"(UTC-02:00) Coordinated\ - \ Universal Time-02\",\"(UTC-02:00) Mid-Atlantic - Old\",\"(UTC-01:00) Azores\"\ - ,\"(UTC-01:00) Cabo Verde Is.\",\"(UTC) Coordinated Universal Time\",\"(UTC+00:00)\ - \ Dublin, Edinburgh, Lisbon, London\",\"(UTC+00:00) Monrovia, Reykjavik\"\ - ,\"(UTC+00:00) Sao Tome\",\"(UTC+01:00) Casablanca\",\"(UTC+01:00) Amsterdam,\ - \ Berlin, Bern, Rome, Stockholm, Vienna\",\"(UTC+01:00) Belgrade, Bratislava,\ - \ Budapest, Ljubljana, Prague\",\"(UTC+01:00) Brussels, Copenhagen, Madrid,\ - \ Paris\",\"(UTC+01:00) Sarajevo, Skopje, Warsaw, Zagreb\",\"(UTC+01:00) West\ - \ Central Africa\",\"(UTC+02:00) Amman\",\"(UTC+02:00) Athens, Bucharest\"\ - ,\"(UTC+02:00) Beirut\",\"(UTC+02:00) Cairo\",\"(UTC+02:00) Chisinau\",\"\ - (UTC+02:00) Damascus\",\"(UTC+02:00) Gaza, Hebron\",\"(UTC+02:00) Harare,\ - \ Pretoria\",\"(UTC+02:00) Helsinki, Kyiv, Riga, Sofia, Tallinn, Vilnius\"\ - ,\"(UTC+02:00) Jerusalem\",\"(UTC+02:00) Kaliningrad\",\"(UTC+02:00) Khartoum\"\ - ,\"(UTC+02:00) Tripoli\",\"(UTC+02:00) Windhoek\",\"(UTC+03:00) Baghdad\"\ - ,\"(UTC+03:00) Istanbul\",\"(UTC+03:00) Kuwait, Riyadh\",\"(UTC+03:00) Minsk\"\ - ,\"(UTC+03:00) Moscow, St. Petersburg\",\"(UTC+03:00) Nairobi\",\"(UTC+03:30)\ - \ Tehran\",\"(UTC+04:00) Abu Dhabi, Muscat\",\"(UTC+04:00) Astrakhan, Ulyanovsk\"\ - ,\"(UTC+04:00) Baku\",\"(UTC+04:00) Izhevsk, Samara\",\"(UTC+04:00) Port Louis\"\ - ,\"(UTC+04:00) Saratov\",\"(UTC+04:00) Tbilisi\",\"(UTC+04:00) Volgograd\"\ - ,\"(UTC+04:00) Yerevan\",\"(UTC+04:30) Kabul\",\"(UTC+05:00) Ashgabat, Tashkent\"\ - ,\"(UTC+05:00) Ekaterinburg\",\"(UTC+05:00) Islamabad, Karachi\",\"(UTC+05:00)\ - \ Qyzylorda\",\"(UTC+05:30) Chennai, Kolkata, Mumbai, New Delhi\",\"(UTC+05:30)\ - \ Sri Jayawardenepura\",\"(UTC+05:45) Kathmandu\",\"(UTC+06:00) Astana\",\"\ - (UTC+06:00) Dhaka\",\"(UTC+06:00) Omsk\",\"(UTC+06:30) Yangon (Rangoon)\"\ - ,\"(UTC+07:00) Bangkok, Hanoi, Jakarta\",\"(UTC+07:00) Barnaul, Gorno-Altaysk\"\ - ,\"(UTC+07:00) Hovd\",\"(UTC+07:00) Krasnoyarsk\",\"(UTC+07:00) Novosibirsk\"\ - ,\"(UTC+07:00) Tomsk\",\"(UTC+08:00) Beijing, Chongqing, Hong Kong, Urumqi\"\ - ,\"(UTC+08:00) Irkutsk\",\"(UTC+08:00) Kuala Lumpur, Singapore\",\"(UTC+08:00)\ - \ Perth\",\"(UTC+08:00) Taipei\",\"(UTC+08:00) Ulaanbaatar\",\"(UTC+08:45)\ - \ Eucla\",\"(UTC+09:00) Chita\",\"(UTC+09:00) Osaka, Sapporo, Tokyo\",\"(UTC+09:00)\ - \ Pyongyang\",\"(UTC+09:00) Seoul\",\"(UTC+09:00) Yakutsk\",\"(UTC+09:30)\ - \ Adelaide\",\"(UTC+09:30) Darwin\",\"(UTC+10:00) Brisbane\",\"(UTC+10:00)\ - \ Canberra, Melbourne, Sydney\",\"(UTC+10:00) Guam, Port Moresby\",\"(UTC+10:00)\ - \ Hobart\",\"(UTC+10:00) Vladivostok\",\"(UTC+10:30) Lord Howe Island\",\"\ - (UTC+11:00) Bougainville Island\",\"(UTC+11:00) Chokurdakh\",\"(UTC+11:00)\ - \ Magadan\",\"(UTC+11:00) Norfolk Island\",\"(UTC+11:00) Sakhalin\",\"(UTC+11:00)\ - \ Solomon Is., New Caledonia\",\"(UTC+12:00) Anadyr, Petropavlovsk-Kamchatsky\"\ - ,\"(UTC+12:00) Auckland, Wellington\",\"(UTC+12:00) Coordinated Universal\ - \ Time+12\",\"(UTC+12:00) Fiji\",\"(UTC+12:00) Petropavlovsk-Kamchatsky -\ - \ Old\",\"(UTC+12:45) Chatham Islands\",\"(UTC+13:00) Coordinated Universal\ - \ Time+13\",\"(UTC+13:00) Nuku'alofa\",\"(UTC+13:00) Samoa\",\"(UTC+14:00)\ - \ Kiritimati Island\"]}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsTimeZone\",\"existenceCondition\":{\"allOf\":[{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsTimeZone]WindowsTimeZone1;TimeZone',\ - \ '=', parameters('TimeZone')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c633f6a2-7f8b-4d9e-9456-02f0f04f5505\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c633f6a2-7f8b-4d9e-9456-02f0f04f5505\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not have\ - \ the specified Windows PowerShell execution policy\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if the Windows PowerShell command Get-ExecutionPolicy\ - \ returns a value other than what was selected in the policy parameter.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"WindowsPowerShellExecutionPolicy\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"ExecutionPolicy\":\"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ExecutionPolicy\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"PowerShell Execution\ - \ Policy\",\"description\":\"The expected PowerShell execution policy.\"},\"\ - allowedValues\":[\"AllSigned\",\"Bypass\",\"Default\",\"RemoteSigned\",\"\ - Restricted\",\"Undefined\",\"Unrestricted\"]},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - WindowsPowerShellExecutionPolicy\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy',\ - \ '=', parameters('ExecutionPolicy')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c648fbbb-591c-4acd-b465-ce9b176ca173\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c648fbbb-591c-4acd-b465-ce9b176ca173\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1190 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1190\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c66a3d1e-465b-4f28-9da5-aef701b59892\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c66a3d1e-465b-4f28-9da5-aef701b59892\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1120 - Audit\ - \ Review, Analysis, And Reporting | Integration / Scanning And Monitoring\ - \ Capabilities\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1120\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c69b870e-857b-458b-af02-bb234f7a00d3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c69b870e-857b-458b-af02-bb234f7a00d3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1125 - Audit\ - \ Reduction And Report Generation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Audit and Accountability\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1125\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c6ce745a-670e-47d3-a6c4-3cfe5ef00c10\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c6ce745a-670e-47d3-a6c4-3cfe5ef00c10\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy Diagnostic Settings\ - \ for Recovery Services Vault to Log Analytics workspace for resource specific\ - \ categories.\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploy Diagnostic Settings for Recovery Services Vault to stream to Log\ - \ Analytics workspace for Resource specific categories. If any of the Resource\ - \ specific categories are not enabled, a new diagnostic setting is created.\"\ - ,\"metadata\":{\"version\":\"1.0.1-preview\",\"preview\":true,\"category\"\ - :\"Backup\"},\"parameters\":{\"profileName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Profile name\",\"description\":\"The diagnostic\ - \ settings profile name\"},\"defaultValue\":\"setbypolicy_logAnalytics\"},\"\ - logAnalytics\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Log Analytics workspace\",\"description\":\"Select Log Analytics workspace\ - \ from dropdown list. If this workspace is outside of the scope of the assignment\ - \ you must manually grant 'Log Analytics Contributor' permissions (or similar)\ - \ to the policy assignment's principal ID.\",\"strongType\":\"omsWorkspace\"\ - ,\"assignPermissions\":true}},\"tagName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Exclusion Tag Name\",\"description\":\"Name\ - \ of the tag to use for excluding vaults from this policy. This should be\ - \ used along with the Exclusion Tag Value parameter.\"},\"defaultValue\":\"\ - \"},\"tagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Exclusion Tag Value\",\"description\":\"Value of the tag to use for excluding\ - \ vaults from this policy. This should be used along with the Exclusion Tag\ - \ Name parameter.\"},\"defaultValue\":\"\"}},\"policyRule\":{\"if\":{\"allof\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.RecoveryServices/vaults\"},{\"\ - not\":{\"field\":\"[concat('tags[',parameters('tagName'), ']')]\",\"equals\"\ - :\"[parameters('tagValue')]\"}}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\",\"existenceCondition\"\ - :{\"allof\":[{\"count\":{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\"\ - ,\"where\":{\"allof\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].Category\"\ - ,\"in\":[\"CoreAzureBackup\",\"AddonAzureBackupJobs\",\"AddonAzureBackupAlerts\"\ - ,\"AddonAzureBackupPolicy\",\"AddonAzureBackupStorage\",\"AddonAzureBackupProtectedInstance\"\ - ]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].Enabled\",\"\ - equals\":\"True\"}]}},\"Equals\":6},{\"field\":\"Microsoft.Insights/diagnosticSettings/workspaceId\"\ - ,\"notEquals\":\"\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logAnalyticsDestinationType\"\ - ,\"equals\":\"Dedicated\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vaultName\":{\"type\":\"\ - string\"},\"logAnalytics\":{\"type\":\"string\"},\"profileName\":{\"type\"\ - :\"string\"}},\"variables\":{},\"resources\":[{\"type\":\"Microsoft.RecoveryServices/vaults/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('vaultName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"dependsOn\"\ - :[],\"properties\":{\"workspaceId\":\"[parameters('logAnalytics')]\",\"logAnalyticsDestinationType\"\ - :\"Dedicated\",\"metrics\":[],\"logs\":[{\"category\":\"CoreAzureBackup\"\ - ,\"enabled\":\"true\"},{\"category\":\"AddonAzureBackupAlerts\",\"enabled\"\ - :\"true\"},{\"category\":\"AddonAzureBackupJobs\",\"enabled\":\"true\"},{\"\ - category\":\"AddonAzureBackupPolicy\",\"enabled\":\"true\"},{\"category\"\ - :\"AddonAzureBackupProtectedInstance\",\"enabled\":\"true\"},{\"category\"\ - :\"AddonAzureBackupStorage\",\"enabled\":\"true\"}]}}],\"outputs\":{\"policy\"\ - :{\"type\":\"string\",\"value\":\"[concat(parameters('logAnalytics'), 'configured\ - \ for diagnostic logs for ', ': ', parameters('vaultName'), '/', 'Microsoft.Insights/',\ - \ parameters('profileName'))]\"}}},\"parameters\":{\"logAnalytics\":{\"value\"\ - :\"[parameters('logAnalytics')]\"},\"vaultName\":{\"value\":\"[field('name')]\"\ - },\"profileName\":{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/c717fb0c-d118-4c43-ab3d-ece30ac81fb3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c717fb0c-d118-4c43-ab3d-ece30ac81fb3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1619 - Information\ - \ In Shared Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1619\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c722e569-cb52-45f3-a643-836547d016e1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c722e569-cb52-45f3-a643-836547d016e1\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1121 - Audit\ - \ Review, Analysis, And Reporting | Correlation With Physical Monitoring\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Audit and Accountability control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1121\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c72b0eb9-1fc2-44e5-a866-e7cb0532f7c1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c72b0eb9-1fc2-44e5-a866-e7cb0532f7c1\"\ - },{\"properties\":{\"displayName\":\"Authentication should be enabled on your\ - \ Function app\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Azure App Service Authentication is a feature that can prevent anonymous\ - \ HTTP requests from reaching the Function app, or authenticate those that\ - \ have tokens before they reach the Function app\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"\ - field\":\"kind\",\"equals\":\"functionapp\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/siteAuthEnabled\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c75248c1-ea1d-4a9c-8fc9-29a6aabd5da8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c75248c1-ea1d-4a9c-8fc9-29a6aabd5da8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1353 - Incident\ - \ Response Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1353\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c785ad59-f78f-44ad-9a7f-d1202318c748\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c785ad59-f78f-44ad-9a7f-d1202318c748\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Email notifications to\ - \ admins should be enabled in SQL server advanced data security settings\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Audit that\ - \ 'email notification to admins and subscription owners' is enabled in the\ - \ SQL server advanced threat protection settings. This ensures that any detections\ - \ of anomalous activities on SQL server are reported as soon as possible to\ - \ the admins.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\"\ - :\"SQL\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"\ - Enable or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"Disabled\"}},\"policyRule\":{\"if\":{\"\ - field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/emailAccountAdmins\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c8343d2f-fdc9-4a97-b76f-fc71d1163bfc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c8343d2f-fdc9-4a97-b76f-fc71d1163bfc\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Batch\ - \ Account to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Deploys the diagnostic settings for Batch Account\ - \ to stream to a regional Log Analytics workspace when any Batch Account which\ - \ is missing this diagnostic settings is created or updated.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Batch/batchAccounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"ServiceLog\",\"enabled\":\"\ - [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"logAnalytics\":{\"value\":\"[parameters('logAnalytics')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c84e5349-db6d-4769-805e-e14037dab9b5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c84e5349-db6d-4769-805e-e14037dab9b5\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: API App should only be\ - \ accessible over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Use of HTTPS ensures server/service authentication and protects data in\ - \ transit from network layer eavesdropping attacks.\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"\ - field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\"\ - :\"kind\",\"equals\":\"api\"},{\"field\":\"kind\",\"equals\":\"apiApp\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"OnlyHttpsForApiApp\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c85538c1-b527-4ce4-bdb4-1dabcb3fd90d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c85538c1-b527-4ce4-bdb4-1dabcb3fd90d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1470 - Emergency\ - \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1470\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c89ba09f-2e0f-44d0-8095-65b05bd151ef\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c89ba09f-2e0f-44d0-8095-65b05bd151ef\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Interactive Logon'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Interactive Logon'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsInteractiveLogon\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c8abcef9-fc26-482f-b8db-5fa60ee4586d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c8abcef9-fc26-482f-b8db-5fa60ee4586d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1018 - Account\ - \ Management | Role-Based Schemes\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1018\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c9121abf-e698-4ee9-b1cf-71ee528ff07f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c9121abf-e698-4ee9-b1cf-71ee528ff07f\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Data Lake Analytics\ - \ should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Data Lake\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DataLakeAnalytics/accounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c95c74d9-38fe-4f0d-af86-0c7d626a315c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c95c74d9-38fe-4f0d-af86-0c7d626a315c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'User Rights Assignment'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'User Rights Assignment'.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_UserRightsAssignment\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c961dac9-5916-42e8-8fb1-703148323994\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c961dac9-5916-42e8-8fb1-703148323994\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs with a pending reboot\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"This policy creates a Guest Configuration\ - \ assignment to audit Windows virtual machines with a pending reboot. It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPendingReboot\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsPendingReboot\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c96f3246-4382-4264-bf6b-af0b35e23c3c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c96f3246-4382-4264-bf6b-af0b35e23c3c\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Network\ - \ Security Groups\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy automatically deploys diagnostic settings to network security\ - \ groups. A storage account with name '{storagePrefixParameter}{NSGLocation}'\ - \ will be automatically created.\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Monitoring\"},\"parameters\":{\"storagePrefix\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Storage Account Prefix for Regional\ - \ Storage Account\",\"description\":\"This prefix will be combined with the\ - \ network security group location to form the created storage account name.\"\ - }},\"rgName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Resource\ - \ Group Name for Storage Account (must exist)\",\"description\":\"The resource\ - \ group that the storage account will be created in. This resource group must\ - \ already exist.\",\"strongType\":\"ExistingResourceGroups\"}}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"setbypolicy\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ - string\"},\"storagePrefix\":{\"type\":\"string\"},\"nsgName\":{\"type\":\"\ - string\"},\"rgName\":{\"type\":\"string\"}},\"variables\":{\"storageDeployName\"\ - :\"[concat('policyStorage_', uniqueString(parameters('location'), parameters('nsgName')))]\"\ - },\"resources\":[{\"type\":\"Microsoft.Network/networkSecurityGroups/providers/diagnosticSettings\"\ - ,\"name\":\"[concat(parameters('nsgName'),'/Microsoft.Insights/setbypolicy')]\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"location\":\"[parameters('location')]\"\ - ,\"dependsOn\":[\"[variables('storageDeployName')]\"],\"properties\":{\"storageAccountId\"\ - :\"[reference(variables('storageDeployName')).outputs.storageAccountId.value]\"\ - ,\"logs\":[{\"category\":\"NetworkSecurityGroupEvent\",\"enabled\":true,\"\ - retentionPolicy\":{\"enabled\":false,\"days\":0}},{\"category\":\"NetworkSecurityGroupRuleCounter\"\ - ,\"enabled\":true,\"retentionPolicy\":{\"enabled\":false,\"days\":0}}]}},{\"\ - apiVersion\":\"2017-05-10\",\"name\":\"[variables('storageDeployName')]\"\ - ,\"type\":\"Microsoft.Resources/deployments\",\"resourceGroup\":\"[parameters('rgName')]\"\ - ,\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"location\":{\"\ - value\":\"[parameters('location')]\"},\"storagePrefix\":{\"value\":\"[parameters('storagePrefix')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"location\":{\"type\":\"\ - string\"},\"storagePrefix\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ - :\"2017-06-01\",\"type\":\"Microsoft.Storage/storageAccounts\",\"name\":\"\ - [concat(parameters('storageprefix'), parameters('location'))]\",\"sku\":{\"\ - name\":\"Standard_LRS\",\"tier\":\"Standard\"},\"kind\":\"Storage\",\"location\"\ - :\"[parameters('location')]\",\"tags\":{\"created-by\":\"policy\"},\"scale\"\ - :null,\"properties\":{\"networkAcls\":{\"bypass\":\"AzureServices\",\"defaultAction\"\ - :\"Allow\",\"ipRules\":[],\"virtualNetworkRules\":[]},\"supportsHttpsTrafficOnly\"\ - :true}}],\"outputs\":{\"storageAccountId\":{\"type\":\"string\",\"value\"\ - :\"[resourceId(parameters('rgName'), 'Microsoft.Storage/storageAccounts',concat(parameters('storagePrefix'),\ - \ parameters('location')))]\"}}}}}]},\"parameters\":{\"location\":{\"value\"\ - :\"[field('location')]\"},\"storagePrefix\":{\"value\":\"[parameters('storagePrefix')]\"\ - },\"rgName\":{\"value\":\"[parameters('rgName')]\"},\"nsgName\":{\"value\"\ - :\"[field('name')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c9c29499-c1d1-4195-99bd-2ec9e3a9dc89\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c9c29499-c1d1-4195-99bd-2ec9e3a9dc89\"\ - },{\"properties\":{\"displayName\":\"Storage accounts should allow access\ - \ from trusted Microsoft services\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Some Microsoft services that interact with storage\ - \ accounts operate from networks that can't be granted access through network\ - \ rules. To help this type of service work as intended, allow the set of trusted\ - \ Microsoft services to bypass the network rules. These services will then\ - \ use strong authentication to access the storage account.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Storage\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"The effect determines what happens when the policy rule is evaluated to\ - \ match\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Storage/storageAccounts\"},{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.bypass\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Storage/storageAccounts/networkAcls.bypass\"\ - ,\"notContains\":\"AzureServices\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c9d007d0-c057-4772-b18c-01e546713bcd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c9d007d0-c057-4772-b18c-01e546713bcd\"\ - },{\"properties\":{\"displayName\":\"App Configuration should use a private\ - \ link\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - Private endpoint connections allow clients on a virtual network to securely\ - \ access Azure App Configuration over a private link.\",\"metadata\":{\"version\"\ - :\"1.0.1\",\"category\":\"App Configuration\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.AppConfiguration/configurationStores\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.AppConfiguration/configurationStores/privateEndpointConnections\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.AppConfiguration/configurationStores/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ca610c1d-041c-4332-9d88-7ed3094967c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ca610c1d-041c-4332-9d88-7ed3094967c7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1035 - Least\ - \ Privilege | Authorize Access To Security Functions\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1035\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ca94b046-45e2-444f-a862-dc8ce262a516\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ca94b046-45e2-444f-a862-dc8ce262a516\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1243 - Contingency\ - \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Contingency Planning control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1243\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ca9a4469-d6df-4ab2-a42f-1213c396f0ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ca9a4469-d6df-4ab2-a42f-1213c396f0ec\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Microsoft Network Server'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Microsoft Network\ - \ Server' for disabling SMB v1 server. This policy requires that the Guest\ - \ Configuration prerequisites have been deployed to the policy assignment\ - \ scope. For details, visit https://aka.ms/gcpol.\",\"metadata\":{\"category\"\ - :\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkServer\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\",\"\ - description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsMicrosoftNetworkServer\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/caf2d518-f029-4f6b-833b-d7081702f253\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"caf2d518-f029-4f6b-833b-d7081702f253\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1306 - Identification\ - \ And Authentication (Org. Users) | Net. Access To Priv. Accts. - Replay\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Identification and Authentication control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1306\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cafc6c3c-5fc5-4c5e-a99b-a0ccb1d34eff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cafc6c3c-5fc5-4c5e-a99b-a0ccb1d34eff\"\ - },{\"properties\":{\"displayName\":\"Remote debugging should be turned off\ - \ for Web Applications\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Remote debugging requires inbound ports to be opened on a\ - \ web application. Remote debugging should be turned off.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Web/sites/config/web.remoteDebuggingEnabled\",\"equals\"\ - :\"false\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cb510bfd-1cba-4d9f-a230-cb0976f4bb71\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cb510bfd-1cba-4d9f-a230-cb0976f4bb71\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1486 - Alternate\ - \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1486\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cb790345-a51f-43de-934e-98dbfaf9dca5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cb790345-a51f-43de-934e-98dbfaf9dca5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1167 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1167\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cbb2be76-4891-430b-95a7-ca0b0a3d1300\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cbb2be76-4891-430b-95a7-ca0b0a3d1300\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1374 - Incident\ - \ Response Assistance\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Incident Response control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1374\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cc5c8616-52ef-4e5e-8000-491634ed9249\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cc5c8616-52ef-4e5e-8000-491634ed9249\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs if the Administrators group doesn't contain only specified members\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines in which the Administrators group does not contain only\ - \ the specified members. For more information on Guest Configuration policies,\ - \ please visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembers\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cc7cda28-f867-4311-8497-a526129a8d19\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cc7cda28-f867-4311-8497-a526129a8d19\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Sensitive data in your SQL\ - \ databases should be classified\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Azure Security Center monitors the data discovery\ - \ and classification scan results for your SQL databases and provides recommendations\ - \ to classify the sensitive data in your databases for better monitoring and\ - \ security\",\"metadata\":{\"version\":\"2.0.0-preview\",\"category\":\"Security\ - \ Center\",\"preview\":true},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"Microsoft.Sql/servers/databases\",\"Microsoft.Sql/managedInstances/databases\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"b0df6f56-862d-4730-8597-38c0fd4ebd59\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cc9835f2-9f6b-4cc8-ab4a-f8ef615eb349\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cc9835f2-9f6b-4cc8-ab4a-f8ef615eb349\"\ - },{\"properties\":{\"displayName\":\"Allowed virtual machine size SKUs\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ enables you to specify a set of virtual machine size SKUs that your organization\ - \ can deploy.\",\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Compute\"\ - },\"parameters\":{\"listOfAllowedSKUs\":{\"type\":\"Array\",\"metadata\":{\"\ - description\":\"The list of size SKUs that can be specified for virtual machines.\"\ - ,\"displayName\":\"Allowed Size SKUs\",\"strongType\":\"VMSKUs\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"not\":{\"field\":\"Microsoft.Compute/virtualMachines/sku.name\",\"in\"\ - :\"[parameters('listOfAllowedSKUs')]\"}}]},\"then\":{\"effect\":\"Deny\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/cccc23c7-8427-4f53-ad12-b6a63eb452b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cccc23c7-8427-4f53-ad12-b6a63eb452b3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1443 - Media\ - \ Use\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1443\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd0ec6fa-a2e7-4361-aee4-a8688659a9ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd0ec6fa-a2e7-4361-aee4-a8688659a9ed\"\ - },{\"properties\":{\"displayName\":\"Inherit a tag from the resource group\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Adds or\ - \ replaces the specified tag and value from the parent resource group when\ - \ any resource is created or updated. Existing resources can be remediated\ - \ by triggering a remediation task.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Name of the tag,\ - \ such as 'environment'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"notEquals\":\"[resourceGroup().tags[parameters('tagName')]]\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagName')]]\",\"notEquals\"\ - :\"\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[resourceGroup().tags[parameters('tagName')]]\"\ - }]}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd3aa116-8754-49c9-a813-ad46512ece54\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd3aa116-8754-49c9-a813-ad46512ece54\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ if 'department' tag set\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Allows resource creation only if the 'department' tag is\ - \ set\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Tags\"\ - ,\"deprecated\":true},\"parameters\":{},\"policyRule\":{\"if\":{\"not\":{\"\ - field\":\"tags\",\"containsKey\":\"department\"}},\"then\":{\"effect\":\"\ - Deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd8dc879-a2ae-43c3-8211-1877c5755064\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd8dc879-a2ae-43c3-8211-1877c5755064\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1582 - Information\ - \ System Documentation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1582\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cd9e2f38-259b-462c-bfad-0ad7ab4e65c5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cd9e2f38-259b-462c-bfad-0ad7ab4e65c5\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that allow re-use of the previous 24 passwords\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ that allow re-use of the previous 24 passwords. For more information on\ - \ Guest Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"EnforcePasswordHistory\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cdbf72d9-ac9c-4026-8a3a-491a5ac59293\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cdbf72d9-ac9c-4026-8a3a-491a5ac59293\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1104 - Audit\ - \ Events\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1104\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cdd8d244-18b2-4306-a1d1-df175ae0935f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cdd8d244-18b2-4306-a1d1-df175ae0935f\"\ - },{\"properties\":{\"displayName\":\"Deploy export to Event Hub for Azure\ - \ Security Center alerts and recommendations\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Enable export to Event Hub of Azure Security\ - \ Center alerts and/or recommendations. This policy deploys an export to Event\ - \ Hub configuration with your conditions and target Event Hub on the assigned\ - \ scope. To deploy this policy on newly created subscriptions, open the Compliance\ - \ tab, select the relevant non-compliant assignment and create a remediation\ - \ task.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"\ - },\"parameters\":{\"resourceGroupName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Resource group name\",\"description\":\"The resource group\ - \ name where the export to Event Hub configuration is created. If you enter\ - \ a name for a resource group that doesn't exist, it'll be created in the\ - \ subscription. Note that each resource group can only have one export to\ - \ Event Hub configured.\"}},\"resourceGroupLocation\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Resource group location\",\"description\"\ - :\"The location where the resource group and the export to Event Hub configuration\ - \ are created.\",\"strongType\":\"location\"}},\"exportedDataTypes\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Exported data types\",\"description\"\ - :\"The data types to be exported. Example: Security recommendations;Security\ - \ alerts;\"},\"allowedValues\":[\"Security recommendations\",\"Security alerts\"\ - ],\"defaultValue\":[\"Security recommendations\",\"Security alerts\"]},\"\ - recommendationNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ - Recommendation IDs\",\"description\":\"Applicable only for export of security\ - \ recommendations. To export all recommendations, leave this empty. To export\ - \ specific recommendations, enter a list of recommendation IDs separated by\ - \ semicolons (';'). Recommendation IDs are available through the Assessments\ - \ API (https://docs.microsoft.com/rest/api/securitycenter/assessments), or\ - \ Azure Resource Graph Explorer (https://portal.azure.com/#blade/HubsExtension/ArgQueryBlade),\ - \ choose securityresources and microsoft.security/assessments.\"},\"defaultValue\"\ - :[]},\"recommendationSeverities\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Recommendation severities\",\"description\":\"Applicable only for export\ - \ of security recommendations. Determines recommendation severities. Example:\ - \ High;Medium;Low;\"},\"allowedValues\":[\"High\",\"Medium\",\"Low\"],\"defaultValue\"\ - :[\"High\",\"Medium\",\"Low\"]},\"alertSeverities\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Alert severities\",\"description\":\"Applicable\ - \ only for export of security alerts. Determines alert severities. Example:\ - \ High;Medium;Low;\"},\"allowedValues\":[\"High\",\"Medium\",\"Low\"],\"defaultValue\"\ - :[\"High\",\"Medium\",\"Low\"]},\"eventHubDetails\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Event Hub details\",\"description\":\"The Event\ - \ Hub details of where the data should be exported to: Subscription, Event\ - \ Hub Namespace, Event Hub, and Authorizations rules with 'Send' claim. If\ - \ you do not already have an event hub, visit Event Hubs to create one (https://portal.azure.com/#blade/HubsExtension/BrowseResource/resourceType/Microsoft.EventHub%2Fnamespaces).\"\ - ,\"strongType\":\"Microsoft.EventHub/namespaces/eventhubs/authorizationrules\"\ - ,\"assignPermissions\":true}}},\"policyRule\":{\"if\":{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"\ - deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Security/automations\"\ - ,\"name\":\"exportToEventHub\",\"existenceScope\":\"resourcegroup\",\"ResourceGroupName\"\ - :\"[parameters('resourceGroupName')]\",\"deploymentScope\":\"subscription\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"location\":\"westeurope\",\"properties\":{\"mode\":\"\ - incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceGroupName\":{\"\ - type\":\"string\"},\"resourceGroupLocation\":{\"type\":\"string\"},\"exportedDataTypes\"\ - :{\"type\":\"array\"},\"recommendationNames\":{\"type\":\"array\"},\"recommendationSeverities\"\ - :{\"type\":\"array\"},\"alertSeverities\":{\"type\":\"array\"},\"eventHubDetails\"\ - :{\"type\":\"string\"},\"guidValue\":{\"type\":\"string\",\"defaultValue\"\ - :\"[newGuid()]\"}},\"variables\":{\"scopeDescription\":\"scope for subscription\ - \ {0}\",\"recommendationNamesLength\":\"[length(parameters('recommendationNames'))]\"\ - ,\"recommendationSeveritiesLength\":\"[length(parameters('recommendationSeverities'))]\"\ - ,\"alertSeveritiesLength\":\"[length(parameters('alertSeverities'))]\",\"\ - recommendationNamesLengthIfEmpty\":\"[if(equals(variables('recommendationNamesLength'),\ - \ 0), 1, variables('recommendationNamesLength'))]\",\"recommendationSeveritiesLengthIfEmpty\"\ - :\"[if(equals(variables('recommendationSeveritiesLength'), 0), 1, variables('recommendationSeveritiesLength'))]\"\ - ,\"alertSeveritiesLengthIfEmpty\":\"[if(equals(variables('alertSeveritiesLength'),\ - \ 0), 1, variables('alertSeveritiesLength'))]\",\"totalRuleCombinationsForOneRecommendationName\"\ - :\"[variables('recommendationSeveritiesLengthIfEmpty')]\",\"totalRuleCombinationsForOneRecommendationSeverity\"\ - :1,\"exportedDataTypesLength\":\"[length(parameters('exportedDataTypes'))]\"\ - ,\"exportedDataTypesLengthIfEmpty\":\"[if(equals(variables('exportedDataTypesLength'),\ - \ 0), 1, variables('exportedDataTypesLength'))]\",\"SeperatedEventHubDetails\"\ - :\"[split(parameters('eventHubDetails'),'/')]\",\"dataTypeMap\":{\"Security\ - \ recommendations\":\"Assessments\",\"Security alerts\":\"Alerts\"},\"alertSeverityMap\"\ - :{\"High\":\"high\",\"Medium\":\"medium\",\"Low\":\"low\"},\"ruleSetsForAssessmentsObj\"\ - :{\"copy\":[{\"name\":\"ruleSetsForAssessmentsArr\",\"count\":\"[mul(variables('recommendationNamesLengthIfEmpty'),variables('recommendationSeveritiesLengthIfEmpty'))]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"[if(equals(variables('recommendationNamesLength'),0),'type','name')]\"\ - ,\"propertyType\":\"string\",\"expectedValue\":\"[if(equals(variables('recommendationNamesLength'),0),'Microsoft.Security/assessments',parameters('recommendationNames')[mod(div(copyIndex('ruleSetsForAssessmentsArr'),variables('totalRuleCombinationsForOneRecommendationName')),variables('recommendationNamesLength'))])]\"\ - ,\"operator\":\"Contains\"},{\"propertyJPath\":\"properties.metadata.severity\"\ - ,\"propertyType\":\"string\",\"expectedValue\":\"[parameters('recommendationSeverities')[mod(div(copyIndex('ruleSetsForAssessmentsArr'),variables('totalRuleCombinationsForOneRecommendationSeverity')),variables('recommendationSeveritiesLength'))]]\"\ - ,\"operator\":\"Equals\"}]}}]},\"ruleSetsForAlertsObj\":{\"copy\":[{\"name\"\ - :\"ruleSetsForAlertsArr\",\"count\":\"[variables('alertSeveritiesLengthIfEmpty')]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"Severity\",\"propertyType\":\"\ - string\",\"expectedValue\":\"[variables('alertSeverityMap')[parameters('alertSeverities')[mod(copyIndex('ruleSetsForAlertsArr'),variables('alertSeveritiesLengthIfEmpty'))]]]\"\ - ,\"operator\":\"Equals\"}]}}]}},\"resources\":[{\"name\":\"[parameters('resourceGroupName')]\"\ - ,\"type\":\"Microsoft.Resources/resourceGroups\",\"apiVersion\":\"2019-10-01\"\ - ,\"location\":\"[parameters('resourceGroupLocation')]\",\"tags\":{},\"properties\"\ - :{}},{\"type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2019-10-01\"\ - ,\"name\":\"[concat('nestedAutomationDeployment', '_', parameters('guidValue'))]\"\ - ,\"resourceGroup\":\"[parameters('resourceGroupName')]\",\"dependsOn\":[\"\ - [resourceId('Microsoft.Resources/resourceGroups/', parameters('resourceGroupName'))]\"\ - ],\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ - :[{\"tags\":{},\"apiVersion\":\"2019-01-01-preview\",\"location\":\"[parameters('resourceGroupLocation')]\"\ - ,\"name\":\"exportToEventHub\",\"type\":\"Microsoft.Security/automations\"\ - ,\"dependsOn\":[],\"properties\":{\"description\":\"Export Azure Security\ - \ Center alerts and/or recommendations to Event Hub via policy\",\"isEnabled\"\ - :true,\"scopes\":[{\"description\":\"[replace(variables('scopeDescription'),'{0}',\ - \ subscription().subscriptionId)]\",\"scopePath\":\"[subscription().id]\"\ - }],\"copy\":[{\"name\":\"sources\",\"count\":\"[variables('exportedDataTypesLengthIfEmpty')]\"\ - ,\"input\":{\"eventSource\":\"[variables('dataTypeMap')[parameters('exportedDataTypes')[copyIndex('sources')]]]\"\ - ,\"ruleSets\":\"[if(equals(parameters('exportedDataTypes')[copyIndex('sources')],\ - \ 'Security recommendations'), variables('ruleSetsForAssessmentsObj').ruleSetsForAssessmentsArr,\ - \ variables('ruleSetsForAlertsObj').ruleSetsForAlertsArr)]\"}}],\"actions\"\ - :[{\"actionType\":\"EventHub\",\"eventHubResourceId\":\"[concat('/', variables('SeperatedEventHubDetails')[1],\ - \ '/', variables('SeperatedEventHubDetails')[2], '/', variables('SeperatedEventHubDetails')[3],\ - \ '/', variables('SeperatedEventHubDetails')[4], '/', variables('SeperatedEventHubDetails')[5],\ - \ '/', variables('SeperatedEventHubDetails')[6], '/', variables('SeperatedEventHubDetails')[7],\ - \ '/', variables('SeperatedEventHubDetails')[8], '/', variables('SeperatedEventHubDetails')[9],\ - \ '/', variables('SeperatedEventHubDetails')[10])]\",\"connectionString\"\ - :\"[listkeys(parameters('eventHubDetails'),'2017-04-01').primaryConnectionString]\"\ - }]}}]}}}]},\"parameters\":{\"resourceGroupName\":{\"value\":\"[parameters('resourceGroupName')]\"\ - },\"resourceGroupLocation\":{\"value\":\"[parameters('resourceGroupLocation')]\"\ - },\"exportedDataTypes\":{\"value\":\"[parameters('exportedDataTypes')]\"},\"\ - recommendationNames\":{\"value\":\"[parameters('recommendationNames')]\"},\"\ - recommendationSeverities\":{\"value\":\"[parameters('recommendationSeverities')]\"\ - },\"alertSeverities\":{\"value\":\"[parameters('alertSeverities')]\"},\"eventHubDetails\"\ - :{\"value\":\"[parameters('eventHubDetails')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cdfcce10-4578-4ecd-9703-530938e4abcb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cdfcce10-4578-4ecd-9703-530938e4abcb\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - Privilege Use'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - Privilege Use'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesPrivilegeUse\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SystemAuditPoliciesPrivilegeUse\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ce2370f6-0ac5-4d85-8ab4-10721cc640b0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ce2370f6-0ac5-4d85-8ab4-10721cc640b0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1209 - Configuration\ - \ Settings\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1209\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ce669c31-9103-4552-ae9c-cdef4e03580d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ce669c31-9103-4552-ae9c-cdef4e03580d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1242 - Contingency\ - \ Planning Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Contingency Planning control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1242\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cf3b3293-667a-445e-a722-fa0b0afc0958\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cf3b3293-667a-445e-a722-fa0b0afc0958\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1097 - Role-Based\ - \ Security Training | Suspicious Communications And Anomalous System Behavior\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Awareness and Training control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1097\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cf3e4836-f19e-47eb-a8cd-c3ca150452c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cf3e4836-f19e-47eb-a8cd-c3ca150452c0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1424 - Maintenance\ - \ Personnel | Individuals Without Appropriate Access\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Maintenance\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1424\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cf55fc87-48e1-4676-a2f8-d9a8cf993283\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cf55fc87-48e1-4676-a2f8-d9a8cf993283\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Key Vault should be\ - \ enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Key Vault\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cf820ca0-f99e-4f3e-84fb-66e913812d21\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cf820ca0-f99e-4f3e-84fb-66e913812d21\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1292 - Information\ - \ System Backup | Test Restoration Using Sampling\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1292\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d03516cf-0293-489f-9b32-a18f2a79f836\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d03516cf-0293-489f-9b32-a18f2a79f836\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1724 - Error\ - \ Handling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1724\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d07594d1-0307-4c08-94db-5d71ff31f0f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d07594d1-0307-4c08-94db-5d71ff31f0f6\"\ - },{\"properties\":{\"displayName\":\"Container registries should not allow\ - \ unrestricted network access\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Audit container registries that do not have any network\ - \ or firewall (IP) rules configured and so allow all network access by default.\ - \ Restricting network access protects container registries from potential\ - \ threats. Container registries with at least one IP / firewall rule or configured\ - \ virtual network are deemed compliant. For more information on Container\ - \ Registry network rules, visit: https://aka.ms/acr/portal/public-network\ - \ and https://aka.ms/acr/vnet.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Container Registry\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"\ - ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.ContainerRegistry/registries\"},{\"anyof\"\ - :[{\"field\":\"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ContainerRegistry/registries/networkRuleSet.defaultAction\"\ - ,\"equals\":\"Allow\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d0793b48-0edc-4296-a390-4c75d1bdfd71\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d0793b48-0edc-4296-a390-4c75d1bdfd71\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1084 - Publicly\ - \ Accessible Content\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1084\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d0eb15db-dd1c-4d1d-b200-b12dd6cd060c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d0eb15db-dd1c-4d1d-b200-b12dd6cd060c\"\ - },{\"properties\":{\"displayName\":\"Add or replace a tag on resource groups\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"Adds or replaces\ - \ the specified tag and value when any resource group is created or updated.\ - \ Existing resource groups can be remediated by triggering a remediation task.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Tags\"},\"parameters\"\ - :{\"tagName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Name\"\ - ,\"description\":\"Name of the tag, such as 'environment'\"}},\"tagValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Tag Value\",\"description\"\ - :\"Value of the tag, such as 'production'\"}}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"notEquals\"\ - :\"[parameters('tagValue')]\"}]},\"then\":{\"effect\":\"modify\",\"details\"\ - :{\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ - \ parameters('tagName'), ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/d157c373-a6c4-483d-aaad-570756956268\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d157c373-a6c4-483d-aaad-570756956268\"\ - },{\"properties\":{\"displayName\":\"Enforce SSL connection should be enabled\ - \ for PostgreSQL database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy audits any PostgreSQL server that\ - \ is not enforcing SSL connection. Azure Database for PostgreSQL prefers connecting\ - \ your client applications to the PostgreSQL service using Secure Sockets\ - \ Layer (SSL). Enforcing SSL connections between your database server and\ - \ your client applications helps protect against 'man-in-the-middle' attacks\ - \ by encrypting the data stream between the server and your application\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },{\"field\":\"Microsoft.DBforPostgreSQL/servers/sslEnforcement\",\"exists\"\ - :\"true\"},{\"field\":\"Microsoft.DBforPostgreSQL/servers/sslEnforcement\"\ - ,\"notEquals\":\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d158790f-bfb0-486c-8631-2dc6b4e8e6af\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d158790f-bfb0-486c-8631-2dc6b4e8e6af\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1620 - Denial\ - \ Of Service Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this System and Communications Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1620\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d17c826b-1dec-43e1-a984-7b71c446649c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d17c826b-1dec-43e1-a984-7b71c446649c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1409 - Maintenance\ - \ Tools | Prevent Unauthorized Removal\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1409\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d1880188-e51a-4772-b2ab-68f5e8bd27f6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d1880188-e51a-4772-b2ab-68f5e8bd27f6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Function Apps that\ - \ are not using custom domains\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Use of custom domains protects a Function app from common\ - \ attacks such as phishing and other DNS-related attacks.\",\"metadata\":{\"\ - version\":\"1.0.0-deprecated\",\"category\":\"Security Center\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"\ - field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\"\ - :\"kind\",\"equals\":\"functionapp\"},{\"field\":\"kind\",\"equals\":\"functionapp,linux\"\ - },{\"field\":\"kind\",\"equals\":\"functionapp,linux,container\"}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UsedCustomDomains\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d1cb47db-b7a1-4c46-814e-aad1c0e84f3c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d1cb47db-b7a1-4c46-814e-aad1c0e84f3c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1195 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1195\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d1e1d65c-1013-4484-bd54-991332e6a0d2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d1e1d65c-1013-4484-bd54-991332e6a0d2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1721 - Spam\ - \ Protection | Central Management\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1721\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d207aaef-7c4d-4f8c-9dce-4d62dfa3d29a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d207aaef-7c4d-4f8c-9dce-4d62dfa3d29a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1106 - Audit\ - \ Events | Reviews And Updates\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Audit and Accountability control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1106\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d2b4feae-61ab-423f-a4c5-0e38ac4464d8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d2b4feae-61ab-423f-a4c5-0e38ac4464d8\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1030 - Information\ - \ Flow Enforcement | Physical / Logical Separation Of Information Flows\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Access Control control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1030\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d3531453-b869-4606-9122-29c1cd6e7ed1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d3531453-b869-4606-9122-29c1cd6e7ed1\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs on which the DSC configuration is not compliant\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows VMs on which the Desired\ - \ State Configuration (DSC) configuration is not compliant. This policy is\ - \ only applicable to machines with WMF 4 and above. It also creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration. This\ - \ policy should only be used along with its corresponding audit policy in\ - \ an initiative. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.2.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsDscConfiguration\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsDscConfiguration\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d38b4c26-9d2e-47d7-aefe-18d859a8706a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d38b4c26-9d2e-47d7-aefe-18d859a8706a\"\ - },{\"properties\":{\"displayName\":\"Long-term geo-redundant backup should\ - \ be enabled for Azure SQL Databases\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"This policy audits any Azure SQL Database with\ - \ long-term geo-redundant backup not enabled.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers/databases\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"anyOf\":[{\"field\":\"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/weeklyRetention\"\ - ,\"notEquals\":\"PT0S\"},{\"field\":\"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/monthlyRetention\"\ - ,\"notEquals\":\"PT0S\"},{\"field\":\"Microsoft.Sql/servers/databases/backupLongTermRetentionPolicies/yearlyRetention\"\ - ,\"notEquals\":\"PT0S\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d38fc420-0735-4ef3-ac11-c806f651a570\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d38fc420-0735-4ef3-ac11-c806f651a570\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1641 - Transmission\ - \ Confidentiality And Integrity | Cryptographic Or Alternate Physical Protection\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Communications Protection control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1641\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d39d4f68-7346-4133-8841-15318a714a24\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d39d4f68-7346-4133-8841-15318a714a24\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that don't have\ - \ the specified applications installed\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the Chef InSpec resource indicates that one or more\ - \ of the packages provided by the parameter are not installed.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"installed_application_linux\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"ApplicationName\":\"[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ApplicationName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Application names\"\ - ,\"description\":\"A semicolon-separated list of the names of the applications\ - \ that should be installed. e.g. 'python; powershell'\"}}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"installed_application_linux\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[ChefInSpec]InstalledApplicationLinuxResource1;AttributesYmlContent',\ - \ '=', concat('packages: [', replace(parameters('ApplicationName'), ';', ','),\ - \ ']')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d3b823c9-e0fc-4453-9fb2-8213b7338523\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d3b823c9-e0fc-4453-9fb2-8213b7338523\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1249 - Contingency\ - \ Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1249\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d3bf4251-0818-42db-950b-afd5b25a51c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d3bf4251-0818-42db-950b-afd5b25a51c2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1562 - Allocation\ - \ Of Resources\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1562\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d4142013-7964-4163-a313-a900301c2cef\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d4142013-7964-4163-a313-a900301c2cef\"\ - },{\"properties\":{\"displayName\":\"Virtual machines should be connected\ - \ to an approved virtual network\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy audits any virtual machine connected\ - \ to a virtual network that is not approved.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Network\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"The effect\ - \ determines what happens when the policy rule is evaluated to match\"},\"\ - allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"\ - },\"virtualNetworkId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Virtual network Id\",\"description\":\"Resource Id of the virtual network.\ - \ Example: /subscriptions/YourSubscriptionId/resourceGroups/YourResourceGroupName/providers/Microsoft.Network/virtualNetworks/Name\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkInterfaces\"\ - },{\"not\":{\"field\":\"Microsoft.Network/networkInterfaces/ipconfigurations[*].subnet.id\"\ - ,\"like\":\"[concat(parameters('virtualNetworkId'),'/*')]\"}}]},\"then\":{\"\ - effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d416745a-506c-48b6-8ab1-83cb814bcaa3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d416745a-506c-48b6-8ab1-83cb814bcaa3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1383 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1383\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d4558451-e16a-4d2d-a066-fe12a6282bb9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d4558451-e16a-4d2d-a066-fe12a6282bb9\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Interactive Logon'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Interactive Logon'\ - \ for displaying last user name and requiring ctrl-alt-del. This policy requires\ - \ that the Guest Configuration prerequisites have been deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AzureBaseline_SecurityOptionsInteractiveLogon\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\",\"\ - description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsInteractiveLogon\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d472d2c9-d6a3-4500-9f5f-b15f123005aa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d472d2c9-d6a3-4500-9f5f-b15f123005aa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1112 - Response\ - \ To Audit Processing Failures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Audit and Accountability control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1112\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d530aad8-4ee2-45f4-b234-c061dae683c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d530aad8-4ee2-45f4-b234-c061dae683c0\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Data Lake\ - \ Analytics to Log Analytics workspace\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Deploys the diagnostic settings for Data Lake\ - \ Analytics to stream to a regional Log Analytics workspace when any Data\ - \ Lake Analytics which is missing this diagnostic settings is created or updated.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"\ - },\"profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_logAnalytics\"},\"logAnalytics\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Log Analytics workspace\",\"description\":\"Select Log\ - \ Analytics workspace from dropdown list. If this workspace is outside of\ - \ the scope of the assignment you must manually grant 'Log Analytics Contributor'\ - \ permissions (or similar) to the policy assignment's principal ID.\",\"strongType\"\ - :\"omsWorkspace\",\"assignPermissions\":true}},\"metricsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Log Analytics workspace - True\ - \ or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Log Analytics\ - \ workspace - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DataLakeAnalytics/accounts\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/749f88d5-cbae-40b8-bcfc-e573ddc772fa\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"logAnalytics\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.DataLakeAnalytics/accounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"workspaceId\"\ - :\"[parameters('logAnalytics')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Audit\",\"enabled\":\"[parameters('logsEnabled')]\"\ - },{\"category\":\"Requests\",\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"\ - outputs\":{}},\"parameters\":{\"location\":{\"value\":\"[field('location')]\"\ - },\"resourceName\":{\"value\":\"[field('name')]\"},\"logAnalytics\":{\"value\"\ - :\"[parameters('logAnalytics')]\"},\"metricsEnabled\":{\"value\":\"[parameters('metricsEnabled')]\"\ - },\"logsEnabled\":{\"value\":\"[parameters('logsEnabled')]\"},\"profileName\"\ - :{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d56a5a7c-72d7-42bc-8ceb-3baf4c0eae03\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d56a5a7c-72d7-42bc-8ceb-3baf4c0eae03\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1585 - Security\ - \ Engineering Principles\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1585\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d57f8732-5cdc-4cda-8d27-ab148e1f3a55\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d57f8732-5cdc-4cda-8d27-ab148e1f3a55\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1667 - System\ - \ And Information Integrity Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1667\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d61880dc-6e38-4f2a-a30c-3406a98f8220\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d61880dc-6e38-4f2a-a30c-3406a98f8220\"\ - },{\"properties\":{\"displayName\":\"Log Analytics agent health issues should\ - \ be resolved on your machines\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Security Center uses the Log Analytics agent, formerly\ - \ known as the Microsoft Monitoring Agent (MMA). To make sure your virtual\ - \ machines are successfully monitored, you need to make sure the agent is\ - \ installed on the virtual machines and properly collects security events\ - \ to the configured workspace.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.ClassicCompute/virtualMachines\",\"Microsoft.Compute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"8e2b96ff-3de2-289b-b5c1-3b9921a3441e\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"NotApplicable\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d62cfe2b-3ab0-4d41-980d-76803b58ca65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d62cfe2b-3ab0-4d41-980d-76803b58ca65\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1150 - Security\ - \ Assessments | External Organizations\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Security Assessment\ - \ and Authorization control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1150\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d630429d-e763-40b1-8fba-d20ba7314afb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d630429d-e763-40b1-8fba-d20ba7314afb\"\ - },{\"properties\":{\"displayName\":\"Event Hub should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any Event Hub not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.EventHub/namespaces\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.EventHub/namespaces/virtualNetworkRules\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.EventHub/namespaces/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d63edb4a-c612-454d-b47d-191a724fcbf0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d63edb4a-c612-454d-b47d-191a724fcbf0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1549 - Vulnerability\ - \ Scanning\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1549\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d6976a08-d969-4df2-bb38-29556c2eb48a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d6976a08-d969-4df2-bb38-29556c2eb48a\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Log Analytics agent should\ - \ be installed on your Windows Azure Arc machines\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy audits Windows Azure Arc\ - \ machines if the Log Analytics agent is not installed.\",\"metadata\":{\"\ - version\":\"1.0.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\"\ - :\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.HybridCompute/machines\"},{\"field\":\"Microsoft.HybridCompute/imageOffer\"\ - ,\"like\":\"windows*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\",\"\ - existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"MicrosoftMonitoringAgent\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d69b1763-b96d-40b8-a2d9-ca31e9fd0d3e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d69b1763-b96d-40b8-a2d9-ca31e9fd0d3e\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Microsoft Network Client'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Microsoft Network\ - \ Client' for Microsoft network client/server and SMB v1. This policy requires\ - \ that the Guest Configuration prerequisites have been deployed to the policy\ - \ assignment scope. For details, visit https://aka.ms/gcpol.\",\"metadata\"\ - :{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkClient\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"MicrosoftNetworkClientDigitallySignCommunicationsAlways\"\ - :\"Microsoft network client: Digitally sign communications (always);ExpectedValue\"\ - ,\"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers\":\"\ - Microsoft network client: Send unencrypted password to third-party SMB servers;ExpectedValue\"\ - ,\"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession\"\ - :\"Microsoft network server: Amount of idle time required before suspending\ - \ session;ExpectedValue\",\"MicrosoftNetworkServerDigitallySignCommunicationsAlways\"\ - :\"Microsoft network server: Digitally sign communications (always);ExpectedValue\"\ - ,\"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire\":\"Microsoft\ - \ network server: Disconnect clients when logon hours expire;ExpectedValue\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"MicrosoftNetworkClientDigitallySignCommunicationsAlways\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Microsoft network client:\ - \ Digitally sign communications (always)\",\"description\":\"Specifies whether\ - \ packet signing is required by the SMB client component.\"},\"defaultValue\"\ - :\"1\"},\"MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Microsoft network client:\ - \ Send unencrypted password to third-party SMB servers\",\"description\":\"\ - Specifies whether the SMB redirector will send plaintext passwords during\ - \ authentication to third-party SMB servers that do not support password encryption.\ - \ It is recommended that you disable this policy setting unless there is a\ - \ strong business case to enable it.\"},\"defaultValue\":\"0\"},\"MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Microsoft network server:\ - \ Amount of idle time required before suspending session\",\"description\"\ - :\"Specifies the amount of continuous idle time that must pass in an SMB session\ - \ before the session is suspended because of inactivity. The format of the\ - \ value is two integers separated by a comma, denoting an inclusive range.\"\ - },\"defaultValue\":\"1,15\"},\"MicrosoftNetworkServerDigitallySignCommunicationsAlways\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Microsoft network server:\ - \ Digitally sign communications (always)\",\"description\":\"Specifies whether\ - \ packet signing is required by the SMB server component.\"},\"defaultValue\"\ - :\"1\"},\"MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Microsoft network server:\ - \ Disconnect clients when logon hours expire\",\"description\":\"Specifies\ - \ whether to disconnect users who are connected to the local computer outside\ - \ their user account's valid logon hours. This setting affects the Server\ - \ Message Block (SMB) component. If you enable this policy setting you should\ - \ also enable 'Network security: Force logoff when logon hours expire'\"},\"\ - defaultValue\":\"1\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of this policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsMicrosoftNetworkClient\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Microsoft network client: Digitally sign communications\ - \ (always);ExpectedValue', '=', parameters('MicrosoftNetworkClientDigitallySignCommunicationsAlways'),\ - \ ',', 'Microsoft network client: Send unencrypted password to third-party\ - \ SMB servers;ExpectedValue', '=', parameters('MicrosoftNetworkClientSendUnencryptedPasswordToThirdpartySMBServers'),\ - \ ',', 'Microsoft network server: Amount of idle time required before suspending\ - \ session;ExpectedValue', '=', parameters('MicrosoftNetworkServerAmountOfIdleTimeRequiredBeforeSuspendingSession'),\ - \ ',', 'Microsoft network server: Digitally sign communications (always);ExpectedValue',\ - \ '=', parameters('MicrosoftNetworkServerDigitallySignCommunicationsAlways'),\ - \ ',', 'Microsoft network server: Disconnect clients when logon hours expire;ExpectedValue',\ - \ '=', parameters('MicrosoftNetworkServerDisconnectClientsWhenLogonHoursExpire')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d6c69680-54f0-4349-af10-94dd05f4225e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d6c69680-54f0-4349-af10-94dd05f4225e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1473 - Emergency\ - \ Power\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"\ - Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1473\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d7047705-d719-46a7-8bb0-76ad233eba71\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d7047705-d719-46a7-8bb0-76ad233eba71\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1529 - Third-Party\ - \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1529\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d74fdc92-1cb8-4a34-9978-8556425cd14c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d74fdc92-1cb8-4a34-9978-8556425cd14c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1350 - Identification\ - \ And Authentication (Non-Org. Users) | Use Of FICAM-Issued Profiles\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Identification and Authentication control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1350\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d77fd943-6ba6-4a21-ba07-22b03e347cc4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d77fd943-6ba6-4a21-ba07-22b03e347cc4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows Server VMs on which Windows Serial Console is not enabled\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows Server virtual\ - \ machines on which Windows Serial Console is not enabled. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsSerialConsole\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d7ccd0ca-8d78-42af-a43d-6b7f928accbc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d7ccd0ca-8d78-42af-a43d-6b7f928accbc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1016 - Account\ - \ Management | Automated Audit Actions\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1016\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d8b43277-512e-40c3-ab00-14b3b6e72238\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d8b43277-512e-40c3-ab00-14b3b6e72238\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1488 - Alternate\ - \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1488\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d8ef30eb-a44f-47af-8524-ac19a36d41d2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d8ef30eb-a44f-47af-8524-ac19a36d41d2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1577 - Acquisition\ - \ Process | Continuous Monitoring Plan\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1577\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d922484a-8cfc-4a6b-95a4-77d6a685407f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d922484a-8cfc-4a6b-95a4-77d6a685407f\"\ - },{\"properties\":{\"displayName\":\"Public network access should be disabled\ - \ for MySQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits MySQL servers in your environment with public network\ - \ access enabled. For more details, visit https://go.microsoft.com/fwlink/?linkid=2120014.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },{\"field\":\"Microsoft.DBforMySQL/servers/publicNetworkAccess\",\"notEquals\"\ - :\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/d9844e8a-1437-4aeb-a32c-0c992f056095\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d9844e8a-1437-4aeb-a32c-0c992f056095\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that do not store\ - \ passwords using reversible encryption\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if Windows machines that do not store passwords using\ - \ reversible encryption\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"StorePasswordsUsingReversibleEncryption\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Include Arc connected servers\",\"\ - description\":\"By selecting this option, you agree to be charged monthly\ - \ per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"],\"\ - defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - StorePasswordsUsingReversibleEncryption\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/da0f98fe-a24b-4ad5-af69-bd0400233661\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"da0f98fe-a24b-4ad5-af69-bd0400233661\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1271 - Alternate\ - \ Storage Site | Accessibility\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Contingency Planning control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1271\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/da3bfb53-9c46-4010-b3db-a7ba1296dada\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"da3bfb53-9c46-4010-b3db-a7ba1296dada\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1516 - Personnel\ - \ Termination\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1516\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/da3cd269-156f-435b-b472-c3af34c032ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"da3cd269-156f-435b-b472-c3af34c032ed\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Batch\ - \ Account to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Deploys the diagnostic settings for Batch Account to stream\ - \ to a regional Event Hub when any Batch Account which is missing this diagnostic\ - \ settings is created or updated.\",\"metadata\":{\"version\":\"2.0.0\",\"\ - category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ - :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"\ - },\"eventHubRuleId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Event Hub Authorization Rule Id\",\"description\":\"The Event Hub authorization\ - \ rule Id for Azure Diagnostics. The authorization rule needs to be at Event\ - \ Hub namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource\ - \ group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization\ - \ rule}\",\"strongType\":\"Microsoft.EventHub/Namespaces/AuthorizationRules\"\ - ,\"assignPermissions\":true}},\"eventHubLocation\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Event Hub Location\",\"description\":\"The location\ - \ the Event Hub resides in. Only Batch Accounts in this location will be linked\ - \ to this Event Hub.\",\"strongType\":\"location\"},\"defaultValue\":\"\"\ - },\"metricsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Enable metrics\",\"description\":\"Whether to enable metrics stream to the\ - \ Event Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"False\"},\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Enable logs\",\"description\":\"Whether to enable logs stream to the Event\ - \ Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Batch/batchAccounts\"},{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\"\ - ,\"equals\":\"\"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.Batch/batchAccounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"ServiceLog\",\"enabled\":\"\ - [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/db51110f-0865-4a6e-b274-e2e07a5b2cd7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"db51110f-0865-4a6e-b274-e2e07a5b2cd7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1277 - Alternate\ - \ Processing Site | Priority Of Service\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1277\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dc43e829-3d50-4a0a-aa0f-428d551862aa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dc43e829-3d50-4a0a-aa0f-428d551862aa\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1439 - Media\ - \ Sanitization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1439\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dce72873-c5f1-47c3-9b4f-6b8207fd5a45\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dce72873-c5f1-47c3-9b4f-6b8207fd5a45\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1264 - Contingency\ - \ Plan Testing | Coordinate With Related Plans\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1264\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd280d4b-50a1-42fb-a479-ece5878acf19\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd280d4b-50a1-42fb-a479-ece5878acf19\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using custom domains\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Use of custom domains protects a web application\ - \ from common attacks such as phishing and other DNS-related attacks.\",\"\ - metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\"\ - ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\"\ - :[{\"field\":\"kind\",\"equals\":\"app\"},{\"field\":\"kind\",\"equals\":\"\ - WebApp\"},{\"field\":\"kind\",\"equals\":\"app,linux\"},{\"field\":\"kind\"\ - ,\"equals\":\"app,linux,container\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - UsedCustomDomains\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd2ea520-6b06-45c3-806e-ea297c23e06a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd2ea520-6b06-45c3-806e-ea297c23e06a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'System Audit Policies - Policy Change'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'System\ - \ Audit Policies - Policy Change'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesPolicyChange\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd4680ed-0559-4a6a-ad10-081d14cbb484\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd4680ed-0559-4a6a-ad10-081d14cbb484\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1715 - Software,\ - \ Firmware, And Information Integrity | Automated Response To Integrity Violations\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1715\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd469ae0-71a8-4adc-aafc-de6949ca3339\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd469ae0-71a8-4adc-aafc-de6949ca3339\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1678 - Malicious\ - \ Code Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1678\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd533cb0-b416-4be7-8e86-4d154824dfd7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd533cb0-b416-4be7-8e86-4d154824dfd7\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1391 - Information\ - \ Spillage Response | Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Incident Response control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1391\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd6ac1a1-660e-4810-baa8-74e868e2ed47\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd6ac1a1-660e-4810-baa8-74e868e2ed47\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1146 - Security\ - \ Assessments\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1146\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dd83410c-ecb6-4547-8f14-748c3cbdc7ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dd83410c-ecb6-4547-8f14-748c3cbdc7ac\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1602 - Developer\ - \ Security Testing And Evaluation\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1602\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ddae2e97-a449-499f-a1c8-aea4a7e52ec9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ddae2e97-a449-499f-a1c8-aea4a7e52ec9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Settings - Account Policies'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Settings - Account Policies'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecuritySettingsAccountPolicies\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ddb53c61-9db4-41d4-a953-2abff5b66c12\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ddb53c61-9db4-41d4-a953-2abff5b66c12\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Recovery console'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Recovery console'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Recovery\ - \ console: Allow floppy copy and access to all drives and all folders\",\"\ - description\":\"Specifies whether to make the Recovery Console SET command\ - \ available, which allows setting of recovery console environment variables.\"\ - },\"defaultValue\":\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsRecoveryconsole\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Recovery console: Allow floppy copy and access\ - \ to all drives and all folders;ExpectedValue', '=', parameters('RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsRecoveryconsole\"},\"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders\"\ - :{\"value\":\"[parameters('RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Recovery console:\ - \ Allow floppy copy and access to all drives and all folders;ExpectedValue\"\ - ,\"value\":\"[parameters('RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Recovery console:\ - \ Allow floppy copy and access to all drives and all folders;ExpectedValue\"\ - ,\"value\":\"[parameters('RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ddc0a4d5-5e08-43d5-9fd9-b586d8d7116b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ddc0a4d5-5e08-43d5-9fd9-b586d8d7116b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1689 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1689\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/de901f2f-a01a-4456-97f0-33cda7966172\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"de901f2f-a01a-4456-97f0-33cda7966172\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Deploy Dependency agent to\ - \ hybrid Linux Azure Arc machines\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"This policy deploys the Dependency agent to Linux\ - \ Azure Arc machines if the agent isn't installed.\",\"metadata\":{\"version\"\ - :\"1.1.0-preview\",\"category\":\"Monitoring\",\"preview\":true},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.HybridCompute/machines/extensions\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/92aaf0da-9dab-42b6-94a3-d43ce8d16293\"\ - ],\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.HybridCompute/machines/extensions/type\"\ - ,\"equals\":\"DependencyAgentLinux\"},{\"field\":\"Microsoft.HybridCompute/machines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"},{\"field\":\"\ - Microsoft.HybridCompute/machines/extensions/provisioningState\",\"equals\"\ - :\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"variables\":{\"vmExtensionName\":\"\ - DependencyAgentLinux\",\"vmExtensionPublisher\":\"Microsoft.Azure.Monitoring.DependencyAgent\"\ - ,\"vmExtensionType\":\"DependencyAgentLinux\"},\"resources\":[{\"name\":\"\ - [concat(parameters('vmName'), '/', variables('vmExtensionName'))]\",\"type\"\ - :\"Microsoft.HybridCompute/machines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"apiVersion\":\"2019-12-12\",\"properties\":{\"publisher\":\"[variables('vmExtensionPublisher')]\"\ - ,\"type\":\"[variables('vmExtensionType')]\",\"settings\":{}}}],\"outputs\"\ - :{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled DA extension\ - \ for VM', ': ', parameters('vmName'))]\"}}},\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/deacecc0-9f84-44d2-bb82-46f32d766d43\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"deacecc0-9f84-44d2-bb82-46f32d766d43\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1528 - Access\ - \ Agreements\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1528\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/deb9797c-22f8-40e8-b342-a84003c924e6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"deb9797c-22f8-40e8-b342-a84003c924e6\"\ - },{\"properties\":{\"displayName\":\"MariaDB server should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits MariaDB servers not configured to use a virtual network\ - \ service endpoint. For more details, visit https://aka.ms/mariadbvirtualnetwork.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforMariaDB/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforMariaDB/servers/virtualNetworkRules\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.DBforMariaDB/servers/virtualNetworkRules/virtualNetworkSubnetId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dfbd9a64-6114-48de-a47d-90574dc2e489\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dfbd9a64-6114-48de-a47d-90574dc2e489\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1673 - Flaw\ - \ Remediation | Automated Flaw Remediation Status\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Information Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1673\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/dff0b90d-5a6f-491c-b2f8-b90aa402d844\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dff0b90d-5a6f-491c-b2f8-b90aa402d844\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Allow resource creation\ - \ only in Japan data centers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Allows resource creation in the following locations only:\ - \ Japan East, Japan West\",\"metadata\":{\"category\":\"General\",\"deprecated\"\ - :true},\"parameters\":{},\"policyRule\":{\"if\":{\"not\":{\"field\":\"location\"\ - ,\"in\":[\"japaneast\",\"japanwest\"]}},\"then\":{\"effect\":\"Deny\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/e01598e8-6538-41ed-95e8-8b29746cd697\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e01598e8-6538-41ed-95e8-8b29746cd697\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'User Rights Assignment'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Windows machines should have the specified Group Policy\ - \ settings in the category 'User Rights Assignment' for allowing log on locally,\ - \ RDP, access from the network, and many other user activities. This policy\ - \ requires that the Guest Configuration prerequisites have been deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_UserRightsAssignment\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork\":\"Access this computer\ - \ from the network;ExpectedValue\",\"UsersOrGroupsThatMayLogOnLocally\":\"\ - Allow log on locally;ExpectedValue\",\"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices\"\ - :\"Allow log on through Remote Desktop Services;ExpectedValue\",\"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork\"\ - :\"Deny access to this computer from the network;ExpectedValue\",\"UsersOrGroupsThatMayManageAuditingAndSecurityLog\"\ - :\"Manage auditing and security log;ExpectedValue\",\"UsersOrGroupsThatMayBackUpFilesAndDirectories\"\ - :\"Back up files and directories;ExpectedValue\",\"UsersOrGroupsThatMayChangeTheSystemTime\"\ - :\"Change the system time;ExpectedValue\",\"UsersOrGroupsThatMayChangeTheTimeZone\"\ - :\"Change the time zone;ExpectedValue\",\"UsersOrGroupsThatMayCreateATokenObject\"\ - :\"Create a token object;ExpectedValue\",\"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob\"\ - :\"Deny log on as a batch job;ExpectedValue\",\"UsersAndGroupsThatAreDeniedLoggingOnAsAService\"\ - :\"Deny log on as a service;ExpectedValue\",\"UsersAndGroupsThatAreDeniedLocalLogon\"\ - :\"Deny log on locally;ExpectedValue\",\"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices\"\ - :\"Deny log on through Remote Desktop Services;ExpectedValue\",\"UserAndGroupsThatMayForceShutdownFromARemoteSystem\"\ - :\"Force shutdown from a remote system;ExpectedValue\",\"UsersAndGroupsThatMayRestoreFilesAndDirectories\"\ - :\"Restore files and directories;ExpectedValue\",\"UsersAndGroupsThatMayShutDownTheSystem\"\ - :\"Shut down the system;ExpectedValue\",\"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects\"\ - :\"Take ownership of files or other objects;ExpectedValue\"}}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"UsersOrGroupsThatMayAccessThisComputerFromTheNetwork\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may access this computer from the network\",\"description\":\"Specifies\ - \ which remote users on the network are permitted to connect to the computer.\ - \ This does not include Remote Desktop Connection.\"},\"defaultValue\":\"\ - Administrators, Authenticated Users\"},\"UsersOrGroupsThatMayLogOnLocally\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may log on locally\",\"description\":\"Specifies which users or groups can\ - \ interactively log on to the computer. Users who attempt to log on via Remote\ - \ Desktop Connection or IIS also require this user right.\"},\"defaultValue\"\ - :\"Administrators\"},\"UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may log on through Remote Desktop Services\",\"description\":\"Specifies\ - \ which users or groups are permitted to log on as a Terminal Services client,\ - \ Remote Desktop, or for Remote Assistance.\"},\"defaultValue\":\"Administrators,\ - \ Remote Desktop Users\"},\"UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that\ - \ are denied access to this computer from the network\",\"description\":\"\ - Specifies which users or groups are explicitly prohibited from connecting\ - \ to the computer across the network.\"},\"defaultValue\":\"Guests\"},\"UsersOrGroupsThatMayManageAuditingAndSecurityLog\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may manage auditing and security log\",\"description\":\"Specifies users\ - \ and groups permitted to change the auditing options for files and directories\ - \ and clear the Security log.\"},\"defaultValue\":\"Administrators\"},\"UsersOrGroupsThatMayBackUpFilesAndDirectories\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may back up files and directories\",\"description\":\"Specifies users and\ - \ groups allowed to circumvent file and directory permissions to back up the\ - \ system.\"},\"defaultValue\":\"Administrators, Backup Operators\"},\"UsersOrGroupsThatMayChangeTheSystemTime\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may change the system time\",\"description\":\"Specifies which users and\ - \ groups are permitted to change the time and date on the internal clock of\ - \ the computer.\"},\"defaultValue\":\"Administrators, LOCAL SERVICE\"},\"\ - UsersOrGroupsThatMayChangeTheTimeZone\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Users or groups that may change the time zone\",\"description\"\ - :\"Specifies which users and groups are permitted to change the time zone\ - \ of the computer.\"},\"defaultValue\":\"Administrators, LOCAL SERVICE\"},\"\ - UsersOrGroupsThatMayCreateATokenObject\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Users or groups that may create a token object\",\"description\"\ - :\"Specifies which users and groups are permitted to create an access token,\ - \ which may provide elevated rights to access sensitive data.\"},\"defaultValue\"\ - :\"No One\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Users and groups that are denied\ - \ logging on as a batch job\",\"description\":\"Specifies which users and\ - \ groups are explicitly not permitted to log on to the computer as a batch\ - \ job (i.e. scheduled task).\"},\"defaultValue\":\"Guests\"},\"UsersAndGroupsThatAreDeniedLoggingOnAsAService\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that\ - \ are denied logging on as a service\",\"description\":\"Specifies which service\ - \ accounts are explicitly not permitted to register a process as a service.\"\ - },\"defaultValue\":\"Guests\"},\"UsersAndGroupsThatAreDeniedLocalLogon\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that are\ - \ denied local logon\",\"description\":\"Specifies which users and groups\ - \ are explicitly not permitted to log on to the computer.\"},\"defaultValue\"\ - :\"Guests\"},\"UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that\ - \ are denied log on through Remote Desktop Services\",\"description\":\"Specifies\ - \ which users and groups are explicitly not permitted to log on to the computer\ - \ via Terminal Services/Remote Desktop Client.\"},\"defaultValue\":\"Guests\"\ - },\"UserAndGroupsThatMayForceShutdownFromARemoteSystem\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"User and groups that may force shutdown from\ - \ a remote system\",\"description\":\"Specifies which users and groups are\ - \ permitted to shut down the computer from a remote location on the network.\"\ - },\"defaultValue\":\"Administrators\"},\"UsersAndGroupsThatMayRestoreFilesAndDirectories\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that\ - \ may restore files and directories\",\"description\":\"Specifies which users\ - \ and groups are permitted to bypass file, directory, registry, and other\ - \ persistent object permissions when restoring backed up files and directories.\"\ - },\"defaultValue\":\"Administrators, Backup Operators\"},\"UsersAndGroupsThatMayShutDownTheSystem\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users and groups that\ - \ may shut down the system\",\"description\":\"Specifies which users and groups\ - \ who are logged on locally to the computers in your environment are permitted\ - \ to shut down the operating system with the Shut Down command.\"},\"defaultValue\"\ - :\"Administrators\"},\"UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Users or groups that\ - \ may take ownership of files or other objects\",\"description\":\"Specifies\ - \ which users and groups are permitted to take ownership of files, folders,\ - \ registry keys, processes, or threads. This user right bypasses any permissions\ - \ that are in place to protect objects to give ownership to the specified\ - \ user.\"},\"defaultValue\":\"Administrators\"},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_UserRightsAssignment\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Access this computer from the network;ExpectedValue',\ - \ '=', parameters('UsersOrGroupsThatMayAccessThisComputerFromTheNetwork'),\ - \ ',', 'Allow log on locally;ExpectedValue', '=', parameters('UsersOrGroupsThatMayLogOnLocally'),\ - \ ',', 'Allow log on through Remote Desktop Services;ExpectedValue', '=',\ - \ parameters('UsersOrGroupsThatMayLogOnThroughRemoteDesktopServices'), ',',\ - \ 'Deny access to this computer from the network;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedAccessToThisComputerFromTheNetwork'),\ - \ ',', 'Manage auditing and security log;ExpectedValue', '=', parameters('UsersOrGroupsThatMayManageAuditingAndSecurityLog'),\ - \ ',', 'Back up files and directories;ExpectedValue', '=', parameters('UsersOrGroupsThatMayBackUpFilesAndDirectories'),\ - \ ',', 'Change the system time;ExpectedValue', '=', parameters('UsersOrGroupsThatMayChangeTheSystemTime'),\ - \ ',', 'Change the time zone;ExpectedValue', '=', parameters('UsersOrGroupsThatMayChangeTheTimeZone'),\ - \ ',', 'Create a token object;ExpectedValue', '=', parameters('UsersOrGroupsThatMayCreateATokenObject'),\ - \ ',', 'Deny log on as a batch job;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLoggingOnAsABatchJob'),\ - \ ',', 'Deny log on as a service;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLoggingOnAsAService'),\ - \ ',', 'Deny log on locally;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLocalLogon'),\ - \ ',', 'Deny log on through Remote Desktop Services;ExpectedValue', '=', parameters('UsersAndGroupsThatAreDeniedLogOnThroughRemoteDesktopServices'),\ - \ ',', 'Force shutdown from a remote system;ExpectedValue', '=', parameters('UserAndGroupsThatMayForceShutdownFromARemoteSystem'),\ - \ ',', 'Restore files and directories;ExpectedValue', '=', parameters('UsersAndGroupsThatMayRestoreFilesAndDirectories'),\ - \ ',', 'Shut down the system;ExpectedValue', '=', parameters('UsersAndGroupsThatMayShutDownTheSystem'),\ - \ ',', 'Take ownership of files or other objects;ExpectedValue', '=', parameters('UsersOrGroupsThatMayTakeOwnershipOfFilesOrOtherObjects')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e068b215-0026-4354-b347-8fb2766f73a2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e068b215-0026-4354-b347-8fb2766f73a2\"\ - },{\"properties\":{\"displayName\":\"Cosmos DB should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any Cosmos DB not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DocumentDB/databaseAccounts\"},{\"field\":\"Microsoft.DocumentDB/databaseAccounts/virtualNetworkRules[*].id\"\ - ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/e0a2b1a3-f7f9-4569-807f-2a9edebdf4d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e0a2b1a3-f7f9-4569-807f-2a9edebdf4d9\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Administrative Templates - MSS (Legacy)'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Administrative Templates - MSS (Legacy)'\ - \ for automatic logon, screen saver, network behavior, safe DLL, and event\ - \ log. This policy requires that the Guest Configuration prerequisites have\ - \ been deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_AdminstrativeTemplatesMSSLegacy\",\"version\":\"\ - 1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of this policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_AdminstrativeTemplatesMSSLegacy\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e0a7e899-2ce2-4253-8a13-d808fdeb75af\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e0a7e899-2ce2-4253-8a13-d808fdeb75af\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1206 - Access\ - \ Restrictions For Change | Limit Production / Operational Privileges\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1206\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e0de232d-02a0-4652-872d-88afb4ae5e91\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e0de232d-02a0-4652-872d-88afb4ae5e91\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that do not have the specified Windows PowerShell execution\ - \ policy\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines where Windows PowerShell is not configured to use the specified\ - \ PowerShell execution policy. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"ExecutionPolicy\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: PowerShell Execution Policy\",\"description\":\"The expected\ - \ PowerShell execution policy.\"},\"allowedValues\":[\"AllSigned\",\"Bypass\"\ - ,\"Default\",\"RemoteSigned\",\"Restricted\",\"Undefined\",\"Unrestricted\"\ - ]}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPowerShellExecutionPolicy\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy',\ - \ '=', parameters('ExecutionPolicy')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"WindowsPowerShellExecutionPolicy\"\ - },\"ExecutionPolicy\":{\"value\":\"[parameters('ExecutionPolicy')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ExecutionPolicy\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy\"\ - ,\"value\":\"[parameters('ExecutionPolicy')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[PowerShellExecutionPolicy]PowerShellExecutionPolicy1;ExecutionPolicy\"\ - ,\"value\":\"[parameters('ExecutionPolicy')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e0efc13a-122a-47c5-b817-2ccfe5d12615\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e0efc13a-122a-47c5-b817-2ccfe5d12615\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1714 - Software,\ - \ Firmware, And Information Integrity | Automated Notifications Of Integrity\ - \ Violations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1714\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e12494fa-b81e-4080-af71-7dbacc2da0ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e12494fa-b81e-4080-af71-7dbacc2da0ec\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1686 - Information\ - \ System Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1686\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e17085c5-0be8-4423-b39b-a52d3d1402e5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e17085c5-0be8-4423-b39b-a52d3d1402e5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1722 - Spam\ - \ Protection | Automatic Updates\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Information Integrity\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1722\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1da06bd-25b6-4127-a301-c313d6873fff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1da06bd-25b6-4127-a301-c313d6873fff\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities in security configuration\ - \ on your machines should be remediated\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Servers which do not satisfy the configured baseline\ - \ will be monitored by Azure Security Center as recommendations\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\"\ - ,\"Microsoft.ClassicCompute/virtualMachines\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"181ac480-f7c4-544b-9865-11b8ffe87f47\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1e5fd5d-3e4c-4ce1-8661-7d1873ae6b15\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1e5fd5d-3e4c-4ce1-8661-7d1873ae6b15\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1047 - System\ - \ Use Notification\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1047\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1ff6d62-a55c-41ab-90ba-90bb5b7b6f62\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1ff6d62-a55c-41ab-90ba-90bb5b7b6f62\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1276 - Alternate\ - \ Processing Site | Accessibility\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Contingency Planning\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1276\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e214e563-1206-4a43-a56b-ac5880c9c571\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e214e563-1206-4a43-a56b-ac5880c9c571\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1560 - System\ - \ And Services Acquisition Policy And Procedures\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Services Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1560\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e29e0915-5c2f-4d09-8806-048b749ad763\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e29e0915-5c2f-4d09-8806-048b749ad763\"\ - },{\"properties\":{\"displayName\":\"Ensure that 'HTTP Version' is the latest,\ - \ if used to run the Function app\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Indexed\",\"description\":\"Periodically, newer versions are released for\ - \ HTTP either due to security flaws or to include additional functionality.\ - \ Using the latest HTTP version for web apps to take advantage of security\ - \ fixes, if any, and/or new functionalities of the newer version.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.http20Enabled\"\ - ,\"equals\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e2c1c086-2d84-4019-bff3-c44ccd95113c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e2c1c086-2d84-4019-bff3-c44ccd95113c\"\ - },{\"properties\":{\"displayName\":\"Audit Dependency agent deployment in\ - \ virtual machine scale sets - VM Image (OS) unlisted\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Reports virtual machine scale\ - \ sets as non-compliant if the VM Image (OS) is not in the list defined and\ - \ the agent is not installed. The list of OS images will be updated over time\ - \ as support is updated.\",\"metadata\":{\"version\":\"1.0.1\",\"category\"\ - :\"Monitoring\"},\"parameters\":{\"listOfImageIdToInclude_windows\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Optional: List of VM images that\ - \ have supported Windows OS to add to scope\",\"description\":\"Example value:\ - \ '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]},\"listOfImageIdToInclude_linux\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"Optional: List of VM images that have supported\ - \ Linux OS to add to scope\",\"description\":\"Example value: '/subscriptions//resourceGroups/YourResourceGroup/providers/Microsoft.Compute/images/ContosoStdImage'\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"not\":{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_windows')]\"\ - },{\"field\":\"Microsoft.Compute/imageId\",\"in\":\"[parameters('listOfImageIdToInclude_linux')]\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - in\":[\"2008-R2-SP1\",\"2008-R2-SP1-smalldisk\",\"2012-Datacenter\",\"2012-Datacenter-smalldisk\"\ - ,\"2012-R2-Datacenter\",\"2012-R2-Datacenter-smalldisk\",\"2016-Datacenter\"\ - ,\"2016-Datacenter-Server-Core\",\"2016-Datacenter-Server-Core-smalldisk\"\ - ,\"2016-Datacenter-smalldisk\",\"2016-Datacenter-with-Containers\",\"2016-Datacenter-with-RDSH\"\ - ,\"2019-Datacenter\",\"2019-Datacenter-Core\",\"2019-Datacenter-Core-smalldisk\"\ - ,\"2019-Datacenter-Core-with-Containers\",\"2019-Datacenter-Core-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-smalldisk\",\"2019-Datacenter-with-Containers\",\"2019-Datacenter-with-Containers-smalldisk\"\ - ,\"2019-Datacenter-zhcn\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"WindowsServerSemiAnnual\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"Datacenter-Core-1709-smalldisk\",\"Datacenter-Core-1709-with-Containers-smalldisk\"\ - ,\"Datacenter-Core-1803-with-Containers-smalldisk\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServerHPCPack\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"WindowsServerHPCPack\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"*-WS2016\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"*-WS2016-BYOL\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"\ - *-WS2012R2\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"*-WS2012R2-BYOL\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"MLServer-WS2016\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftVisualStudio\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"VisualStudio\",\"Windows\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftDynamicsAX\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Dynamics\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"equals\"\ - :\"Pre-Req-AX7-Onebox-U8\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"windows-data-science-vm\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsDesktop\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"Windows-10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"RHEL\",\"RHEL-SAP-HANA\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ - }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"SLES\",\"\ - SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-Priority\"\ - ,\"SLES-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"in\":[\"12-SP2\",\"12-SP3\",\"12-SP4\"]}]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"Canonical\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"UbuntuServer\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"in\":[\"14.04.0-LTS\"\ - ,\"14.04.1-LTS\",\"14.04.5-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"16.04-LTS\",\"16.04.0-LTS\"]},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"in\":[\"18.04-LTS\"]}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"Centos\",\"Centos-LVM\",\"CentOS-SRIOV\"]},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"like\":\"6.*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"like\":\"7*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ - :\"7*\"}]}]}}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"\ - type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Monitoring.DependencyAgent\"}}}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/e2dd799a-a932-4e9d-ac17-d473bc3c6c10\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e2dd799a-a932-4e9d-ac17-d473bc3c6c10\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1161 - Continuous\ - \ Monitoring\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1161\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e2f8f6c6-dde4-436b-a79d-bc50e129eb3a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e2f8f6c6-dde4-436b-a79d-bc50e129eb3a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1387 - Information\ - \ Spillage Response\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1387\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3007185-3857-43a9-8237-06ca94f1084c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3007185-3857-43a9-8237-06ca94f1084c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1479 - Fire\ - \ Protection | Automatic Fire Suppression\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Physical and Environmental\ - \ Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1479\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e327b072-281d-4f75-9c28-4216e5d72f26\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e327b072-281d-4f75-9c28-4216e5d72f26\"\ - },{\"properties\":{\"displayName\":\"Azure VPN gateways should not use 'basic'\ - \ SKU\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This\ - \ policy ensures that VPN gateways do not use 'basic' SKU.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworkGateways\"\ - },{\"field\":\"Microsoft.Network/virtualNetworkGateways/gatewayType\",\"equals\"\ - :\"Vpn\"},{\"field\":\"Microsoft.Network/virtualNetworkGateways/sku.tier\"\ - ,\"equals\":\"Basic\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/e345b6c3-24bd-4c93-9bbb-7e5e49a17b78\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e345b6c3-24bd-4c93-9bbb-7e5e49a17b78\"\ - },{\"properties\":{\"displayName\":\"MFA should be enabled on accounts with\ - \ read permissions on your subscription\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Multi-Factor Authentication (MFA) should be enabled\ - \ for all subscription accounts with read privileges to prevent a breach of\ - \ accounts or resources.\",\"metadata\":{\"version\":\"2.0.0\",\"category\"\ - :\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/assessments\"\ - ,\"name\":\"151e82c5-5341-a74b-1eb0-bc38d2c84bb5\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Security/assessments/status.code\",\"in\":[\"Healthy\"\ - ]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3576e28-8b17-4677-84c3-db2990658d64\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3576e28-8b17-4677-84c3-db2990658d64\"\ - },{\"properties\":{\"displayName\":\"RDP access from the Internet should be\ - \ blocked\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy audits any network security rule that allows RDP access from Internet\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Network\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - },{\"allOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Allow\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"},{\"anyOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange\"\ - ,\"equals\":\"*\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange\"\ - ,\"equals\":\"3389\"},{\"value\":\"[if(and(not(empty(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'))),\ - \ contains(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),'-')),\ - \ and(lessOrEquals(int(first(split(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),\ - \ '-'))),3389),greaterOrEquals(int(last(split(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRange'),\ - \ '-'))),3389)), 'false')]\",\"equals\":\"true\"},{\"count\":{\"field\":\"\ - Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"where\":{\"value\":\"[if(and(not(empty(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')))),\ - \ contains(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),'-')),\ - \ and(lessOrEquals(int(first(split(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),\ - \ '-'))),3389),greaterOrEquals(int(last(split(first(field('Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]')),\ - \ '-'))),3389)) , 'false')]\",\"equals\":\"true\"}},\"greater\":0},{\"not\"\ - :{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"notEquals\":\"*\"}},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/destinationPortRanges[*]\"\ - ,\"notEquals\":\"3389\"}}]},{\"anyOf\":[{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"*\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Internet\"},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]\"\ - ,\"notEquals\":\"*\"}},{\"not\":{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefixes[*]\"\ - ,\"notEquals\":\"Internet\"}}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e372f825-a257-4fb8-9175-797a8a8627d6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e372f825-a257-4fb8-9175-797a8a8627d6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Shutdown'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Shutdown'. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"deprecated\":true},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsShutdown\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3a77a94-cf41-4ee8-b45c-98be28841c03\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3a77a94-cf41-4ee8-b45c-98be28841c03\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Settings - Account Policies'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Settings\ - \ - Account Policies'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"EnforcePasswordHistory\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Enforce password history\",\"description\"\ - :\"Specifies limits on password reuse - how many times a new password must\ - \ be created for a user account before the password can be repeated.\"},\"\ - defaultValue\":\"24\"},\"MaximumPasswordAge\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Maximum password age\",\"description\":\"\ - Specifies the maximum number of days that may elapse before a user account\ - \ password must be changed. The format of the value is two integers separated\ - \ by a comma, denoting an inclusive range.\"},\"defaultValue\":\"1,70\"},\"\ - MinimumPasswordAge\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - [Deprecated]: Minimum password age\",\"description\":\"Specifies the minimum\ - \ number of days that must elapse before a user account password can be changed.\"\ - },\"defaultValue\":\"1\"},\"MinimumPasswordLength\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Deprecated]: Minimum password length\",\"description\"\ - :\"Specifies the minimum number of characters that a user account password\ - \ may contain.\"},\"defaultValue\":\"14\"},\"PasswordMustMeetComplexityRequirements\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Password\ - \ must meet complexity requirements\",\"description\":\"Specifies whether\ - \ a user account password must be complex. If required, a complex password\ - \ must not contain part of user's account name or full name; be at least\ - \ 6 characters long; contain a mix of uppercase, lowercase, number, and non-alphabetic\ - \ characters.\"},\"defaultValue\":\"1\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecuritySettingsAccountPolicies\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Enforce password history;ExpectedValue', '=',\ - \ parameters('EnforcePasswordHistory'), ',', 'Maximum password age;ExpectedValue',\ - \ '=', parameters('MaximumPasswordAge'), ',', 'Minimum password age;ExpectedValue',\ - \ '=', parameters('MinimumPasswordAge'), ',', 'Minimum password length;ExpectedValue',\ - \ '=', parameters('MinimumPasswordLength'), ',', 'Password must meet complexity\ - \ requirements;ExpectedValue', '=', parameters('PasswordMustMeetComplexityRequirements')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecuritySettingsAccountPolicies\"},\"EnforcePasswordHistory\"\ - :{\"value\":\"[parameters('EnforcePasswordHistory')]\"},\"MaximumPasswordAge\"\ - :{\"value\":\"[parameters('MaximumPasswordAge')]\"},\"MinimumPasswordAge\"\ - :{\"value\":\"[parameters('MinimumPasswordAge')]\"},\"MinimumPasswordLength\"\ - :{\"value\":\"[parameters('MinimumPasswordLength')]\"},\"PasswordMustMeetComplexityRequirements\"\ - :{\"value\":\"[parameters('PasswordMustMeetComplexityRequirements')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"EnforcePasswordHistory\":{\"type\":\"string\"},\"\ - MaximumPasswordAge\":{\"type\":\"string\"},\"MinimumPasswordAge\":{\"type\"\ - :\"string\"},\"MinimumPasswordLength\":{\"type\":\"string\"},\"PasswordMustMeetComplexityRequirements\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Enforce password\ - \ history;ExpectedValue\",\"value\":\"[parameters('EnforcePasswordHistory')]\"\ - },{\"name\":\"Maximum password age;ExpectedValue\",\"value\":\"[parameters('MaximumPasswordAge')]\"\ - },{\"name\":\"Minimum password age;ExpectedValue\",\"value\":\"[parameters('MinimumPasswordAge')]\"\ - },{\"name\":\"Minimum password length;ExpectedValue\",\"value\":\"[parameters('MinimumPasswordLength')]\"\ - },{\"name\":\"Password must meet complexity requirements;ExpectedValue\",\"\ - value\":\"[parameters('PasswordMustMeetComplexityRequirements')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Enforce password\ - \ history;ExpectedValue\",\"value\":\"[parameters('EnforcePasswordHistory')]\"\ - },{\"name\":\"Maximum password age;ExpectedValue\",\"value\":\"[parameters('MaximumPasswordAge')]\"\ - },{\"name\":\"Minimum password age;ExpectedValue\",\"value\":\"[parameters('MinimumPasswordAge')]\"\ - },{\"name\":\"Minimum password length;ExpectedValue\",\"value\":\"[parameters('MinimumPasswordLength')]\"\ - },{\"name\":\"Password must meet complexity requirements;ExpectedValue\",\"\ - value\":\"[parameters('PasswordMustMeetComplexityRequirements')]\"}]}}},{\"\ - condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3d95ab7-f47a-49d8-a347-784177b6c94c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3d95ab7-f47a-49d8-a347-784177b6c94c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1451 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1451\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e3f1e5a3-25c1-4476-8cb6-3955031f8e65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3f1e5a3-25c1-4476-8cb6-3955031f8e65\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1357 - Incident\ - \ Response Training | Automated Training Environments\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Incident Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1357\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e4213689-05e8-4241-9d4e-8dd1cdafd105\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e4213689-05e8-4241-9d4e-8dd1cdafd105\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - User Account Control'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - User Account Control'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"UACAdminApprovalModeForTheBuiltinAdministratorAccount\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: UAC: Admin\ - \ Approval Mode for the Built-in Administrator account\",\"description\":\"\ - Specifies the behavior of Admin Approval Mode for the built-in Administrator\ - \ account.\"},\"defaultValue\":\"1\"},\"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: UAC: Behavior\ - \ of the elevation prompt for administrators in Admin Approval Mode\",\"description\"\ - :\"Specifies the behavior of the elevation prompt for administrators.\"},\"\ - defaultValue\":\"2\"},\"UACDetectApplicationInstallationsAndPromptForElevation\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: UAC: Detect\ - \ application installations and prompt for elevation\",\"description\":\"\ - Specifies the behavior of application installation detection for the computer.\"\ - },\"defaultValue\":\"1\"},\"UACRunAllAdministratorsInAdminApprovalMode\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: UAC: Run all\ - \ administrators in Admin Approval Mode\",\"description\":\"Specifies the\ - \ behavior of all User Account Control (UAC) policy settings for the computer.\"\ - },\"defaultValue\":\"1\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsUserAccountControl\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('User Account Control: Admin Approval Mode for\ - \ the Built-in Administrator account;ExpectedValue', '=', parameters('UACAdminApprovalModeForTheBuiltinAdministratorAccount'),\ - \ ',', 'User Account Control: Behavior of the elevation prompt for administrators\ - \ in Admin Approval Mode;ExpectedValue', '=', parameters('UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode'),\ - \ ',', 'User Account Control: Detect application installations and prompt\ - \ for elevation;ExpectedValue', '=', parameters('UACDetectApplicationInstallationsAndPromptForElevation'),\ - \ ',', 'User Account Control: Run all administrators in Admin Approval Mode;ExpectedValue',\ - \ '=', parameters('UACRunAllAdministratorsInAdminApprovalMode')))]\"},\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsUserAccountControl\"},\"UACAdminApprovalModeForTheBuiltinAdministratorAccount\"\ - :{\"value\":\"[parameters('UACAdminApprovalModeForTheBuiltinAdministratorAccount')]\"\ - },\"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode\"\ - :{\"value\":\"[parameters('UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode')]\"\ - },\"UACDetectApplicationInstallationsAndPromptForElevation\":{\"value\":\"\ - [parameters('UACDetectApplicationInstallationsAndPromptForElevation')]\"},\"\ - UACRunAllAdministratorsInAdminApprovalMode\":{\"value\":\"[parameters('UACRunAllAdministratorsInAdminApprovalMode')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"UACAdminApprovalModeForTheBuiltinAdministratorAccount\"\ - :{\"type\":\"string\"},\"UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode\"\ - :{\"type\":\"string\"},\"UACDetectApplicationInstallationsAndPromptForElevation\"\ - :{\"type\":\"string\"},\"UACRunAllAdministratorsInAdminApprovalMode\":{\"\ - type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"User Account\ - \ Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue\"\ - ,\"value\":\"[parameters('UACAdminApprovalModeForTheBuiltinAdministratorAccount')]\"\ - },{\"name\":\"User Account Control: Behavior of the elevation prompt for administrators\ - \ in Admin Approval Mode;ExpectedValue\",\"value\":\"[parameters('UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode')]\"\ - },{\"name\":\"User Account Control: Detect application installations and prompt\ - \ for elevation;ExpectedValue\",\"value\":\"[parameters('UACDetectApplicationInstallationsAndPromptForElevation')]\"\ - },{\"name\":\"User Account Control: Run all administrators in Admin Approval\ - \ Mode;ExpectedValue\",\"value\":\"[parameters('UACRunAllAdministratorsInAdminApprovalMode')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"User Account\ - \ Control: Admin Approval Mode for the Built-in Administrator account;ExpectedValue\"\ - ,\"value\":\"[parameters('UACAdminApprovalModeForTheBuiltinAdministratorAccount')]\"\ - },{\"name\":\"User Account Control: Behavior of the elevation prompt for administrators\ - \ in Admin Approval Mode;ExpectedValue\",\"value\":\"[parameters('UACBehaviorOfTheElevationPromptForAdministratorsInAdminApprovalMode')]\"\ - },{\"name\":\"User Account Control: Detect application installations and prompt\ - \ for elevation;ExpectedValue\",\"value\":\"[parameters('UACDetectApplicationInstallationsAndPromptForElevation')]\"\ - },{\"name\":\"User Account Control: Run all administrators in Admin Approval\ - \ Mode;ExpectedValue\",\"value\":\"[parameters('UACRunAllAdministratorsInAdminApprovalMode')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e425e402-a050-45e5-b010-bd3f934589fc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e425e402-a050-45e5-b010-bd3f934589fc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1340 - Authenticator\ - \ Management | No Embedded Unencrypted Static Authenticators\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Identification and Authentication control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1340\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e51ff84b-e5ea-408f-b651-2ecc2933e4c6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e51ff84b-e5ea-408f-b651-2ecc2933e4c6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1381 - Incident\ - \ Response Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1381\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e5368258-9684-4567-8126-269f34e65eab\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e5368258-9684-4567-8126-269f34e65eab\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1421 - Maintenance\ - \ Personnel\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1421\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e539caaa-da8c-41b8-9e1e-449851e2f7a6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e539caaa-da8c-41b8-9e1e-449851e2f7a6\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1716 - Software,\ - \ Firmware, And Information Integrity | Integration Of Detection And Response\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1716\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e54c325e-42a0-4dcf-b105-046e0f6f590f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e54c325e-42a0-4dcf-b105-046e0f6f590f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1023 - Account\ - \ Management | Usage Conditions\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Access Control control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1023\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e55698b6-3dea-4aa9-99b9-d8218c6ab6e5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e55698b6-3dea-4aa9-99b9-d8218c6ab6e5\"\ - },{\"properties\":{\"displayName\":\"Allowed locations\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy enables you to\ - \ restrict the locations your organization can specify when deploying resources.\ - \ Use to enforce your geo-compliance requirements. Excludes resource groups,\ - \ Microsoft.AzureActiveDirectory/b2cDirectories, and resources that use the\ - \ 'global' region.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"General\"\ - },\"parameters\":{\"listOfAllowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"description\":\"The list of locations that can be specified when deploying\ - \ resources.\",\"strongType\":\"location\",\"displayName\":\"Allowed locations\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"notIn\":\"\ - [parameters('listOfAllowedLocations')]\"},{\"field\":\"location\",\"notEquals\"\ - :\"global\"},{\"field\":\"type\",\"notEquals\":\"Microsoft.AzureActiveDirectory/b2cDirectories\"\ - }]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e56962a6-4747-49cd-b67b-bf8b01975c4c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e56962a6-4747-49cd-b67b-bf8b01975c4c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1296 - Information\ - \ System Recovery And Reconstitution | Transaction Recovery\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1296\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e57b98a0-a011-4956-a79d-5d17ed8b8e48\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e57b98a0-a011-4956-a79d-5d17ed8b8e48\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1499 - Rules\ - \ Of Behavior\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1499\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e59671ab-9720-4ee2-9c60-170e8c82251e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e59671ab-9720-4ee2-9c60-170e8c82251e\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Accounts'\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines with non-compliant\ - \ settings in Group Policy category: 'Security Options - Accounts'. It also\ - \ creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AccountsGuestAccountStatus\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Accounts: Guest account status\",\"description\"\ - :\"Specifies whether the local Guest account is disabled.\"},\"defaultValue\"\ - :\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsAccounts\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Accounts: Guest account status;ExpectedValue',\ - \ '=', parameters('AccountsGuestAccountStatus')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SecurityOptionsAccounts\"\ - },\"AccountsGuestAccountStatus\":{\"value\":\"[parameters('AccountsGuestAccountStatus')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AccountsGuestAccountStatus\":{\"type\":\"string\"\ - }},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Accounts: Guest\ - \ account status;ExpectedValue\",\"value\":\"[parameters('AccountsGuestAccountStatus')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Accounts: Guest\ - \ account status;ExpectedValue\",\"value\":\"[parameters('AccountsGuestAccountStatus')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e5b81f87-9185-4224-bf00-9f505e9f89f3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e5b81f87-9185-4224-bf00-9f505e9f89f3\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Applications\ - \ that are not using latest supported Node.js Framework\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"Use the latest supported Node.js\ - \ version for the latest security classes. Using older classes and types can\ - \ make your application vulnerable.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"Security Center\",\"deprecated\":true},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"type\"\ - ,\"equals\":\"microsoft.Web/sites\"},{\"anyof\":[{\"field\":\"kind\",\"equals\"\ - :\"app,linux\"},{\"field\":\"kind\",\"equals\":\"app,linux,container\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Security/complianceResults\"\ - ,\"name\":\"UseLatestNodeJS\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e67687e8-08d5-4e7f-8226-5b4753bba008\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e67687e8-08d5-4e7f-8226-5b4753bba008\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that do not have\ - \ the passwd file permissions set to 0644\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if Linux machines that do not have the passwd\ - \ file permissions set to 0644\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"PasswordPolicy_msid121\",\"version\"\ - :\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Include Arc connected servers\",\"description\"\ - :\"By selecting this option, you agree to be charged monthly per Arc connected\ - \ machine.\"},\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid121\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e6955644-301c-44b5-a4c4-528577de6861\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e6955644-301c-44b5-a4c4-528577de6861\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1465 - Monitoring\ - \ Physical Access | Monitoring Physical Access To Information Systems\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this Physical and Environmental Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1465\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e6e41554-86b5-4537-9f7f-4fc41a1d1640\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e6e41554-86b5-4537-9f7f-4fc41a1d1640\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines on which the specified\ - \ services are not installed and 'Running'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if result of the Windows PowerShell command Get-Service\ - \ do not include the service name with matching status as specified by the\ - \ policy parameter.\",\"metadata\":{\"category\":\"Guest Configuration\",\"\ - version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"WindowsServiceStatus\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"ServiceName\":\"[WindowsServiceStatus]WindowsServiceStatus1;ServiceName\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"ServiceName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Service names (supports\ - \ wildcards)\",\"description\":\"A semicolon-separated list of the names of\ - \ the services that should be installed and 'Running'. e.g. 'WinRm;Wi*'\"\ - }}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"\ - equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\"\ - ,\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\"\ - ,\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsServiceStatus\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[WindowsServiceStatus]WindowsServiceStatus1;ServiceName',\ - \ '=', parameters('ServiceName')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e6ebf138-3d71-4935-a13b-9c7fdddd94df\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e6ebf138-3d71-4935-a13b-9c7fdddd94df\"\ - },{\"properties\":{\"displayName\":\"Subnets should be associated with a Network\ - \ Security Group\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"Protect your subnet from potential threats by restricting access to it\ - \ with a Network Security Group (NSG). NSGs contain a list of Access Control\ - \ List (ACL) rules that allow or deny network traffic to your subnet.\",\"\ - metadata\":{\"version\":\"3.0.0\",\"category\":\"Security Center\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"eade5b56-eefd-444f-95c8-23f29e5d93cb\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"NotApplicable\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e71308d3-144b-4262-b144-efdc3cc90517\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e71308d3-144b-4262-b144-efdc3cc90517\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1567 - System\ - \ Development Life Cycle\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this System and Services Acquisition\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1567\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e72edbf6-aa61-436d-a227-0f32b77194b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e72edbf6-aa61-436d-a227-0f32b77194b3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1311 - Identifier\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1311\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e7568697-0c9e-4ea3-9cec-9e567d14f3c6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e7568697-0c9e-4ea3-9cec-9e567d14f3c6\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Advanced Threat Protection\ - \ types should be set to 'All' in SQL server Advanced Data Security settings\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"It is recommended\ - \ to enable all Advanced Threat Protection types on your SQL servers. Enabling\ - \ all types protects against SQL injection, database vulnerabilities, and\ - \ any other anomalous activities.\",\"metadata\":{\"version\":\"1.0.0-deprecated\"\ - ,\"category\":\"SQL\",\"deprecated\":true},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"Disabled\"}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/disabledAlerts[*]\"\ - ,\"equals\":\"\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e756b945-1b1b-480b-8de8-9a0859d5f7ad\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e756b945-1b1b-480b-8de8-9a0859d5f7ad\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1154 - System\ - \ Interconnections | Unclassified Non-National Security System Connections\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Security Assessment and Authorization control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1154\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e757ceb9-93b3-45fe-a4f4-f43f64f1ac5a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e757ceb9-93b3-45fe-a4f4-f43f64f1ac5a\"\ - },{\"properties\":{\"displayName\":\"Allowed locations for resource groups\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ enables you to restrict the locations your organization can create resource\ - \ groups in. Use to enforce your geo-compliance requirements.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"General\"},\"parameters\":{\"listOfAllowedLocations\"\ - :{\"type\":\"Array\",\"metadata\":{\"description\":\"The list of locations\ - \ that resource groups can be created in.\",\"strongType\":\"location\",\"\ - displayName\":\"Allowed locations\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions/resourceGroups\"\ - },{\"field\":\"location\",\"notIn\":\"[parameters('listOfAllowedLocations')]\"\ - }]},\"then\":{\"effect\":\"deny\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e765b5de-1225-4ba3-bd56-1ac6695af988\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e765b5de-1225-4ba3-bd56-1ac6695af988\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1273 - Alternate\ - \ Processing Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Contingency Planning control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1273\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e77fcbf2-a1e8-44f1-860e-ed6583761e65\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e77fcbf2-a1e8-44f1-860e-ed6583761e65\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Audit Web Sockets state\ - \ for a Web Application\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\"\ - :\"The Web Sockets protocol is vulnerable to different types of security threats.\ - \ Use of Web Sockets within a web application must be carefully reviewed.\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Security Center\"\ - ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allof\":[{\"field\":\"type\",\"equals\":\"microsoft.Web/sites\"},{\"anyof\"\ - :[{\"field\":\"kind\",\"equals\":\"app\"},{\"field\":\"kind\",\"equals\":\"\ - WebApp\"},{\"field\":\"kind\",\"equals\":\"app,linux\"},{\"field\":\"kind\"\ - ,\"equals\":\"app,linux,container\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - DisableWebSockets\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e797f851-8be7-4c40-bb56-2e3395215b0e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e797f851-8be7-4c40-bb56-2e3395215b0e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1169 - Continuous\ - \ Monitoring | Trend Analyses\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Security Assessment and Authorization\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1169\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e7ba2cb3-5675-4468-8b50-8486bdd998a5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e7ba2cb3-5675-4468-8b50-8486bdd998a5\"\ - },{\"properties\":{\"displayName\":\"Enforce SSL connection should be enabled\ - \ for MySQL database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any MySQL server that is not enforcing\ - \ SSL connection. Azure Database for MySQL supports connecting your Azure\ - \ Database for MySQL server to client applications using Secure Sockets Layer\ - \ (SSL). Enforcing SSL connections between your database server and your client\ - \ applications helps protect against 'man in the middle' attacks by encrypting\ - \ the data stream between the server and your application.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMySQL/servers\"\ - },{\"field\":\"Microsoft.DBforMySQL/servers/sslEnforcement\",\"exists\":\"\ - true\"},{\"field\":\"Microsoft.DBforMySQL/servers/sslEnforcement\",\"notEquals\"\ - :\"Enabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/e802a67a-daf5-4436-9ea6-f6d821dd0c5d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e802a67a-daf5-4436-9ea6-f6d821dd0c5d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1237 - Software\ - \ Usage Restrictions | Open Source Software\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1237\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e80b6812-0bfa-4383-8223-cdd86a46a890\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e80b6812-0bfa-4383-8223-cdd86a46a890\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities in container security\ - \ configurations should be remediated\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"All\",\"description\":\"Audit vulnerabilities in security configuration\ - \ on machines with Docker installed and display as recommendations in Azure\ - \ Security Center.\",\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security\ - \ Center\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ,\"Microsoft.Compute/virtualMachineScaleSets\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"0677209d-e675-2c6f-e91a-54cef2878663\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e8cbc669-f12d-49eb-93e7-9273119e9933\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8cbc669-f12d-49eb-93e7-9273119e9933\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Data Lake\ - \ Storage Gen1 to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Data Lake Storage Gen1\ - \ to stream to a regional Event Hub when any Data Lake Storage Gen1 which\ - \ is missing this diagnostic settings is created or updated.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - DeployIfNotExists\",\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"\ - profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Profile\ - \ name\",\"description\":\"The diagnostic settings profile name\"},\"defaultValue\"\ - :\"setbypolicy_eventHub\"},\"eventHubRuleId\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Event Hub Authorization Rule Id\",\"description\":\"The\ - \ Event Hub authorization rule Id for Azure Diagnostics. The authorization\ - \ rule needs to be at Event Hub namespace level. e.g. /subscriptions/{subscription\ - \ Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ - \ in. Only Data Lake Storage in this location will be linked to this Event\ - \ Hub.\",\"strongType\":\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"\ - description\":\"Whether to enable metrics stream to the Event Hub - True or\ - \ False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"\ - },\"logsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable\ - \ logs\",\"description\":\"Whether to enable logs stream to the Event Hub\ - \ - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"defaultValue\"\ - :\"True\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.DataLakeStore/accounts\"},{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\"\ - ,\"equals\":\"\"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.DataLakeStore/accounts/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Audit\",\"enabled\":\"[parameters('logsEnabled')]\"\ - },{\"category\":\"Requests\",\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"\ - outputs\":{}},\"parameters\":{\"location\":{\"value\":\"[field('location')]\"\ - },\"resourceName\":{\"value\":\"[field('name')]\"},\"eventHubRuleId\":{\"\ - value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\":{\"value\"\ - :\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\":\"[parameters('logsEnabled')]\"\ - },\"profileName\":{\"value\":\"[parameters('profileName')]\"}}}}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/e8d096bc-85de-4c5f-8cfb-857bd1b9d62d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8d096bc-85de-4c5f-8cfb-857bd1b9d62d\"\ - },{\"properties\":{\"displayName\":\"Container registries should use private\ - \ links\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit container registries that do not have at least one approved private\ - \ endpoint connection. Clients in a virtual network can securely access resources\ - \ that have private endpoint connections through private links. Public access\ - \ can then be disabled to ensure that only private links can be used to connect\ - \ to the registry. For more information, visit: https://aka.ms/acr/private-link.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Container Registry\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerRegistry/registries\"\ - },{\"count\":{\"field\":\"Microsoft.ContainerRegistry/registries/privateEndpointConnections[*]\"\ - ,\"where\":{\"field\":\"Microsoft.ContainerRegistry/registries/privateEndpointConnections[*].privateLinkServiceConnectionState.status\"\ - ,\"equals\":\"Approved\"}},\"less\":1}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e8eef0a8-67cf-4eb4-9386-14b0e78733d4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8eef0a8-67cf-4eb4-9386-14b0e78733d4\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1626 - Boundary\ - \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1626\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e8f6bddd-6d67-439a-88d4-c5fe39a79341\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8f6bddd-6d67-439a-88d4-c5fe39a79341\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1502 - Rules\ - \ Of Behavior | Social Media And Networking Restrictions\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1502\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e901375c-8f01-4ac8-9183-d5312f47fe63\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e901375c-8f01-4ac8-9183-d5312f47fe63\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1723 - Information\ - \ Input Validation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Information Integrity control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1723\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e91927a0-ac1d-44a0-95f8-5185f9dfce9f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e91927a0-ac1d-44a0-95f8-5185f9dfce9f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1200 - Security\ - \ Impact Analysis\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1200\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e98fe9d7-2ed3-44f8-93b7-24dca69783ff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e98fe9d7-2ed3-44f8-93b7-24dca69783ff\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1487 - Alternate\ - \ Work Site\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1487\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e9c3371d-c30c-4f58-abd9-30b8a8199571\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e9c3371d-c30c-4f58-abd9-30b8a8199571\"\ - },{\"properties\":{\"displayName\":\"Remote debugging should be turned off\ - \ for API Apps\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Remote debugging requires inbound ports to be opened on API apps. Remote\ - \ debugging should be turned off.\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"*api\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/remoteDebuggingEnabled\"\ - ,\"equals\":\"false\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e9c8d085-d9cc-4b17-9cdc-059f1f01f19e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e9c8d085-d9cc-4b17-9cdc-059f1f01f19e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1363 - Incident\ - \ Handling | Automated Incident Handling Processes\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Incident\ - \ Response control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1363\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea3e8156-89a1-45b1-8bd6-938abc79fdfd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea3e8156-89a1-45b1-8bd6-938abc79fdfd\"\ - },{\"properties\":{\"displayName\":\"Inherit a tag from the resource group\ - \ if missing\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Adds the specified tag with its value from the parent resource group when\ - \ any resource missing this tag is created or updated. Existing resources\ - \ can be remediated by triggering a remediation task. If the tag exists with\ - \ a different value it will not be changed.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Tags\"},\"parameters\":{\"tagName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Name of the\ - \ tag, such as 'environment'\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"},{\"\ - value\":\"[resourceGroup().tags[parameters('tagName')]]\",\"notEquals\":\"\ - \"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"operations\":[{\"operation\":\"add\",\"field\":\"[concat('tags[', parameters('tagName'),\ - \ ']')]\",\"value\":\"[resourceGroup().tags[parameters('tagName')]]\"}]}}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea3f2387-9b95-492a-a190-fcdc54f7b070\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea3f2387-9b95-492a-a190-fcdc54f7b070\"\ - },{\"properties\":{\"displayName\":\"Key Vault should use a virtual network\ - \ service endpoint\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy audits any Key Vault not configured to use a virtual network\ - \ service endpoint.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Network\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\"\ - :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.KeyVault/vaults\"},{\"anyOf\":[{\"field\":\"Microsoft.KeyVault/vaults/networkAcls.defaultAction\"\ - ,\"notEquals\":\"Deny\"},{\"field\":\"Microsoft.KeyVault/vaults/networkAcls.virtualNetworkRules[*].id\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea4d6841-2173-4317-9747-ff522a45120f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea4d6841-2173-4317-9747-ff522a45120f\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that allow remote\ - \ connections from accounts without passwords\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if Linux machines that allow remote connections\ - \ from accounts without passwords\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"PasswordPolicy_msid110\",\"version\"\ - :\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Include Arc connected servers\",\"description\"\ - :\"By selecting this option, you agree to be charged monthly per Arc connected\ - \ machine.\"},\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid110\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea53dbee-c6c9-4f0e-9f9e-de0039b78023\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea53dbee-c6c9-4f0e-9f9e-de0039b78023\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1422 - Maintenance\ - \ Personnel\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Maintenance control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1422\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ea556850-838d-4a37-8ce5-9d7642f95e11\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ea556850-838d-4a37-8ce5-9d7642f95e11\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1542 - Risk\ - \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1542\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eab340d0-3d55-4826-a0e5-feebfeb0131d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eab340d0-3d55-4826-a0e5-feebfeb0131d\"\ - },{\"properties\":{\"displayName\":\"Ensure Function app has 'Client Certificates\ - \ (Incoming client certificates)' set to 'On'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Client certificates allow for the\ - \ app to request a certificate for incoming requests. Only clients that have\ - \ a valid certificate will be able to reach the app.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\":\"kind\"\ - ,\"like\":\"functionapp*\"},{\"field\":\"Microsoft.Web/sites/clientCertEnabled\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/eaebaea7-8013-4ceb-9d14-7eb32271373c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eaebaea7-8013-4ceb-9d14-7eb32271373c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1064 - Remote\ - \ Access | Privileged Commands / Access\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1064\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb4d9508-cbf0-4a3c-bb5c-6c95b159f3fb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb4d9508-cbf0-4a3c-bb5c-6c95b159f3fb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1321 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1321\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb627cc6-3a9d-46b5-96b7-5fca49178a37\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb627cc6-3a9d-46b5-96b7-5fca49178a37\"\ - },{\"properties\":{\"displayName\":\"Log checkpoints should be enabled for\ - \ PostgreSQL database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy helps audit any PostgreSQL databases in your\ - \ environment without log_checkpoints setting enabled.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforPostgreSQL/servers/configurations\",\"name\":\"log_checkpoints\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/configurations/value\"\ - ,\"equals\":\"ON\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e43d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb6f77b9-bd53-4e35-a23d-7f65d5f0e43d\"\ - },{\"properties\":{\"displayName\":\"Log connections should be enabled for\ - \ PostgreSQL database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy helps audit any PostgreSQL databases in your\ - \ environment without log_connections setting enabled.\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.DBforPostgreSQL/servers/configurations\",\"name\":\"log_connections\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/configurations/value\"\ - ,\"equals\":\"ON\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e442\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb6f77b9-bd53-4e35-a23d-7f65d5f0e442\"\ - },{\"properties\":{\"displayName\":\"Disconnections should be logged for PostgreSQL\ - \ database servers.\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy helps audit any PostgreSQL databases in your environment without\ - \ log_disconnections enabled.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.DBforPostgreSQL/servers/configurations\"\ - ,\"name\":\"log_disconnections\",\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/configurations/value\"\ - ,\"equals\":\"ON\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e446\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb6f77b9-bd53-4e35-a23d-7f65d5f0e446\"\ - },{\"properties\":{\"displayName\":\"Log duration should be enabled for PostgreSQL\ - \ database servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy helps audit any PostgreSQL databases in your environment without\ - \ log_duration setting enabled.\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"SQL\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.DBforPostgreSQL/servers\"},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.DBforPostgreSQL/servers/configurations\"\ - ,\"name\":\"log_duration\",\"existenceCondition\":{\"field\":\"Microsoft.DBforPostgreSQL/servers/configurations/value\"\ - ,\"equals\":\"ON\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eb6f77b9-bd53-4e35-a23d-7f65d5f0e8f3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb6f77b9-bd53-4e35-a23d-7f65d5f0e8f3\"\ - },{\"properties\":{\"displayName\":\"Deprecated accounts with owner permissions\ - \ should be removed from your subscription\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"All\",\"description\":\"Deprecated accounts with owner permissions\ - \ should be removed from your subscription. Deprecated accounts are accounts\ - \ that have been blocked from signing in.\",\"metadata\":{\"version\":\"2.0.0\"\ - ,\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"e52064aa-6853-e252-a11e-dffc675689c2\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ebb62a0c-3560-49e1-89ed-27e074e9f8ad\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ebb62a0c-3560-49e1-89ed-27e074e9f8ad\"\ - },{\"properties\":{\"displayName\":\"Audit Windows machines that don't have\ - \ the specified applications installed\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Requires that prerequisites are deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol. Machines\ - \ are non-compliant if the application name is not found in any of the following\ - \ registry paths: HKLM:SOFTWARE\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\ - \\Uninstall, HKLM:SOFTWARE\\\\Wow6432node\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\ - \\Uninstall, HKCU:Software\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Uninstall.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"1.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"WhitelistedApplication\",\"version\":\"1.*\",\"configurationParameter\"\ - :{\"installedApplication\":\"[InstalledApplication]bwhitelistedapp;Name\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"installedApplication\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Application names (supports\ - \ wildcards)\",\"description\":\"A semicolon-separated list of the names of\ - \ the applications that should be installed. e.g. 'Microsoft SQL Server 2014\ - \ (64-bit); Microsoft Visual Studio Code' or 'Microsoft SQL Server 2014*'\ - \ (to match any application starting with 'Microsoft SQL Server 2014')\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WhitelistedApplication\",\"existenceCondition\":{\"allOf\":[{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[InstalledApplication]bwhitelistedapp;Name',\ - \ '=', parameters('installedApplication')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ebb67efd-3c46-49b0-adfe-5599eb944998\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ebb67efd-3c46-49b0-adfe-5599eb944998\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Linux VMs that allow remote connections from accounts without passwords\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Linux virtual machines\ - \ that allow remote connections from accounts without passwords. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"3.0.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid110\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"PasswordPolicy_msid110\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ec49586f-4939-402d-a29e-6ff502b20592\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ec49586f-4939-402d-a29e-6ff502b20592\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Administrative Templates - Control\ - \ Panel'\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines with non-compliant settings in Group Policy category: 'Administrative\ - \ Templates - Control Panel'. It also creates a system-assigned managed identity\ - \ and deploys the VM extension for Guest Configuration. This policy should\ - \ only be used along with its corresponding audit policy in an initiative.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdministrativeTemplatesControlPanel\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_AdministrativeTemplatesControlPanel\"}},\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ec7ac234-2af5-4729-94d2-c557c071799d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ec7ac234-2af5-4729-94d2-c557c071799d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1241 - User-Installed\ - \ Software | Alerts For Unauthorized Installations\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1241\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/eca4d7b2-65e2-4e04-95d4-c68606b063c3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eca4d7b2-65e2-4e04-95d4-c68606b063c3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1622 - Boundary\ - \ Protection\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1622\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ecf56554-164d-499a-8d00-206b07c27bed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ecf56554-164d-499a-8d00-206b07c27bed\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Key Vault\ - \ to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploys the diagnostic settings for Key Vault to stream to a regional Event\ - \ Hub when any Key Vault which is missing this diagnostic settings is created\ - \ or updated.\",\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Key Vault\"\ - },\"parameters\":{\"profileName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Profile name\",\"description\":\"The diagnostic settings profile name\"\ - },\"defaultValue\":\"setbypolicy\"},\"eventHubRuleId\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Event Hub Authorization Rule Id\",\"description\"\ - :\"The Event Hub authorization rule Id for Azure Diagnostics. The authorization\ - \ rule needs to be at Event Hub namespace level. e.g. /subscriptions/{subscription\ - \ Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Location\",\"description\":\"The location the Event Hub resides\ - \ in. Only Key Vaults in this location will be linked to this Event Hub.\"\ - ,\"strongType\":\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Enable metrics\",\"description\"\ - :\"Whether to enable metrics stream to the Event Hub - True or False\"},\"\ - allowedValues\":[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ - :\"Whether to enable logs stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"},{\"\ - anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\"},{\"\ - field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Insights/diagnosticSettings\"\ - ,\"name\":\"[parameters('profileName')]\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\",\"equals\"\ - :\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vaultName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"resources\":[{\"\ - type\":\"Microsoft.KeyVault/vaults/providers/diagnosticSettings\",\"apiVersion\"\ - :\"2017-05-01-preview\",\"name\":\"[concat(parameters('vaultName'), '/', 'Microsoft.Insights/',\ - \ parameters('profileName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\":\"[parameters('eventHubRuleId')]\"\ - ,\"metrics\":[{\"category\":\"AllMetrics\",\"enabled\":\"[parameters('metricsEnabled')]\"\ - ,\"retentionPolicy\":{\"enabled\":false,\"days\":0}}],\"logs\":[{\"category\"\ - :\"AuditEvent\",\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"outputs\"\ - :{\"policy\":{\"type\":\"string\",\"value\":\"[concat('Enabled diagnostic\ - \ settings for ', parameters('vaultName'))]\"}}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"vaultName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ed7c8c13-51e7-49d1-8a43-8490431a0da2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ed7c8c13-51e7-49d1-8a43-8490431a0da2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1217 - Least\ - \ Functionality | Periodic Review\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this Configuration Management\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1217\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/edea4f20-b02c-4115-be75-86c080e5c0ed\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"edea4f20-b02c-4115-be75-86c080e5c0ed\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Stream\ - \ Analytics to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"Deploys the diagnostic settings for Stream Analytics to\ - \ stream to a regional Event Hub when any Stream Analytics which is missing\ - \ this diagnostic settings is created or updated.\",\"metadata\":{\"version\"\ - :\"2.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"DeployIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"DeployIfNotExists\"},\"profileName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Profile name\",\"description\"\ - :\"The diagnostic settings profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"\ - },\"eventHubRuleId\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Event Hub Authorization Rule Id\",\"description\":\"The Event Hub authorization\ - \ rule Id for Azure Diagnostics. The authorization rule needs to be at Event\ - \ Hub namespace level. e.g. /subscriptions/{subscription Id}/resourceGroups/{resource\ - \ group}/providers/Microsoft.EventHub/namespaces/{Event Hub namespace}/authorizationrules/{authorization\ - \ rule}\",\"strongType\":\"Microsoft.EventHub/Namespaces/AuthorizationRules\"\ - ,\"assignPermissions\":true}},\"eventHubLocation\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Event Hub Location\",\"description\":\"The location\ - \ the Event Hub resides in. Only Stream Analytics in this location will be\ - \ linked to this Event Hub.\",\"strongType\":\"location\"},\"defaultValue\"\ - :\"\"},\"metricsEnabled\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Enable metrics\",\"description\":\"Whether to enable metrics stream to\ - \ the Event Hub - True or False\"},\"allowedValues\":[\"True\",\"False\"],\"\ - defaultValue\":\"False\"},\"logsEnabled\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Enable logs\",\"description\":\"Whether to enable logs\ - \ stream to the Event Hub - True or False\"},\"allowedValues\":[\"True\"\ - ,\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.StreamAnalytics/streamingjobs\"\ - },{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\ - \"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.StreamAnalytics/streamingjobs/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"Execution\",\"enabled\":\"\ - [parameters('logsEnabled')]\"},{\"category\":\"Authoring\",\"enabled\":\"\ - [parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\":{\"location\"\ - :{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\":\"[field('name')]\"\ - },\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"},\"metricsEnabled\"\ - :{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\":{\"value\"\ - :\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"[parameters('profileName')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/edf3780c-3d70-40fe-b17e-ab72013dafca\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"edf3780c-3d70-40fe-b17e-ab72013dafca\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1189 - Configuration\ - \ Change Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1189\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ee45e02a-4140-416c-82c4-fecfea660b9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ee45e02a-4140-416c-82c4-fecfea660b9d\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Accounts'\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Accounts' for\ - \ limiting local account use of blank passwords and guest account status.\ - \ This policy requires that the Guest Configuration prerequisites have been\ - \ deployed to the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsAccounts\",\"version\":\"1.*\",\"\ - configurationParameter\":{\"AccountsGuestAccountStatus\":\"Accounts: Guest\ - \ account status;ExpectedValue\"}}},\"parameters\":{\"IncludeArcMachines\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"AccountsGuestAccountStatus\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Accounts: Guest account status\"\ - ,\"description\":\"Specifies whether the local Guest account is disabled.\"\ - },\"defaultValue\":\"0\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsAccounts\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Accounts: Guest account status;ExpectedValue',\ - \ '=', parameters('AccountsGuestAccountStatus')))]\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ee984370-154a-4ee8-9726-19d900e56fc0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ee984370-154a-4ee8-9726-19d900e56fc0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1089 - Security\ - \ Awareness Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Awareness and Training control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1089\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef080e67-0d1a-4f76-a0c5-fb9b0358485e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef080e67-0d1a-4f76-a0c5-fb9b0358485e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1314 - Identifier\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1314\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef0c8530-efd9-45b8-b753-f03083d06295\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef0c8530-efd9-45b8-b753-f03083d06295\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1128 - Time\ - \ Stamps\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Audit and Accountability control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1128\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef212163-3bc4-4e86-bcf8-705127086393\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef212163-3bc4-4e86-bcf8-705127086393\"\ - },{\"properties\":{\"displayName\":\"Vulnerability assessment should be enabled\ - \ on your SQL servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Audit Azure SQL servers which do not have recurring vulnerability\ - \ assessment scans enabled. Vulnerability assessment can discover, track,\ - \ and help you remediate potential database vulnerabilities.\",\"metadata\"\ - :{\"version\":\"2.0.0\",\"category\":\"SQL\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },{\"field\":\"kind\",\"notContains\":\"analytics\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Sql/servers/vulnerabilityAssessments\"\ - ,\"name\":\"default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/vulnerabilityAssessments/recurringScans.isEnabled\"\ - ,\"equals\":\"True\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef2a8f2a-b3d9-49cd-a8a8-9a3aaaf647d9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef2a8f2a-b3d9-49cd-a8a8-9a3aaaf647d9\"\ - },{\"properties\":{\"displayName\":\"API Management services should use a\ - \ virtual network\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Virtual network on API Management services of the specified SKU should\ - \ be enabled.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"API Management\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"\ - evaluatedSkuNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"API\ - \ Management SKU Names\",\"description\":\"List of API Management SKUs against\ - \ which this policy will be evaluated.\"},\"allowedValues\":[\"Developer\"\ - ,\"Basic\",\"Standard\",\"Premium\",\"Consumption\"],\"defaultValue\":[\"\ - Developer\",\"Premium\"]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"\ - type\",\"equals\":\"Microsoft.ApiManagement/service\"},{\"field\":\"Microsoft.ApiManagement/service/sku.name\"\ - ,\"in\":\"[parameters('evaluatedSkuNames')]\"},{\"anyOf\":[{\"field\":\"Microsoft.ApiManagement/service/virtualNetworkType\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.ApiManagement/service/virtualNetworkType\"\ - ,\"equals\":\"None\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef619a2c-cc4d-4d03-b2ba-8c94a834d85b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef619a2c-cc4d-4d03-b2ba-8c94a834d85b\"\ - },{\"properties\":{\"displayName\":\"Deploy Diagnostic Settings for Event\ - \ Hub to Event Hub\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Deploys the diagnostic settings for Event Hub to stream to a regional Event\ - \ Hub when any Event Hub which is missing this diagnostic settings is created\ - \ or updated.\",\"metadata\":{\"version\":\"2.1.0\",\"category\":\"Monitoring\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"DeployIfNotExists\",\"Disabled\"],\"defaultValue\"\ - :\"DeployIfNotExists\"},\"profileName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Profile name\",\"description\":\"The diagnostic settings\ - \ profile name\"},\"defaultValue\":\"setbypolicy_eventHub\"},\"eventHubRuleId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Event Hub Authorization\ - \ Rule Id\",\"description\":\"The Event Hub authorization rule Id for Azure\ - \ Diagnostics. The authorization rule needs to be at Event Hub namespace level.\ - \ e.g. /subscriptions/{subscription Id}/resourceGroups/{resource group}/providers/Microsoft.EventHub/namespaces/{Event\ - \ Hub namespace}/authorizationrules/{authorization rule}\",\"strongType\"\ - :\"Microsoft.EventHub/Namespaces/AuthorizationRules\",\"assignPermissions\"\ - :true}},\"eventHubLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Event Hub Destination Location\",\"description\":\"The location the Event\ - \ Hub that will get diagnostic data resides in. Only source Event Hubs in\ - \ this location will be linked to this destination Event Hub.\",\"strongType\"\ - :\"location\"},\"defaultValue\":\"\"},\"metricsEnabled\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Enable metrics\",\"description\":\"Whether\ - \ to enable metrics stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"False\"},\"logsEnabled\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Enable logs\",\"description\"\ - :\"Whether to enable logs stream to the Event Hub - True or False\"},\"allowedValues\"\ - :[\"True\",\"False\"],\"defaultValue\":\"True\"}},\"policyRule\":{\"if\":{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces\"\ - },{\"anyOf\":[{\"value\":\"[parameters('eventHubLocation')]\",\"equals\":\"\ - \"},{\"field\":\"location\",\"equals\":\"[parameters('eventHubLocation')]\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Insights/diagnosticSettings\",\"name\":\"[parameters('profileName')]\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"[parameters('logsEnabled')]\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/metrics.enabled\"\ - ,\"equals\":\"[parameters('metricsEnabled')]\"}]},\"roleDefinitionIds\":[\"\ - /providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceName\":{\"type\"\ - :\"string\"},\"location\":{\"type\":\"string\"},\"eventHubRuleId\":{\"type\"\ - :\"string\"},\"metricsEnabled\":{\"type\":\"string\"},\"logsEnabled\":{\"\ - type\":\"string\"},\"profileName\":{\"type\":\"string\"}},\"variables\":{},\"\ - resources\":[{\"type\":\"Microsoft.EventHub/namespaces/providers/diagnosticSettings\"\ - ,\"apiVersion\":\"2017-05-01-preview\",\"name\":\"[concat(parameters('resourceName'),\ - \ '/', 'Microsoft.Insights/', parameters('profileName'))]\",\"location\":\"\ - [parameters('location')]\",\"dependsOn\":[],\"properties\":{\"eventHubAuthorizationRuleId\"\ - :\"[parameters('eventHubRuleId')]\",\"metrics\":[{\"category\":\"AllMetrics\"\ - ,\"enabled\":\"[parameters('metricsEnabled')]\",\"retentionPolicy\":{\"enabled\"\ - :false,\"days\":0}}],\"logs\":[{\"category\":\"ArchiveLogs\",\"enabled\":\"\ - [parameters('logsEnabled')]\"},{\"category\":\"OperationalLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"},{\"category\":\"AutoScaleLogs\",\"enabled\"\ - :\"[parameters('logsEnabled')]\"},{\"category\":\"KafkaCoordinatorLogs\",\"\ - enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"KafkaUserErrorLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"EventHubVNetConnectionEvent\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"},{\"category\":\"CustomerManagedKeyUserLogs\"\ - ,\"enabled\":\"[parameters('logsEnabled')]\"}]}}],\"outputs\":{}},\"parameters\"\ - :{\"location\":{\"value\":\"[field('location')]\"},\"resourceName\":{\"value\"\ - :\"[field('name')]\"},\"eventHubRuleId\":{\"value\":\"[parameters('eventHubRuleId')]\"\ - },\"metricsEnabled\":{\"value\":\"[parameters('metricsEnabled')]\"},\"logsEnabled\"\ - :{\"value\":\"[parameters('logsEnabled')]\"},\"profileName\":{\"value\":\"\ - [parameters('profileName')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef7b61ef-b8e4-4c91-8e78-6946c6b0023f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef7b61ef-b8e4-4c91-8e78-6946c6b0023f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1472 - Emergency\ - \ Shutoff\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1472\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ef869332-921d-4c28-9402-3be73e6e50c8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ef869332-921d-4c28-9402-3be73e6e50c8\"\ - },{\"properties\":{\"displayName\":\"The Log Analytics agent should be installed\ - \ on Virtual Machine Scale Sets\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any Windows/Linux Virtual Machine Scale\ - \ Sets if the Log Analytics agent is not installed.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Compute/virtualMachineScaleSets/extensions\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"in\":[\"MicrosoftMonitoringAgent\",\"OmsAgentForLinux\"]},{\"field\":\"\ - Microsoft.Compute/virtualMachineScaleSets/extensions/provisioningState\",\"\ - equals\":\"Succeeded\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/settings.workspaceId\"\ - ,\"exists\":\"true\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/efbde977-ba53-4479-b8e9-10b957924fbf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"efbde977-ba53-4479-b8e9-10b957924fbf\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1012 - Account\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1012\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/efd7b9ae-1db6-4eb6-b0fe-87e6565f9738\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"efd7b9ae-1db6-4eb6-b0fe-87e6565f9738\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1358 - Incident\ - \ Response Testing\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Incident Response control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1358\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/effbaeef-5bf4-400d-895e-ef8cbc0e64c7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"effbaeef-5bf4-400d-895e-ef8cbc0e64c7\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure that Register with\ - \ Azure Active Directory is enabled on Function App\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy is a duplicate of the\ - \ respective Managed Identity policies. Please use /providers/Microsoft.Authorization/policyDefinitions/0da106f2-4ca3-48e8-bc85-c638fe6aea8f\ - \ instead.\",\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"\ - App Service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"\ - },{\"field\":\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Web/sites/config\"\ - ,\"name\":\"web\",\"existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/web.managedServiceIdentityId\"\ - ,\"exists\":\"true\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f0473e7a-a1ba-4e86-afb2-e829e11b01d8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0473e7a-a1ba-4e86-afb2-e829e11b01d8\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy creates a\ - \ Guest Configuration assignment to audit Windows virtual machines that have\ - \ the specified applications installed. It also creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration. This\ - \ policy should only be used along with its corresponding audit policy in\ - \ an initiative. For more information on Guest Configuration policies, please\ - \ visit https://aka.ms/gcpol\",\"metadata\":{\"version\":\"1.2.0-deprecated\"\ - ,\"category\":\"Guest Configuration\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"deprecated\":true},\"parameters\":{\"ApplicationName\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Deprecated]: Application names (supports\ - \ wildcards)\",\"description\":\"A semicolon-separated list of the names of\ - \ the applications that should not be installed. e.g. 'Microsoft SQL Server\ - \ 2014 (64-bit); Microsoft Visual Studio Code' or 'Microsoft SQL Server 2014*'\ - \ (to match any application starting with 'Microsoft SQL Server 2014')\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"NotInstalledApplication\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[InstalledApplication]NotInstalledApplicationResource1;Name',\ - \ '=', parameters('ApplicationName')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"NotInstalledApplication\"\ - },\"ApplicationName\":{\"value\":\"[parameters('ApplicationName')]\"}},\"\ - template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"ApplicationName\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[InstalledApplication]NotInstalledApplicationResource1;Name\"\ - ,\"value\":\"[parameters('ApplicationName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[InstalledApplication]NotInstalledApplicationResource1;Name\"\ - ,\"value\":\"[parameters('ApplicationName')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f0633351-c7b2-41ff-9981-508fc08553c2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0633351-c7b2-41ff-9981-508fc08553c2\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1531 - Third-Party\ - \ Personnel Security\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1531\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f0643e0c-eee5-4113-8684-c608d05c5236\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0643e0c-eee5-4113-8684-c608d05c5236\"\ - },{\"properties\":{\"displayName\":\"Latest TLS version should be used in\ - \ your Web App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Upgrade to the latest TLS version\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"app*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/minTlsVersion\"\ - ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0e6e85b-9b9f-4a4b-b67b-f730d42f1b0b\"\ - },{\"properties\":{\"displayName\":\"Deploy Workflow Automation for Azure\ - \ Security Center alerts\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"\ - description\":\"Enable automation of Azure Security Center alerts. This policy\ - \ deploys a workflow automation with your conditions and triggers on the assigned\ - \ scope. To deploy this policy on newly created subscriptions, open the Compliance\ - \ tab, select the relevant non-compliant assignment and create a remediation\ - \ task.\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Security Center\"\ - },\"parameters\":{\"automationName\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Automation name\",\"description\":\"This is the automation\ - \ name.\"}},\"resourceGroupName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Resource group name\",\"description\":\"The resource group name where the\ - \ workflow automation is created. If you enter a name for a resource group\ - \ that doesn't exist, it'll be created in the subscription.\"}},\"resourceGroupLocation\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Resource group location\"\ - ,\"description\":\"The location where the resource group and the workflow\ - \ automation are created.\",\"strongType\":\"location\"}},\"alertName\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Alert name contains\",\"\ - description\":\"String included in the required alert name. For a full reference\ - \ list of Security Center's alerts, see https://docs.microsoft.com/azure/security-center/alerts-reference.\"\ - },\"defaultValue\":\"\"},\"alertSeverities\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Alert severities\",\"description\":\"Determines alert\ - \ severities. Example: High;Medium;Low;\"},\"allowedValues\":[\"High\",\"\ - Medium\",\"Low\"],\"defaultValue\":[\"High\",\"Medium\",\"Low\"]},\"logicAppResourceId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Logic App\",\"description\"\ - :\"The Logic App that is triggered. If you do not already have a logic app,\ - \ visit Logic Apps to create one (https://portal.azure.com/#blade/HubsExtension/BrowseResourceBlade/resourceType/Microsoft.Logic%2Fworkflows).\"\ - ,\"strongType\":\"Microsoft.Logic/workflows\",\"assignPermissions\":true}},\"\ - logicAppTrigger\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Logic\ - \ app trigger\",\"description\":\"The trigger connector of the logic app that\ - \ is triggered. Possible values: 'Manual (Incoming HTTP request)', 'When an\ - \ Azure Security Center Alert is created or triggered'.\"},\"allowedValues\"\ - :[\"Manual (Incoming HTTP request)\",\"When an Azure Security Center Alert\ - \ is created or triggered\"]}},\"policyRule\":{\"if\":{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"\ - deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Security/automations\"\ - ,\"name\":\"[parameters('automationName')]\",\"existenceScope\":\"resourcegroup\"\ - ,\"ResourceGroupName\":\"[parameters('resourceGroupName')]\",\"deploymentScope\"\ - :\"subscription\",\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"location\":\"westeurope\",\"properties\":{\"mode\":\"\ - incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"automationName\":{\"type\"\ - :\"string\"},\"resourceGroupName\":{\"type\":\"string\"},\"resourceGroupLocation\"\ - :{\"type\":\"string\"},\"alertName\":{\"type\":\"string\"},\"alertSeverities\"\ - :{\"type\":\"array\"},\"logicAppResourceId\":{\"type\":\"string\"},\"logicAppTrigger\"\ - :{\"type\":\"string\"},\"guidValue\":{\"type\":\"string\",\"defaultValue\"\ - :\"[newGuid()]\"}},\"variables\":{\"scopeDescription\":\"scope for subscription\ - \ {0}\",\"alertSeveritiesLength\":\"[length(parameters('alertSeverities'))]\"\ - ,\"alertSeveritiesLengthIfEmpty\":\"[if(equals(variables('alertSeveritiesLength'),\ - \ 0), 1, variables('alertSeveritiesLength'))]\",\"severityMap\":{\"High\"\ - :\"high\",\"Medium\":\"medium\",\"Low\":\"low\"},\"triggerMap\":{\"Manual\ - \ (Incoming HTTP request)\":\"manual\",\"When an Azure Security Center Alert\ - \ is created or triggered\":\"When_an_Azure_Security_Center_Alert_is_created_or_triggered\"\ - }},\"resources\":[{\"name\":\"[parameters('resourceGroupName')]\",\"type\"\ - :\"Microsoft.Resources/resourceGroups\",\"apiVersion\":\"2019-10-01\",\"location\"\ - :\"[parameters('resourceGroupLocation')]\",\"tags\":{},\"properties\":{}},{\"\ - type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2019-10-01\",\"\ - name\":\"[concat('nestedAutomationDeployment', '_', parameters('guidValue'))]\"\ - ,\"resourceGroup\":\"[parameters('resourceGroupName')]\",\"dependsOn\":[\"\ - [resourceId('Microsoft.Resources/resourceGroups/', parameters('resourceGroupName'))]\"\ - ],\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ - :[{\"tags\":{},\"apiVersion\":\"2019-01-01-preview\",\"location\":\"[parameters('resourceGroupLocation')]\"\ - ,\"name\":\"[parameters('automationName')]\",\"type\":\"Microsoft.Security/automations\"\ - ,\"dependsOn\":[],\"properties\":{\"description\":\"Workflow Automation for\ - \ Azure Security Center alerts via policy\",\"isEnabled\":true,\"scopes\"\ - :[{\"description\":\"[replace(variables('scopeDescription'),'{0}', subscription().subscriptionId)]\"\ - ,\"scopePath\":\"[subscription().id]\"}],\"sources\":[{\"eventSource\":\"\ - Alerts\",\"copy\":[{\"name\":\"ruleSets\",\"count\":\"[variables('alertSeveritiesLengthIfEmpty')]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"[if(equals(parameters('alertName'),\ - \ ''), 'Version', 'AlertDisplayName')]\",\"propertyType\":\"string\",\"expectedValue\"\ - :\"[if(equals(parameters('alertName'), ''), '3.', parameters('alertName'))]\"\ - ,\"operator\":\"Contains\"},{\"propertyJPath\":\"Severity\",\"propertyType\"\ - :\"string\",\"expectedValue\":\"[variables('severityMap')[parameters('alertSeverities')[mod(copyIndex('ruleSets'),\ - \ variables('alertSeveritiesLengthIfEmpty'))]]]\",\"operator\":\"Equals\"\ - }]}}]}],\"actions\":[{\"actionType\":\"LogicApp\",\"logicAppResourceId\":\"\ - [parameters('logicAppResourceId')]\",\"uri\":\"[listCallbackUrl(concat(parameters('logicAppResourceId'),\ - \ '/triggers/', variables('triggerMap')[parameters('logicAppTrigger')]),'2016-06-01').value]\"\ - }]}}]}}}]},\"parameters\":{\"automationName\":{\"value\":\"[parameters('automationName')]\"\ - },\"resourceGroupName\":{\"value\":\"[parameters('resourceGroupName')]\"},\"\ - resourceGroupLocation\":{\"value\":\"[parameters('resourceGroupLocation')]\"\ - },\"alertName\":{\"value\":\"[parameters('alertName')]\"},\"alertSeverities\"\ - :{\"value\":\"[parameters('alertSeverities')]\"},\"logicAppResourceId\":{\"\ - value\":\"[parameters('logicAppResourceId')]\"},\"logicAppTrigger\":{\"value\"\ - :\"[parameters('logicAppTrigger')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f1525828-9a90-4fcf-be48-268cdd02361e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f1525828-9a90-4fcf-be48-268cdd02361e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1028 - Information\ - \ Flow Enforcement\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1028\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f171df5c-921b-41e9-b12b-50801c315475\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f171df5c-921b-41e9-b12b-50801c315475\"\ - },{\"properties\":{\"displayName\":\"Virtual networks should use specified\ - \ virtual network gateway\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\"\ - ,\"description\":\"This policy audits any virtual network if the default route\ - \ does not point to the specified virtual network gateway.\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Network\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"\ - virtualNetworkGatewayId\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Virtual network gateway Id\",\"description\":\"Resource Id of the virtual\ - \ network gateway. Example: /subscriptions/YourSubscriptionId/resourceGroups/YourResourceGroup/providers/Microsoft.Network/virtualNetworkGateways/Name\"\ - }}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Network/virtualNetworks/subnets\",\"name\":\"GatewaySubnet\",\"\ - existenceCondition\":{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/ipConfigurations[*].id\"\ - ,\"notContains\":\"[concat(parameters('virtualNetworkGatewayId'), '/')]\"\ - }}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f1776c76-f58c-4245-a8d0-2b207198dc8b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f1776c76-f58c-4245-a8d0-2b207198dc8b\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Linux VMs that do not have the passwd file permissions set to 0644\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Linux virtual machines\ - \ that do not have the passwd file permissions set to 0644. It also creates\ - \ a system-assigned managed identity and deploys the VM extension for Guest\ - \ Configuration. This policy should only be used along with its corresponding\ - \ audit policy in an initiative. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"3.0.0-deprecated\",\"category\":\"Guest Configuration\",\"requiredProviders\"\ - :[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid121\",\"deployment\":{\"properties\":{\"mode\"\ - :\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"PasswordPolicy_msid121\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforLinux')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f19aa1c1-6b91-4c27-ae6a-970279f03db9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f19aa1c1-6b91-4c27-ae6a-970279f03db9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Administrative Templates - MSS (Legacy)'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Administrative Templates\ - \ - MSS (Legacy)'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_AdminstrativeTemplatesMSSLegacy\",\"deployment\"\ - :{\"properties\":{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"\ - value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_AdminstrativeTemplatesMSSLegacy\"}},\"template\":{\"$schema\"\ - :\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\"}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f1f4825d-58fb-4257-8016-8c00e3c9ed9d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f1f4825d-58fb-4257-8016-8c00e3c9ed9d\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Settings - Account Policies'\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Settings - Account Policies'\ - \ for password history, age, length, complexity, and storing passwords using\ - \ reversible encryption. This policy requires that the Guest Configuration\ - \ prerequisites have been deployed to the policy assignment scope. For details,\ - \ visit https://aka.ms/gcpol.\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"2.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"AzureBaseline_SecuritySettingsAccountPolicies\"\ - ,\"version\":\"1.*\",\"configurationParameter\":{\"EnforcePasswordHistory\"\ - :\"Enforce password history;ExpectedValue\",\"MaximumPasswordAge\":\"Maximum\ - \ password age;ExpectedValue\",\"MinimumPasswordAge\":\"Minimum password age;ExpectedValue\"\ - ,\"MinimumPasswordLength\":\"Minimum password length;ExpectedValue\",\"PasswordMustMeetComplexityRequirements\"\ - :\"Password must meet complexity requirements;ExpectedValue\"}}},\"parameters\"\ - :{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Include Arc connected servers\",\"description\":\"By selecting this option,\ - \ you agree to be charged monthly per Arc connected machine.\"},\"allowedValues\"\ - :[\"true\",\"false\"],\"defaultValue\":\"false\"},\"EnforcePasswordHistory\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Enforce password history\"\ - ,\"description\":\"Specifies limits on password reuse - how many times a new\ - \ password must be created for a user account before the password can be repeated.\"\ - },\"defaultValue\":\"24\"},\"MaximumPasswordAge\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Maximum password age\",\"description\":\"Specifies\ - \ the maximum number of days that may elapse before a user account password\ - \ must be changed. The format of the value is two integers separated by a\ - \ comma, denoting an inclusive range.\"},\"defaultValue\":\"1,70\"},\"MinimumPasswordAge\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Minimum password age\"\ - ,\"description\":\"Specifies the minimum number of days that must elapse before\ - \ a user account password can be changed.\"},\"defaultValue\":\"1\"},\"MinimumPasswordLength\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Minimum password length\"\ - ,\"description\":\"Specifies the minimum number of characters that a user\ - \ account password may contain.\"},\"defaultValue\":\"14\"},\"PasswordMustMeetComplexityRequirements\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Password must meet complexity\ - \ requirements\",\"description\":\"Specifies whether a user account password\ - \ must be complex. If required, a complex password must not contain part of\ - \ user's account name or full name; be at least 6 characters long; contain\ - \ a mix of uppercase, lowercase, number, and non-alphabetic characters.\"\ - },\"defaultValue\":\"1\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Effect\",\"description\":\"Enable or disable the execution\ - \ of this policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"\ - defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecuritySettingsAccountPolicies\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Enforce password history;ExpectedValue', '=',\ - \ parameters('EnforcePasswordHistory'), ',', 'Maximum password age;ExpectedValue',\ - \ '=', parameters('MaximumPasswordAge'), ',', 'Minimum password age;ExpectedValue',\ - \ '=', parameters('MinimumPasswordAge'), ',', 'Minimum password length;ExpectedValue',\ - \ '=', parameters('MinimumPasswordLength'), ',', 'Password must meet complexity\ - \ requirements;ExpectedValue', '=', parameters('PasswordMustMeetComplexityRequirements')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f2143251-70de-4e81-87a8-36cee5a2f29d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f2143251-70de-4e81-87a8-36cee5a2f29d\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1701 - Information\ - \ System Monitoring | Host-Based Devices\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1701\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f25bc08f-27cb-43b6-9a23-014d00700426\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f25bc08f-27cb-43b6-9a23-014d00700426\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1457 - Physical\ - \ Access Control\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Physical and Environmental Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1457\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f2d9d3e6-8886-4305-865d-639163e5c305\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f2d9d3e6-8886-4305-865d-639163e5c305\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1309 - Identification\ - \ And Authentication (Org. Users) | Acceptance Of Piv Credentials\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Identification and Authentication control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1309\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f355d62b-39a8-4ba3-abf7-90f71cb3b000\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f355d62b-39a8-4ba3-abf7-90f71cb3b000\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1615 - System\ - \ And Communications Protection Policy And Procedures\",\"policyType\":\"\ - Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Communications Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1615\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f35e02aa-0a55-49f8-8811-8abfa7e6f2c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f35e02aa-0a55-49f8-8811-8abfa7e6f2c0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1255 - Contingency\ - \ Plan | Continue Essential Missions / Business Functions\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Contingency Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1255\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f3793f5e-937f-44f7-bfba-40647ef3efa0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f3793f5e-937f-44f7-bfba-40647ef3efa0\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs if the Administrators group doesn't contain all of the specified\ - \ members\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy should only be used along with its corresponding deploy policy\ - \ in an initiative. This definition allows Azure Policy to process the results\ - \ of auditing Windows virtual machines in which the Administrators group does\ - \ not contain all of the specified members. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AdministratorsGroupMembersToInclude\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f3b44e5d-1456-475f-9c67-c66c4618e85a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f3b44e5d-1456-475f-9c67-c66c4618e85a\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not contain the specified certificates in Trusted Root\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ VMs that do not contain the specified certificates in the Trusted Root Certification\ - \ Authorities certificate store (Cert:\\\\LocalMachine\\\\Root). For more\ - \ information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsCertificateInTrustedRoot\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f3b9ad83-000d-4dc1-bff0-6d54533dd03f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f3b9ad83-000d-4dc1-bff0-6d54533dd03f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1706 - Security\ - \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1706\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f475ee0e-f560-4c9b-876b-04a77460a404\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f475ee0e-f560-4c9b-876b-04a77460a404\"\ - },{\"properties\":{\"displayName\":\"Audit Log Analytics workspace for VM\ - \ - Report Mismatch\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Reports VMs as non-compliant if they aren't logging to the Log Analytics\ - \ workspace specified in the policy/initiative assignment.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Monitoring\"},\"parameters\":{\"logAnalyticsWorkspaceId\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Log Analytics Workspace\ - \ Id that VMs should be configured for\",\"description\":\"This is the Id\ - \ (GUID) of the Log Analytics Workspace that the VMs should be configured\ - \ for.\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines/extensions\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.EnterpriseCloud.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/settings.workspaceId\"\ - ,\"notEquals\":\"[parameters('logAnalyticsWorkspaceId')]\"}]},\"then\":{\"\ - effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f47b5582-33ec-4c5c-87c0-b010a6b2e917\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f47b5582-33ec-4c5c-87c0-b010a6b2e917\"\ - },{\"properties\":{\"displayName\":\"Authorization rules on the Event Hub\ - \ instance should be defined\",\"policyType\":\"BuiltIn\",\"mode\":\"All\"\ - ,\"description\":\"Audit existence of authorization rules on Event Hub entities\ - \ to grant least-privileged access\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Event Hub\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"field\":\"type\",\"equals\":\"Microsoft.EventHub/namespaces/eventhubs\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.EventHub/namespaces/eventHubs/authorizationRules\"}}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/f4826e5f-6a27-407c-ae3e-9582eb39891d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4826e5f-6a27-407c-ae3e-9582eb39891d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have the password complexity setting enabled\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should\ - \ only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines that do not have the password complexity setting enabled.\ - \ For more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordMustMeetComplexityRequirements\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f48b2913-1dc5-4834-8c72-ccc1dfd819bb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f48b2913-1dc5-4834-8c72-ccc1dfd819bb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1495 - System\ - \ Security Plan\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Planning control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1495\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f4978d0e-a596-48e7-9f8c-bbf52554ce8d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4978d0e-a596-48e7-9f8c-bbf52554ce8d\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs that have not restarted within the specified number of\ - \ days\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"\ - This policy creates a Guest Configuration assignment to audit Windows virtual\ - \ machines that have not restarted within the specified number of days. It\ - \ also creates a system-assigned managed identity and deploys the VM extension\ - \ for Guest Configuration. This policy should only be used along with its\ - \ corresponding audit policy in an initiative. For more information on Guest\ - \ Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.1.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"NumberOfDays\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Number of days\",\"description\":\"The number of days without\ - \ restart until the machine is considered non-compliant\"},\"defaultValue\"\ - :\"12\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"MachineLastBootUpTime\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('[MachineUpTime]MachineLastBootUpTime;NumberOfDays',\ - \ '=', parameters('NumberOfDays')))]\"},\"deployment\":{\"properties\":{\"\ - mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"MachineLastBootUpTime\"\ - },\"NumberOfDays\":{\"value\":\"[parameters('NumberOfDays')]\"}},\"template\"\ - :{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"NumberOfDays\":{\"type\":\"string\"}},\"resources\"\ - :[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[MachineUpTime]MachineLastBootUpTime;NumberOfDays\"\ - ,\"value\":\"[parameters('NumberOfDays')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"[MachineUpTime]MachineLastBootUpTime;NumberOfDays\"\ - ,\"value\":\"[parameters('NumberOfDays')]\"}]}}},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\"\ - ,\"type\":\"ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f4b245d4-46c9-42be-9b1a-49e2b5b94194\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4b245d4-46c9-42be-9b1a-49e2b5b94194\"\ - },{\"properties\":{\"displayName\":\"Deploy Auditing on SQL servers\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy ensures that\ - \ Auditing is enabled on SQL Servers for enhanced security and compliance.\ - \ It will automatically create a storage account in the same region as the\ - \ SQL server to store audit records.\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"SQL\"},\"parameters\":{\"retentionDays\":{\"type\":\"String\"\ - ,\"metadata\":{\"description\":\"The value in days of the retention period\ - \ (0 indicates unlimited retention)\",\"displayName\":\"Retention days (optional,\ - \ 180 days if unspecified)\"},\"defaultValue\":\"180\"},\"storageAccountsResourceGroup\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Resource group name\ - \ for storage accounts\",\"description\":\"Auditing writes database events\ - \ to an audit log in your Azure Storage account (a storage account will be\ - \ created in each region where a SQL Server is created that will be shared\ - \ by all servers in that region). Important - for proper operation of Auditing\ - \ do not delete or rename the resource group or the storage accounts.\",\"\ - strongType\":\"existingResourceGroups\"}}},\"policyRule\":{\"if\":{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Sql/servers\"},\"then\":{\"effect\":\"DeployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Sql/servers/auditingSettings\",\"name\"\ - :\"Default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/auditingSettings.state\"\ - ,\"equals\":\"Enabled\"},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/056cd41c-7e88-42e1-933e-88ba6a50c9c3\"\ - ,\"/providers/microsoft.authorization/roleDefinitions/17d1049b-9a84-46fb-8f53-869881c3d3ab\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"serverName\":{\"type\":\"\ - string\"},\"auditRetentionDays\":{\"type\":\"string\"},\"storageAccountsResourceGroup\"\ - :{\"type\":\"string\"},\"location\":{\"type\":\"string\"}},\"variables\":{\"\ - retentionDays\":\"[int(parameters('auditRetentionDays'))]\",\"subscriptionId\"\ - :\"[subscription().subscriptionId]\",\"uniqueStorage\":\"[uniqueString(variables('subscriptionId'),\ - \ parameters('location'), parameters('storageAccountsResourceGroup'))]\",\"\ - locationCode\":\"[substring(parameters('location'), 0, 3)]\",\"storageName\"\ - :\"[tolower(concat('sqlaudit', variables('locationCode'), variables('uniqueStorage')))]\"\ - ,\"createStorageAccountDeploymentName\":\"[concat('sqlServerAuditingStorageAccount-',\ - \ uniqueString(variables('locationCode'), parameters('serverName')))]\"},\"\ - resources\":[{\"apiVersion\":\"2017-05-10\",\"name\":\"[variables('createStorageAccountDeploymentName')]\"\ - ,\"type\":\"Microsoft.Resources/deployments\",\"resourceGroup\":\"[parameters('storageAccountsResourceGroup')]\"\ - ,\"properties\":{\"mode\":\"Incremental\",\"parameters\":{\"location\":{\"\ - value\":\"[parameters('location')]\"},\"storageName\":{\"value\":\"[variables('storageName')]\"\ - }},\"templateLink\":{\"uri\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/samples/SQL/deploy-sql-server-auditing/createStorage.template.json\"\ - ,\"contentVersion\":\"1.0.0.0\"}}},{\"name\":\"[concat(parameters('serverName'),\ - \ '/Default')]\",\"type\":\"Microsoft.Sql/servers/auditingSettings\",\"apiVersion\"\ - :\"2017-03-01-preview\",\"properties\":{\"state\":\"Enabled\",\"storageEndpoint\"\ - :\"[reference(variables('createStorageAccountDeploymentName')).outputs.storageAccountEndPoint.value]\"\ - ,\"storageAccountAccessKey\":\"[reference(variables('createStorageAccountDeploymentName')).outputs.storageAccountKey.value]\"\ - ,\"retentionDays\":\"[variables('retentionDays')]\",\"auditActionsAndGroups\"\ - :null,\"storageAccountSubscriptionId\":\"[subscription().subscriptionId]\"\ - ,\"isStorageSecondaryKeyInUse\":false}}]},\"parameters\":{\"serverName\":{\"\ - value\":\"[field('name')]\"},\"auditRetentionDays\":{\"value\":\"[parameters('retentionDays')]\"\ - },\"storageAccountsResourceGroup\":{\"value\":\"[parameters('storageAccountsResourceGroup')]\"\ - },\"location\":{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f4c68484-132f-41f9-9b6d-3e4b1cb55036\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4c68484-132f-41f9-9b6d-3e4b1cb55036\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1469 - Power\ - \ Equipment And Cabling\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1469\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f509c5b6-0de0-4a4e-9b2e-cd9cbf3a58fd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f509c5b6-0de0-4a4e-9b2e-cd9cbf3a58fd\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1618 - Security\ - \ Function Isolation\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Communications Protection control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1618\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f52f89aa-4489-4ec4-950e-8c96a036baa9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f52f89aa-4489-4ec4-950e-8c96a036baa9\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'Security Options - Network Access'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'Security Options\ - \ - Network Access'. It also creates a system-assigned managed identity and\ - \ deploys the VM extension for Guest Configuration. This policy should only\ - \ be used along with its corresponding audit policy in an initiative. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol\"\ - ,\"metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"NetworkAccessRemotelyAccessibleRegistryPaths\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network access: Remotely\ - \ accessible registry paths\",\"description\":\"Specifies which registry paths\ - \ will be accessible over the network, regardless of the users or groups listed\ - \ in the access control list (ACL) of the `winreg` registry key.\"},\"defaultValue\"\ - :\"System\\\\CurrentControlSet\\\\Control\\\\ProductOptions|#|System\\\\CurrentControlSet\\\ - \\Control\\\\Server Applications|#|Software\\\\Microsoft\\\\Windows NT\\\\\ - CurrentVersion\"},\"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ access: Remotely accessible registry paths and sub-paths\",\"description\"\ - :\"Specifies which registry paths and sub-paths will be accessible over the\ - \ network, regardless of the users or groups listed in the access control\ - \ list (ACL) of the `winreg` registry key.\"},\"defaultValue\":\"System\\\\\ - CurrentControlSet\\\\Control\\\\Print\\\\Printers|#|System\\\\CurrentControlSet\\\ - \\Services\\\\Eventlog|#|Software\\\\Microsoft\\\\OLAP Server|#|Software\\\ - \\Microsoft\\\\Windows NT\\\\CurrentVersion\\\\Print|#|Software\\\\Microsoft\\\ - \\Windows NT\\\\CurrentVersion\\\\Windows|#|System\\\\CurrentControlSet\\\\\ - Control\\\\ContentIndex|#|System\\\\CurrentControlSet\\\\Control\\\\Terminal\ - \ Server|#|System\\\\CurrentControlSet\\\\Control\\\\Terminal Server\\\\UserConfig|#|System\\\ - \\CurrentControlSet\\\\Control\\\\Terminal Server\\\\DefaultUserConfiguration|#|Software\\\ - \\Microsoft\\\\Windows NT\\\\CurrentVersion\\\\Perflib|#|System\\\\CurrentControlSet\\\ - \\Services\\\\SysmonLog\"},\"NetworkAccessSharesThatCanBeAccessedAnonymously\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Network\ - \ access: Shares that can be accessed anonymously\",\"description\":\"Specifies\ - \ which network shares can be accessed by anonymous users. The default configuration\ - \ for this policy setting has little effect because all users have to be authenticated\ - \ before they can access shared resources on the server.\"},\"defaultValue\"\ - :\"0\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsNetworkAccess\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Network access: Remotely accessible registry\ - \ paths;ExpectedValue', '=', parameters('NetworkAccessRemotelyAccessibleRegistryPaths'),\ - \ ',', 'Network access: Remotely accessible registry paths and sub-paths;ExpectedValue',\ - \ '=', parameters('NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths'),\ - \ ',', 'Network access: Shares that can be accessed anonymously;ExpectedValue',\ - \ '=', parameters('NetworkAccessSharesThatCanBeAccessedAnonymously')))]\"\ - },\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"parameters\"\ - :{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - },\"type\":{\"value\":\"[field('type')]\"},\"configurationName\":{\"value\"\ - :\"AzureBaseline_SecurityOptionsNetworkAccess\"},\"NetworkAccessRemotelyAccessibleRegistryPaths\"\ - :{\"value\":\"[parameters('NetworkAccessRemotelyAccessibleRegistryPaths')]\"\ - },\"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths\":{\"value\":\"\ - [parameters('NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths')]\"\ - },\"NetworkAccessSharesThatCanBeAccessedAnonymously\":{\"value\":\"[parameters('NetworkAccessSharesThatCanBeAccessedAnonymously')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"NetworkAccessRemotelyAccessibleRegistryPaths\":{\"\ - type\":\"string\"},\"NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths\"\ - :{\"type\":\"string\"},\"NetworkAccessSharesThatCanBeAccessedAnonymously\"\ - :{\"type\":\"string\"}},\"resources\":[{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('microsoft.hybridcompute/machines'))]\",\"apiVersion\":\"2018-11-20\"\ - ,\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Network access:\ - \ Remotely accessible registry paths;ExpectedValue\",\"value\":\"[parameters('NetworkAccessRemotelyAccessibleRegistryPaths')]\"\ - },{\"name\":\"Network access: Remotely accessible registry paths and sub-paths;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths')]\"\ - },{\"name\":\"Network access: Shares that can be accessed anonymously;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkAccessSharesThatCanBeAccessedAnonymously')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Network access:\ - \ Remotely accessible registry paths;ExpectedValue\",\"value\":\"[parameters('NetworkAccessRemotelyAccessibleRegistryPaths')]\"\ - },{\"name\":\"Network access: Remotely accessible registry paths and sub-paths;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkAccessRemotelyAccessibleRegistryPathsAndSubpaths')]\"\ - },{\"name\":\"Network access: Shares that can be accessed anonymously;ExpectedValue\"\ - ,\"value\":\"[parameters('NetworkAccessSharesThatCanBeAccessedAnonymously')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f56a3ab2-89d1-44de-ac0d-2ada5962e22a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f56a3ab2-89d1-44de-ac0d-2ada5962e22a\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1198 - Configuration\ - \ Change Control | Security Representative\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Configuration\ - \ Management control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1198\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f56be5c3-660b-4c61-9078-f67cf072c356\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f56be5c3-660b-4c61-9078-f67cf072c356\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1328 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1328\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f5c66fdc-3d02-4034-9db5-ba57802609de\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f5c66fdc-3d02-4034-9db5-ba57802609de\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1193 - Configuration\ - \ Change Control | Automated Document / Notification / Prohibition Of Changes\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Configuration Management control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1193\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f5fd629f-3075-4cae-ab53-bad65495a4ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f5fd629f-3075-4cae-ab53-bad65495a4ac\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Web Application Firewall\ - \ should be a set mode for Application Gateway and Azure Front Door Service\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"Mandates\ - \ detect or prevent mode to be active on all Web Application Firewall policies\ - \ for Azure Front Door and Application Gateway. Web Application Firewall policies\ - \ can have a consistent mode configuration across a resource group.\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Network\",\"deprecated\"\ - :true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"\ - defaultValue\":\"Deny\"},\"modeRequirement\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Mode Requirement\",\"description\":\"Mode\ - \ required for all WAF policies\"},\"allowedValues\":[\"Prevention\",\"Detection\"\ - ],\"defaultValue\":\"Detection\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/frontdoorwebapplicationfirewallpolicies\"\ - },{\"field\":\"Microsoft.Network/frontdoorWebApplicationFirewallPolicies/policySettings.mode\"\ - ,\"notEquals\":\"[parameters('modeRequirement')]\"}]},{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies\"\ - },{\"field\":\"Microsoft.Network/applicationGatewayWebApplicationFirewallPolicies/policySettings.mode\"\ - ,\"notEquals\":\"[parameters('modeRequirement')]\"}]}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f6b68e5a-7207-4638-a1fb-47d90404209e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f6b68e5a-7207-4638-a1fb-47d90404209e\"\ - },{\"properties\":{\"displayName\":\"Internet-facing virtual machines should\ - \ be protected with network security groups\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"All\",\"description\":\"Protect your virtual machines from potential\ - \ threats by restricting access to them with network security groups (NSG).\ - \ Learn more about controlling traffic with NSGs at https://aka.ms/nsg-doc\"\ - ,\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - Microsoft.Compute/virtualMachines\",\"Microsoft.ClassicCompute/virtualMachines\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Security/assessments\",\"name\":\"483f12ed-ae23-447e-a2de-a67a10db4353\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f6de0be7-9a8a-4b8a-b349-43cf02d22f7c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f6de0be7-9a8a-4b8a-b349-43cf02d22f7c\"\ - },{\"properties\":{\"displayName\":\"Audit Linux machines that have accounts\ - \ without passwords\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Requires that prerequisites are deployed to the policy assignment scope.\ - \ For details, visit https://aka.ms/gcpol. Machines are non-compliant if Linux\ - \ machines that have accounts without passwords\",\"metadata\":{\"category\"\ - :\"Guest Configuration\",\"version\":\"1.0.0\",\"requiredProviders\":[\"Microsoft.GuestConfiguration\"\ - ],\"guestConfiguration\":{\"name\":\"PasswordPolicy_msid232\",\"version\"\ - :\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Include Arc connected servers\",\"description\"\ - :\"By selecting this option, you agree to be charged monthly per Arc connected\ - \ machine.\"},\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"\ - },\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"microsoft-aks\",\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\"\ - ,\"checkpoint\",\"paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"OpenLogic\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"PasswordPolicy_msid232\",\"existenceCondition\":{\"field\":\"\ - Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f6ec09a3-78bf-4f8f-99dc-6c77182d0f99\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f6ec09a3-78bf-4f8f-99dc-6c77182d0f99\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1214 - Least\ - \ Functionality\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Configuration Management control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1214\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f714a4e2-b580-47b6-ae8c-f2812d3750f3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f714a4e2-b580-47b6-ae8c-f2812d3750f3\"\ - },{\"properties\":{\"displayName\":\"Windows machines should meet requirements\ - \ for 'Security Options - Recovery console'\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Indexed\",\"description\":\"Windows machines should have the specified\ - \ Group Policy settings in the category 'Security Options - Recovery console'\ - \ for allowing floppy copy and access to all drives and folders. This policy\ - \ requires that the Guest Configuration prerequisites have been deployed to\ - \ the policy assignment scope. For details, visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"category\":\"Guest Configuration\",\"version\":\"2.0.0\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"guestConfiguration\"\ - :{\"name\":\"AzureBaseline_SecurityOptionsRecoveryconsole\",\"version\":\"\ - 1.*\",\"configurationParameter\":{\"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders\"\ - :\"Recovery console: Allow floppy copy and access to all drives and all folders;ExpectedValue\"\ - }}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Include Arc connected servers\",\"description\":\"By selecting\ - \ this option, you agree to be charged monthly per Arc connected machine.\"\ - },\"allowedValues\":[\"true\",\"false\"],\"defaultValue\":\"false\"},\"RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Recovery console: Allow\ - \ floppy copy and access to all drives and all folders\",\"description\":\"\ - Specifies whether to make the Recovery Console SET command available, which\ - \ allows setting of recovery console environment variables.\"},\"defaultValue\"\ - :\"0\"},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of this policy\"},\"allowedValues\"\ - :[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"\ - }},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"in\":[\"esri\",\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\"\ - ,\"MicrosoftVisualStudio\",\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"\ - ]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"\ - notLike\":\"2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"notLike\":\"SQL2008*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"equals\":\"dsvm-windows\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"center-for-internet-security-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"cis-windows-server-201*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\"\ - :\"bosh-windows-server*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\"\ - ,\"equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments\",\"name\":\"\ - AzureBaseline_SecurityOptionsRecoveryconsole\",\"existenceCondition\":{\"\ - allOf\":[{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"},{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Recovery console: Allow floppy copy and access\ - \ to all drives and all folders;ExpectedValue', '=', parameters('RecoveryConsoleAllowFloppyCopyAndAccessToAllDrivesAndAllFolders')))]\"\ - }]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f71be03e-e25b-4d0f-b8bc-9b3e309b66c0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f71be03e-e25b-4d0f-b8bc-9b3e309b66c0\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1591 - External\ - \ Information System Services | Ident. Of Functions / Ports / Protocols /\ - \ Services\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1591\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f751cdb7-fbee-406b-969b-815d367cb9b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f751cdb7-fbee-406b-969b-815d367cb9b3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1330 - Authenticator\ - \ Management | Password-Based Authentication\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1330\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f75cedb2-5def-4b31-973e-b69e8c7bd031\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f75cedb2-5def-4b31-973e-b69e8c7bd031\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1540 - Security\ - \ Categorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1540\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f771f8cb-6642-45cc-9a15-8a41cd5c6977\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f771f8cb-6642-45cc-9a15-8a41cd5c6977\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1449 - Physical\ - \ Access Authorizations\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Physical and Environmental Protection\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1449\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f784d3b0-5f2b-49b7-b9f3-00ba8653ced5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f784d3b0-5f2b-49b7-b9f3-00ba8653ced5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1506 - Personnel\ - \ Security Policy And Procedures\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Personnel Security control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1506\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f7d2ff17-d604-4dd9-b607-9ecf63f28ad2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f7d2ff17-d604-4dd9-b607-9ecf63f28ad2\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs that do not have the specified Windows PowerShell execution\ - \ policy\",\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"\ - This policy should only be used along with its corresponding deploy policy\ - \ in an initiative. This definition allows Azure Policy to process the results\ - \ of auditing Windows virtual machines where Windows PowerShell is not configured\ - \ to use the specified PowerShell execution policy. For more information on\ - \ Guest Configuration policies, please visit https://aka.ms/gcpol\",\"metadata\"\ - :{\"version\":\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"\ - deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\"\ - ,\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"WindowsPowerShellExecutionPolicy\",\"existenceCondition\":{\"\ - field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f8036bd0-c10b-4931-86bb-94a878add855\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f8036bd0-c10b-4931-86bb-94a878add855\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1705 - Security\ - \ Alerts, Advisories, And Directives\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this System and Information\ - \ Integrity control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1705\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f82e3639-fa2b-4e06-a786-932d8379b972\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f82e3639-fa2b-4e06-a786-932d8379b972\"\ - },{\"properties\":{\"displayName\":\"External accounts with owner permissions\ - \ should be removed from your subscription\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"All\",\"description\":\"External accounts with owner permissions\ - \ should be removed from your subscription in order to prevent unmonitored\ - \ access.\",\"metadata\":{\"version\":\"2.0.0\",\"category\":\"Security Center\"\ - },\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Resources/subscriptions\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/assessments\",\"name\":\"c3b6ae71-f1f0-31b4-e6c1-d5951285d03d\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Security/assessments/status.code\"\ - ,\"in\":[\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f8456c1c-aa66-4dfb-861a-25d127b775c9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f8456c1c-aa66-4dfb-861a-25d127b775c9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1345 - Cryptographic\ - \ Module Authentication\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Identification and Authentication\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1345\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f86aa129-7c07-4aa4-bbf5-792d93ffd9ea\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f86aa129-7c07-4aa4-bbf5-792d93ffd9ea\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1065 - Remote\ - \ Access | Privileged Commands / Access\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Access Control control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1065\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f87b8085-dca9-4cf1-8f7b-9822b997797c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f87b8085-dca9-4cf1-8f7b-9822b997797c\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ audit Windows VMs configurations in 'System Audit Policies - System'\",\"\ - policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy\ - \ creates a Guest Configuration assignment to audit Windows virtual machines\ - \ with non-compliant settings in Group Policy category: 'System Audit Policies\ - \ - System'. It also creates a system-assigned managed identity and deploys\ - \ the VM extension for Guest Configuration. This policy should only be used\ - \ along with its corresponding audit policy in an initiative. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"1.2.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - parameters\":{\"AuditOtherSystemEvents\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Audit Other System Events\",\"description\"\ - :\"Specifies whether audit events are generated for Windows Firewall Service\ - \ and Windows Firewall driver start and stop events, failure events for these\ - \ services and Windows Firewall Service policy processing failures.\"},\"\ - allowedValues\":[\"No Auditing\",\"Success\",\"Failure\",\"Success and Failure\"\ - ],\"defaultValue\":\"No Auditing\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"\ - allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\"\ - ,\"incredibuild\",\"MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\"\ - ,\"MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SystemAuditPoliciesSystem\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/parameterHash\"\ - ,\"equals\":\"[base64(concat('Audit Other System Events;ExpectedValue', '=',\ - \ parameters('AuditOtherSystemEvents')))]\"},\"deployment\":{\"properties\"\ - :{\"mode\":\"incremental\",\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ - },\"location\":{\"value\":\"[field('location')]\"},\"type\":{\"value\":\"\ - [field('type')]\"},\"configurationName\":{\"value\":\"AzureBaseline_SystemAuditPoliciesSystem\"\ - },\"AuditOtherSystemEvents\":{\"value\":\"[parameters('AuditOtherSystemEvents')]\"\ - }},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"configurationName\"\ - :{\"type\":\"string\"},\"AuditOtherSystemEvents\":{\"type\":\"string\"}},\"\ - resources\":[{\"condition\":\"[equals(toLower(parameters('type')), toLower('microsoft.hybridcompute/machines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.HybridCompute/machines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Other System\ - \ Events;ExpectedValue\",\"value\":\"[parameters('AuditOtherSystemEvents')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2018-11-20\",\"type\":\"Microsoft.Compute/virtualMachines/providers/guestConfigurationAssignments\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.GuestConfiguration/',\ - \ parameters('configurationName'))]\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"guestConfiguration\":{\"name\":\"[parameters('configurationName')]\"\ - ,\"version\":\"1.*\",\"configurationParameter\":[{\"name\":\"Audit Other System\ - \ Events;ExpectedValue\",\"value\":\"[parameters('AuditOtherSystemEvents')]\"\ - }]}}},{\"condition\":\"[equals(toLower(parameters('type')), toLower('Microsoft.Compute/virtualMachines'))]\"\ - ,\"apiVersion\":\"2019-07-01\",\"type\":\"Microsoft.Compute/virtualMachines\"\ - ,\"identity\":{\"type\":\"SystemAssigned\"},\"name\":\"[parameters('vmName')]\"\ - ,\"location\":\"[parameters('location')]\"},{\"condition\":\"[equals(toLower(parameters('type')),\ - \ toLower('Microsoft.Compute/virtualMachines'))]\",\"apiVersion\":\"2019-07-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/AzurePolicyforWindows')]\",\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"[parameters('location')]\"\ - ,\"properties\":{\"publisher\":\"Microsoft.GuestConfiguration\",\"type\":\"\ - ConfigurationforWindows\",\"typeHandlerVersion\":\"1.1\",\"autoUpgradeMinorVersion\"\ - :true,\"settings\":{},\"protectedSettings\":{}},\"dependsOn\":[\"[concat('Microsoft.Compute/virtualMachines/',parameters('vmName'),'/providers/Microsoft.GuestConfiguration/guestConfigurationAssignments/',parameters('configurationName'))]\"\ - ]}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f8b0158d-4766-490f-bea0-259e52dba473\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f8b0158d-4766-490f-bea0-259e52dba473\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Service Bus should\ - \ be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Service Bus\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ServiceBus/namespaces\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f8d36e2f-389b-4ee4-898d-21aeb69a0f45\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f8d36e2f-389b-4ee4-898d-21aeb69a0f45\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1203 - Access\ - \ Restrictions For Change | Automated Access Enforcement / Auditing\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Configuration Management control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1203\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9012d14-e3e6-4d7b-b926-9f37b5537066\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9012d14-e3e6-4d7b-b926-9f37b5537066\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1697 - Information\ - \ System Monitoring | Analyze Traffic / Covert Exfiltration\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ System and Information Integrity control\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"\ - /providers/Microsoft.PolicyInsights/policyMetadata/ACF1697\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9873db2-18ad-46b3-a11a-1a1f8cbf0335\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9873db2-18ad-46b3-a11a-1a1f8cbf0335\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1478 - Fire\ - \ Protection | Suppression Devices / Systems\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Physical and\ - \ Environmental Protection control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1478\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f997df46-cfbb-4cc8-aac8-3fecdaf6a183\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f997df46-cfbb-4cc8-aac8-3fecdaf6a183\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1535 - Personnel\ - \ Sanctions\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Personnel Security control\",\"metadata\":{\"\ - version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1535\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9a165d2-967d-4733-8399-1074270dae2e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9a165d2-967d-4733-8399-1074270dae2e\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1108 - Content\ - \ Of Audit Records | Additional Audit Information\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Audit and\ - \ Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1108\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9ad559e-c12d-415e-9a78-e50fdd7da7ba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9ad559e-c12d-415e-9a78-e50fdd7da7ba\"\ - },{\"properties\":{\"displayName\":\"Diagnostic logs in Azure Stream Analytics\ - \ should be enabled\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Audit enabling of diagnostic logs. This enables you to recreate activity\ - \ trails to use for investigation purposes; when a security incident occurs\ - \ or when your network is compromised\",\"metadata\":{\"version\":\"3.0.0\"\ - ,\"category\":\"Stream Analytics\"},\"parameters\":{\"effect\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"},\"requiredRetentionDays\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Required retention (days)\"\ - ,\"description\":\"The required diagnostic logs retention in days\"},\"defaultValue\"\ - :\"365\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.StreamAnalytics/streamingJobs\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"\ - Microsoft.Insights/diagnosticSettings\",\"existenceCondition\":{\"count\"\ - :{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*]\",\"where\":{\"\ - anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"0\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.days\"\ - ,\"equals\":\"[parameters('requiredRetentionDays')]\"}]},{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs.enabled\"\ - ,\"equals\":\"true\"},{\"anyOf\":[{\"field\":\"Microsoft.Insights/diagnosticSettings/logs[*].retentionPolicy.enabled\"\ - ,\"notEquals\":\"true\"},{\"field\":\"Microsoft.Insights/diagnosticSettings/storageAccountId\"\ - ,\"exists\":false}]}]}]}},\"greaterOrEquals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9be5368-9bf5-4b84-9e0a-7850da98bb46\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9be5368-9bf5-4b84-9e0a-7850da98bb46\"\ - },{\"properties\":{\"displayName\":\"Latest TLS version should be used in\ - \ your Function App\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"description\"\ - :\"Upgrade to the latest TLS version\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"App Service\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"AuditIfNotExists\",\"\ - Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Web/sites\"},{\"field\"\ - :\"kind\",\"like\":\"functionapp*\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Web/sites/config\",\"name\":\"web\",\"\ - existenceCondition\":{\"field\":\"Microsoft.Web/sites/config/minTlsVersion\"\ - ,\"equals\":\"1.2\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f9d614c5-c173-4d56-95a7-b4437057d193\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f9d614c5-c173-4d56-95a7-b4437057d193\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1280 - Telecommunications\ - \ Services | Priority Of Service Provisions\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Contingency\ - \ Planning control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1280\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fa108498-b3a8-4ffb-9e79-1107e76afad3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fa108498-b3a8-4ffb-9e79-1107e76afad3\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1037 - Least\ - \ Privilege | Network Access To Privileged Commands\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this Access Control\ - \ control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory\ - \ Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1037\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fa4c2a3d-1294-41a3-9ada-0e540471e9fb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fa4c2a3d-1294-41a3-9ada-0e540471e9fb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1435 - Media\ - \ Transport\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Media Protection control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1435\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fa8d221b-d130-4637-ba16-501e666628bb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fa8d221b-d130-4637-ba16-501e666628bb\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1675 - Flaw\ - \ Remediation | Time To Remediate Flaws / Benchmarks For Corrective Actions\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this System and Information Integrity control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1675\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/facb66e0-1c48-478a-bed5-747a312323e1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"facb66e0-1c48-478a-bed5-747a312323e1\"\ - },{\"properties\":{\"displayName\":\"Audit Linux virtual machines on which\ - \ the Linux Guest Configuration extension is not enabled\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Indexed\",\"description\":\"This policy audits Linux\ - \ virtual machines hosted in Azure that are supported by Guest Configuration\ - \ but do not have the Guest Configuration extension enabled. For more information\ - \ on Guest Configuration, visit https://aka.ms/gcpol.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Guest Configuration\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"\ - type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzurePolicyforLinux\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.GuestConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"ConfigurationforLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/faf25c8c-9598-4305-b4de-0aee1317fb31\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"faf25c8c-9598-4305-b4de-0aee1317fb31\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Deploy prerequisites to\ - \ enable Guest Configuration Policy on Linux VMs.\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"This policy creates a system-assigned\ - \ managed identity and deploys the VM extension for Guest Configuration on\ - \ Linux VMs. This is a prerequisite for Guest Configuration Policy and must\ - \ be assigned to the scope before using any Guest Configuration policy. For\ - \ more information on Guest Configuration policies, please visit https://aka.ms/gcpol.\"\ - ,\"metadata\":{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"requiredProviders\":[\"Microsoft.GuestConfiguration\"],\"deprecated\":true},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"roleDefinitionIds\"\ - :[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"AzurePolicyforLinux\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.GuestConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"ConfigurationforLinux\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ - ,\"equals\":\"Succeeded\"}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\":{\"\ - value\":\"[field('location')]\"}},\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2019-07-01\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines\",\"identity\":{\"type\":\"\ - SystemAssigned\"},\"name\":\"[parameters('vmName')]\",\"location\":\"[parameters('location')]\"\ - },{\"apiVersion\":\"2019-07-01\",\"name\":\"[concat(parameters('vmName'),\ - \ '/AzurePolicyforLinux')]\",\"type\":\"Microsoft.Compute/virtualMachines/extensions\"\ - ,\"location\":\"[parameters('location')]\",\"properties\":{\"publisher\":\"\ - Microsoft.GuestConfiguration\",\"type\":\"ConfigurationforLinux\",\"typeHandlerVersion\"\ - :\"1.0\",\"autoUpgradeMinorVersion\":true,\"settings\":{},\"protectedSettings\"\ - :{}}}]}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fb27e9e0-526e-4ae1-89f2-a2a0bf0f8a50\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fb27e9e0-526e-4ae1-89f2-a2a0bf0f8a50\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1086 - Publicly\ - \ Accessible Content\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Access Control control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1086\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fb321e6f-16a0-4be3-878f-500956e309c5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fb321e6f-16a0-4be3-878f-500956e309c5\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1222 - Information\ - \ System Component Inventory\",\"policyType\":\"Static\",\"mode\":\"Indexed\"\ - ,\"description\":\"Microsoft implements this Configuration Management control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1222\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fb39e62f-6bda-4558-8088-ec03d5670914\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fb39e62f-6bda-4558-8088-ec03d5670914\"\ - },{\"properties\":{\"displayName\":\"Kubernetes Services should be upgraded\ - \ to a non-vulnerable Kubernetes version\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Indexed\",\"description\":\"Upgrade your Kubernetes service cluster to\ - \ a later Kubernetes version to protect against known vulnerabilities in your\ - \ current Kubernetes version. Vulnerability CVE-2019-9946 has been patched\ - \ in Kubernetes versions 1.11.9+, 1.12.7+, 1.13.5+, and 1.14.0+\",\"metadata\"\ - :{\"version\":\"1.0.2\",\"category\":\"Security Center\"},\"parameters\":{\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"in\":[\"1.13.4\",\"1.13.3\",\"1.13.2\",\"1.13.1\",\"1.13.0\"]},{\"field\"\ - :\"Microsoft.ContainerService/managedClusters/kubernetesVersion\",\"in\":[\"\ - 1.12.6\",\"1.12.5\",\"1.12.4\",\"1.12.3\",\"1.12.2\",\"1.12.1\",\"1.12.0\"\ - ]},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"in\":[\"1.11.8\",\"1.11.7\",\"1.11.6\",\"1.11.5\",\"1.11.4\",\"1.11.3\"\ - ,\"1.11.2\",\"1.11.1\",\"1.11.0\"]},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.10.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.9.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.8.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.7.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.6.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.5.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.4.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.3.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.2.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.1.*\"},{\"field\":\"Microsoft.ContainerService/managedClusters/kubernetesVersion\"\ - ,\"Like\":\"1.0.*\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Authorization/policyDefinitions/fb893a29-21bb-418c-a157-e99480ec364c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fb893a29-21bb-418c-a157-e99480ec364c\"\ - },{\"properties\":{\"displayName\":\"Storage account containing the container\ - \ with activity logs must be encrypted with BYOK\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"This policy audits if the Storage account\ - \ containing the container with activity logs is encrypted with BYOK. The\ - \ policy works only if the storage account lies on the same subscription as\ - \ activity logs by design. More information on Azure Storage encryption at\ - \ rest can be found here https://aka.ms/azurestoragebyok. \",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Monitoring\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Insights/logProfiles\"\ - },{\"field\":\"Microsoft.Insights/logProfiles/storageAccountId\",\"exists\"\ - :\"true\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"\ - type\":\"Microsoft.Storage/storageAccounts\",\"existenceScope\":\"subscription\"\ - ,\"existenceCondition\":{\"allOf\":[{\"value\":\"[contains(field('Microsoft.Insights/logProfiles/storageAccountId'),\ - \ subscription().Id)]\",\"equals\":\"true\"},{\"field\":\"name\",\"equals\"\ - :\"[last(split(field('Microsoft.Insights/logProfiles/storageAccountId'),'/'))]\"\ - },{\"field\":\"Microsoft.Storage/storageAccounts/encryption.keySource\",\"\ - equals\":\"Microsoft.Keyvault\"}]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fbb99e8e-e444-4da0-9ff1-75c92f5a85b2\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fbb99e8e-e444-4da0-9ff1-75c92f5a85b2\"\ - },{\"properties\":{\"displayName\":\"[Preview]: All Internet traffic should\ - \ be routed via your deployed Azure Firewall\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"All\",\"description\":\"Azure Security Center has identified that\ - \ some of your subnets aren't protected with a next generation firewall. Protect\ - \ your subnets from potential threats by restricting access to them with Azure\ - \ Firewall or a supported next generation firewall\",\"metadata\":{\"version\"\ - :\"3.0.0-preview\",\"category\":\"Network\",\"preview\":true},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Effect\",\"description\":\"Enable or disable All Internet traffic should\ - \ be routed via your deployed Azure Firewall\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks\"\ - },{\"count\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets[*]\",\"\ - where\":{\"allOf\":[{\"count\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets[*].ipConfigurations[*]\"\ - ,\"where\":{\"value\":\"[empty(field('Microsoft.Network/virtualNetworks/subnets[*].ipConfigurations[*].id'))]\"\ - ,\"equals\":false}},\"greaterOrEquals\":2},{\"field\":\"Microsoft.Network/virtualNetworks/subnets[*].routeTable\"\ - ,\"exists\":false},{\"not\":{\"anyOf\":[{\"field\":\"Microsoft.Network/virtualNetworks/subnets[*].name\"\ - ,\"equals\":\"AzureBastionSubnet\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets[*].name\"\ - ,\"equals\":\"GatewaySubnet\"}]}}]}},\"greater\":0}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.Network/azureFirewalls\"\ - ,\"existenceCondition\":{\"count\":{\"field\":\"Microsoft.Network/azureFirewalls/ipConfigurations[*]\"\ - ,\"where\":{\"field\":\"Microsoft.Network/azureFirewalls/ipConfigurations[*].subnet.id\"\ - ,\"like\":\"[concat('/subscriptions/', subscription().subscriptionId, '/resourceGroups/*/providers/Microsoft.Network/virtualNetworks/',\ - \ first(split(field('fullName'), '/')), '/subnets/AzureFirewallSubnet')]\"\ - }},\"equals\":1}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fc5e4038-4584-4632-8c85-c0448d374b2c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fc5e4038-4584-4632-8c85-c0448d374b2c\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1075 - Access\ - \ Control For Mobile Devices | Full Device / Container-Based Encryption\"\ - ,\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft\ - \ implements this Access Control control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1075\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fc933d22-04df-48ed-8f87-22a3773d4309\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fc933d22-04df-48ed-8f87-22a3773d4309\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Linux machines should meet\ - \ requirements for the Azure security baseline\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Indexed\",\"description\":\"Requires that prerequisites are deployed\ - \ to the policy assignment scope. For details, visit https://aka.ms/gcpol.\ - \ Machines are non-compliant if Linux machines should meet the requirements\ - \ for the Azure security baseline\",\"metadata\":{\"category\":\"Guest Configuration\"\ - ,\"version\":\"1.0.0-preview\",\"preview\":true,\"requiredProviders\":[\"\ - Microsoft.GuestConfiguration\"],\"guestConfiguration\":{\"name\":\"LinuxOMSBaseline\"\ - ,\"version\":\"1.*\"}},\"parameters\":{\"IncludeArcMachines\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Preview]: Include Arc connected\ - \ servers\",\"description\":\"By selecting this option, you agree to be charged\ - \ monthly per Arc connected machine.\"},\"allowedValues\":[\"true\",\"false\"\ - ],\"defaultValue\":\"false\"},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"Enable or disable\ - \ the execution of this policy\"},\"allowedValues\":[\"AuditIfNotExists\"\ - ,\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"policyRule\":{\"\ - if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\"\ - ,\"qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"\ - paloaltonetworks\",\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"value\":\"[parameters('IncludeArcMachines')]\",\"\ - equals\":\"true\"},{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"LinuxOMSBaseline\",\"existenceCondition\":{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fc9b3da7-8347-4380-8e70-0a0361d8dedd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fc9b3da7-8347-4380-8e70-0a0361d8dedd\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Windows VMs configurations in 'Security Options - Microsoft Network Client'\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy\ - \ should only be used along with its corresponding deploy policy in an initiative.\ - \ This definition allows Azure Policy to process the results of auditing Windows\ - \ virtual machines with non-compliant settings in Group Policy category: 'Security\ - \ Options - Microsoft Network Client'. For more information on Guest Configuration\ - \ policies, please visit https://aka.ms/gcpol\",\"metadata\":{\"version\"\ - :\"1.0.0-deprecated\",\"category\":\"Guest Configuration\",\"deprecated\"\ - :true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"in\":[\"esri\",\"incredibuild\",\"\ - MicrosoftDynamicsAX\",\"MicrosoftSharepoint\",\"MicrosoftVisualStudio\",\"\ - MicrosoftWindowsDesktop\",\"MicrosoftWindowsServerHPCPack\"]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftWindowsServer\"\ - },{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"2008*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftSQLServer\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\":\"SQL2008*\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-dsvm\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"dsvm-windows\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - standard-data-science-vm\",\"windows-data-science-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"equals\":\"rendering-windows2016\"}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"cis-windows-server-201*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"like\":\"bosh-windows-server*\"\ - }]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"ad*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Windows*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"exists\":\"false\"},{\"allOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ - ,\"notLike\":\"2008*\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"notLike\"\ - :\"SQL2008*\"}]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"windows*\"\ - }]}]},\"then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"AzureBaseline_SecurityOptionsMicrosoftNetworkClient\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fcbc55c9-f25a-4e55-a6cb-33acb3be778b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fcbc55c9-f25a-4e55-a6cb-33acb3be778b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1318 - Authenticator\ - \ Management\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Identification and Authentication control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1318\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fced5fda-3bdb-4d73-bfea-0e2c80428b66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fced5fda-3bdb-4d73-bfea-0e2c80428b66\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1543 - Risk\ - \ Assessment\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Risk Assessment control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1543\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd00b778-b5b5-49c0-a994-734ea7bd3624\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd00b778-b5b5-49c0-a994-734ea7bd3624\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1707 - Security\ - \ Alerts, Advisories, And Directives | Automated Alerts And Advisories\",\"\ - policyType\":\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements\ - \ this System and Information Integrity control\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1707\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd4a2ac8-868a-4702-a345-6c896c3361ce\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd4a2ac8-868a-4702-a345-6c896c3361ce\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1299 - Identification\ - \ And Authentication Policy And Procedures\",\"policyType\":\"Static\",\"\ - mode\":\"Indexed\",\"description\":\"Microsoft implements this Identification\ - \ and Authentication control\",\"metadata\":{\"version\":\"1.0.0\",\"category\"\ - :\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1299\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd4e54f7-9ab0-4bae-b6cc-457809948a89\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd4e54f7-9ab0-4bae-b6cc-457809948a89\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1627 - Boundary\ - \ Protection | External Telecommunications Services\",\"policyType\":\"Static\"\ - ,\"mode\":\"Indexed\",\"description\":\"Microsoft implements this System and\ - \ Communications Protection control\",\"metadata\":{\"version\":\"1.0.0\"\ - ,\"category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1627\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd73310d-76fc-422d-bda4-3a077149f179\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd73310d-76fc-422d-bda4-3a077149f179\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1130 - Time\ - \ Stamps | Synchronization With Authoritative Time Source\",\"policyType\"\ - :\"Static\",\"mode\":\"Indexed\",\"description\":\"Microsoft implements this\ - \ Audit and Accountability control\",\"metadata\":{\"version\":\"1.0.0\",\"\ - category\":\"Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1130\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fd7c4c1d-51ee-4349-9dab-89a7f8c8d102\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fd7c4c1d-51ee-4349-9dab-89a7f8c8d102\"\ - },{\"properties\":{\"displayName\":\"Public network access should be disabled\ - \ for MariaDB servers\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"This policy audits MariaDB servers in your environment with\ - \ public network access enabled. For more details, visit https://go.microsoft.com/fwlink/?linkid=2119542.\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"SQL\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"Audit\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.DBforMariaDB/servers\"\ - },{\"field\":\"Microsoft.DBforMariaDB/servers/publicNetworkAccess\",\"notEquals\"\ - :\"Disabled\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/fdccbe47-f3e3-4213-ad5d-ea459b2fa077\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fdccbe47-f3e3-4213-ad5d-ea459b2fa077\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1611 - Developer-Provided\ - \ Training\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this System and Services Acquisition control\",\"\ - metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"\ - additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1611\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fdda8a0c-ac32-43f6-b2f4-7dc1df03f43f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fdda8a0c-ac32-43f6-b2f4-7dc1df03f43f\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1405 - Maintenance\ - \ Tools | Inspect Tools\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"\ - description\":\"Microsoft implements this Maintenance control\",\"metadata\"\ - :{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\",\"additionalMetadataId\"\ - :\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1405\"},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fe1a0bf3-409a-4b00-b60d-0b1f917f7e7b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fe1a0bf3-409a-4b00-b60d-0b1f917f7e7b\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1613 - Developer\ - \ Security Architecture And Design\",\"policyType\":\"Static\",\"mode\":\"\ - Indexed\",\"description\":\"Microsoft implements this System and Services\ - \ Acquisition control\",\"metadata\":{\"version\":\"1.0.0\",\"category\":\"\ - Regulatory Compliance\",\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1613\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fe2ad78b-8748-4bff-a924-f74dfca93f30\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fe2ad78b-8748-4bff-a924-f74dfca93f30\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Show audit results from\ - \ Linux VMs that do not have the specified applications installed\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"All\",\"description\":\"This policy should only be\ - \ used along with its corresponding deploy policy in an initiative. This definition\ - \ allows Azure Policy to process the results of auditing Linux virtual machines\ - \ that do not have the specified applications installed. For more information\ - \ on Guest Configuration policies, please visit https://aka.ms/gcpol\",\"\ - metadata\":{\"version\":\"3.0.0-deprecated\",\"category\":\"Guest Configuration\"\ - ,\"deprecated\":true},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"anyOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"in\":[\"microsoft-aks\",\"\ - qubole-inc\",\"datastax\",\"couchbase\",\"scalegrid\",\"checkpoint\",\"paloaltonetworks\"\ - ,\"debian\"]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - like\":\"CentOS*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"Oracle-Linux\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"RHEL\"\ - ,\"RHEL-HA\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HA\",\"RHEL-SAP-HANA\"\ - ]},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"6*\"}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"rhel-byos\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-7-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-centos-8-l1\",\"cis-debian-linux-8-l1\"\ - ,\"cis-debian-linux-9-l1\",\"cis-nginx-centos-7-v1-1-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-oracle-linux-8-l1\",\"cis-postgresql-11-centos-linux-7-level-1\",\"\ - cis-rhel-7-l2\",\"cis-rhel-7-v2-2-0-l1\",\"cis-rhel-8-l1\",\"cis-suse-linux-12-v2-0-0-l1\"\ - ,\"cis-ubuntu-linux-1604-v1-0-0-l1\",\"cis-ubuntu-linux-1804-l1\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\":\"Debian\"},{\"field\"\ - :\"Microsoft.Compute/imageSKU\",\"notLike\":\"7*\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Suse\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"SLES*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"11*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"UbuntuServer\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\":\"\ - 12*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - linux-data-science-vm-ubuntu\",\"azureml\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-centos-os\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"notLike\"\ - :\"6*\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"equals\"\ - :\"cloudera-altus-centos-os\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-ads\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"like\":\"linux*\"}]},{\"allOf\":[{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachines/storageProfile.osDisk.osType\"\ - ,\"like\":\"Linux*\"}]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - notIn\":[\"OpenLogic\",\"RedHat\",\"credativ\",\"Suse\",\"Canonical\",\"microsoft-dsvm\"\ - ,\"cloudera\",\"microsoft-ads\",\"center-for-internet-security-inc\",\"Oracle\"\ - ]}]}]}]}]},{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.HybridCompute/machines\"\ - },{\"field\":\"Microsoft.HybridCompute/imageOffer\",\"like\":\"linux*\"}]}]},\"\ - then\":{\"effect\":\"auditIfNotExists\",\"details\":{\"type\":\"Microsoft.GuestConfiguration/guestConfigurationAssignments\"\ - ,\"name\":\"installed_application_linux\",\"existenceCondition\":{\"field\"\ - :\"Microsoft.GuestConfiguration/guestConfigurationAssignments/complianceStatus\"\ - ,\"equals\":\"Compliant\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fee5cb2b-9d9b-410e-afe3-2902d90d0004\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fee5cb2b-9d9b-410e-afe3-2902d90d0004\"\ - },{\"properties\":{\"displayName\":\"Vulnerabilities on your SQL databases\ - \ should be remediated\",\"policyType\":\"BuiltIn\",\"mode\":\"Indexed\",\"\ - description\":\"Monitor Vulnerability Assessment scan results and recommendations\ - \ for how to remediate database vulnerabilities.\",\"metadata\":{\"version\"\ - :\"1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"Enable or disable the execution of the policy\"},\"allowedValues\":[\"\ - AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"AuditIfNotExists\"}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"Microsoft.Sql/servers/databases\"\ - ,\"Microsoft.Sql/managedinstances/databases\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"type\":\"Microsoft.Security/complianceResults\",\"name\":\"\ - sqlVulnerabilityAssessment\",\"existenceCondition\":{\"field\":\"Microsoft.Security/complianceResults/resourceStatus\"\ - ,\"in\":[\"OffByPolicy\",\"Healthy\"]}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/feedbf84-6b99-488c-acc2-71c829aa5ffc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"feedbf84-6b99-488c-acc2-71c829aa5ffc\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1407 - Maintenance\ - \ Tools | Prevent Unauthorized Removal\",\"policyType\":\"Static\",\"mode\"\ - :\"Indexed\",\"description\":\"Microsoft implements this Maintenance control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1407\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ff9fbd83-1d8d-4b41-aac2-94cb44b33976\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ff9fbd83-1d8d-4b41-aac2-94cb44b33976\"\ - },{\"properties\":{\"displayName\":\"Deploy export to Log Analytics workspace\ - \ for Azure Security Center alerts and recommendations\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"All\",\"description\":\"Enable export to Log Analytics\ - \ workspace of Azure Security Center alerts and/or recommendations. This policy\ - \ deploys an export to Log Analytics workspace configuration with your conditions\ - \ and target workspace on the assigned scope. To deploy this policy on newly\ - \ created subscriptions, open the Compliance tab, select the relevant non-compliant\ - \ assignment and create a remediation task.\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Security Center\"},\"parameters\":{\"resourceGroupName\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Resource group name\"\ - ,\"description\":\"The resource group name where the export to Log Analytics\ - \ workspace configuration is created. If you enter a name for a resource group\ - \ that doesn't exist, it'll be created in the subscription. Note that each\ - \ resource group can only have one export to Log Analytics workspace configured.\"\ - }},\"resourceGroupLocation\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Resource group location\",\"description\":\"The location where the resource\ - \ group and the export to Log Analytics workspace configuration are created.\"\ - ,\"strongType\":\"location\"}},\"exportedDataTypes\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Exported data types\",\"description\":\"The\ - \ data types to be exported. Example: Security recommendations;Security alerts;\"\ - },\"allowedValues\":[\"Security recommendations\",\"Security alerts\"],\"\ - defaultValue\":[\"Security recommendations\",\"Security alerts\"]},\"recommendationNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Recommendation IDs\"\ - ,\"description\":\"Applicable only for export of security recommendations.\ - \ To export all recommendations, leave this empty. To export specific recommendations,\ - \ enter a list of recommendation IDs separated by semicolons (';'). Recommendation\ - \ IDs are available through the Assessments API (https://docs.microsoft.com/rest/api/securitycenter/assessments),\ - \ or Azure Resource Graph Explorer (https://portal.azure.com/#blade/HubsExtension/ArgQueryBlade),\ - \ choose securityresources and microsoft.security/assessments.\"},\"defaultValue\"\ - :[]},\"recommendationSeverities\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Recommendation severities\",\"description\":\"Applicable only for export\ - \ of security recommendations. Determines recommendation severities. Example:\ - \ High;Medium;Low;\"},\"allowedValues\":[\"High\",\"Medium\",\"Low\"],\"defaultValue\"\ - :[\"High\",\"Medium\",\"Low\"]},\"alertSeverities\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Alert severities\",\"description\":\"Applicable\ - \ only for export of security alerts. Determines alert severities. Example:\ - \ High;Medium;Low;\"},\"allowedValues\":[\"High\",\"Medium\",\"Low\"],\"defaultValue\"\ - :[\"High\",\"Medium\",\"Low\"]},\"workspaceResourceId\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Log Analytics workspace\",\"description\"\ - :\"The Log Analytics workspace of where the data should be exported to. If\ - \ you do not already have a log analytics workspace, visit Log Analytics workspaces\ - \ to create one (https://portal.azure.com/#blade/HubsExtension/BrowseResource/resourceType/Microsoft.OperationalInsights%2Fworkspaces).\"\ - ,\"strongType\":\"Microsoft.OperationalInsights/workspaces\",\"assignPermissions\"\ - :true}}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.Resources/subscriptions\"\ - },\"then\":{\"effect\":\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Security/automations\"\ - ,\"name\":\"ExportToWorkspace\",\"existenceScope\":\"resourcegroup\",\"ResourceGroupName\"\ - :\"[parameters('resourceGroupName')]\",\"deploymentScope\":\"subscription\"\ - ,\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\"\ - ],\"deployment\":{\"location\":\"westeurope\",\"properties\":{\"mode\":\"\ - incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"resourceGroupName\":{\"\ - type\":\"string\"},\"resourceGroupLocation\":{\"type\":\"string\"},\"exportedDataTypes\"\ - :{\"type\":\"array\"},\"recommendationNames\":{\"type\":\"array\"},\"recommendationSeverities\"\ - :{\"type\":\"array\"},\"alertSeverities\":{\"type\":\"array\"},\"workspaceResourceId\"\ - :{\"type\":\"string\"},\"guidValue\":{\"type\":\"string\",\"defaultValue\"\ - :\"[newGuid()]\"}},\"variables\":{\"scopeDescription\":\"scope for subscription\ - \ {0}\",\"recommendationNamesLength\":\"[length(parameters('recommendationNames'))]\"\ - ,\"recommendationSeveritiesLength\":\"[length(parameters('recommendationSeverities'))]\"\ - ,\"alertSeveritiesLength\":\"[length(parameters('alertSeverities'))]\",\"\ - recommendationNamesLengthIfEmpty\":\"[if(equals(variables('recommendationNamesLength'),\ - \ 0), 1, variables('recommendationNamesLength'))]\",\"recommendationSeveritiesLengthIfEmpty\"\ - :\"[if(equals(variables('recommendationSeveritiesLength'), 0), 1, variables('recommendationSeveritiesLength'))]\"\ - ,\"alertSeveritiesLengthIfEmpty\":\"[if(equals(variables('alertSeveritiesLength'),\ - \ 0), 1, variables('alertSeveritiesLength'))]\",\"totalRuleCombinationsForOneRecommendationName\"\ - :\"[variables('recommendationSeveritiesLengthIfEmpty')]\",\"totalRuleCombinationsForOneRecommendationSeverity\"\ - :1,\"exportedDataTypesLength\":\"[length(parameters('exportedDataTypes'))]\"\ - ,\"exportedDataTypesLengthIfEmpty\":\"[if(equals(variables('exportedDataTypesLength'),\ - \ 0), 1, variables('exportedDataTypesLength'))]\",\"dataTypeMap\":{\"Security\ - \ recommendations\":\"Assessments\",\"Security alerts\":\"Alerts\"},\"alertSeverityMap\"\ - :{\"High\":\"high\",\"Medium\":\"medium\",\"Low\":\"low\"},\"ruleSetsForAssessmentsObj\"\ - :{\"copy\":[{\"name\":\"ruleSetsForAssessmentsArr\",\"count\":\"[mul(variables('recommendationNamesLengthIfEmpty'),variables('recommendationSeveritiesLengthIfEmpty'))]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"[if(equals(variables('recommendationNamesLength'),0),'type','name')]\"\ - ,\"propertyType\":\"string\",\"expectedValue\":\"[if(equals(variables('recommendationNamesLength'),0),'Microsoft.Security/assessments',parameters('recommendationNames')[mod(div(copyIndex('ruleSetsForAssessmentsArr'),variables('totalRuleCombinationsForOneRecommendationName')),variables('recommendationNamesLength'))])]\"\ - ,\"operator\":\"Contains\"},{\"propertyJPath\":\"properties.metadata.severity\"\ - ,\"propertyType\":\"string\",\"expectedValue\":\"[parameters('recommendationSeverities')[mod(div(copyIndex('ruleSetsForAssessmentsArr'),variables('totalRuleCombinationsForOneRecommendationSeverity')),variables('recommendationSeveritiesLength'))]]\"\ - ,\"operator\":\"Equals\"}]}}]},\"ruleSetsForAlertsObj\":{\"copy\":[{\"name\"\ - :\"ruleSetsForAlertsArr\",\"count\":\"[variables('alertSeveritiesLengthIfEmpty')]\"\ - ,\"input\":{\"rules\":[{\"propertyJPath\":\"Severity\",\"propertyType\":\"\ - string\",\"expectedValue\":\"[variables('alertSeverityMap')[parameters('alertSeverities')[mod(copyIndex('ruleSetsForAlertsArr'),variables('alertSeveritiesLengthIfEmpty'))]]]\"\ - ,\"operator\":\"Equals\"}]}}]}},\"resources\":[{\"name\":\"[parameters('resourceGroupName')]\"\ - ,\"type\":\"Microsoft.Resources/resourceGroups\",\"apiVersion\":\"2019-10-01\"\ - ,\"location\":\"[parameters('resourceGroupLocation')]\",\"tags\":{},\"properties\"\ - :{}},{\"type\":\"Microsoft.Resources/deployments\",\"apiVersion\":\"2019-10-01\"\ - ,\"name\":\"[concat('nestedAutomationDeployment', '_', parameters('guidValue'))]\"\ - ,\"resourceGroup\":\"[parameters('resourceGroupName')]\",\"dependsOn\":[\"\ - [resourceId('Microsoft.Resources/resourceGroups/', parameters('resourceGroupName'))]\"\ - ],\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{},\"variables\":{},\"resources\"\ - :[{\"tags\":{},\"apiVersion\":\"2019-01-01-preview\",\"location\":\"[parameters('resourceGroupLocation')]\"\ - ,\"name\":\"ExportToWorkspace\",\"type\":\"Microsoft.Security/automations\"\ - ,\"dependsOn\":[],\"properties\":{\"description\":\"Export Azure Security\ - \ Center alerts and/or recommendations to Log Analytics workspace via policy\"\ - ,\"isEnabled\":true,\"scopes\":[{\"description\":\"[replace(variables('scopeDescription'),'{0}',\ - \ subscription().subscriptionId)]\",\"scopePath\":\"[subscription().id]\"\ - }],\"copy\":[{\"name\":\"sources\",\"count\":\"[variables('exportedDataTypesLengthIfEmpty')]\"\ - ,\"input\":{\"eventSource\":\"[variables('dataTypeMap')[parameters('exportedDataTypes')[copyIndex('sources')]]]\"\ - ,\"ruleSets\":\"[if(equals(parameters('exportedDataTypes')[copyIndex('sources')],\ - \ 'Security recommendations'), variables('ruleSetsForAssessmentsObj').ruleSetsForAssessmentsArr,\ - \ variables('ruleSetsForAlertsObj').ruleSetsForAlertsArr)]\"}}],\"actions\"\ - :[{\"actionType\":\"Workspace\",\"workspaceResourceId\":\"[parameters('workspaceResourceId')]\"\ - }]}}]}}}]},\"parameters\":{\"resourceGroupName\":{\"value\":\"[parameters('resourceGroupName')]\"\ - },\"resourceGroupLocation\":{\"value\":\"[parameters('resourceGroupLocation')]\"\ - },\"exportedDataTypes\":{\"value\":\"[parameters('exportedDataTypes')]\"},\"\ - recommendationNames\":{\"value\":\"[parameters('recommendationNames')]\"},\"\ - recommendationSeverities\":{\"value\":\"[parameters('recommendationSeverities')]\"\ - },\"alertSeverities\":{\"value\":\"[parameters('alertSeverities')]\"},\"workspaceResourceId\"\ - :{\"value\":\"[parameters('workspaceResourceId')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ffb6f416-7bd2-4488-8828-56585fef2be9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ffb6f416-7bd2-4488-8828-56585fef2be9\"\ - },{\"properties\":{\"displayName\":\"Microsoft Managed Control 1158 - Security\ - \ Authorization\",\"policyType\":\"Static\",\"mode\":\"Indexed\",\"description\"\ - :\"Microsoft implements this Security Assessment and Authorization control\"\ - ,\"metadata\":{\"version\":\"1.0.0\",\"category\":\"Regulatory Compliance\"\ - ,\"additionalMetadataId\":\"/providers/Microsoft.PolicyInsights/policyMetadata/ACF1158\"\ - },\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"in\":[\"Microsoft.Resources/subscriptions\"\ - ,\"Microsoft.Resources/subscriptions/resourceGroups\"]},{\"value\":\"false\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/fff50cf2-28eb-45b4-b378-c99412688907\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fff50cf2-28eb-45b4-b378-c99412688907\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pod hostPath volumes\ - \ should only use allowed host paths\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures pod hostPath\ - \ volumes can only use allowed host paths in a Kubernetes Cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedHostPaths\":{\"type\":\"Object\",\"metadata\":{\"displayName\":\"Allowed\ - \ host paths\",\"description\":\"The host paths allowed for pod hostPath volumes\ - \ to use. Provide an empty paths list to block all host paths.\",\"schema\"\ - :{\"type\":\"object\",\"properties\":{\"paths\":{\"type\":\"array\",\"items\"\ - :{\"type\":\"object\",\"properties\":{\"pathPrefix\":{\"type\":\"string\"\ - },\"readOnly\":{\"type\":\"boolean\"}},\"required\":[\"pathPrefix\",\"readOnly\"\ - ],\"additionalProperties\":false}}},\"required\":[\"paths\"],\"additionalProperties\"\ - :false}},\"defaultValue\":{\"paths\":[]}}},\"policyRule\":{\"if\":{\"field\"\ - :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-host-paths/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-host-paths/constraint.yaml\"\ - ,\"values\":{\"allowedHostPaths\":\"[parameters('allowedHostPaths').paths]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/098fc59e-46c7-4d99-9b16-64990e543d75\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"098fc59e-46c7-4d99-9b16-64990e543d75\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should have the\ - \ specified maximum validity period\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ - \ compliance requirements by specifying the maximum amount of time that a\ - \ certificate can be valid within your key vault.\",\"metadata\":{\"version\"\ - :\"2.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ - :{\"maximumValidityInMonths\":{\"type\":\"Integer\",\"metadata\":{\"displayName\"\ - :\"[Preview]: The maximum validity in months\",\"description\":\"The limit\ - \ to how long a certificate may be valid for. Certificates with lengthy validity\ - \ periods aren't best practice.\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ - \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/properties.validityInMonths\"\ - ,\"greater\":\"[parameters('maximumValidityInMonths')]\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a075868-4c26-42ef-914c-5bc007359560\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a075868-4c26-42ef-914c-5bc007359560\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure containers listen\ - \ only on allowed ports in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy enforces containers to listen only on allowed\ - \ ports in an Azure Kubernetes Service cluster. This policy is deprecated,\ - \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ - \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ - category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ - allowedContainerPortsRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Allowed container ports regex\",\"description\":\"Regex representing\ - \ container ports allowed in Kubernetes cluster. E.g. Regex for allowing ports\ - \ 443,446 is ^(443|446)$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ - ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ - :\"ContainerAllowedPorts\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-allowed-ports/limited-preview/gatekeeperpolicy.rego\"\ - ,\"policyParameters\":{\"allowedContainerPortsRegex\":\"[parameters('allowedContainerPortsRegex')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f636243-1b1c-4d50-880f-310f6199f2cb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f636243-1b1c-4d50-880f-310f6199f2cb\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should use allowed\ - \ key types\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ - ,\"description\":\"Manage your organizational compliance requirements by restricting\ - \ the key types allowed for certificates.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ - ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"allowedKeyTypes\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Allowed key\ - \ types\",\"description\":\"The list of allowed certificate key types.\"},\"\ - allowedValues\":[\"RSA\",\"RSA-HSM\",\"EC\",\"EC-HSM\"],\"defaultValue\":[\"\ - RSA\",\"RSA-HSM\"]},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ - \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ - \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\"\ - :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ - ,\"notIn\":\"[parameters('allowedKeyTypes')]\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1151cede-290b-4ba0-8b38-0ad145ac888f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1151cede-290b-4ba0-8b38-0ad145ac888f\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should have the\ - \ specified lifetime action triggers\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ - \ compliance requirements by specifying whether a certificate lifetime action\ - \ is triggered at a specific percentage of its lifetime or at a certain number\ - \ of days prior to its expiration.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ - ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"maximumPercentageLife\"\ - :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: The maximum\ - \ lifetime percentage\",\"description\":\"Enter the percentage of lifetime\ - \ of the certificate when you want to trigger the policy action. For example,\ - \ to trigger a policy action at 80% of the certificate's valid life, enter\ - \ '80'.\"}},\"minimumDaysBeforeExpiry\":{\"type\":\"Integer\",\"metadata\"\ - :{\"displayName\":\"[Preview]: The minimum days before expiry\",\"description\"\ - :\"Enter the days before expiration of the certificate when you want to trigger\ - \ the policy action. For example, to trigger a policy action 90 days before\ - \ the certificate's expiration, enter '90'.\"}},\"effect\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit'\ - \ allows a non-compliant resource to be created, but flags it as non-compliant.\ - \ 'Deny' blocks the resource creation. 'Disable' turns off the policy.\"},\"\ - allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.daysBeforeExpiry\"\ - ,\"exists\":true},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.daysBeforeExpiry\"\ - ,\"less\":\"[parameters('minimumDaysBeforeExpiry')]\"}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.lifetimePercentage\"\ - ,\"exists\":true},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.lifetimePercentage\"\ - ,\"greater\":\"[parameters('maximumPercentageLife')]\"}]}]}]},\"then\":{\"\ - effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12ef42cb-9903-4e39-9c26-422d29570417\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12ef42cb-9903-4e39-9c26-422d29570417\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pods should only use\ - \ allowed volume types\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy ensures pods can only use allowed volume types\ - \ in a Kubernetes cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ - \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ - \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedVolumeTypes\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ - Allowed volume types\",\"description\":\"The list of volume types that can\ - \ be used by a pod. Provide empty list as input to block everything.\"},\"\ - defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ - :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-volume-types/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-volume-types/constraint.yaml\"\ - ,\"values\":{\"volumes\":\"[parameters('allowedVolumeTypes')]\",\"excludedNamespaces\"\ - :\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16697877-1118-4fb1-9b65-9898ec2509ec\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16697877-1118-4fb1-9b65-9898ec2509ec\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce labels on pods\ - \ in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy enforces the specified labels are provided\ - \ for pods in an Azure Kubernetes Service cluster. This policy is deprecated,\ - \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ - \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ - category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ - commaSeparatedListOfLabels\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Comma-separated list of labels\",\"description\":\"A comma-separated\ - \ list of labels to be specified on Pods in Kubernetes cluster. E.g. test1,test2\"\ - }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\"\ - :\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerService/managedClusters\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"policyId\":\"PodEnforceLabels\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/pod-enforce-labels/limited-preview/gatekeeperpolicy.rego\"\ - ,\"policyParameters\":{\"commaSeparatedListOfLabels\":\"[parameters('commaSeparatedListOfLabels')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16c6ca72-89d2-4798-b87e-496f9de7fcb7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16c6ca72-89d2-4798-b87e-496f9de7fcb7\"\ - },{\"properties\":{\"displayName\":\"Enforce HTTPS ingress in Kubernetes cluster\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\",\"description\"\ - :\"This policy enforces HTTPS ingress in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"4.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created, but flags it as\ - \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ - \ the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\"\ - :\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Namespace exclusions\",\"description\":\"List of Kubernetes namespaces\ - \ to exclude from policy evaluation.\"},\"defaultValue\":[\"kube-system\"\ - ,\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"if\":{\"field\"\ - :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-https-only/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-https-only/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1a5b4dca-0b6f-4cf5-907c-56316bc1bf3d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1a5b4dca-0b6f-4cf5-907c-56316bc1bf3d\"\ - },{\"properties\":{\"displayName\":\"Kubernetes clusters should not allow\ - \ container privilege escalation\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Microsoft.Kubernetes.Data\",\"description\":\"This policy does not allow containers\ - \ to use privilege escalation in a Kubernetes cluster. For instructions on\ - \ using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"\ - version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege-escalation/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege-escalation/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1c6e92c9-99f0-4e55-9cf2-0c234dc48f99\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1c6e92c9-99f0-4e55-9cf2-0c234dc48f99\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure log filter expressions\ - \ and datastore to be used for full logs for specified Azure Machine Learning\ - \ computes\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\"\ - ,\"description\":\"This policy helps provide log filter expression and datastore\ - \ to be used for full logs in specified Azure Machine Learning computes and\ - \ can be assigned at the workspace. For more information, visit https://aka.ms/amlpolicydoc.\"\ - ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Machine Learning\"\ - ,\"preview\":true},\"parameters\":{\"computeNames\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"[Preview]: Compute names where Azure ML jobs\ - \ run\",\"description\":\"List of compute names where this policy should be\ - \ applied. Ex. cpu-cluster;gpu-cluster. If no value is provided to this parameter\ - \ then policy is applicable to all computes.\"},\"defaultValue\":[]},\"logFilters\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Log filter\ - \ expressions\",\"description\":\"List of log filter expressions used to filter\ - \ logs. Ex. ^prefix1.*$\"},\"defaultValue\":[]},\"datastore\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"[Preview]: Datastore\",\"description\"\ - :\"Datastore used to store filtered logs. Ex. LogsDatastore which is configured\ - \ in AML.\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\"\ - :\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"logFilter\",\"value\":{\"filters\":\"[parameters('logFilters')]\"\ - ,\"datastore\":\"[parameters('datastore')]\"}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d413020-63de-11ea-bc55-0242ac130003\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d413020-63de-11ea-bc55-0242ac130003\"\ - },{\"properties\":{\"displayName\":\"Ensure services listen only on allowed\ - \ ports in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy enforces services to listen only on allowed\ - \ ports in a Kubernetes cluster. For instructions on using this policy, visit\ - \ https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"4.0.1\",\"category\"\ - :\"Kubernetes\"},\"parameters\":{\"allowedServicePortsList\":{\"type\":\"\ - Array\",\"metadata\":{\"displayName\":\"Allowed service ports list\",\"description\"\ - :\"The list of service ports allowed in a Kubernetes cluster.\"}},\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created, but flags it as\ - \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ - \ the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\"\ - :\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Namespace exclusions\",\"description\":\"List of Kubernetes namespaces\ - \ to exclude from policy evaluation.\"},\"defaultValue\":[\"kube-system\"\ - ,\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"if\":{\"field\"\ - :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/service-allowed-ports/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/service-allowed-ports/constraint.yaml\"\ - ,\"values\":{\"allowedServicePorts\":\"[parameters('allowedServicePortsList')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/233a2a17-77ca-4fb1-9b6b-69223d272a44\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"233a2a17-77ca-4fb1-9b6b-69223d272a44\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure services listen\ - \ only on allowed ports in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy enforces services to listen only on allowed\ - \ ports in an Azure Kubernetes Service cluster. This policy is deprecated,\ - \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ - \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ - category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ - allowedServicePortsRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Allowed service ports regex\",\"description\":\"Regex representing\ - \ service ports allowed in Kubernetes cluster. E.g. Regex for allowing ports\ - \ 443,446 is ^(443|446)$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ - ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ - :\"ServiceAllowedPorts\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/service-allowed-ports/limited-preview/gatekeeperpolicy.rego\"\ - ,\"policyParameters\":{\"allowedServicePortsRegex\":\"[parameters('allowedServicePortsRegex')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/25dee3db-6ce0-4c02-ab5d-245887b24077\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"25dee3db-6ce0-4c02-ab5d-245887b24077\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce HTTPS ingress in\ - \ AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy enforces HTTPS ingress in an Azure Kubernetes\ - \ Service cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ - \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ - :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ - defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"HttpsIngressOnly\"\ - ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/ingress-https-only/limited-preview/gatekeeperpolicy.rego\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2fbff515-eecc-4b7e-9b63-fcc7138b7dc3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2fbff515-eecc-4b7e-9b63-fcc7138b7dc3\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure an approval endpoint\ - \ called prior to jobs running for specified Azure Machine Learning computes\"\ - ,\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\"\ - ,\"description\":\"This policy helps configure an approval endpoint called\ - \ prior to jobs running for specified Azure Machine Learning computes and\ - \ can be assigned at the workspace. For more information. For more information,\ - \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ - ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ - \ where Azure ML jobs run\",\"description\":\"List of compute names where\ - \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ - \ is provided to this parameter then policy is applicable to all computes.\"\ - },\"defaultValue\":[]},\"approvalEndpoint\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Approval endpoint\",\"description\":\"Approval\ - \ endpoint that needs to be called before an Azure ML job is run. Ex. http://amlrunapproval/approve\"\ - }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ - \ Effect\",\"description\":\"Enable or disable the execution of the policy.\"\ - },\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\":\"\ - enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"approvalEndpoint\",\"value\":\"[parameters('approvalEndpoint')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3948394e-63de-11ea-bc55-0242ac130003\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3948394e-63de-11ea-bc55-0242ac130003\"\ - },{\"properties\":{\"displayName\":\"Enforce internal load balancers in Kubernetes\ - \ cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy enforces load balancers do not have public\ - \ IPs in a Kubernetes cluster. For instructions on using this policy, visit\ - \ https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"4.0.1\",\"category\"\ - :\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Effect\",\"description\":\"'Audit' allows a non-compliant\ - \ resource to be created, but flags it as non-compliant. 'Deny' blocks the\ - \ resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/load-balancer-no-public-ips/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/load-balancer-no-public-ips/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3fc4dc25-5baf-40d8-9b05-7fe74c1bc64e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3fc4dc25-5baf-40d8-9b05-7fe74c1bc64e\"\ - },{\"properties\":{\"displayName\":\"Ensure containers listen only on allowed\ - \ ports in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy enforces containers to listen only on allowed\ - \ ports in a Kubernetes cluster. For instructions on using this policy, visit\ - \ https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"4.0.1\",\"category\"\ - :\"Kubernetes\"},\"parameters\":{\"allowedContainerPortsList\":{\"type\":\"\ - Array\",\"metadata\":{\"displayName\":\"Allowed container ports list\",\"\ - description\":\"The list of container ports allowed in a Kubernetes cluster.\"\ - }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ - \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ - \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ - ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ - \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ - :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-ports/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-ports/constraint.yaml\"\ - ,\"values\":{\"allowedContainerPorts\":\"[parameters('allowedContainerPortsList')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/440b515e-a580-421e-abeb-b159a61ddcbc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"440b515e-a580-421e-abeb-b159a61ddcbc\"\ - },{\"properties\":{\"displayName\":\"Enforce labels on pods in Kubernetes\ - \ cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy enforces the specified labels are provided\ - \ for pods in a Kubernetes cluster. For instructions on using this policy,\ - \ visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"4.0.1\"\ - ,\"category\":\"Kubernetes\"},\"parameters\":{\"labelsList\":{\"type\":\"\ - Array\",\"metadata\":{\"displayName\":\"List of labels\",\"description\":\"\ - The list of labels to be specified on Pods in a Kubernetes cluster.\"}},\"\ - effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"\ - description\":\"'Audit' allows a non-compliant resource to be created, but\ - \ flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ - \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ - ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ - \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ - :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/pod-enforce-labels/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/pod-enforce-labels/constraint.yaml\"\ - ,\"values\":{\"labels\":\"[parameters('labelsList')]\",\"excludedNamespaces\"\ - :\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/46592696-4c7b-4bf3-9e45-6c2763bdc0a6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"46592696-4c7b-4bf3-9e45-6c2763bdc0a6\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ not share host process ID or host IPC namespace\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy blocks\ - \ pod containers from sharing the host process ID namespace and host IPC namespace\ - \ in a Kubernetes cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc/.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ - \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ - \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-host-namespace/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-host-namespace/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/47a1ee2f-2a2a-4576-bf2a-e0e36709c2b8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"47a1ee2f-2a2a-4576-bf2a-e0e36709c2b8\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ only use allowed AppArmor profiles\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ - \ only use allowed AppArmor profiles in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedProfiles\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed\ - \ AppArmor profiles\",\"description\":\"The list of AppArmor profiles that\ - \ containers are allowed to use. E.g. 'runtime/default;docker/default'. Provide\ - \ empty list as input to block everything.\"},\"defaultValue\":[]}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/enforce-apparmor-profile/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/enforce-apparmor-profile/constraint.yaml\"\ - ,\"values\":{\"allowedProfiles\":\"[parameters('allowedProfiles')]\",\"excludedNamespaces\"\ - :\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/511f5417-5d12-434d-ab2e-816901e72a5e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"511f5417-5d12-434d-ab2e-816901e72a5e\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed module authors\ - \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\"This\ - \ policy helps provide allowed module authors in specified Azure Machine Learning\ - \ computes and can be assigned at the workspace. For more information, visit\ - \ https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ - ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ - \ where Azure ML jobs run\",\"description\":\"List of compute names where\ - \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ - \ is provided to this parameter then policy is applicable to all computes.\"\ - },\"defaultValue\":[]},\"allowedModuleAuthors\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Allowed module authors\",\"description\":\"\ - List of allowed module authors.\"},\"defaultValue\":[]},\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ - :\"Enable or disable the execution of the policy.\"},\"allowedValues\":[\"\ - enforceSetting\",\"disabled\"],\"defaultValue\":\"enforceSetting\"}},\"policyRule\"\ - :{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"allowedModuleAuthors\",\"value\":\"[parameters('allowedModuleAuthors')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53c70b02-63dd-11ea-bc55-0242ac130003\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53c70b02-63dd-11ea-bc55-0242ac130003\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ not use forbidden sysctl interfaces\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ - \ do not use forbidden sysctl interfaces in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - forbiddenSysctls\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Forbidden\ - \ sysctls\",\"description\":\"The list of plain sysctl names or sysctl patterns\ - \ which end with *. The string * matches all sysctls. For more information,\ - \ visit https://aka.ms/k8s-policy-sysctl-interfaces.\"}}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ - :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/forbidden-sysctl-interfaces/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/forbidden-sysctl-interfaces/constraint.yaml\"\ - ,\"values\":{\"forbiddenSysctls\":\"[parameters('forbiddenSysctls')]\",\"\ - excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"\ - /providers/Microsoft.Authorization/policyDefinitions/56d0a13f-712f-466b-8416-56fb354fb823\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"56d0a13f-712f-466b-8416-56fb354fb823\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed registries\ - \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\"This\ - \ policy helps provide registries that are allowed in specified Azure Machine\ - \ Learning computes and can be assigned at the workspace. For more information,\ - \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ - ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ - \ where Azure ML jobs run\",\"description\":\"List of compute names where\ - \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ - \ is provided to this parameter then policy is applicable to all computes.\"\ - },\"defaultValue\":[]},\"allowedACRs\":{\"type\":\"Array\",\"metadata\":{\"\ - displayName\":\"[Preview]: Azure Container Registries\",\"description\":\"\ - List of Azure Container Registries that can be used with Azure ML. Ex. amlrepo.azurecr.io;amlrepo.azurecr.io/foo\"\ - },\"defaultValue\":[]},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ - \ the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\"\ - :\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"allowedACRs\",\"value\":\"[parameters('allowedACRs')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5853517a-63de-11ea-bc55-0242ac130003\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5853517a-63de-11ea-bc55-0242ac130003\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure only allowed container\ - \ images in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy ensures only allowed container images are running\ - \ in an Azure Kubernetes Service cluster. This policy is deprecated, please\ - \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ - \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ - :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"allowedContainerImagesRegex\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allowed\ - \ container images regex\",\"description\":\"Regex representing container\ - \ images allowed in Kubernetes cluster. E.g. Regex of azure container registry\ - \ images is ^.+azurecr.io/.+$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ - \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ - ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ - :\"ContainerAllowedImages\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-allowed-images/limited-preview/gatekeeperpolicy.rego\"\ - ,\"policyParameters\":{\"allowedContainerImagesRegex\":\"[parameters('allowedContainerImagesRegex')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f86cb6e-c4da-441b-807c-44bd0cc14e66\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f86cb6e-c4da-441b-807c-44bd0cc14e66\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure code signing for\ - \ training code for specified Azure Machine Learning computes\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\"\ - :\"This policy helps provide code signing for training code in specified Azure\ - \ Machine Learning computes and can be assigned at the workspace. For more\ - \ information, visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\"\ - :\"1.0.0-preview\",\"category\":\"Machine Learning\",\"preview\":true},\"\ - parameters\":{\"computeNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Compute names where Azure Machine Learning jobs run\",\"description\"\ - :\"List of compute names where this policy should be applied. Example: 'cpu-cluster;gpu-cluster'.\ - \ If no value is provided to this parameter, policy is applicable to all computes.\"\ - },\"defaultValue\":[]},\"signingKey\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Preview]: PGP public key\",\"description\":\"Public key text\ - \ in PGP public key format, with newline characters encoded as string literals\ - \ \\\"\\\\r\\\" and \\\"\\\\n\\\".\"}},\"effect\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy.\"},\"allowedValues\":[\"enforceSetting\"\ - ,\"disabled\"],\"defaultValue\":\"enforceSetting\"}},\"policyRule\":{\"if\"\ - :{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"signingKey\",\"value\":\"[parameters('signingKey')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a6f7384-63de-11ea-bc55-0242ac130003\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a6f7384-63de-11ea-bc55-0242ac130003\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed Python packages\ - \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\" This\ - \ policy helps provide allowed Python packages in specified Azure Machine\ - \ Learning computes and can be assigned at the workspace. For more information,\ - \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ - ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ - \ where Azure ML jobs run\",\"description\":\"List of compute names where\ - \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ - \ is provided to this parameter then policy is applicable to all computes.\"\ - },\"defaultValue\":[]},\"allowedPythonPackageChannels\":{\"type\":\"Array\"\ - ,\"metadata\":{\"displayName\":\"[Preview]: Allowed Python package indexes\"\ - ,\"description\":\"List of allowed Python package indexes. Ex. http://somepythonindex.org\ - \ \"},\"defaultValue\":[]},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Preview]: Effect\",\"description\":\"Enable or disable the\ - \ execution of the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"\ - ],\"defaultValue\":\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\"\ - :[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ - ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ - ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"setting\":{\"name\":\"allowedPythonPackageChannels\",\"value\":\"[parameters('allowedPythonPackageChannels')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/77eeea86-7e81-4a7d-9067-de844d096752\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"77eeea86-7e81-4a7d-9067-de844d096752\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Do not allow privileged\ - \ containers in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy does not allow privileged containers creation\ - \ in an Azure Kubernetes Service cluster. This policy is deprecated, please\ - \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ - \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ - :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ - :\"ContainerNoPrivilege\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-no-privilege/limited-preview/gatekeeperpolicy.rego\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ce7ac02-a5c6-45d6-8d1b-844feb1c1531\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ce7ac02-a5c6-45d6-8d1b-844feb1c1531\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pods should only use\ - \ approved host network and port range\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy controls pod\ - \ access to the host network and the allowable host port range in a Kubernetes\ - \ cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ - \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ - \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowHostNetwork\":{\"type\":\"Boolean\",\"metadata\":{\"displayName\":\"\ - Allow host network usage\",\"description\":\"Set this value to true if pod\ - \ is allowed to use host network otherwise false.\"},\"defaultValue\":false},\"\ - minPort\":{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"Min host port\"\ - ,\"description\":\"The minimum value in the allowable host port range that\ - \ pods can use in the host network namespace.\"},\"defaultValue\":0},\"maxPort\"\ - :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"Max host port\",\"\ - description\":\"The maximum value in the allowable host port range that pods\ - \ can use in the host network namespace.\"},\"defaultValue\":0}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/host-network-ports/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/host-network-ports/constraint.yaml\"\ - ,\"values\":{\"allowHostNetwork\":\"[parameters('allowHostNetwork')]\",\"\ - minPort\":\"[parameters('minPort')]\",\"maxPort\":\"[parameters('maxPort')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/82985f06-dc18-4a48-bc1c-b9f4f0098cfe\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82985f06-dc18-4a48-bc1c-b9f4f0098cfe\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should be issued\ - \ by the specified integrated certificate authority\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ - \ compliance requirements by specifying the Azure integrated certificate authorities\ - \ that can issue certificates in your key vault such as Digicert or GlobalSign.\"\ - ,\"metadata\":{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"\ - preview\":true},\"parameters\":{\"allowedCAs\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Allowed Azure Key Vault Supported CAs\",\"\ - description\":\"The list of allowed certificate authorities supported by Azure\ - \ Key Vault.\"},\"allowedValues\":[\"DigiCert\",\"GlobalSign\"],\"defaultValue\"\ - :[\"DigiCert\",\"GlobalSign\"]},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ - \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/issuer.name\",\"\ - notIn\":\"[parameters('allowedCAs')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8e826246-c976-48f6-b03e-619bb92b3d82\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8e826246-c976-48f6-b03e-619bb92b3d82\"\ - },{\"properties\":{\"displayName\":\"Do not allow privileged containers in\ - \ Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy does not allow privileged containers creation\ - \ in a Kubernetes cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"4.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ - \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ - \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ - ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ - \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ - :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/95edb821-ddaf-4404-9732-666045e056b4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"95edb821-ddaf-4404-9732-666045e056b4\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ only use allowed seccomp profiles\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ - \ only use allowed seccomp profiles in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedProfiles\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed\ - \ seccomp profiles\",\"description\":\"The list of seccomp profiles that containers\ - \ are allowed to use. E.g. 'runtime/default;docker/default'. Provide empty\ - \ list as input to block everything.\"},\"defaultValue\":[]}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-seccomp-profiles/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-seccomp-profiles/constraint.yaml\"\ - ,\"values\":{\"allowedProfiles\":\"[parameters('allowedProfiles')]\",\"excludedNamespaces\"\ - :\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/975ce327-682c-4f2e-aa46-b9598289b86c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"975ce327-682c-4f2e-aa46-b9598289b86c\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should be issued\ - \ by the specified non-integrated certificate authority\",\"policyType\":\"\ - BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your\ - \ organizational compliance requirements by specifying the custom or internal\ - \ certificate authorities that can issue certificates in your key vault.\"\ - ,\"metadata\":{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"\ - preview\":true},\"parameters\":{\"caCommonName\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: The common name of the certificate authority\"\ - ,\"description\":\"The common name (CN) of the Certificate Authority (CA)\ - \ provider. For example, for an issuer CN = Contoso, OU = .., DC = .., you\ - \ can specify Contoso\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant\ - \ resource to be created, but flags it as non-compliant. 'Deny' blocks the\ - \ resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/issuer.commonName\"\ - ,\"notContains\":\"[parameters('caCommonName')]\"}]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a22f4a40-01d3-4c7d-8071-da157eeff341\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a22f4a40-01d3-4c7d-8071-da157eeff341\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure CPU and memory resource\ - \ limits defined on containers in AKS\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.ContainerService.Data\",\"description\":\"This policy ensures\ - \ CPU and memory resource limits are defined on containers in an Azure Kubernetes\ - \ Service cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ - \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ - :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ - defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"ContainerResourceLimits\"\ - ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-resource-limits/limited-preview/gatekeeperpolicy.rego\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2d3ed81-8d11-4079-80a5-1faadc0024f4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2d3ed81-8d11-4079-80a5-1faadc0024f4\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce internal load balancers\ - \ in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ - ,\"description\":\"This policy enforces load balancers do not have public\ - \ IPs in an Azure Kubernetes Service cluster. This policy is deprecated, please\ - \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ - \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ - :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"\ - description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ - :[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"\ - }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ - :\"LoadBalancersInternal\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/loadbalancer-no-publicips/limited-preview/gatekeeperpolicy.rego\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a74d8f00-2fd9-4ce4-968e-0ee1eb821698\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a74d8f00-2fd9-4ce4-968e-0ee1eb821698\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce unique ingress\ - \ hostnames across namespaces in Kubernetes cluster\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy enforces\ - \ unique ingress hostnames across namespaces in a Kubernetes cluster. For\ - \ instructions on using this policy, please go to https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"3.0.1-deprecated\",\"category\":\"Kubernetes\"\ - ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"'Audit' allows\ - \ a non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Deprecated]: Namespace\ - \ exclusions\",\"description\":\"List of Kubernetes namespaces to exclude\ - \ from policy evaluation.\"},\"defaultValue\":[\"kube-system\",\"gatekeeper-system\"\ - ,\"azure-arc\"]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS\ - \ Engine\",\"Microsoft.Kubernetes/connectedClusters\"]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-hostnames-conflict/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-hostnames-conflict/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b2fd3e59-6390-4f2b-8247-ea676bd03e2d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b2fd3e59-6390-4f2b-8247-ea676bd03e2d\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates using elliptic\ - \ curve cryptography should have allowed curve names\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage the allowed\ - \ elliptic curve names for ECC Certificates stored in key vault. More information\ - \ can be found at https://aka.ms/akvpolicy.\",\"metadata\":{\"version\":\"\ - 2.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ - :{\"allowedECNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ - [Preview]: Allowed elliptic curve names\",\"description\":\"The list of allowed\ - \ curve names for elliptic curve cryptography certificates.\"},\"allowedValues\"\ - :[\"P-256\",\"P-256K\",\"P-384\",\"P-521\"],\"defaultValue\":[\"P-256\",\"\ - P-256K\",\"P-384\",\"P-521\"]},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ - \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ - ,\"in\":[\"EC\",\"EC-HSM\"]},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.ellipticCurveName\"\ - ,\"notIn\":\"[parameters('allowedECNames')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bd78111f-4953-4367-9fd5-7e08808b54bf\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bd78111f-4953-4367-9fd5-7e08808b54bf\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ only use allowed capabilities\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy ensures containers only use allowed capabilities\ - \ in a Kubernetes cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ - \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ - \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedCapabilities\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ - Allowed capabilities\",\"description\":\"The list of capabilities that are\ - \ allowed to be added to a container. Provide empty list as input to block\ - \ everything.\"},\"defaultValue\":[]},\"requiredDropCapabilities\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Required drop capabilities\",\"\ - description\":\"The list of capabilities that must be dropped by a container.\"\ - },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ - :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ - ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ - :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-capabilities/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-capabilities/constraint.yaml\"\ - ,\"values\":{\"allowedCapabilities\":\"[parameters('allowedCapabilities')]\"\ - ,\"requiredDropCapabilities\":\"[parameters('requiredDropCapabilities')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/c26596ff-4d70-4e6a-9a30-c2506bd2f80c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c26596ff-4d70-4e6a-9a30-c2506bd2f80c\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates using RSA cryptography\ - \ should have the specified minimum key size\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ - \ compliance requirements by specifying a minimum key size for RSA certificates\ - \ stored in your key vault.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ - ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"minimumRSAKeySize\"\ - :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: Minimum\ - \ RSA key size\",\"description\":\"The minimum key size for RSA certificates.\"\ - },\"allowedValues\":[2048,3072,4096]},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ - \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ - ,\"in\":[\"RSA\",\"RSA-HSM\"]},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keySize\"\ - ,\"less\":\"[parameters('minimumRSAKeySize')]\"}]},\"then\":{\"effect\":\"\ - [parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cee51871-e572-4576-855c-047c820360f0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cee51871-e572-4576-855c-047c820360f0\"\ - },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce unique ingress\ - \ hostnames across namespaces in AKS\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.ContainerService.Data\",\"description\":\"This policy enforces\ - \ unique ingress hostnames across namespaces in an Azure Kubernetes Service\ - \ cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ - \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ - :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ - parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ - \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ - defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ - :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"UniqueIngressHostnames\"\ - ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/ingress-hostnames-conflict/limited-preview/gatekeeperpolicy.rego\"\ - }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d011d9f7-ba32-4005-b727-b3d09371ca60\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d011d9f7-ba32-4005-b727-b3d09371ca60\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ run with a read only root file system\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ - \ run with a read only root file system in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc/.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"\ - policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/read-only-root-filesystem/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/read-only-root-filesystem/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/df49d893-a74c-421d-bc95-c663042e5b80\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"df49d893-a74c-421d-bc95-c663042e5b80\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pods and containers\ - \ should only use allowed SELinux options\",\"policyType\":\"BuiltIn\",\"\ - mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures\ - \ pods and containers only use allowed SELinux options in a Kubernetes cluster.\ - \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ - \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ - \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedSELinuxOptions\":{\"type\":\"Object\",\"metadata\":{\"displayName\"\ - :\"Allowed SELinux options\",\"description\":\"The allowed configurations\ - \ for pod and container level SELinux Options. Provide empty options list\ - \ as input to block everything.\",\"schema\":{\"type\":\"object\",\"properties\"\ - :{\"options\":{\"type\":\"array\",\"items\":{\"type\":\"object\",\"properties\"\ - :{\"level\":{\"type\":\"string\"},\"role\":{\"type\":\"string\"},\"type\"\ - :{\"type\":\"string\"},\"user\":{\"type\":\"string\"}},\"additionalProperties\"\ - :false}}},\"required\":[\"options\"],\"additionalProperties\":false}},\"defaultValue\"\ - :{\"options\":[]}}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ - AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"]},\"then\":{\"effect\"\ - :\"[parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/selinux/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/selinux/constraint.yaml\"\ - ,\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - ,\"allowedSELinuxOptions\":\"[parameters('allowedSELinuxOptions').options]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1e6c427-07d9-46ab-9689-bfa85431e636\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1e6c427-07d9-46ab-9689-bfa85431e636\"\ - },{\"properties\":{\"displayName\":\"Ensure container CPU and memory resource\ - \ limits do not exceed the specified limits in Kubernetes cluster\",\"policyType\"\ - :\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This\ - \ policy ensures container CPU and memory resource limits are defined and\ - \ do not exceed the specified limits in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"4.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"cpuLimit\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Max allowed CPU units\"\ - ,\"description\":\"The maximum CPU units allowed for a container. E.g. 200m.\ - \ For more information, please refer https://aka.ms/k8s-policy-pod-limits\"\ - }},\"memoryLimit\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Max\ - \ allowed memory bytes\",\"description\":\"The maximum memory bytes allowed\ - \ for a container. E.g. 1Gi. For more information, please refer https://aka.ms/k8s-policy-pod-limits\"\ - }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ - \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ - \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ - ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ - \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ - :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-resource-limits/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-resource-limits/constraint.yaml\"\ - ,\"values\":{\"cpuLimit\":\"[parameters('cpuLimit')]\",\"memoryLimit\":\"\ - [parameters('memoryLimit')]\",\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e345eecc-fa47-480f-9e88-67dcc122b164\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e345eecc-fa47-480f-9e88-67dcc122b164\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pods and containers\ - \ should only run with approved user and group IDs\",\"policyType\":\"BuiltIn\"\ - ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy controls\ - \ the user, primary group, supplemental group and file system group IDs that\ - \ pods and containers can use to run in a Kubernetes Cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - runAsUserRule\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Run as\ - \ user rule\",\"description\":\"The 'RunAsUser' rule that containers are allowed\ - \ to run with.\"},\"allowedValues\":[\"MustRunAs\",\"MustRunAsNonRoot\",\"\ - RunAsAny\"],\"defaultValue\":\"MustRunAsNonRoot\"},\"runAsUserRanges\":{\"\ - type\":\"Object\",\"metadata\":{\"displayName\":\"Allowed user ID ranges\"\ - ,\"description\":\"The user ID ranges that are allowed for containers to use.\"\ - ,\"schema\":{\"type\":\"object\",\"properties\":{\"ranges\":{\"type\":\"array\"\ - ,\"items\":{\"type\":\"object\",\"properties\":{\"min\":{\"type\":\"integer\"\ - },\"max\":{\"type\":\"integer\"}},\"required\":[\"min\",\"max\"],\"additionalProperties\"\ - :false}}},\"required\":[\"ranges\"],\"additionalProperties\":false}},\"defaultValue\"\ - :{\"ranges\":[]}},\"runAsGroupRule\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Run as group rule\",\"description\":\"The 'RunAsGroup' rule\ - \ that containers are allowed to run with.\"},\"allowedValues\":[\"MustRunAs\"\ - ,\"MayRunAs\",\"RunAsAny\"],\"defaultValue\":\"RunAsAny\"},\"runAsGroupRanges\"\ - :{\"type\":\"Object\",\"metadata\":{\"displayName\":\"Allowed group ID ranges\"\ - ,\"description\":\"The group ID ranges that are allowed for containers to\ - \ use.\",\"schema\":{\"type\":\"object\",\"properties\":{\"ranges\":{\"type\"\ - :\"array\",\"items\":{\"type\":\"object\",\"properties\":{\"min\":{\"type\"\ - :\"integer\"},\"max\":{\"type\":\"integer\"}},\"required\":[\"min\",\"max\"\ - ],\"additionalProperties\":false}}},\"required\":[\"ranges\"],\"additionalProperties\"\ - :false}},\"defaultValue\":{\"ranges\":[]}},\"supplementalGroupsRule\":{\"\ - type\":\"String\",\"metadata\":{\"displayName\":\"Supplemental group rule\"\ - ,\"description\":\"The 'SupplementalGroups' rule that containers are allowed\ - \ to run with.\"},\"allowedValues\":[\"MustRunAs\",\"MayRunAs\",\"RunAsAny\"\ - ],\"defaultValue\":\"RunAsAny\"},\"supplementalGroupsRanges\":{\"type\":\"\ - Object\",\"metadata\":{\"displayName\":\"Allowed supplemental group ID ranges\"\ - ,\"description\":\"The supplemental group ID ranges that are allowed for containers\ - \ to use.\",\"schema\":{\"type\":\"object\",\"properties\":{\"ranges\":{\"\ - type\":\"array\",\"items\":{\"type\":\"object\",\"properties\":{\"min\":{\"\ - type\":\"integer\"},\"max\":{\"type\":\"integer\"}},\"required\":[\"min\"\ - ,\"max\"],\"additionalProperties\":false}}},\"required\":[\"ranges\"],\"additionalProperties\"\ - :false}},\"defaultValue\":{\"ranges\":[]}},\"fsGroupRule\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"File system group rule\",\"description\"\ - :\"The 'FSGroup' rule that containers are allowed to run with.\"},\"allowedValues\"\ - :[\"MustRunAs\",\"MayRunAs\",\"RunAsAny\"],\"defaultValue\":\"RunAsAny\"},\"\ - fsGroupRanges\":{\"type\":\"Object\",\"metadata\":{\"displayName\":\"Allowed\ - \ file system group ID ranges\",\"description\":\"The file system group ranges\ - \ that are allowed for pods to use.\",\"schema\":{\"type\":\"object\",\"properties\"\ - :{\"ranges\":{\"type\":\"array\",\"items\":{\"type\":\"object\",\"properties\"\ - :{\"min\":{\"type\":\"integer\"},\"max\":{\"type\":\"integer\"}},\"required\"\ - :[\"min\",\"max\"],\"additionalProperties\":false}}},\"required\":[\"ranges\"\ - ],\"additionalProperties\":false}},\"defaultValue\":{\"ranges\":[]}}},\"policyRule\"\ - :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-users-groups/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-users-groups/constraint.yaml\"\ - ,\"values\":{\"runAsUser\":{\"rule\":\"[parameters('runAsUserRule')]\",\"\ - ranges\":\"[parameters('runAsUserRanges').ranges]\"},\"runAsGroup\":{\"rule\"\ - :\"[parameters('runAsGroupRule')]\",\"ranges\":\"[parameters('runAsGroupRanges').ranges]\"\ - },\"supplementalGroups\":{\"rule\":\"[parameters('supplementalGroupsRule')]\"\ - ,\"ranges\":\"[parameters('supplementalGroupsRanges').ranges]\"},\"fsGroup\"\ - :{\"rule\":\"[parameters('fsGroupRule')]\",\"ranges\":\"[parameters('fsGroupRanges').ranges]\"\ - },\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/f06ddb64-5fa3-4b77-b166-acb36f7f6042\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f06ddb64-5fa3-4b77-b166-acb36f7f6042\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster pod FlexVolume volumes\ - \ should only use allowed drivers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures pod FlexVolume\ - \ volumes only use allowed drivers in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"1.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - allowedFlexVolumeDrivers\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed FlexVolume drivers\",\"description\":\"The list of drivers that\ - \ FlexVolume volumes are allowed to use. Provide empty list as input to block\ - \ everything.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"\ - type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"\ - Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/flexvolume-drivers/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/flexvolume-drivers/constraint.yaml\"\ - ,\"values\":{\"allowedFlexVolumeDrivers\":\"[parameters('allowedFlexVolumeDrivers')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/f4a8fce0-2dd5-4c21-9a36-8f0ec809d663\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4a8fce0-2dd5-4c21-9a36-8f0ec809d663\"\ - },{\"properties\":{\"displayName\":\"[Preview]: Certificates should not expire\ - \ within the specified number of days\",\"policyType\":\"BuiltIn\",\"mode\"\ - :\"Microsoft.KeyVault.Data\",\"description\":\"Manage certificates that will\ - \ expire within a specified number of days to ensure your organization has\ - \ sufficient time to rotate the certificate prior to expiration.\",\"metadata\"\ - :{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"\ - parameters\":{\"daysToExpire\":{\"type\":\"Integer\",\"metadata\":{\"displayName\"\ - :\"[Preview]: Days to expire\",\"description\":\"The number of days for a\ - \ certificate to expire.\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ - \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ - \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ - :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ - },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/attributes.expiresOn\"\ - ,\"lessOrEquals\":\"[addDays(utcNow(), parameters('daysToExpire'))]\"}]},\"\ - then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f772fb64-8e40-40ad-87bc-7706e1949427\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f772fb64-8e40-40ad-87bc-7706e1949427\"\ - },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ - \ only use allowed ProcMountType\",\"policyType\":\"BuiltIn\",\"mode\":\"\ - Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ - \ only use allowed ProcMountType in a Kubernetes cluster. For instructions\ - \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ - :{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ - :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ - \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ - \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ - ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ - ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ - },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ - procMountType\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"ProcMountType\"\ - ,\"description\":\"The ProcMountType that containers are allowed to use in\ - \ the cluster.\"},\"allowedValues\":[\"Unmasked\",\"Default\"],\"defaultValue\"\ - :\"Default\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\"\ - ,\"Microsoft.Kubernetes/connectedClusters\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - ,\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-proc-mount-types/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-proc-mount-types/constraint.yaml\"\ - ,\"values\":{\"procMount\":\"[parameters('procMountType')]\",\"excludedNamespaces\"\ - :\"[parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f85eb0dd-92ee-40e9-8a76-db25a507d6d3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f85eb0dd-92ee-40e9-8a76-db25a507d6d3\"\ - },{\"properties\":{\"displayName\":\"Ensure only allowed container images\ - \ in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ - ,\"description\":\"This policy ensures only allowed container images are running\ - \ in a Kubernetes cluster. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ - ,\"metadata\":{\"version\":\"4.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ - :{\"allowedContainerImagesRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Allowed container images regex\",\"description\":\"The RegEx rule used\ - \ to match allowed container images in a Kubernetes cluster. For example,\ - \ to allow any Azure Container Registry image by matching partial path: ^.+azurecr.io/.+$\"\ - }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ - ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ - \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ - \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ - ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ - metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ - \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ - :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]}},\"policyRule\":{\"\ - if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ - ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ - [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-images/template.yaml\"\ - ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-images/constraint.yaml\"\ - ,\"values\":{\"allowedContainerImagesRegex\":\"[parameters('allowedContainerImagesRegex')]\"\ - ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ - :\"/providers/Microsoft.Authorization/policyDefinitions/febd0533-8e55-448f-b837-bd0e06f16469\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"febd0533-8e55-448f-b837-bd0e06f16469\"\ - },{\"properties\":{\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"description\"\ - :\"Don't create a VM anywhere\",\"metadata\":{\"createdBy\":\"123743cc-88ef-49ee-920e-13958fe5697d\"\ - ,\"createdOn\":\"2020-09-17T09:02:55.7481401Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"policyRule\":{\"if\":{\"allOf\":[{\"source\":\"action\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines/read\"},{\"field\":\"location\",\"in\"\ - :[\"eastus\",\"eastus2\",\"centralus\"]}]},\"then\":{\"effect\":\"deny\"}}},\"\ - id\":\"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"pypolicyea4a13f0\"\ - },{\"properties\":{\"displayName\":\"nrms-hdinsight-require-subnet_1.0\",\"\ - policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-04-01T22:24:01.1484325Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"not\":{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"11094169db59074f\"\ - },{\"properties\":{\"displayName\":\"nrms-hdinsight-require-subnet_1.2\",\"\ - policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T19:32:57.4990001Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"tags['NRMSVNetIntException']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['NRMSVNetIntException']]\",\"equals\":\"\"},{\"field\"\ - :\"tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"not\":{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b0f9cd579f5f04a\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ append policy for vmss_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-06-23T19:35:01.9059556Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname1\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"resourcegrouptagname2\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ - \ the resource group level\",\"description\":\"Rule is not deployed if this\ - \ tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription\ - \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ - \ Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\"\ - ,\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname1')]]\",\"equals\"\ - :\"\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname2')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ - ,\"notEquals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ - ,\"notEquals\":\"VirtualMachineRuntimeService\"},{\"not\":{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ - ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ - field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ - ,\"value\":{\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"properties\"\ - :{\"publisher\":\"Microsoft.Azure.Geneva\",\"type\":\"GenevaMonitoring\",\"\ - typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ - :{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b5a57eabcce7d7d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b5a57eabcce7d7d\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-102_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:23.2021003Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/21f42d11eb755867\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21f42d11eb755867\"\ - },{\"properties\":{\"displayName\":\"nrms-kubernet-require-azure-networkplugin_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-04-01T22:23:57.6004986Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerService/managedClusters\"},{\"field\":\"location\",\"\ - in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"equals\":\"azure\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26db8d27b6fa91aa\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on existing resources_1.1\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMs use password-only authentication for SSH on\ - \ existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-12-06T21:04:41.4787743Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}}},\"policyRule\":{\"if\":{\"allof\":[{\"field\"\ - :\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\",\"notEquals\"\ - :\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/28b685eba93cc71f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28b685eba93cc71f\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-101_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:14.0863618Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/34612a1acdd0093\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34612a1acdd0093\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-103_1.4\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:27:38.9264536Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3c07197392ad62f\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-105_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:18.4394851Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/40879463350508de\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40879463350508de\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on new vmss_1.4\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ - \ any Linux VMSSs use password-only authentication for SSH on new resources.\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-05-12T23:41:52.0436302Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ - \ the subscription level\",\"description\":\"Rule is not deployed if this\ - \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ - :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"128t_networking_platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"4psa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voipnow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"a10networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"a10-lightning-adc\",\"a10-vthunder-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"accellion\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kiteworks-by-accellion\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"abiquo\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"abiquo-hybrid-cloud-34\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"accops\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hysecure5050\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"actian_matrix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - actian_matrix\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actifio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"actifio-sky\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actian-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"vector-community\",\"vector-enterprise\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Acronis\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"storage\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"activeeon\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"activeeon-workload-scheduler\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aerospike\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"aerospike-database-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"affinio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"platform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aiscaler-cache-control-ddos-and-url-rewriting-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aimobile-site-acceleration\",\"aiprotect-ddos-firewall\",\"aiscaler-traffic-manager-caching\"\ - ,\"aivideo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"akamai-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"enterprise-application-access\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alces-flight-limited\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"alces-flight-compute-solo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alertlogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"alert-logic-tm\",\"alert-logic-wsm\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"alienvault\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"unified-security-management-anywhere\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"alldigital-brevity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alldigital-brevity-uploader\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altair-engineering-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"altair_hwulva\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altamira-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"lumify\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"antmedia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ams_community_edition\",\"ant_media_server_enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"apigee\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"apigee-edge\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcara\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"app360v43-001\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcelerator\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appcelerator-arrow-azure-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"appex-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appistry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"genomepilot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appscale-marketplace\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appscale\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arangodb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"arangodb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arista-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"veos-router\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"array_networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"array-networks-vapv\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"astadia-1148316\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"astadia-ui-automation-tee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"atomicorp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"secure-os\",\"secure-ubuntu-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"audiocodes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"mediantsessionbordercontroller\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"auriq-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"essentia\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"awingu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"awingu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"aviatrix-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aviatrix-cloud-services\",\"aviatrix-companion-gateway\",\"aviatrix-companion-gateway-v2\"\ - ,\"aviatrix-vpn-gw\",\"aviatrix_multi_cloud_service\",\"aviatrix_openvpn_service\"\ - ,\"aviatrix_openvpn_service10\",\"aviatrix_openvpn_service25\",\"aviatrix_openvpn_service50\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"avi-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - avi-vantage-adc\",\"internal-avi-vantage-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"axway\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"axway-mailgate-secure-collaboration-advanced\"\ - ,\"axway-mailgate-secure-collaboration-premium\",\"axway-mailgate-secure-collaboration-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azul\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"azul-zulu-ubuntu-1804\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azurecyclecloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - azure-cyclecloud-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"AzureDatabricks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"Databricks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"baas-techbureau\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"b1327623-d29b-4cc1-b833-85067dcc7bce\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"baffle-io\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"baffle-application-data-protection\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"balabit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"balabit-shell-control-box\"\ - ,\"psm\",\"sps\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"barracudanetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"barracuda-app-sec-control-center\",\"barracuda-email-security-gateway\"\ - ,\"barracuda-ng-cc\",\"barracuda-ng-firewall\",\"waf\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"basho\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"riak-2-0-1\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"autodesk-maya-arnold-centos73\"\ - ,\"rendering-centos73\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"bdy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - buddy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Bitnami\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - 3-4\",\"abantecart\",\"activemq\",\"akeneo\",\"alfrescocommunity\",\"apachesolr\"\ - ,\"artifactory\",\"canvaslms\",\"cassandra\",\"civicrm\",\"cmsmadesimple\"\ - ,\"codiad\",\"concrete5\",\"consul\",\"coppermine\",\"couchdb\",\"diaspora\"\ - ,\"discourse\",\"djangostack\",\"dokuwiki\",\"dolibarr\",\"DreamFactory\"\ - ,\"drupal\",\"elastic-search\",\"elk\",\"erpnext\",\"espocrm\",\"etcd\",\"\ - eXo-Platform\",\"exoplatform\",\"fatfreecrm\",\"ghost\",\"gitlab\",\"grafana\"\ - ,\"hadoop\",\"hhvmstack\",\"hordegroupwarewebmail\",\"jasperreports\",\"jenkins\"\ - ,\"joomla\",\"jrubystack\",\"kafka\",\"kong\",\"kubernetessandbox\",\"lampstack\"\ - ,\"lappstack\",\"letschat\",\"liferay\",\"limesurvey\",\"livehelperchat\"\ - ,\"magento\",\"mahara\",\"mantis\",\"mariadb\",\"mattermost\",\"mautic\",\"\ - mean\",\"mediawiki\",\"memcached\",\"modx\",\"mongodb\",\"moodle\",\"multicraft\"\ - ,\"mybb\",\"mysql\",\"nats\",\"neo4j\",\"neos\",\"nginxstack\",\"noalyss\"\ - ,\"nodejs\",\"ocportal\",\"odoo\",\"openatrium\",\"opencart\",\"openedx\"\ - ,\"openfire\",\"openproject\",\"orangehrm\",\"osclass\",\"owncloud\",\"oxid-eshop\"\ - ,\"parseserver\",\"phabricator\",\"phpbb\",\"phplist\",\"pimcore\",\"piwik\"\ - ,\"plone\",\"pootle\",\"postgresql\",\"prestashop\",\"processmakerenterprise\"\ - ,\"processmakeropensourceedition\",\"processwire\",\"publify\",\"rabbitmq\"\ - ,\"redash\",\"redis\",\"redmine\",\"redmineplusagile\",\"reportserver\",\"\ - reportserverenterprise\",\"resourcespace\",\"reviewboard\",\"reviewboardpowerpack\"\ - ,\"roundcube\",\"rubystack\",\"seopanel\",\"shopware\",\"silverstripe\",\"\ - simplemachinesforum\",\"sonarqube\",\"spree\",\"subversion\",\"suitecrm\"\ - ,\"tensorflowserving\",\"testlink\",\"tikiwikicmsgroupware\",\"tinytinyrss\"\ - ,\"tom-cat\",\"trac\",\"typo3\",\"weblate\",\"webmailpro\",\"wildfly\",\"\ - wordpress\",\"wordpress-multisite\",\"wordpresspro\",\"x2enginesalescrm\"\ - ,\"xoops\",\"youtrack\",\"zookeeper\",\"zurmo\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"black-duck-software\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blackduck_hub_vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"blk-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blk-io-erc-20-rest-service\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockapps\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"strato-blockchain-base-template-latest\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockstack-core-v14\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockchain-foundry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"syscoin-api\",\"syscoin-full-node\",\"syscoin-price-peg\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bloombase\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bloombase-storesafe-3_4_7_0_el7_x86_64\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bluecat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluecat-bam-for-azure\"\ - ,\"bluecat-dns-for-azure\",\"bluecat-edge-service-point-vm-for-azure\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bluetalon\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluetalon\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"brocade_communications\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"brocade-virtual-traffic-manager\"\ - ,\"brocade-virtual-traffic-manager-with-waf-module\",\"brocade-virtual-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bt-americas-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - diamondip-sapphire-ev10\",\"diamondip-sapphire-ev20\",\"diamondip-sapphire-v10\"\ - ,\"diamondip-sapphire-v20\",\"diamondip-sapphire-v5\",\"diamondip-sapphire-vcaa20\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"buddhalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sles_12_pci\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"carto\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cartobuilder2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cask\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cdap-cloud-sandbox\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"UbuntuServer\"\ - ,\"Ubuntu_Core\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cavirin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cavirin-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cautelalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"log_management\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"celum-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"celumdam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cds\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cds-data-migration-solution-for-legacy-to-cloud\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-6-v2-0-2-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-oracle-linux-6-v1-0-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-rhel-6-v2-0-2-l1\",\"cis-rhel-7-v2-2-0-l1\",\"cis-suse-linux-11-v2-0-0-l1\"\ - ,\"cis-suse-linux-12-v2-0-0-l1\",\"cis-ubuntu-linux-1404-v2-0-0-l1\",\"cis-ubuntu-linux-1604-v1-0-0-l1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"certivox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sso-test\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cfd-direct\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cfd-direct-from-the-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"chain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chain-core-developer-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"checkpoint\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"check-point-r77-10\"\ - ,\"check-point-vsec-r80\",\"check-point-vsec-r80-blink\",\"sg2\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"chef-software\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chef-automate-vm-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"circleci\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"circleci-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cires21\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"c21l-enc\"\ - ,\"c21l-mos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cisco\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cisco-asav\",\"cisco-csr-1000v\",\"cisco-ftdv\",\"cisco-meraki-vmx100\"\ - ,\"cisco-ngfwv-vm-test-unsupported\",\"cisco_cloud_vedge_17_2_4\",\"cos65\"\ - ,\"cos72\",\"cos72_main_dev\",\"uos14\",\"vwaas-azure\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"citrix\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"citrix-sd-wan-opt\",\"netscaler-ma-service-agent-120\"\ - ,\"netscaler-ma-service-agent-121\",\"netscaler-sd-wan\",\"netscaler-vpx\"\ - ,\"netscalervpx-120\",\"netscalervpx-121\",\"netscalervpx110-6531\",\"netscalervpx111\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"clear-linux-project\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"clear-linux-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"clouber\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cuber\",\"cws\",\"mcenter\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-cruiser\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-cruiser-16\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbees\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"jenkins-enterprise\",\"jenkins-operations-center\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudbees-enterprise-jenkins\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbees-jenkins-enterprise\"\ - ,\"cloudbees-jenkins-operations-center\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbolt-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudbolt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudboost\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloudboost\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudenablers-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"corestack\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"squid-proxy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudera-altus-centos-os\",\"cloudera-centos-6\",\"cloudera-centos-os\"\ - ,\"test-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudlanes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloud-video-accelerator-nfs\",\"cloudlanes-cloud-backup-accelerator-vtl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudlink\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudlink-securevm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudplan-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudplan_pcn_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"paladion_ondemand_nextgen_firewall\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudsoft\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudsoft-amp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"clustrix\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"clustrixdb\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"codelathe\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codelathe-filecloud-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"codenvy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codenvy-on-prem\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cognosys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"1-click-secured-joomla-on-centos-7-3\"\ - ,\"1-click-secured-joomla-on-ubuntu-1404-lts\",\"1-click-secured-joomla-on-ubuntu-1604-lts\"\ - ,\"1-click-secured-joomla-on-ubuntu-1804-lts\",\"centos-6-9\",\"centos-7-3\"\ - ,\"centos-7-4\",\"centos-7-5\",\"deploy-a-secured-modx-on-ubuntu-14-04-lts\"\ - ,\"deploy-a-secured-silverstripe-on-ubuntu-14-04-lts\",\"hardened-mysql-5-6-on-centos-7-3\"\ - ,\"hardened-mysql-5-6-on-ubu-1404-lts\",\"hardened-mysql-5-7-on-centos-7-3\"\ - ,\"hardened-mysql-5-7-on-ubu-1404-lts\",\"hardened-postgresql-on-ubu-1404-lts\"\ - ,\"invoice-ninja-2-5-1-1-on-ubuntu-1404\",\"jruby-on-ubuntu-14-04-lts\",\"\ - low-latency-broadcasting-server-for-live-events\",\"owncloud-9-with-lamp-stack-on-ubuntu-1404\"\ - ,\"piwigogallerys-ubuntu_14-04_lts\",\"sec1011-dokuwiki-on-ubuntu-1404\",\"\ - sec1013-elasticsearch-on-ubuntu-1404\",\"sec1014-opencart-on-ubuntu-1404\"\ - ,\"sec1015-orangehrm-on-ubuntu-1404\",\"sec1016-nodejs-server-on-ubuntu-1404\"\ - ,\"sec1018-haproxy-on-ubuntu-1404\",\"sec1019-secured-tomcat-on-ubuntu-1404\"\ - ,\"sec1020-phpbb-on-hardened-ubuntu-1404\",\"sec1021-mybb-on-hardened-ubuntu-1404\"\ - ,\"sec1022-sugarcrm-on-ubuntu-1404\",\"sec1023-moodle-on-ubuntu-1404\",\"\ - sec1024_magento-on-ubuntu-1404\",\"sec1025-secured-drupal-on-ubuntu-1404\"\ - ,\"sec1027-secured-wordpress-on-ubuntu-1404\",\"sec1028-secured-lamp-sever-on-ubuntu-1404\"\ - ,\"sec1029-secured-mediawiki-on-ubuntu-1404\",\"sec1030-secured-subversion-on-ubuntu-1404\"\ - ,\"sec1031-secured-passenger-nginx-on-ubuntu-1404\",\"sec1033-secured-piwik-on-ubuntu-1404\"\ - ,\"sec1034-secured-pligg-on-ubuntu-1404\",\"sec1035-secured-jenkins-on-ubuntu-1404\"\ - ,\"sec1036-secured-postgresql-on-ubuntu-1404\",\"secure-cloud-lamp-ubuntu-1404\"\ - ,\"secured-abantecart-on-centos\",\"secured-abantecart-on-ubuntu-14-04-lts\"\ - ,\"secured-acquia-drupal-on-centos\",\"secured-acquiadurpal-on-ubuntu-14-04-lts\"\ - ,\"secured-apachesolr-on-centos\",\"secured-apachesolr-on-ubuntu-14-04-lts\"\ - ,\"secured-arartifactory-on-centos\",\"secured-artifactory-on-ubuntu-14-04-lts\"\ - ,\"secured-cakephp-on-centos\",\"secured-cakephp-on-ubuntu-14-04-lts\",\"\ - secured-cms-made-simple-on-centos\",\"secured-cms-made-simple-on-ubuntu-14-04-lts\"\ - ,\"secured-codiad-on-centos\",\"secured-codiad-on-ubuntu-14-04-lts\",\"secured-cogdam-on-centos\"\ - ,\"secured-cogdam-on-ubuntu-14-04-lts\",\"secured-concrete5-on-centos\",\"\ - secured-concrete5-on-ubuntu-14-04-lts\",\"secured-coppermine-on-centos\",\"\ - secured-coppermine-on-ubuntu-14-04-lts\",\"secured-crushftp-on-centos\",\"\ - secured-crushftp-on-ubuntu-14-04-lts\",\"secured-django-on-centos\",\"secured-django-on-ubuntu-14-04-lts\"\ - ,\"secured-dokuwiki-on-centos\",\"secured-dolibarr-on-centos\",\"secured-dolivbarr-on-ubuntu-14-04-lts\"\ - ,\"secured-drupal-on-centos\",\"secured-elasticsearch-on-centos\",\"secured-enterprise-nginx-varnish-haproxy-php\"\ - ,\"secured-espocrm-on-centos\",\"secured-espocrm-on-ubuntu-14-04-lts\",\"\ - secured-exoplatform-on-centos\",\"secured-exoplatform-on-ubuntu-14-04-lts\"\ - ,\"secured-ghost-on-centos\",\"secured-ghost-on-ubuntu-14-04-lts\",\"secured-gradle-on-centos\"\ - ,\"secured-gradle-on-ubuntu-14-04-lts\",\"secured-haproxy-on-centos\",\"secured-invoice-ninja-on-centos\"\ - ,\"secured-jboss-as-on-centos\",\"secured-jbossas-on-ubuntu-14-04-lts\",\"\ - secured-jenkins-on-centos\",\"secured-jruby-on-cento\",\"secured-lamp-on-centos\"\ - ,\"secured-lamp-on-centos-m10\",\"secured-lapp-on-centos\",\"secured-lapp-on-ubuntu-14-04-lts\"\ - ,\"secured-lemp-sever-on-ubuntu-1404\",\"secured-lime-survey-on-centos\",\"\ - secured-limesurvey-on-ubuntu-1404\",\"secured-live-helper-chat-on-centos\"\ - ,\"secured-livehelperchat-on-ubuntu-14-04-lts\",\"secured-magento-on-centos\"\ - ,\"secured-mahara-on-centos\",\"secured-mahara-on-ubuntu-14-04-lts\",\"secured-mantis-on-centos\"\ - ,\"secured-mantis-on-ubuntu-14-04-lts\",\"secured-mariadb-on-ubuntu-16-04\"\ - ,\"secured-mautic-on-centos\",\"secured-mautic-on-ubuntu-14-04-lts\",\"secured-media-wiki-on-centos\"\ - ,\"secured-modx-on-centos\",\"secured-moodle-on-centos\",\"secured-ngnix-on-centos-7-3\"\ - ,\"secured-ngnix-on-ubuntu-14-04-lts\",\"secured-ngnix-on-ubuntu-16-04-lts\"\ - ,\"secured-noalyss-on-centos\",\"secured-noalyss-on-ubuntu-14-04-lts\",\"\ - secured-nodejs-on-centos\",\"secured-occlass-on-ubuntu-14-04-lts\",\"secured-ocportal-on-ubuntu-14-04-lts\"\ - ,\"secured-open-cart-on-centos\",\"secured-orangehrm-on-centos\",\"secured-osclass-on-centos\"\ - ,\"secured-owncloud-on-centos\",\"secured-oxid-eshop-on-centos\",\"secured-oxideshop-on-ubuntu-14-04-lts\"\ - ,\"secured-passenger-nginx-on-centos\",\"secured-piwigo-gallery-on-centos\"\ - ,\"secured-plone-on-centos\",\"secured-plone-on-ubuntu-14-04-lts\",\"secured-prestashop-on-centos\"\ - ,\"secured-prestashop-on-ubuntu-14-04-lts\",\"secured-railo-on-ubuntu-14-04-lts\"\ - ,\"secured-redis-on-centos\",\"secured-redis-on-ubuntu-1404\",\"secured-redmine-on-centos\"\ - ,\"secured-redmine-on-ubuntu-14-04-lts\",\"secured-redmineagile-on-ubuntu-14-04-lts\"\ - ,\"secured-report-server-on-centos\",\"secured-reportserverent-on-ubuntu-14-04-lts\"\ - ,\"secured-resource-space-on-centos\",\"secured-resourcespace-on-ubuntu-14-04-lts\"\ - ,\"secured-round-cube-on-centos\",\"secured-roundcube-on-ubuntu-14-04-lts\"\ - ,\"secured-ruby-on-centos\",\"secured-ruby-on-ubuntu-14-04-lts\",\"secured-seopanel-on-centos\"\ - ,\"secured-seopanel-on-ubuntu-14-04-lts\",\"secured-silverstripe-on-centos\"\ - ,\"secured-simple-invoice-on-centos\",\"secured-simple-machines-on-centos\"\ - ,\"secured-simple-machines-on-ubuntu-14-04-lts\",\"secured-simpleinvoice-on-ubuntu-14-04-lts\"\ - ,\"secured-subversion-on-centos\",\"secured-suitecrm-on-centos\",\"secured-suitecrm-on-ubuntu-14-04-lts\"\ - ,\"secured-test-link-on-centos\",\"secured-testlink-on-ubuntu-14-04-lts\"\ - ,\"secured-thinkup-on-centos\",\"secured-thinkup-on-ubuntu-14-04-lts\",\"\ - secured-tikiwikicms-on-centos\",\"secured-tikiwikicms-on-ubuntu-14-04-lts\"\ - ,\"secured-tiny-tiny-rss-on-centos\",\"secured-tinytinyrss-on-ubuntu-14-04-lts\"\ - ,\"secured-tomcat-on-centos\",\"secured-trac-on-centos\",\"secured-trac-on-ubuntu-14-04-lts\"\ - ,\"secured-typo3-on-centos\",\"secured-typo3-on-ubuntu-14-04-lts\",\"secured-varnish-on-centos\"\ - ,\"secured-varnish-on-ubuntu-1404\",\"secured-wildfly-on-centos\",\"secured-wildfly-on-ubuntu-14-04-lts\"\ - ,\"secured-wordpress-on-centos-7-3\",\"secured-wordpress-on-ubuntu-16-04-lts\"\ - ,\"secured-x-cart-on-ubuntu-14-04-lts\",\"secured-xoops-on-centos\",\"secured-xoops-on-ubuntu-14-04-lts\"\ - ,\"secured-zurmo-on-centos\",\"secured-zurmo-on-ubuntu-14-04-lts\",\"suse15\"\ - ,\"ubuntu-14-04-lts\",\"ubuntu-16-04-lts\",\"ubuntu-17-04-high-performance-hardened-tcp-bbr\"\ - ,\"ubuntu-18-04\",\"ubuntu-18-04-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cohesity-cloudtd-tool\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vns3_4x_network_security\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"confluentinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"confluentplatform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"consensys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"truffle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"convertigo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"convertigo-for-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"corda\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"corda\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"CoreOS\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"CoreOS\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"couchbase\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"couchbase-server-enterprise\",\"couchbase-sync-gateway-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cryptzone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appgate-appliance-3_2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cybernetica-as\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - uxp-securityserver-connector\",\"uxp-securityserver_vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cyxtera\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"appgatesdp-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"dataart\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"devicehive\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"databricks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"spfqogzeculbhdh\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datalayer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datalayer-notebook\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datastax\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datastax-enterprise\"\ - ,\"datastax-enterprise-non-production-use-only\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"datasunrise\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"datasunrise-database-security-suite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dataiku\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dataiku-data-science-studio\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datometry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyper-q\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dellemc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dell-emc-avamar-virtual-edition\"\ - ,\"dell-emc-datadomain-management-center\",\"dell-emc-datadomain-virtual-edition\"\ - ,\"dell-emc-datadomain-virtual-edition-v4\",\"dell-emc-networker-virtual-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"delphix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"delphix_dynamic_data_platform\"\ - ,\"omniosce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"denodo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"denodo-platform\",\"denodo-platform-7_0\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"denyall\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"denyall-rweb\",\"denyall-vulnerability-manager\",\"denyall-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dgsecure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dgsecure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"diladele\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"websafety\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dimensionalmechanics-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neopulse-ai-studio\",\"neopulse-query-runtime\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"docker\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"docker-ce\",\"docker-ce-edge\"\ - ,\"docker-datacenter-custom\",\"docker-ee\",\"docker-ee-basic\",\"docker4azure\"\ - ,\"docker4azure-cs\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dome9\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"dome9ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drizti\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hpcbox-ansys-19-cluster-master\",\"hpcbox-cluster-compute-node\",\"hpcbox-cluster-cuda-node\"\ - ,\"hpcbox-cluster-gpu-node\",\"hpcbox-docker-cluster-master\",\"hpcbox-openfoam-cluster-master\"\ - ,\"hpcbox-su2-cluster-master\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"drone\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dyadic_security\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"dyadic_sec\",\"ukc_image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dynatrace\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ruxit-managed-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"eastwind-networks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"eastwind-ixia-sensor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"egnyte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"egnyte-connect\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elasticbox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"elasticbox-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"electric-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"electricflowce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elfiqnetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"emercoin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"emercoin\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprise-ethereum-alliance\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"quorum-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprisedb-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"edb-postgres-ark\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"equalum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"equalum-vm-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"esdenera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"esdenera-firewall-3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ethereum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ethereum-studio\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"evostream-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ems-for-template\",\"ems-test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"exasol\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"exasol-analytics-database-byol\",\"exasolution-analytic-database\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"falconstorsoftware\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"fss-v9\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"f5-networks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"f5-big-ip-adc\",\"\ - f5-big-ip-advanced-waf\",\"f5-big-ip-best\",\"f5-big-ip-better\",\"f5-big-ip-byol\"\ - ,\"f5-big-ip-good\",\"f5-big-ip-per-app-ve\",\"f5-big-iq\",\"f5-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"filecatalyst\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - filecatalyst-direct-per-hr-billing\",\"filecatalyst-direct-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"firehost\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"firehost_armor\",\"\ - firehost_armor_ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flexify-io\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"single-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flashgrid-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"flashgrid-racnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"foghorn-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"foghorn-edge-device-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forcepoint-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"forcepoint-ngfw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forscene\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"forscene-edgeserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortycloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"fortycloud-gw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortinet\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fortinet-fortianalyzer\",\"fortinet-fortimanager\",\"fortinet_fortigate-vm_v5\"\ - ,\"fortinet_fortimail\",\"fortinet_fortivoice\",\"fortinet_fortiweb-vm_v5\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"fujitsu_fast\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - fep10-rh7-test\",\"feptest\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"gemalto-safenet\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"safenet-keysecure-k170v\",\"safenet-protectv\",\"safenet-protectv-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gigamon-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gigamon-fm-5_3_01\"\ - ,\"gigamon-fm-5_3_01_hourly\",\"gigamon-fm-5_4_00\",\"gigamon-fm-5_4_00_hourly\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gitlab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gitlab-ce\"\ - ,\"gitlab-ee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"GitHub\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"GitHub-Enterprise\",\"githubenterprise-test-publishing\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"great-software-laboratory-private-limited\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"xid\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"greensql\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"greensql-database-security\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gridgain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gridgain-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"guardicore\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"guardicorecentra\"\ - ,\"infection_monkey\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"haivision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"haivision-media-gateway-1-2\",\"haivision-media-gateway-1-5\",\"haivision-media-gateway-1-6-2\"\ - ,\"media-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"h2o-ai\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"h2o-driverles-ai\",\"h2o-driverless-ai\",\"h2o-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"haproxy-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hapee-rhel\",\"hapee-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"harpaitalia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mcuboenergy\"\ - ,\"yg\",\"yougreen_trial\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hcl-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hcl17cp1104\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"heimdall-data\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"heimdall-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"help-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"goanywheremftubuntulinux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hewlett-packard\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hpe-helion-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hillstone-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudedge-virtual-ngfw-advanced-edition\",\"cloudedge-virtual-ngfw-standard-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hortonworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbreak-for-hortonworks-data-platform\"\ - ,\"hortonworks-sandbox\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hitachi-solutions\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"credeon-sfs-and-kms-for-sharepoint-online\",\"credeonsecurefull-textsearch1_0\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hpe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storeoncevsa\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"huawei\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"euleros-v2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hyperglance\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperglance-dynamic-topology\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hypergrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hytrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hytrust-keycontrol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"ibm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ibm-security-guardium-multi-cloud\"\ - ,\"qradar_security_analytics\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iaansys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iaansys-magento\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iboss\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iboss-14600-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"imaginecommunications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudxtream-cdvr\",\"cloudxtream-dai-vms\",\"telurio-aim\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"imperva\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"imperva-dam-v13\"\ - ,\"securesphere-waf\",\"securesphere-waf-for-azr\",\"securesphere-waf-v12\"\ - ,\"securesphere-waf-v13\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"infoblox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"infoblox-vnios-te-v1420\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"informatica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"bdm10-1-1-u2\",\"big-data-management-10-2\",\"big-data-management-10-2-1\"\ - ,\"data_accelerator_for_azure_byol\",\"data_quality_10_1_1_rhel_7_3_byol\"\ - ,\"eic\",\"ics-byol\",\"ics-payg-ubuntu\",\"platform_10_1_1_multi_node_domain_rhel-7-3_byol\"\ - ,\"platform_10_2_hf1_domain_rhel-7-3_byol\",\"powercenter-v10-domain-image-ubuntu14-04-3\"\ - ,\"powercenter-v10-update1-domain-image-ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"informationbuilders\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"iway-big-data-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ingrammicro\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ingrammicroensimcentostrial\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"lustre-cloud-edition-gs-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel-bigdl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bigdl-0815\"\ - ,\"bigdl__vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intel-fpga\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"quartus_pro_opencl_sdk\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intellicus-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intellicus_bi_server_100_user_linux\",\"intellicus_bi_server_10_user_linux\"\ - ,\"intellicus_bi_server_25_user_linux\",\"intellicus_bi_server_50_user_linux\"\ - ,\"intellicus_bi_server_5_user_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intersystems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intersystems-iris-single-node\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intigua\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"intigua-agent-manager-3_7_0-trial\",\"intigua-agent-manager-trial\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"iquest\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"keyhub\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ishlangu-load-balancer-adc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ishlangu-load-balancer-byol\"\ - ,\"ishlangu-load-balancer-is10\",\"ishlangu-load-balancer-is100\",\"ishlangu-load-balancer-is1000\"\ - ,\"ishlangu-load-balancer-is200\",\"ishlangu-load-balancer-is5000\",\"ishlangu-load-balancer-isbfg\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"issp-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ispocr\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"itelios\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"magento2-on-zendserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jamcracker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"4632d5b4-feb0-4332-8452-f2e66133672f\",\"jamcracker-cloudanalytics\"\ - ,\"jamcracker-cloudanalytics-version4\",\"jamcracker-cloudanalytics-version5\"\ - ,\"jamcracker-csb-service-provider\",\"jamcracker-csb-serviceprovider\",\"\ - jamcracker-csb-standard\",\"jamcracker-csb-standard-v3\",\"jamcracker-csb-standard-version4\"\ - ,\"jamcracker-hybrid-cloud-management-version4\",\"jamcracker_cloud_control_appliance_version4\"\ - ,\"jsdnapp_csb_serviceprovider-version4\",\"jsdnapp_hybrid\",\"jsdnapp_hybrid_v3\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jedox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jedox-for-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jelastic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jelastic-hybrid-paas-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jetnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dvwa\"\ - ,\"jetnexus-application-load-balancer\",\"jetnexus-global-load-balancer\"\ - ,\"jetnexus-waf\",\"zap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jetware-srl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"caffe2\",\"caffe_python_cpu\",\"caffe_python_gpu\",\"cockroachdb\"\ - ,\"lamp_optimized\",\"lemp7_optimized\",\"memcached\",\"mongodb\",\"mxnet_python\"\ - ,\"mysql\",\"nodejs_nginx\",\"percona_mongodb\",\"percona_mysql\",\"postgresql\"\ - ,\"pytorch\",\"pytorch_cuda_notebook\",\"pytorch_cuda_production\",\"redis\"\ - ,\"redmine\",\"tensorflow_cpu_notebook\",\"tensorflow_cpu_production\",\"\ - tensorflow_cuda_notebook\",\"tensorflow_cuda_production\",\"tensorflow_python\"\ - ,\"theano_python\",\"wordpress4_lemp7\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jitterbit_integration\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"jitterbit-harmony-agent\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jm-technology-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"smart-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"juniper-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vmx-services-gateway-byol\",\"vmx-services-gateway-byol-soltemp\"\ - ,\"vmx-virtual-router\",\"vsrx-next-generation-firewall\",\"vsrx-next-generation-firewall-payg\"\ - ,\"vsrx-next-generation-firewall-solution-templ-payg\",\"vsrx-next-generation-firewall-solution-template\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"kaazing\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"kaazing-kwic\"\ - ,\"kaazing-vpa\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kali-linux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"kali-linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kemptech\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kemp360central-byol\",\"vlm-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kinetica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kineticadbbyol\",\"kineticadbpayasyougo\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"kaspersky_lab\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kaspersky_secure_mail_gateway\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"knime\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"knime-server-5-user_4-4-0\"\ - ,\"knime-server-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"krypc-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"krypccore\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leap-orbit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"leaporbitstoragebackedsftp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leostream-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"connection-broker\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquid-files\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"liquidfiles\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquidware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stratusphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"literatu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"literatu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"loadbalancer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"loadbalancer-org-load-balancer-for-azure\",\"loadbalancer-org-load-balancer-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logsign\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logsignfocus\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logtrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logtrust-log-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"looker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"looker-analytics-platform\"\ - ,\"looker-analytics-platform-326\",\"looker-analytics-platform-5_6\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"lti-lt-infotech\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"trade-finance-blockchain\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"luminate-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"luminate-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mapr-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"mapr52-base-dev\",\"mapr60-base\",\"mapr60-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mariadb\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mariadb-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"marklogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"marklogic-9-byol\"\ - ,\"marklogic-developer-9\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"massiveanalytic-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"oscarap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mathworks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"matlab-ref-arch-18a-v1-linux-disk\",\"mps-ref-arch-18a-v1-linux-disk2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"matillion\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"matillion-etl-snowflake\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mavinglobal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mavin-business-trial\"\ - ,\"mavin-enterprise-edition\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"meanio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"gitlab-enterprise-ready\",\"linnovate-open-source-sla-pro\",\"mean-machine-20\"\ - ,\"openideal3\",\"redash\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"media3-technologies-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cpan1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"memsql\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"memsql-community-single-vm\",\"memsql-enterprise-single-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mendix\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mendix-docker\",\"mendix-pro\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mfe_azure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"atd-mcafee\"\ - ,\"mcafee_vnsp_controller_for_azure\",\"mcafee_vnsp_for_azure\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-ads\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"linux-data-science-vm\"\ - ,\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"micro-focus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"replication_environment\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-avere\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vfxt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-batch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"centos-container\",\"centos-container-rdma\",\"ubuntu-server-container\"\ - ,\"ubuntu-server-container-rdma\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-compute\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureconfidentialcompute\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureml\",\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftAzureSiteRecovery\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ASR-Hydration-VMs\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftOSTC\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - FreeBSD\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"MLServer-CentOS\",\"MLServer-RedHat\",\"MLServer-Ubuntu\",\"RServer-CentOS\"\ - ,\"RServer-Ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midfin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mf_neon_cgw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midvision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ibm-datapower-virtual-edition-75\",\"ibm-datapower-virtual-edition-76\"\ - ,\"ibm-datapower-virtual-edition-77\",\"ibm-http-server\",\"ibm-websphere-portal-server-85\"\ - ,\"ibm-websphere-portal-server-90\",\"websphere-application-server-be\",\"\ - websphere-application-server-be-80\",\"websphere-application-server-be-85\"\ - ,\"websphere-application-server-be-90\",\"websphere-application-server-be-and-mq\"\ - ,\"websphere-application-server-lp\",\"websphere-application-server-lp-16\"\ - ,\"websphere-application-server-lp-17\",\"websphere-application-server-lp-18\"\ - ,\"websphere-application-server-nde\",\"websphere-application-server-nde-80\"\ - ,\"websphere-application-server-nde-85\",\"websphere-application-server-nde-90\"\ - ,\"websphere-mq\",\"websphere-mq-75\",\"websphere-mq-90\",\"websphere-mq-91\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"miraclelinux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - asianux-server-4-sp5\",\"asianux-server-4-sp6\",\"asianux-server-4-sp7\",\"\ - asianux-server-7-sp1\",\"asianux-server-7-sp2\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"miri-infotech-pvt-ltd\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wordpress\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mobilab\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"magento-wirecard-checkout\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moogsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moogsoft-aiops\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moviemasher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moviemasher\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"SQL2017-RHEL7\",\"SQL2017-RHEL73\",\"SQL2017-SLES12SP2\",\"SQL2017-Ubuntu1604\"\ - ,\"SQL2019-RHEL7\",\"SQL2019-Ubuntu1604\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mtnfog\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"idyl-e3-entity-extraction-engine\",\"prose-sentence-extraction-engine\"\ - ,\"renku-language-detection-engine\",\"sonnet-tokenization-engine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mxhero\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mail2cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"my-com\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tarantool\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"narrativescience\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"narratives-for-power-bi\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nasuni\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"nasuni-nmc\"\ - ,\"nasuni_edge_appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ncbi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - ncbi-blast-2-3-0\",\"ncbi-free-2-2-31\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nebbiolo-technologies-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fog-system-manager\",\"fogsm_basic\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"neo4j\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"neo4j-enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netapp\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netapp-altavault-cloud-integrated-storage-solution\"\ - ,\"netapp-oncommand-cloud-manager\",\"netapp-ontap-cloud\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netgate\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netgate-pfsense-azure-fw-vpn-router\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netiq\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"replication_environment\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netscout\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netscout_virtual_ngeniusone_with_vscout\"\ - ,\"netscout_vstream\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netmail\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"netmail-search\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netsweeper\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"netsweeper6-0-6\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netx\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - simplehelp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"neusoft-neteye\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neusoft-nisg-va-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nginxinc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nginx-plus-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nicepeopleatwork\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"youzana\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nodejsapi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"node-js-api\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"noobaa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"noobaa-hybrid-s3-archive-05\",\"noobaa-multi-cloud-deduplication\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"northbridge-secure\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netconnect1\",\"netconnectx\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nubeva-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"controller\"\ - ,\"test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuco-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aionnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuxeo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nuxeo-6-lts\",\"nuxeo-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nvidia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ngc_azure_17_11\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"o2mc-real-time-data-platform\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"o2mc-platform-app\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"oceanblue-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"obc-sdwan-solutions\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"omega-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ods_datastage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onyx-point-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"op-bnf-v1\",\"op-bnf1_6-v1\",\"op-bpnifi-v1\",\"op-bpnifi16-v1\"\ - ,\"op-scc-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onapsis\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"osp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"op5\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - op5-monitor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"opencell\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"meveo\",\"meveo403sp2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"openvpn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openvpnas\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Oracle-Database-Ee\"\ - ,\"Oracle-Database-Se\",\"Oracle-Linux\",\"Oracle-WebLogic-Server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"orientdb\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"orientdb-community-edition\"\ - ,\"orientdb-community-edition-2_2\",\"orientdb-enterprise-edition-2_2\",\"\ - orientdb-enterprise-edition-2_2_17\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osirium-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"osirium-pxm-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quantastorvsav4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"paloaltonetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"panorama\",\"vmseries1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"panzura-file-system\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azura-freedom-filer-v7110\",\"panzura-cloud-filer\",\"panzura-freedom-filer-7140-13222\"\ - ,\"panzura-freedom-filer-716-13549\",\"panzura-freedom-filer-v7020\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"parasoft\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"parasoft-service-virtualization\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"passlogy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"passlogic\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"penta-security-systems-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"wapples\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"percona\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"percona-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"postgres-pro\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"postgres-pro-enterprise\",\"postgres-pro-enterprise-10\",\"postgres-pro-standard\"\ - ,\"postgres-pro-standard-10\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"plesk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"plesk-onyx-linux\",\"solution-server-business\",\"solution-server-wordpress\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"prestashop\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"prestashop16-lamp\"\ - ,\"ubuntu-base-for-prestashop\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"prime-strategy\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"kusanagi-77\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"pivotal-gpdb-vm\",\"pivotal-greenplum-images\",\"pivotal-ops-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"process-one\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ejabberd-community-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"profecia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"full_disk_encryption_vm\"\ - ,\"project_tools_vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"progelspa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"libra-esva-antispam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ptsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ptaf-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pulse-secure\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pulse-connect-secure-vm\",\"pulse-virtual-traffic-manager\",\"\ - pulse-virtual-traffic-manager-with-waf\",\"pulse-virtual-traffic-manager-with-waf2\"\ - ,\"pulse-virtual-traffic-manager2\",\"pulse-virtual-web-application-firewall\"\ - ,\"pulse-virtual-web-application-firewall2\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"PuppetLabs\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"PuppetEnterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"puppet\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"puppet-enterprise\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"pydio\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"pydio-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"qore-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"qorus\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qualysguard\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qualys-virtual-firewall-appliance\",\"qualys-virtual-scanner-v23b\"\ - ,\"qualys-virtual-scanner-v24\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quasardb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quasardb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qubole-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qubole-data-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fve\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"racknap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"racknap-server\",\"racknap-server-linux\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"radware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radware-alteon-va\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"radiant-logic\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radiantone-vms\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rancher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rancheros\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rapid7\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nexpose-scan-engine\",\"rapid7-vm-console\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"rapidminer\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"rapidminer_server_75\",\"rapidminer_server_76\"\ - ,\"rapidminer_server_80\",\"rapidminer_server_81\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"realm\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"realm-mobile-platform\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"reblaze\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"rbzr-image\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"RHEL\",\"rhel-byos\"\ - ,\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"relevance-lab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - rlcatalyst\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"remotelearner\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fully-supported-moodle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"revolution-analytics\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"revolution-r-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RightScaleLinux\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"RightImage-CentOS\",\"RightImage-Ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RiverbedTechnology\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"steelapp_traffic_manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"riverbed\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"riverbed-sccm-5-5-1\"\ - ,\"riverbed-steelcentral-appinternals\",\"riverbed-steelhead-9-2\",\"riverbed-steelhead-9-5-0\"\ - ,\"riverbed-steelhead-9-6-0\",\"riverbed_steelconnect_gw\",\"riverbed_steelconnect_sh\"\ - ,\"steelapp_traffic_manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rocketsoftware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rocket-discover\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsa-security-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rsa-nw-azure-arch\",\"rsa-nw-azure-broker\",\"rsa-nw-azure-con\"\ - ,\"rsa-nw-azure-esa\",\"rsa-nw-azure-ldec\",\"rsa-nw-azure-vlc\",\"rsa-nw-suite-11\"\ - ,\"rsa-nw-suite-11-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsk-labs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rsk-bamboo-beta-node\",\"rsk-node-orchid\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"saama\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"fluidanalyticsengine\",\"insurancefraudanalytics\"\ - ,\"realworldevidence\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"saltstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos65saltstackenterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalearc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalearc-for-mysql-paygo\",\"scalearc-for-sql-server-pay-go\",\"scalearc_mysql-server\"\ - ,\"scalearc_sql_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalegrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - hanaexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scality\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalityconnecthourly\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"secureworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"scwx-azure-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"shadow-soft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"icinga\",\"icinga2-5\",\"icinga2-7\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"signal-sciences\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"signalscienceswpp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"sightapps\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sightapps\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"silver-peak-systems\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"silver_peak_edgeconnect\"\ - ,\"silver_peak_vx\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"simmachinesinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"simmachines_vm_v2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sinefa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sinefa-probe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"skyarc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mt6\",\"mta\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"smartmessage-autoflow\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"martmessage-autoflow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"snapt-adc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"snaptadc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"soasta\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudtest-lite\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"softnas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloud_dev\",\"mp_ce\",\"mp_ent\",\"mp_nas_byol\",\"mp_nas_ep\",\"mp_nas_gp\"\ - ,\"mp_nas_hp\",\"mp_plat\",\"private_offerings\",\"softnas-cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"solanolabs\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"solano-ci-private-beta\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"soha\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"soha-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"solar-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - solar-incode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sonicwall-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"sonicwall-nsz-azure\",\"waf\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sophos\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sophos-xg\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spagobi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"spagobi\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spacecurve\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"spacecurve-quickstart\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"splunk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"splunk-enterprise-base-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"src-solution\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pilot-things-onem2m-smart-network\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sqlstream\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"com\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sphere3d\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"snapcloud-byol\",\"snapcloud-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stackato-platform-as-a-service\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"activestate-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stackstorm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stackstorm-2015-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"startekfingerprintmatch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bioserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ - ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ - ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ - ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ - ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ - ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ - ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ - ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ - teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ - ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ - ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ - ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ - ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ - ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ - vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ - ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ - ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ - ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ - ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ - ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ - ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ - ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ - ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ - ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ - ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ - triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ - ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/408b8964022134ba\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"408b8964022134ba\"\ - },{\"properties\":{\"displayName\":\"sqlads-auditifnotexists-vulnerability\ - \ assessment should be enabled on your sql servers_1.0\",\"policyType\":\"\ - Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-06-10T02:12:37.034264Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"tagname\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ - \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ - \ the SQL Server\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Sql/servers\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('tagname'), ']')]\",\"exists\"\ - :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().tags[parameters('tagname')]]\"\ - ,\"equals\":\"\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Sql/servers/vulnerabilityAssessments\",\"name\":\"\ - default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/vulnerabilityAssessments/recurringScans.isEnabled\"\ - ,\"equals\":\"True\"}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/410c2966a1e1856e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"410c2966a1e1856e\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-103_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:16.1955196Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/42c70bae0daee0b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"42c70bae0daee0b3\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-108_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:59.0487626Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"532396f35af78946\"\ - },{\"properties\":{\"displayName\":\"audit soft delete enabled on key vault_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"description\":\"Audit Soft\ - \ Delete must be enabled on all key vaults\",\"metadata\":{\"version\":\"\ - 1.0.0\",\"category\":\"Key Vault\",\"preview\":false,\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-09-01T00:04:03.801713Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"audit\",\"Disabled\"],\"defaultValue\":\"audit\"},\"\ - allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed\ - \ locations\",\"description\":\"The list of locations that can be specified\ - \ when deploying resources.\",\"strongType\":\"location\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.KeyVault/vaults/enableSoftDelete\",\"exists\"\ - :\"false\"},{\"field\":\"Microsoft.KeyVault/vaults/softDeleteRetentionInDays\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5353f06bfd8b6546\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5353f06bfd8b6546\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on new vms_1.4\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ - \ any Linux VMs use password-only authentication for SSH on new resources.\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-05-12T23:41:56.0529781Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ - \ the subscription level\",\"description\":\"Rule is not deployed if this\ - \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ - field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ - :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"128t_networking_platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"4psa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voipnow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"a10networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"a10-lightning-adc\",\"a10-vthunder-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"accellion\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kiteworks-by-accellion\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"abiquo\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"abiquo-hybrid-cloud-34\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"accops\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hysecure5050\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"actian_matrix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - actian_matrix\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actifio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"actifio-sky\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actian-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"vector-community\",\"vector-enterprise\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Acronis\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"storage\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"activeeon\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"activeeon-workload-scheduler\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aerospike\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"aerospike-database-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"affinio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"platform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aiscaler-cache-control-ddos-and-url-rewriting-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aimobile-site-acceleration\",\"aiprotect-ddos-firewall\",\"aiscaler-traffic-manager-caching\"\ - ,\"aivideo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"akamai-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"enterprise-application-access\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alces-flight-limited\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"alces-flight-compute-solo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alertlogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"alert-logic-tm\",\"alert-logic-wsm\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"alienvault\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"unified-security-management-anywhere\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"alldigital-brevity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alldigital-brevity-uploader\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altair-engineering-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"altair_hwulva\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altamira-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"lumify\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"antmedia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ams_community_edition\",\"ant_media_server_enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"apigee\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"apigee-edge\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcara\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"app360v43-001\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcelerator\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appcelerator-arrow-azure-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"appex-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appistry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"genomepilot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appscale-marketplace\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appscale\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arangodb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"arangodb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arista-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"veos-router\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"array_networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"array-networks-vapv\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"astadia-1148316\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"astadia-ui-automation-tee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"atomicorp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"secure-os\",\"secure-ubuntu-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"audiocodes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"mediantsessionbordercontroller\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"auriq-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"essentia\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"awingu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"awingu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"aviatrix-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aviatrix-cloud-services\",\"aviatrix-companion-gateway\",\"aviatrix-companion-gateway-v2\"\ - ,\"aviatrix-vpn-gw\",\"aviatrix_multi_cloud_service\",\"aviatrix_openvpn_service\"\ - ,\"aviatrix_openvpn_service10\",\"aviatrix_openvpn_service25\",\"aviatrix_openvpn_service50\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"avi-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - avi-vantage-adc\",\"internal-avi-vantage-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"axway\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"axway-mailgate-secure-collaboration-advanced\"\ - ,\"axway-mailgate-secure-collaboration-premium\",\"axway-mailgate-secure-collaboration-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azul\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"azul-zulu-ubuntu-1804\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azurecyclecloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - azure-cyclecloud-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"AzureDatabricks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"Databricks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"baas-techbureau\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"b1327623-d29b-4cc1-b833-85067dcc7bce\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"baffle-io\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"baffle-application-data-protection\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"balabit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"balabit-shell-control-box\"\ - ,\"psm\",\"sps\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"barracudanetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"barracuda-app-sec-control-center\",\"barracuda-email-security-gateway\"\ - ,\"barracuda-ng-cc\",\"barracuda-ng-firewall\",\"waf\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"basho\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"riak-2-0-1\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"autodesk-maya-arnold-centos73\"\ - ,\"rendering-centos73\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"bdy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - buddy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Bitnami\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - 3-4\",\"abantecart\",\"activemq\",\"akeneo\",\"alfrescocommunity\",\"apachesolr\"\ - ,\"artifactory\",\"canvaslms\",\"cassandra\",\"civicrm\",\"cmsmadesimple\"\ - ,\"codiad\",\"concrete5\",\"consul\",\"coppermine\",\"couchdb\",\"diaspora\"\ - ,\"discourse\",\"djangostack\",\"dokuwiki\",\"dolibarr\",\"DreamFactory\"\ - ,\"drupal\",\"elastic-search\",\"elk\",\"erpnext\",\"espocrm\",\"etcd\",\"\ - eXo-Platform\",\"exoplatform\",\"fatfreecrm\",\"ghost\",\"gitlab\",\"grafana\"\ - ,\"hadoop\",\"hhvmstack\",\"hordegroupwarewebmail\",\"jasperreports\",\"jenkins\"\ - ,\"joomla\",\"jrubystack\",\"kafka\",\"kong\",\"kubernetessandbox\",\"lampstack\"\ - ,\"lappstack\",\"letschat\",\"liferay\",\"limesurvey\",\"livehelperchat\"\ - ,\"magento\",\"mahara\",\"mantis\",\"mariadb\",\"mattermost\",\"mautic\",\"\ - mean\",\"mediawiki\",\"memcached\",\"modx\",\"mongodb\",\"moodle\",\"multicraft\"\ - ,\"mybb\",\"mysql\",\"nats\",\"neo4j\",\"neos\",\"nginxstack\",\"noalyss\"\ - ,\"nodejs\",\"ocportal\",\"odoo\",\"openatrium\",\"opencart\",\"openedx\"\ - ,\"openfire\",\"openproject\",\"orangehrm\",\"osclass\",\"owncloud\",\"oxid-eshop\"\ - ,\"parseserver\",\"phabricator\",\"phpbb\",\"phplist\",\"pimcore\",\"piwik\"\ - ,\"plone\",\"pootle\",\"postgresql\",\"prestashop\",\"processmakerenterprise\"\ - ,\"processmakeropensourceedition\",\"processwire\",\"publify\",\"rabbitmq\"\ - ,\"redash\",\"redis\",\"redmine\",\"redmineplusagile\",\"reportserver\",\"\ - reportserverenterprise\",\"resourcespace\",\"reviewboard\",\"reviewboardpowerpack\"\ - ,\"roundcube\",\"rubystack\",\"seopanel\",\"shopware\",\"silverstripe\",\"\ - simplemachinesforum\",\"sonarqube\",\"spree\",\"subversion\",\"suitecrm\"\ - ,\"tensorflowserving\",\"testlink\",\"tikiwikicmsgroupware\",\"tinytinyrss\"\ - ,\"tom-cat\",\"trac\",\"typo3\",\"weblate\",\"webmailpro\",\"wildfly\",\"\ - wordpress\",\"wordpress-multisite\",\"wordpresspro\",\"x2enginesalescrm\"\ - ,\"xoops\",\"youtrack\",\"zookeeper\",\"zurmo\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"black-duck-software\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blackduck_hub_vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"blk-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blk-io-erc-20-rest-service\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockapps\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"strato-blockchain-base-template-latest\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockstack-core-v14\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockchain-foundry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"syscoin-api\",\"syscoin-full-node\",\"syscoin-price-peg\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bloombase\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bloombase-storesafe-3_4_7_0_el7_x86_64\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bluecat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluecat-bam-for-azure\"\ - ,\"bluecat-dns-for-azure\",\"bluecat-edge-service-point-vm-for-azure\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bluetalon\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluetalon\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"brocade_communications\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"brocade-virtual-traffic-manager\"\ - ,\"brocade-virtual-traffic-manager-with-waf-module\",\"brocade-virtual-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bt-americas-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - diamondip-sapphire-ev10\",\"diamondip-sapphire-ev20\",\"diamondip-sapphire-v10\"\ - ,\"diamondip-sapphire-v20\",\"diamondip-sapphire-v5\",\"diamondip-sapphire-vcaa20\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"buddhalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sles_12_pci\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"carto\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cartobuilder2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cask\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cdap-cloud-sandbox\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"UbuntuServer\"\ - ,\"Ubuntu_Core\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cavirin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cavirin-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cautelalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"log_management\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"celum-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"celumdam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cds\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cds-data-migration-solution-for-legacy-to-cloud\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-6-v2-0-2-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-oracle-linux-6-v1-0-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-rhel-6-v2-0-2-l1\",\"cis-rhel-7-v2-2-0-l1\",\"cis-suse-linux-11-v2-0-0-l1\"\ - ,\"cis-suse-linux-12-v2-0-0-l1\",\"cis-ubuntu-linux-1404-v2-0-0-l1\",\"cis-ubuntu-linux-1604-v1-0-0-l1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"certivox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sso-test\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cfd-direct\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cfd-direct-from-the-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"chain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chain-core-developer-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"checkpoint\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"check-point-r77-10\"\ - ,\"check-point-vsec-r80\",\"check-point-vsec-r80-blink\",\"sg2\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"chef-software\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chef-automate-vm-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"circleci\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"circleci-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cires21\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"c21l-enc\"\ - ,\"c21l-mos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cisco\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cisco-asav\",\"cisco-csr-1000v\",\"cisco-ftdv\",\"cisco-meraki-vmx100\"\ - ,\"cisco-ngfwv-vm-test-unsupported\",\"cisco_cloud_vedge_17_2_4\",\"cos65\"\ - ,\"cos72\",\"cos72_main_dev\",\"uos14\",\"vwaas-azure\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"citrix\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"citrix-sd-wan-opt\",\"netscaler-ma-service-agent-120\"\ - ,\"netscaler-ma-service-agent-121\",\"netscaler-sd-wan\",\"netscaler-vpx\"\ - ,\"netscalervpx-120\",\"netscalervpx-121\",\"netscalervpx110-6531\",\"netscalervpx111\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"clear-linux-project\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"clear-linux-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"clouber\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cuber\",\"cws\",\"mcenter\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-cruiser\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-cruiser-16\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbees\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"jenkins-enterprise\",\"jenkins-operations-center\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudbees-enterprise-jenkins\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbees-jenkins-enterprise\"\ - ,\"cloudbees-jenkins-operations-center\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbolt-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudbolt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudboost\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloudboost\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudenablers-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"corestack\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"squid-proxy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudera-altus-centos-os\",\"cloudera-centos-6\",\"cloudera-centos-os\"\ - ,\"test-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudlanes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloud-video-accelerator-nfs\",\"cloudlanes-cloud-backup-accelerator-vtl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudlink\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudlink-securevm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudplan-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudplan_pcn_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"paladion_ondemand_nextgen_firewall\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudsoft\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudsoft-amp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"clustrix\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"clustrixdb\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"codelathe\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codelathe-filecloud-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"codenvy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codenvy-on-prem\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cognosys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"1-click-secured-joomla-on-centos-7-3\"\ - ,\"1-click-secured-joomla-on-ubuntu-1404-lts\",\"1-click-secured-joomla-on-ubuntu-1604-lts\"\ - ,\"1-click-secured-joomla-on-ubuntu-1804-lts\",\"centos-6-9\",\"centos-7-3\"\ - ,\"centos-7-4\",\"centos-7-5\",\"deploy-a-secured-modx-on-ubuntu-14-04-lts\"\ - ,\"deploy-a-secured-silverstripe-on-ubuntu-14-04-lts\",\"hardened-mysql-5-6-on-centos-7-3\"\ - ,\"hardened-mysql-5-6-on-ubu-1404-lts\",\"hardened-mysql-5-7-on-centos-7-3\"\ - ,\"hardened-mysql-5-7-on-ubu-1404-lts\",\"hardened-postgresql-on-ubu-1404-lts\"\ - ,\"invoice-ninja-2-5-1-1-on-ubuntu-1404\",\"jruby-on-ubuntu-14-04-lts\",\"\ - low-latency-broadcasting-server-for-live-events\",\"owncloud-9-with-lamp-stack-on-ubuntu-1404\"\ - ,\"piwigogallerys-ubuntu_14-04_lts\",\"sec1011-dokuwiki-on-ubuntu-1404\",\"\ - sec1013-elasticsearch-on-ubuntu-1404\",\"sec1014-opencart-on-ubuntu-1404\"\ - ,\"sec1015-orangehrm-on-ubuntu-1404\",\"sec1016-nodejs-server-on-ubuntu-1404\"\ - ,\"sec1018-haproxy-on-ubuntu-1404\",\"sec1019-secured-tomcat-on-ubuntu-1404\"\ - ,\"sec1020-phpbb-on-hardened-ubuntu-1404\",\"sec1021-mybb-on-hardened-ubuntu-1404\"\ - ,\"sec1022-sugarcrm-on-ubuntu-1404\",\"sec1023-moodle-on-ubuntu-1404\",\"\ - sec1024_magento-on-ubuntu-1404\",\"sec1025-secured-drupal-on-ubuntu-1404\"\ - ,\"sec1027-secured-wordpress-on-ubuntu-1404\",\"sec1028-secured-lamp-sever-on-ubuntu-1404\"\ - ,\"sec1029-secured-mediawiki-on-ubuntu-1404\",\"sec1030-secured-subversion-on-ubuntu-1404\"\ - ,\"sec1031-secured-passenger-nginx-on-ubuntu-1404\",\"sec1033-secured-piwik-on-ubuntu-1404\"\ - ,\"sec1034-secured-pligg-on-ubuntu-1404\",\"sec1035-secured-jenkins-on-ubuntu-1404\"\ - ,\"sec1036-secured-postgresql-on-ubuntu-1404\",\"secure-cloud-lamp-ubuntu-1404\"\ - ,\"secured-abantecart-on-centos\",\"secured-abantecart-on-ubuntu-14-04-lts\"\ - ,\"secured-acquia-drupal-on-centos\",\"secured-acquiadurpal-on-ubuntu-14-04-lts\"\ - ,\"secured-apachesolr-on-centos\",\"secured-apachesolr-on-ubuntu-14-04-lts\"\ - ,\"secured-arartifactory-on-centos\",\"secured-artifactory-on-ubuntu-14-04-lts\"\ - ,\"secured-cakephp-on-centos\",\"secured-cakephp-on-ubuntu-14-04-lts\",\"\ - secured-cms-made-simple-on-centos\",\"secured-cms-made-simple-on-ubuntu-14-04-lts\"\ - ,\"secured-codiad-on-centos\",\"secured-codiad-on-ubuntu-14-04-lts\",\"secured-cogdam-on-centos\"\ - ,\"secured-cogdam-on-ubuntu-14-04-lts\",\"secured-concrete5-on-centos\",\"\ - secured-concrete5-on-ubuntu-14-04-lts\",\"secured-coppermine-on-centos\",\"\ - secured-coppermine-on-ubuntu-14-04-lts\",\"secured-crushftp-on-centos\",\"\ - secured-crushftp-on-ubuntu-14-04-lts\",\"secured-django-on-centos\",\"secured-django-on-ubuntu-14-04-lts\"\ - ,\"secured-dokuwiki-on-centos\",\"secured-dolibarr-on-centos\",\"secured-dolivbarr-on-ubuntu-14-04-lts\"\ - ,\"secured-drupal-on-centos\",\"secured-elasticsearch-on-centos\",\"secured-enterprise-nginx-varnish-haproxy-php\"\ - ,\"secured-espocrm-on-centos\",\"secured-espocrm-on-ubuntu-14-04-lts\",\"\ - secured-exoplatform-on-centos\",\"secured-exoplatform-on-ubuntu-14-04-lts\"\ - ,\"secured-ghost-on-centos\",\"secured-ghost-on-ubuntu-14-04-lts\",\"secured-gradle-on-centos\"\ - ,\"secured-gradle-on-ubuntu-14-04-lts\",\"secured-haproxy-on-centos\",\"secured-invoice-ninja-on-centos\"\ - ,\"secured-jboss-as-on-centos\",\"secured-jbossas-on-ubuntu-14-04-lts\",\"\ - secured-jenkins-on-centos\",\"secured-jruby-on-cento\",\"secured-lamp-on-centos\"\ - ,\"secured-lamp-on-centos-m10\",\"secured-lapp-on-centos\",\"secured-lapp-on-ubuntu-14-04-lts\"\ - ,\"secured-lemp-sever-on-ubuntu-1404\",\"secured-lime-survey-on-centos\",\"\ - secured-limesurvey-on-ubuntu-1404\",\"secured-live-helper-chat-on-centos\"\ - ,\"secured-livehelperchat-on-ubuntu-14-04-lts\",\"secured-magento-on-centos\"\ - ,\"secured-mahara-on-centos\",\"secured-mahara-on-ubuntu-14-04-lts\",\"secured-mantis-on-centos\"\ - ,\"secured-mantis-on-ubuntu-14-04-lts\",\"secured-mariadb-on-ubuntu-16-04\"\ - ,\"secured-mautic-on-centos\",\"secured-mautic-on-ubuntu-14-04-lts\",\"secured-media-wiki-on-centos\"\ - ,\"secured-modx-on-centos\",\"secured-moodle-on-centos\",\"secured-ngnix-on-centos-7-3\"\ - ,\"secured-ngnix-on-ubuntu-14-04-lts\",\"secured-ngnix-on-ubuntu-16-04-lts\"\ - ,\"secured-noalyss-on-centos\",\"secured-noalyss-on-ubuntu-14-04-lts\",\"\ - secured-nodejs-on-centos\",\"secured-occlass-on-ubuntu-14-04-lts\",\"secured-ocportal-on-ubuntu-14-04-lts\"\ - ,\"secured-open-cart-on-centos\",\"secured-orangehrm-on-centos\",\"secured-osclass-on-centos\"\ - ,\"secured-owncloud-on-centos\",\"secured-oxid-eshop-on-centos\",\"secured-oxideshop-on-ubuntu-14-04-lts\"\ - ,\"secured-passenger-nginx-on-centos\",\"secured-piwigo-gallery-on-centos\"\ - ,\"secured-plone-on-centos\",\"secured-plone-on-ubuntu-14-04-lts\",\"secured-prestashop-on-centos\"\ - ,\"secured-prestashop-on-ubuntu-14-04-lts\",\"secured-railo-on-ubuntu-14-04-lts\"\ - ,\"secured-redis-on-centos\",\"secured-redis-on-ubuntu-1404\",\"secured-redmine-on-centos\"\ - ,\"secured-redmine-on-ubuntu-14-04-lts\",\"secured-redmineagile-on-ubuntu-14-04-lts\"\ - ,\"secured-report-server-on-centos\",\"secured-reportserverent-on-ubuntu-14-04-lts\"\ - ,\"secured-resource-space-on-centos\",\"secured-resourcespace-on-ubuntu-14-04-lts\"\ - ,\"secured-round-cube-on-centos\",\"secured-roundcube-on-ubuntu-14-04-lts\"\ - ,\"secured-ruby-on-centos\",\"secured-ruby-on-ubuntu-14-04-lts\",\"secured-seopanel-on-centos\"\ - ,\"secured-seopanel-on-ubuntu-14-04-lts\",\"secured-silverstripe-on-centos\"\ - ,\"secured-simple-invoice-on-centos\",\"secured-simple-machines-on-centos\"\ - ,\"secured-simple-machines-on-ubuntu-14-04-lts\",\"secured-simpleinvoice-on-ubuntu-14-04-lts\"\ - ,\"secured-subversion-on-centos\",\"secured-suitecrm-on-centos\",\"secured-suitecrm-on-ubuntu-14-04-lts\"\ - ,\"secured-test-link-on-centos\",\"secured-testlink-on-ubuntu-14-04-lts\"\ - ,\"secured-thinkup-on-centos\",\"secured-thinkup-on-ubuntu-14-04-lts\",\"\ - secured-tikiwikicms-on-centos\",\"secured-tikiwikicms-on-ubuntu-14-04-lts\"\ - ,\"secured-tiny-tiny-rss-on-centos\",\"secured-tinytinyrss-on-ubuntu-14-04-lts\"\ - ,\"secured-tomcat-on-centos\",\"secured-trac-on-centos\",\"secured-trac-on-ubuntu-14-04-lts\"\ - ,\"secured-typo3-on-centos\",\"secured-typo3-on-ubuntu-14-04-lts\",\"secured-varnish-on-centos\"\ - ,\"secured-varnish-on-ubuntu-1404\",\"secured-wildfly-on-centos\",\"secured-wildfly-on-ubuntu-14-04-lts\"\ - ,\"secured-wordpress-on-centos-7-3\",\"secured-wordpress-on-ubuntu-16-04-lts\"\ - ,\"secured-x-cart-on-ubuntu-14-04-lts\",\"secured-xoops-on-centos\",\"secured-xoops-on-ubuntu-14-04-lts\"\ - ,\"secured-zurmo-on-centos\",\"secured-zurmo-on-ubuntu-14-04-lts\",\"suse15\"\ - ,\"ubuntu-14-04-lts\",\"ubuntu-16-04-lts\",\"ubuntu-17-04-high-performance-hardened-tcp-bbr\"\ - ,\"ubuntu-18-04\",\"ubuntu-18-04-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cohesity-cloudtd-tool\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vns3_4x_network_security\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"confluentinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"confluentplatform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"consensys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"truffle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"convertigo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"convertigo-for-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"corda\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"corda\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"CoreOS\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"CoreOS\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"couchbase\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"couchbase-server-enterprise\",\"couchbase-sync-gateway-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cryptzone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appgate-appliance-3_2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cybernetica-as\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - uxp-securityserver-connector\",\"uxp-securityserver_vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cyxtera\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"appgatesdp-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"dataart\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"devicehive\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"databricks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"spfqogzeculbhdh\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datalayer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datalayer-notebook\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datastax\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datastax-enterprise\"\ - ,\"datastax-enterprise-non-production-use-only\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"datasunrise\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"datasunrise-database-security-suite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dataiku\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dataiku-data-science-studio\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datometry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyper-q\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dellemc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dell-emc-avamar-virtual-edition\"\ - ,\"dell-emc-datadomain-management-center\",\"dell-emc-datadomain-virtual-edition\"\ - ,\"dell-emc-datadomain-virtual-edition-v4\",\"dell-emc-networker-virtual-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"delphix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"delphix_dynamic_data_platform\"\ - ,\"omniosce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"denodo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"denodo-platform\",\"denodo-platform-7_0\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"denyall\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"denyall-rweb\",\"denyall-vulnerability-manager\",\"denyall-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dgsecure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dgsecure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"diladele\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"websafety\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dimensionalmechanics-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neopulse-ai-studio\",\"neopulse-query-runtime\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"docker\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"docker-ce\",\"docker-ce-edge\"\ - ,\"docker-datacenter-custom\",\"docker-ee\",\"docker-ee-basic\",\"docker4azure\"\ - ,\"docker4azure-cs\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dome9\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"dome9ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drizti\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hpcbox-ansys-19-cluster-master\",\"hpcbox-cluster-compute-node\",\"hpcbox-cluster-cuda-node\"\ - ,\"hpcbox-cluster-gpu-node\",\"hpcbox-docker-cluster-master\",\"hpcbox-openfoam-cluster-master\"\ - ,\"hpcbox-su2-cluster-master\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"drone\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dyadic_security\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"dyadic_sec\",\"ukc_image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dynatrace\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ruxit-managed-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"eastwind-networks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"eastwind-ixia-sensor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"egnyte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"egnyte-connect\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elasticbox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"elasticbox-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"electric-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"electricflowce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elfiqnetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"emercoin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"emercoin\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprise-ethereum-alliance\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"quorum-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprisedb-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"edb-postgres-ark\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"equalum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"equalum-vm-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"esdenera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"esdenera-firewall-3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ethereum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ethereum-studio\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"evostream-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ems-for-template\",\"ems-test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"exasol\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"exasol-analytics-database-byol\",\"exasolution-analytic-database\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"falconstorsoftware\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"fss-v9\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"f5-networks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"f5-big-ip-adc\",\"\ - f5-big-ip-advanced-waf\",\"f5-big-ip-best\",\"f5-big-ip-better\",\"f5-big-ip-byol\"\ - ,\"f5-big-ip-good\",\"f5-big-ip-per-app-ve\",\"f5-big-iq\",\"f5-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"filecatalyst\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - filecatalyst-direct-per-hr-billing\",\"filecatalyst-direct-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"firehost\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"firehost_armor\",\"\ - firehost_armor_ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flexify-io\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"single-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flashgrid-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"flashgrid-racnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"foghorn-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"foghorn-edge-device-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forcepoint-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"forcepoint-ngfw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forscene\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"forscene-edgeserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortycloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"fortycloud-gw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortinet\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fortinet-fortianalyzer\",\"fortinet-fortimanager\",\"fortinet_fortigate-vm_v5\"\ - ,\"fortinet_fortimail\",\"fortinet_fortivoice\",\"fortinet_fortiweb-vm_v5\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"fujitsu_fast\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - fep10-rh7-test\",\"feptest\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"gemalto-safenet\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"safenet-keysecure-k170v\",\"safenet-protectv\",\"safenet-protectv-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gigamon-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gigamon-fm-5_3_01\"\ - ,\"gigamon-fm-5_3_01_hourly\",\"gigamon-fm-5_4_00\",\"gigamon-fm-5_4_00_hourly\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gitlab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gitlab-ce\"\ - ,\"gitlab-ee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"GitHub\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"GitHub-Enterprise\",\"githubenterprise-test-publishing\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"great-software-laboratory-private-limited\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"xid\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"greensql\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"greensql-database-security\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gridgain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gridgain-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"guardicore\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"guardicorecentra\"\ - ,\"infection_monkey\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"haivision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"haivision-media-gateway-1-2\",\"haivision-media-gateway-1-5\",\"haivision-media-gateway-1-6-2\"\ - ,\"media-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"h2o-ai\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"h2o-driverles-ai\",\"h2o-driverless-ai\",\"h2o-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"haproxy-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hapee-rhel\",\"hapee-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"harpaitalia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mcuboenergy\"\ - ,\"yg\",\"yougreen_trial\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hcl-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hcl17cp1104\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"heimdall-data\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"heimdall-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"help-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"goanywheremftubuntulinux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hewlett-packard\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hpe-helion-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hillstone-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudedge-virtual-ngfw-advanced-edition\",\"cloudedge-virtual-ngfw-standard-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hortonworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbreak-for-hortonworks-data-platform\"\ - ,\"hortonworks-sandbox\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hitachi-solutions\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"credeon-sfs-and-kms-for-sharepoint-online\",\"credeonsecurefull-textsearch1_0\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hpe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storeoncevsa\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"huawei\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"euleros-v2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hyperglance\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperglance-dynamic-topology\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hypergrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hytrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hytrust-keycontrol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"ibm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ibm-security-guardium-multi-cloud\"\ - ,\"qradar_security_analytics\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iaansys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iaansys-magento\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iboss\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iboss-14600-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"imaginecommunications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudxtream-cdvr\",\"cloudxtream-dai-vms\",\"telurio-aim\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"imperva\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"imperva-dam-v13\"\ - ,\"securesphere-waf\",\"securesphere-waf-for-azr\",\"securesphere-waf-v12\"\ - ,\"securesphere-waf-v13\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"infoblox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"infoblox-vnios-te-v1420\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"informatica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"bdm10-1-1-u2\",\"big-data-management-10-2\",\"big-data-management-10-2-1\"\ - ,\"data_accelerator_for_azure_byol\",\"data_quality_10_1_1_rhel_7_3_byol\"\ - ,\"eic\",\"ics-byol\",\"ics-payg-ubuntu\",\"platform_10_1_1_multi_node_domain_rhel-7-3_byol\"\ - ,\"platform_10_2_hf1_domain_rhel-7-3_byol\",\"powercenter-v10-domain-image-ubuntu14-04-3\"\ - ,\"powercenter-v10-update1-domain-image-ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"informationbuilders\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"iway-big-data-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ingrammicro\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ingrammicroensimcentostrial\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"lustre-cloud-edition-gs-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel-bigdl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bigdl-0815\"\ - ,\"bigdl__vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intel-fpga\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"quartus_pro_opencl_sdk\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intellicus-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intellicus_bi_server_100_user_linux\",\"intellicus_bi_server_10_user_linux\"\ - ,\"intellicus_bi_server_25_user_linux\",\"intellicus_bi_server_50_user_linux\"\ - ,\"intellicus_bi_server_5_user_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intersystems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intersystems-iris-single-node\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intigua\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"intigua-agent-manager-3_7_0-trial\",\"intigua-agent-manager-trial\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"iquest\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"keyhub\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ishlangu-load-balancer-adc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ishlangu-load-balancer-byol\"\ - ,\"ishlangu-load-balancer-is10\",\"ishlangu-load-balancer-is100\",\"ishlangu-load-balancer-is1000\"\ - ,\"ishlangu-load-balancer-is200\",\"ishlangu-load-balancer-is5000\",\"ishlangu-load-balancer-isbfg\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"issp-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ispocr\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"itelios\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"magento2-on-zendserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jamcracker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"4632d5b4-feb0-4332-8452-f2e66133672f\",\"jamcracker-cloudanalytics\"\ - ,\"jamcracker-cloudanalytics-version4\",\"jamcracker-cloudanalytics-version5\"\ - ,\"jamcracker-csb-service-provider\",\"jamcracker-csb-serviceprovider\",\"\ - jamcracker-csb-standard\",\"jamcracker-csb-standard-v3\",\"jamcracker-csb-standard-version4\"\ - ,\"jamcracker-hybrid-cloud-management-version4\",\"jamcracker_cloud_control_appliance_version4\"\ - ,\"jsdnapp_csb_serviceprovider-version4\",\"jsdnapp_hybrid\",\"jsdnapp_hybrid_v3\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jedox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jedox-for-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jelastic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jelastic-hybrid-paas-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jetnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dvwa\"\ - ,\"jetnexus-application-load-balancer\",\"jetnexus-global-load-balancer\"\ - ,\"jetnexus-waf\",\"zap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jetware-srl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"caffe2\",\"caffe_python_cpu\",\"caffe_python_gpu\",\"cockroachdb\"\ - ,\"lamp_optimized\",\"lemp7_optimized\",\"memcached\",\"mongodb\",\"mxnet_python\"\ - ,\"mysql\",\"nodejs_nginx\",\"percona_mongodb\",\"percona_mysql\",\"postgresql\"\ - ,\"pytorch\",\"pytorch_cuda_notebook\",\"pytorch_cuda_production\",\"redis\"\ - ,\"redmine\",\"tensorflow_cpu_notebook\",\"tensorflow_cpu_production\",\"\ - tensorflow_cuda_notebook\",\"tensorflow_cuda_production\",\"tensorflow_python\"\ - ,\"theano_python\",\"wordpress4_lemp7\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jitterbit_integration\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"jitterbit-harmony-agent\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jm-technology-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"smart-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"juniper-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vmx-services-gateway-byol\",\"vmx-services-gateway-byol-soltemp\"\ - ,\"vmx-virtual-router\",\"vsrx-next-generation-firewall\",\"vsrx-next-generation-firewall-payg\"\ - ,\"vsrx-next-generation-firewall-solution-templ-payg\",\"vsrx-next-generation-firewall-solution-template\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"kaazing\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"kaazing-kwic\"\ - ,\"kaazing-vpa\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kali-linux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"kali-linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kemptech\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kemp360central-byol\",\"vlm-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kinetica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kineticadbbyol\",\"kineticadbpayasyougo\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"kaspersky_lab\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kaspersky_secure_mail_gateway\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"knime\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"knime-server-5-user_4-4-0\"\ - ,\"knime-server-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"krypc-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"krypccore\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leap-orbit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"leaporbitstoragebackedsftp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leostream-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"connection-broker\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquid-files\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"liquidfiles\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquidware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stratusphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"literatu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"literatu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"loadbalancer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"loadbalancer-org-load-balancer-for-azure\",\"loadbalancer-org-load-balancer-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logsign\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logsignfocus\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logtrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logtrust-log-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"looker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"looker-analytics-platform\"\ - ,\"looker-analytics-platform-326\",\"looker-analytics-platform-5_6\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"lti-lt-infotech\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"trade-finance-blockchain\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"luminate-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"luminate-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mapr-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"mapr52-base-dev\",\"mapr60-base\",\"mapr60-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mariadb\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mariadb-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"marklogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"marklogic-9-byol\"\ - ,\"marklogic-developer-9\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"massiveanalytic-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"oscarap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mathworks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"matlab-ref-arch-18a-v1-linux-disk\",\"mps-ref-arch-18a-v1-linux-disk2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"matillion\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"matillion-etl-snowflake\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mavinglobal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mavin-business-trial\"\ - ,\"mavin-enterprise-edition\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"meanio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"gitlab-enterprise-ready\",\"linnovate-open-source-sla-pro\",\"mean-machine-20\"\ - ,\"openideal3\",\"redash\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"media3-technologies-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cpan1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"memsql\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"memsql-community-single-vm\",\"memsql-enterprise-single-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mendix\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mendix-docker\",\"mendix-pro\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mfe_azure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"atd-mcafee\"\ - ,\"mcafee_vnsp_controller_for_azure\",\"mcafee_vnsp_for_azure\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-ads\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"linux-data-science-vm\"\ - ,\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"micro-focus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"replication_environment\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-avere\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vfxt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-batch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"centos-container\",\"centos-container-rdma\",\"ubuntu-server-container\"\ - ,\"ubuntu-server-container-rdma\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-compute\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureconfidentialcompute\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureml\",\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftAzureSiteRecovery\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ASR-Hydration-VMs\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftOSTC\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - FreeBSD\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"MLServer-CentOS\",\"MLServer-RedHat\",\"MLServer-Ubuntu\",\"RServer-CentOS\"\ - ,\"RServer-Ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midfin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mf_neon_cgw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midvision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ibm-datapower-virtual-edition-75\",\"ibm-datapower-virtual-edition-76\"\ - ,\"ibm-datapower-virtual-edition-77\",\"ibm-http-server\",\"ibm-websphere-portal-server-85\"\ - ,\"ibm-websphere-portal-server-90\",\"websphere-application-server-be\",\"\ - websphere-application-server-be-80\",\"websphere-application-server-be-85\"\ - ,\"websphere-application-server-be-90\",\"websphere-application-server-be-and-mq\"\ - ,\"websphere-application-server-lp\",\"websphere-application-server-lp-16\"\ - ,\"websphere-application-server-lp-17\",\"websphere-application-server-lp-18\"\ - ,\"websphere-application-server-nde\",\"websphere-application-server-nde-80\"\ - ,\"websphere-application-server-nde-85\",\"websphere-application-server-nde-90\"\ - ,\"websphere-mq\",\"websphere-mq-75\",\"websphere-mq-90\",\"websphere-mq-91\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"miraclelinux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - asianux-server-4-sp5\",\"asianux-server-4-sp6\",\"asianux-server-4-sp7\",\"\ - asianux-server-7-sp1\",\"asianux-server-7-sp2\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"miri-infotech-pvt-ltd\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wordpress\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mobilab\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"magento-wirecard-checkout\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moogsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moogsoft-aiops\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moviemasher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moviemasher\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"SQL2017-RHEL7\",\"SQL2017-RHEL73\",\"SQL2017-SLES12SP2\",\"SQL2017-Ubuntu1604\"\ - ,\"SQL2019-RHEL7\",\"SQL2019-Ubuntu1604\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mtnfog\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"idyl-e3-entity-extraction-engine\",\"prose-sentence-extraction-engine\"\ - ,\"renku-language-detection-engine\",\"sonnet-tokenization-engine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mxhero\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mail2cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"my-com\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tarantool\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"narrativescience\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"narratives-for-power-bi\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nasuni\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"nasuni-nmc\"\ - ,\"nasuni_edge_appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ncbi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - ncbi-blast-2-3-0\",\"ncbi-free-2-2-31\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nebbiolo-technologies-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fog-system-manager\",\"fogsm_basic\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"neo4j\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"neo4j-enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netapp\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netapp-altavault-cloud-integrated-storage-solution\"\ - ,\"netapp-oncommand-cloud-manager\",\"netapp-ontap-cloud\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netgate\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netgate-pfsense-azure-fw-vpn-router\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netiq\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"replication_environment\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netscout\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netscout_virtual_ngeniusone_with_vscout\"\ - ,\"netscout_vstream\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netmail\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"netmail-search\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netsweeper\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"netsweeper6-0-6\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netx\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - simplehelp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"neusoft-neteye\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neusoft-nisg-va-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nginxinc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nginx-plus-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nicepeopleatwork\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"youzana\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nodejsapi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"node-js-api\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"noobaa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"noobaa-hybrid-s3-archive-05\",\"noobaa-multi-cloud-deduplication\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"northbridge-secure\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netconnect1\",\"netconnectx\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nubeva-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"controller\"\ - ,\"test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuco-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aionnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuxeo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nuxeo-6-lts\",\"nuxeo-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nvidia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ngc_azure_17_11\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"o2mc-real-time-data-platform\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"o2mc-platform-app\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"oceanblue-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"obc-sdwan-solutions\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"omega-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ods_datastage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onyx-point-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"op-bnf-v1\",\"op-bnf1_6-v1\",\"op-bpnifi-v1\",\"op-bpnifi16-v1\"\ - ,\"op-scc-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onapsis\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"osp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"op5\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - op5-monitor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"opencell\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"meveo\",\"meveo403sp2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"openvpn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openvpnas\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Oracle-Database-Ee\"\ - ,\"Oracle-Database-Se\",\"Oracle-Linux\",\"Oracle-WebLogic-Server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"orientdb\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"orientdb-community-edition\"\ - ,\"orientdb-community-edition-2_2\",\"orientdb-enterprise-edition-2_2\",\"\ - orientdb-enterprise-edition-2_2_17\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osirium-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"osirium-pxm-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quantastorvsav4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"paloaltonetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"panorama\",\"vmseries1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"panzura-file-system\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azura-freedom-filer-v7110\",\"panzura-cloud-filer\",\"panzura-freedom-filer-7140-13222\"\ - ,\"panzura-freedom-filer-716-13549\",\"panzura-freedom-filer-v7020\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"parasoft\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"parasoft-service-virtualization\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"passlogy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"passlogic\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"penta-security-systems-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"wapples\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"percona\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"percona-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"postgres-pro\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"postgres-pro-enterprise\",\"postgres-pro-enterprise-10\",\"postgres-pro-standard\"\ - ,\"postgres-pro-standard-10\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"plesk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"plesk-onyx-linux\",\"solution-server-business\",\"solution-server-wordpress\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"prestashop\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"prestashop16-lamp\"\ - ,\"ubuntu-base-for-prestashop\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"prime-strategy\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"kusanagi-77\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"pivotal-gpdb-vm\",\"pivotal-greenplum-images\",\"pivotal-ops-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"process-one\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ejabberd-community-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"profecia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"full_disk_encryption_vm\"\ - ,\"project_tools_vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"progelspa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"libra-esva-antispam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ptsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ptaf-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pulse-secure\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pulse-connect-secure-vm\",\"pulse-virtual-traffic-manager\",\"\ - pulse-virtual-traffic-manager-with-waf\",\"pulse-virtual-traffic-manager-with-waf2\"\ - ,\"pulse-virtual-traffic-manager2\",\"pulse-virtual-web-application-firewall\"\ - ,\"pulse-virtual-web-application-firewall2\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"PuppetLabs\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"PuppetEnterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"puppet\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"puppet-enterprise\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"pydio\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"pydio-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"qore-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"qorus\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qualysguard\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qualys-virtual-firewall-appliance\",\"qualys-virtual-scanner-v23b\"\ - ,\"qualys-virtual-scanner-v24\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quasardb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quasardb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qubole-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qubole-data-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fve\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"racknap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"racknap-server\",\"racknap-server-linux\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"radware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radware-alteon-va\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"radiant-logic\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radiantone-vms\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rancher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rancheros\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rapid7\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nexpose-scan-engine\",\"rapid7-vm-console\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"rapidminer\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"rapidminer_server_75\",\"rapidminer_server_76\"\ - ,\"rapidminer_server_80\",\"rapidminer_server_81\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"realm\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"realm-mobile-platform\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"reblaze\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"rbzr-image\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"RHEL\",\"rhel-byos\"\ - ,\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"relevance-lab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - rlcatalyst\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"remotelearner\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fully-supported-moodle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"revolution-analytics\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"revolution-r-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RightScaleLinux\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"RightImage-CentOS\",\"RightImage-Ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RiverbedTechnology\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"steelapp_traffic_manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"riverbed\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"riverbed-sccm-5-5-1\"\ - ,\"riverbed-steelcentral-appinternals\",\"riverbed-steelhead-9-2\",\"riverbed-steelhead-9-5-0\"\ - ,\"riverbed-steelhead-9-6-0\",\"riverbed_steelconnect_gw\",\"riverbed_steelconnect_sh\"\ - ,\"steelapp_traffic_manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rocketsoftware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rocket-discover\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsa-security-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rsa-nw-azure-arch\",\"rsa-nw-azure-broker\",\"rsa-nw-azure-con\"\ - ,\"rsa-nw-azure-esa\",\"rsa-nw-azure-ldec\",\"rsa-nw-azure-vlc\",\"rsa-nw-suite-11\"\ - ,\"rsa-nw-suite-11-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsk-labs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rsk-bamboo-beta-node\",\"rsk-node-orchid\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"saama\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"fluidanalyticsengine\",\"insurancefraudanalytics\"\ - ,\"realworldevidence\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"saltstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos65saltstackenterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalearc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalearc-for-mysql-paygo\",\"scalearc-for-sql-server-pay-go\",\"scalearc_mysql-server\"\ - ,\"scalearc_sql_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalegrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - hanaexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scality\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalityconnecthourly\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"secureworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"scwx-azure-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"shadow-soft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"icinga\",\"icinga2-5\",\"icinga2-7\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"signal-sciences\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"signalscienceswpp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"sightapps\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sightapps\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"silver-peak-systems\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"silver_peak_edgeconnect\"\ - ,\"silver_peak_vx\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"simmachinesinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"simmachines_vm_v2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sinefa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sinefa-probe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"skyarc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mt6\",\"mta\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"smartmessage-autoflow\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"martmessage-autoflow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"snapt-adc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"snaptadc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"soasta\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudtest-lite\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"softnas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloud_dev\",\"mp_ce\",\"mp_ent\",\"mp_nas_byol\",\"mp_nas_ep\",\"mp_nas_gp\"\ - ,\"mp_nas_hp\",\"mp_plat\",\"private_offerings\",\"softnas-cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"solanolabs\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"solano-ci-private-beta\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"soha\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"soha-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"solar-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - solar-incode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sonicwall-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"sonicwall-nsz-azure\",\"waf\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sophos\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sophos-xg\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spagobi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"spagobi\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spacecurve\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"spacecurve-quickstart\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"splunk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"splunk-enterprise-base-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"src-solution\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pilot-things-onem2m-smart-network\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sqlstream\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"com\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sphere3d\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"snapcloud-byol\",\"snapcloud-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stackato-platform-as-a-service\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"activestate-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stackstorm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stackstorm-2015-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"startekfingerprintmatch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bioserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ - ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ - ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ - ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ - ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ - ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ - ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ - ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ - teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ - ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ - ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ - ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ - ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ - ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ - vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ - ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ - ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ - ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ - ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ - ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ - ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ - ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ - ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ - ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ - ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ - triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ - ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/566405fe94cbf731\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"566405fe94cbf731\"\ - },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_2.1\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2020-02-24T19:32:58.4608022Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts/pools\"},{\"field\":\"\ - location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"tags['NRMSVNetIntException']\"\ - ,\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['NRMSVNetIntException']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ - },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ - :[{\"field\":\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\"\ - ,\"exists\":\"false\"},{\"field\":\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\"\ - ,\"in\":[\"null\",\"\"]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5aac1290d24c772d\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-101_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:18.6642999Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5d9c8a259a63a29b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5d9c8a259a63a29b\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ append policy for vmss_1.0\",\"policyType\":\"Custom\",\"mode\":\"All\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-07-12T00:29:53.2880644Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ - ,\"notEquals\":\"GenevaMonitoring\"}]},\"then\":{\"effect\":\"append\",\"\ - details\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ - ,\"value\":{\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"properties\"\ - :{\"publisher\":\"Microsoft.Azure.Geneva\",\"type\":\"GenevaMonitoring\",\"\ - typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ - :{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5e6e7d4c3e34256b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e6e7d4c3e34256b\"\ - },{\"properties\":{\"displayName\":\"nrms-warning-non-c+ai-security-rules_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:29.4182093Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"priorities\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Rule Priority\",\"description\"\ - :\"List of Rule Priority Numbers reserved for Security\"}},\"allowedLocations\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ - description\":\"The list of locations that can be specified when deploying\ - \ resources.\",\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"In\":\"[parameters('priorities')]\"},{\"field\":\"location\",\"In\":\"\ - [parameters('allowedLocations')]\"},{\"allOf\":[{\"not\":{\"field\":\"name\"\ - ,\"contains\":\"Cleanuptool\"}},{\"not\":{\"field\":\"name\",\"contains\"\ - :\"NRMS-Rule-\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/6221d088cd1bcdc3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6221d088cd1bcdc3\"\ - },{\"properties\":{\"displayName\":\"nrms-warning-non-c+ai-security-rules_1.3\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2020-02-24T19:33:58.9010954Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"priorities\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Rule Priority\",\"description\"\ - :\"List of Rule Priority Numbers reserved for Security\"}},\"allowedLocations\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ - description\":\"The list of locations that can be specified when deploying\ - \ resources.\",\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"In\":\"[parameters('priorities')]\"},{\"field\":\"location\",\"In\":\"\ - [parameters('allowedLocations')]\"},{\"field\":\"tags['autopilotcluster']\"\ - ,\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"allOf\":[{\"not\":{\"field\":\"name\",\"contains\":\"Cleanuptool\"\ - }},{\"not\":{\"field\":\"name\",\"contains\":\"NRMS-Rule-\"}}]}]},\"then\"\ - :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"686f7311dc548f32\"\ - },{\"properties\":{\"displayName\":\"deny creation of new linux vmss with\ - \ ssh password auth_1.5\",\"policyType\":\"Custom\",\"mode\":\"All\",\"description\"\ - :\"This policy audits whether any Linux VMSSs use password-only authentication\ - \ for SSH on new resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-07-14T00:05:22.7366216Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"128t_networking_platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"4psa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voipnow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"a10networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"a10-lightning-adc\",\"a10-vthunder-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"accellion\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kiteworks-by-accellion\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"abiquo\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"abiquo-hybrid-cloud-34\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"accops\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hysecure5050\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"actian_matrix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - actian_matrix\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actifio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"actifio-sky\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"actian-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"vector-community\",\"vector-enterprise\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Acronis\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"storage\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"activeeon\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"activeeon-workload-scheduler\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aerospike\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"aerospike-database-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"affinio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"platform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"aiscaler-cache-control-ddos-and-url-rewriting-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aimobile-site-acceleration\",\"aiprotect-ddos-firewall\",\"aiscaler-traffic-manager-caching\"\ - ,\"aivideo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"akamai-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"enterprise-application-access\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alces-flight-limited\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"alces-flight-compute-solo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"alertlogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"alert-logic-tm\",\"alert-logic-wsm\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"alienvault\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"unified-security-management-anywhere\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"alldigital-brevity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alldigital-brevity-uploader\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altair-engineering-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"altair_hwulva\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"altamira-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"lumify\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"antmedia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ams_community_edition\",\"ant_media_server_enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"apigee\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"apigee-edge\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcara\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"app360v43-001\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcelerator\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appcelerator-arrow-azure-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"appex-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appistry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"genomepilot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"appscale-marketplace\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appscale\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arangodb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"arangodb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"arista-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"veos-router\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"array_networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"array-networks-vapv\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"astadia-1148316\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"astadia-ui-automation-tee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"atomicorp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"secure-os\",\"secure-ubuntu-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"audiocodes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"mediantsessionbordercontroller\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"auriq-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"essentia\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"awingu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"awingu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"aviatrix-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aviatrix-cloud-services\",\"aviatrix-companion-gateway\",\"aviatrix-companion-gateway-v2\"\ - ,\"aviatrix-vpn-gw\",\"aviatrix_multi_cloud_service\",\"aviatrix_openvpn_service\"\ - ,\"aviatrix_openvpn_service10\",\"aviatrix_openvpn_service25\",\"aviatrix_openvpn_service50\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"avi-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - avi-vantage-adc\",\"internal-avi-vantage-adc\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"axway\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"axway-mailgate-secure-collaboration-advanced\"\ - ,\"axway-mailgate-secure-collaboration-premium\",\"axway-mailgate-secure-collaboration-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azul\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"azul-zulu-ubuntu-1804\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"azurecyclecloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - azure-cyclecloud-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"AzureDatabricks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"Databricks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"baas-techbureau\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"b1327623-d29b-4cc1-b833-85067dcc7bce\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"baffle-io\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"baffle-application-data-protection\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"balabit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"balabit-shell-control-box\"\ - ,\"psm\",\"sps\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"barracudanetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"barracuda-app-sec-control-center\",\"barracuda-email-security-gateway\"\ - ,\"barracuda-ng-cc\",\"barracuda-ng-firewall\",\"waf\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"basho\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"riak-2-0-1\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"autodesk-maya-arnold-centos73\"\ - ,\"rendering-centos73\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"bdy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - buddy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"Bitnami\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - 3-4\",\"abantecart\",\"activemq\",\"akeneo\",\"alfrescocommunity\",\"apachesolr\"\ - ,\"artifactory\",\"canvaslms\",\"cassandra\",\"civicrm\",\"cmsmadesimple\"\ - ,\"codiad\",\"concrete5\",\"consul\",\"coppermine\",\"couchdb\",\"diaspora\"\ - ,\"discourse\",\"djangostack\",\"dokuwiki\",\"dolibarr\",\"DreamFactory\"\ - ,\"drupal\",\"elastic-search\",\"elk\",\"erpnext\",\"espocrm\",\"etcd\",\"\ - eXo-Platform\",\"exoplatform\",\"fatfreecrm\",\"ghost\",\"gitlab\",\"grafana\"\ - ,\"hadoop\",\"hhvmstack\",\"hordegroupwarewebmail\",\"jasperreports\",\"jenkins\"\ - ,\"joomla\",\"jrubystack\",\"kafka\",\"kong\",\"kubernetessandbox\",\"lampstack\"\ - ,\"lappstack\",\"letschat\",\"liferay\",\"limesurvey\",\"livehelperchat\"\ - ,\"magento\",\"mahara\",\"mantis\",\"mariadb\",\"mattermost\",\"mautic\",\"\ - mean\",\"mediawiki\",\"memcached\",\"modx\",\"mongodb\",\"moodle\",\"multicraft\"\ - ,\"mybb\",\"mysql\",\"nats\",\"neo4j\",\"neos\",\"nginxstack\",\"noalyss\"\ - ,\"nodejs\",\"ocportal\",\"odoo\",\"openatrium\",\"opencart\",\"openedx\"\ - ,\"openfire\",\"openproject\",\"orangehrm\",\"osclass\",\"owncloud\",\"oxid-eshop\"\ - ,\"parseserver\",\"phabricator\",\"phpbb\",\"phplist\",\"pimcore\",\"piwik\"\ - ,\"plone\",\"pootle\",\"postgresql\",\"prestashop\",\"processmakerenterprise\"\ - ,\"processmakeropensourceedition\",\"processwire\",\"publify\",\"rabbitmq\"\ - ,\"redash\",\"redis\",\"redmine\",\"redmineplusagile\",\"reportserver\",\"\ - reportserverenterprise\",\"resourcespace\",\"reviewboard\",\"reviewboardpowerpack\"\ - ,\"roundcube\",\"rubystack\",\"seopanel\",\"shopware\",\"silverstripe\",\"\ - simplemachinesforum\",\"sonarqube\",\"spree\",\"subversion\",\"suitecrm\"\ - ,\"tensorflowserving\",\"testlink\",\"tikiwikicmsgroupware\",\"tinytinyrss\"\ - ,\"tom-cat\",\"trac\",\"typo3\",\"weblate\",\"webmailpro\",\"wildfly\",\"\ - wordpress\",\"wordpress-multisite\",\"wordpresspro\",\"x2enginesalescrm\"\ - ,\"xoops\",\"youtrack\",\"zookeeper\",\"zurmo\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"black-duck-software\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blackduck_hub_vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"blk-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blk-io-erc-20-rest-service\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockapps\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"strato-blockchain-base-template-latest\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockstack-core-v14\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"blockchain-foundry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"syscoin-api\",\"syscoin-full-node\",\"syscoin-price-peg\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bloombase\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bloombase-storesafe-3_4_7_0_el7_x86_64\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bluecat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluecat-bam-for-azure\"\ - ,\"bluecat-dns-for-azure\",\"bluecat-edge-service-point-vm-for-azure\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bluetalon\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluetalon\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"brocade_communications\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"brocade-virtual-traffic-manager\"\ - ,\"brocade-virtual-traffic-manager-with-waf-module\",\"brocade-virtual-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"bt-americas-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - diamondip-sapphire-ev10\",\"diamondip-sapphire-ev20\",\"diamondip-sapphire-v10\"\ - ,\"diamondip-sapphire-v20\",\"diamondip-sapphire-v5\",\"diamondip-sapphire-vcaa20\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"buddhalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sles_12_pci\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"carto\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cartobuilder2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cask\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cdap-cloud-sandbox\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"UbuntuServer\"\ - ,\"Ubuntu_Core\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cavirin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cavirin-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cautelalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"log_management\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"celum-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"celumdam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cds\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cds-data-migration-solution-for-legacy-to-cloud\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-6-v2-0-2-l1\"\ - ,\"cis-centos-7-v2-1-1-l1\",\"cis-oracle-linux-6-v1-0-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ - ,\"cis-rhel-6-v2-0-2-l1\",\"cis-rhel-7-v2-2-0-l1\",\"cis-suse-linux-11-v2-0-0-l1\"\ - ,\"cis-suse-linux-12-v2-0-0-l1\",\"cis-ubuntu-linux-1404-v2-0-0-l1\",\"cis-ubuntu-linux-1604-v1-0-0-l1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"certivox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sso-test\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cfd-direct\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cfd-direct-from-the-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"chain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chain-core-developer-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"checkpoint\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"check-point-r77-10\"\ - ,\"check-point-vsec-r80\",\"check-point-vsec-r80-blink\",\"sg2\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"chef-software\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chef-automate-vm-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"circleci\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"circleci-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cires21\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"c21l-enc\"\ - ,\"c21l-mos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cisco\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cisco-asav\",\"cisco-csr-1000v\",\"cisco-ftdv\",\"cisco-meraki-vmx100\"\ - ,\"cisco-ngfwv-vm-test-unsupported\",\"cisco_cloud_vedge_17_2_4\",\"cos65\"\ - ,\"cos72\",\"cos72_main_dev\",\"uos14\",\"vwaas-azure\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"citrix\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"citrix-sd-wan-opt\",\"netscaler-ma-service-agent-120\"\ - ,\"netscaler-ma-service-agent-121\",\"netscaler-sd-wan\",\"netscaler-vpx\"\ - ,\"netscalervpx-120\",\"netscalervpx-121\",\"netscalervpx110-6531\",\"netscalervpx111\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"clear-linux-project\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"clear-linux-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"clouber\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cuber\",\"cws\",\"mcenter\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-cruiser\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-cruiser-16\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbees\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"jenkins-enterprise\",\"jenkins-operations-center\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudbees-enterprise-jenkins\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbees-jenkins-enterprise\"\ - ,\"cloudbees-jenkins-operations-center\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudbolt-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudbolt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudboost\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloudboost\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudenablers-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"corestack\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"squid-proxy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudera-altus-centos-os\",\"cloudera-centos-6\",\"cloudera-centos-os\"\ - ,\"test-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudlanes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"cloud-video-accelerator-nfs\",\"cloudlanes-cloud-backup-accelerator-vtl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudlink\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudlink-securevm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cloudplan-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cloudplan_pcn_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cloudsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"paladion_ondemand_nextgen_firewall\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudsoft\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudsoft-amp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"clustrix\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"clustrixdb\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"codelathe\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codelathe-filecloud-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"codenvy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codenvy-on-prem\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cognosys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"1-click-secured-joomla-on-centos-7-3\"\ - ,\"1-click-secured-joomla-on-ubuntu-1404-lts\",\"1-click-secured-joomla-on-ubuntu-1604-lts\"\ - ,\"1-click-secured-joomla-on-ubuntu-1804-lts\",\"centos-6-9\",\"centos-7-3\"\ - ,\"centos-7-4\",\"centos-7-5\",\"deploy-a-secured-modx-on-ubuntu-14-04-lts\"\ - ,\"deploy-a-secured-silverstripe-on-ubuntu-14-04-lts\",\"hardened-mysql-5-6-on-centos-7-3\"\ - ,\"hardened-mysql-5-6-on-ubu-1404-lts\",\"hardened-mysql-5-7-on-centos-7-3\"\ - ,\"hardened-mysql-5-7-on-ubu-1404-lts\",\"hardened-postgresql-on-ubu-1404-lts\"\ - ,\"invoice-ninja-2-5-1-1-on-ubuntu-1404\",\"jruby-on-ubuntu-14-04-lts\",\"\ - low-latency-broadcasting-server-for-live-events\",\"owncloud-9-with-lamp-stack-on-ubuntu-1404\"\ - ,\"piwigogallerys-ubuntu_14-04_lts\",\"sec1011-dokuwiki-on-ubuntu-1404\",\"\ - sec1013-elasticsearch-on-ubuntu-1404\",\"sec1014-opencart-on-ubuntu-1404\"\ - ,\"sec1015-orangehrm-on-ubuntu-1404\",\"sec1016-nodejs-server-on-ubuntu-1404\"\ - ,\"sec1018-haproxy-on-ubuntu-1404\",\"sec1019-secured-tomcat-on-ubuntu-1404\"\ - ,\"sec1020-phpbb-on-hardened-ubuntu-1404\",\"sec1021-mybb-on-hardened-ubuntu-1404\"\ - ,\"sec1022-sugarcrm-on-ubuntu-1404\",\"sec1023-moodle-on-ubuntu-1404\",\"\ - sec1024_magento-on-ubuntu-1404\",\"sec1025-secured-drupal-on-ubuntu-1404\"\ - ,\"sec1027-secured-wordpress-on-ubuntu-1404\",\"sec1028-secured-lamp-sever-on-ubuntu-1404\"\ - ,\"sec1029-secured-mediawiki-on-ubuntu-1404\",\"sec1030-secured-subversion-on-ubuntu-1404\"\ - ,\"sec1031-secured-passenger-nginx-on-ubuntu-1404\",\"sec1033-secured-piwik-on-ubuntu-1404\"\ - ,\"sec1034-secured-pligg-on-ubuntu-1404\",\"sec1035-secured-jenkins-on-ubuntu-1404\"\ - ,\"sec1036-secured-postgresql-on-ubuntu-1404\",\"secure-cloud-lamp-ubuntu-1404\"\ - ,\"secured-abantecart-on-centos\",\"secured-abantecart-on-ubuntu-14-04-lts\"\ - ,\"secured-acquia-drupal-on-centos\",\"secured-acquiadurpal-on-ubuntu-14-04-lts\"\ - ,\"secured-apachesolr-on-centos\",\"secured-apachesolr-on-ubuntu-14-04-lts\"\ - ,\"secured-arartifactory-on-centos\",\"secured-artifactory-on-ubuntu-14-04-lts\"\ - ,\"secured-cakephp-on-centos\",\"secured-cakephp-on-ubuntu-14-04-lts\",\"\ - secured-cms-made-simple-on-centos\",\"secured-cms-made-simple-on-ubuntu-14-04-lts\"\ - ,\"secured-codiad-on-centos\",\"secured-codiad-on-ubuntu-14-04-lts\",\"secured-cogdam-on-centos\"\ - ,\"secured-cogdam-on-ubuntu-14-04-lts\",\"secured-concrete5-on-centos\",\"\ - secured-concrete5-on-ubuntu-14-04-lts\",\"secured-coppermine-on-centos\",\"\ - secured-coppermine-on-ubuntu-14-04-lts\",\"secured-crushftp-on-centos\",\"\ - secured-crushftp-on-ubuntu-14-04-lts\",\"secured-django-on-centos\",\"secured-django-on-ubuntu-14-04-lts\"\ - ,\"secured-dokuwiki-on-centos\",\"secured-dolibarr-on-centos\",\"secured-dolivbarr-on-ubuntu-14-04-lts\"\ - ,\"secured-drupal-on-centos\",\"secured-elasticsearch-on-centos\",\"secured-enterprise-nginx-varnish-haproxy-php\"\ - ,\"secured-espocrm-on-centos\",\"secured-espocrm-on-ubuntu-14-04-lts\",\"\ - secured-exoplatform-on-centos\",\"secured-exoplatform-on-ubuntu-14-04-lts\"\ - ,\"secured-ghost-on-centos\",\"secured-ghost-on-ubuntu-14-04-lts\",\"secured-gradle-on-centos\"\ - ,\"secured-gradle-on-ubuntu-14-04-lts\",\"secured-haproxy-on-centos\",\"secured-invoice-ninja-on-centos\"\ - ,\"secured-jboss-as-on-centos\",\"secured-jbossas-on-ubuntu-14-04-lts\",\"\ - secured-jenkins-on-centos\",\"secured-jruby-on-cento\",\"secured-lamp-on-centos\"\ - ,\"secured-lamp-on-centos-m10\",\"secured-lapp-on-centos\",\"secured-lapp-on-ubuntu-14-04-lts\"\ - ,\"secured-lemp-sever-on-ubuntu-1404\",\"secured-lime-survey-on-centos\",\"\ - secured-limesurvey-on-ubuntu-1404\",\"secured-live-helper-chat-on-centos\"\ - ,\"secured-livehelperchat-on-ubuntu-14-04-lts\",\"secured-magento-on-centos\"\ - ,\"secured-mahara-on-centos\",\"secured-mahara-on-ubuntu-14-04-lts\",\"secured-mantis-on-centos\"\ - ,\"secured-mantis-on-ubuntu-14-04-lts\",\"secured-mariadb-on-ubuntu-16-04\"\ - ,\"secured-mautic-on-centos\",\"secured-mautic-on-ubuntu-14-04-lts\",\"secured-media-wiki-on-centos\"\ - ,\"secured-modx-on-centos\",\"secured-moodle-on-centos\",\"secured-ngnix-on-centos-7-3\"\ - ,\"secured-ngnix-on-ubuntu-14-04-lts\",\"secured-ngnix-on-ubuntu-16-04-lts\"\ - ,\"secured-noalyss-on-centos\",\"secured-noalyss-on-ubuntu-14-04-lts\",\"\ - secured-nodejs-on-centos\",\"secured-occlass-on-ubuntu-14-04-lts\",\"secured-ocportal-on-ubuntu-14-04-lts\"\ - ,\"secured-open-cart-on-centos\",\"secured-orangehrm-on-centos\",\"secured-osclass-on-centos\"\ - ,\"secured-owncloud-on-centos\",\"secured-oxid-eshop-on-centos\",\"secured-oxideshop-on-ubuntu-14-04-lts\"\ - ,\"secured-passenger-nginx-on-centos\",\"secured-piwigo-gallery-on-centos\"\ - ,\"secured-plone-on-centos\",\"secured-plone-on-ubuntu-14-04-lts\",\"secured-prestashop-on-centos\"\ - ,\"secured-prestashop-on-ubuntu-14-04-lts\",\"secured-railo-on-ubuntu-14-04-lts\"\ - ,\"secured-redis-on-centos\",\"secured-redis-on-ubuntu-1404\",\"secured-redmine-on-centos\"\ - ,\"secured-redmine-on-ubuntu-14-04-lts\",\"secured-redmineagile-on-ubuntu-14-04-lts\"\ - ,\"secured-report-server-on-centos\",\"secured-reportserverent-on-ubuntu-14-04-lts\"\ - ,\"secured-resource-space-on-centos\",\"secured-resourcespace-on-ubuntu-14-04-lts\"\ - ,\"secured-round-cube-on-centos\",\"secured-roundcube-on-ubuntu-14-04-lts\"\ - ,\"secured-ruby-on-centos\",\"secured-ruby-on-ubuntu-14-04-lts\",\"secured-seopanel-on-centos\"\ - ,\"secured-seopanel-on-ubuntu-14-04-lts\",\"secured-silverstripe-on-centos\"\ - ,\"secured-simple-invoice-on-centos\",\"secured-simple-machines-on-centos\"\ - ,\"secured-simple-machines-on-ubuntu-14-04-lts\",\"secured-simpleinvoice-on-ubuntu-14-04-lts\"\ - ,\"secured-subversion-on-centos\",\"secured-suitecrm-on-centos\",\"secured-suitecrm-on-ubuntu-14-04-lts\"\ - ,\"secured-test-link-on-centos\",\"secured-testlink-on-ubuntu-14-04-lts\"\ - ,\"secured-thinkup-on-centos\",\"secured-thinkup-on-ubuntu-14-04-lts\",\"\ - secured-tikiwikicms-on-centos\",\"secured-tikiwikicms-on-ubuntu-14-04-lts\"\ - ,\"secured-tiny-tiny-rss-on-centos\",\"secured-tinytinyrss-on-ubuntu-14-04-lts\"\ - ,\"secured-tomcat-on-centos\",\"secured-trac-on-centos\",\"secured-trac-on-ubuntu-14-04-lts\"\ - ,\"secured-typo3-on-centos\",\"secured-typo3-on-ubuntu-14-04-lts\",\"secured-varnish-on-centos\"\ - ,\"secured-varnish-on-ubuntu-1404\",\"secured-wildfly-on-centos\",\"secured-wildfly-on-ubuntu-14-04-lts\"\ - ,\"secured-wordpress-on-centos-7-3\",\"secured-wordpress-on-ubuntu-16-04-lts\"\ - ,\"secured-x-cart-on-ubuntu-14-04-lts\",\"secured-xoops-on-centos\",\"secured-xoops-on-ubuntu-14-04-lts\"\ - ,\"secured-zurmo-on-centos\",\"secured-zurmo-on-ubuntu-14-04-lts\",\"suse15\"\ - ,\"ubuntu-14-04-lts\",\"ubuntu-16-04-lts\",\"ubuntu-17-04-high-performance-hardened-tcp-bbr\"\ - ,\"ubuntu-18-04\",\"ubuntu-18-04-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cohesity-cloudtd-tool\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"cohesive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vns3_4x_network_security\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"confluentinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"confluentplatform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"consensys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"truffle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"convertigo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"convertigo-for-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"corda\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"corda\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"CoreOS\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"CoreOS\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"couchbase\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"couchbase-server-enterprise\",\"couchbase-sync-gateway-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cryptzone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appgate-appliance-3_2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"cybernetica-as\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - uxp-securityserver-connector\",\"uxp-securityserver_vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cyxtera\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"appgatesdp-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"dataart\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"devicehive\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"databricks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"spfqogzeculbhdh\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datalayer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datalayer-notebook\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datastax\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datastax-enterprise\"\ - ,\"datastax-enterprise-non-production-use-only\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"datasunrise\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"datasunrise-database-security-suite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dataiku\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dataiku-data-science-studio\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"datometry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyper-q\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dellemc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dell-emc-avamar-virtual-edition\"\ - ,\"dell-emc-datadomain-management-center\",\"dell-emc-datadomain-virtual-edition\"\ - ,\"dell-emc-datadomain-virtual-edition-v4\",\"dell-emc-networker-virtual-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"delphix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"delphix_dynamic_data_platform\"\ - ,\"omniosce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"denodo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"denodo-platform\",\"denodo-platform-7_0\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"denyall\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"denyall-rweb\",\"denyall-vulnerability-manager\",\"denyall-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dgsecure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dgsecure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"diladele\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"websafety\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"dimensionalmechanics-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neopulse-ai-studio\",\"neopulse-query-runtime\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"docker\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"docker-ce\",\"docker-ce-edge\"\ - ,\"docker-datacenter-custom\",\"docker-ee\",\"docker-ee-basic\",\"docker4azure\"\ - ,\"docker4azure-cs\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dome9\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"dome9ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drizti\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hpcbox-ansys-19-cluster-master\",\"hpcbox-cluster-compute-node\",\"hpcbox-cluster-cuda-node\"\ - ,\"hpcbox-cluster-gpu-node\",\"hpcbox-docker-cluster-master\",\"hpcbox-openfoam-cluster-master\"\ - ,\"hpcbox-su2-cluster-master\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"drone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"drone\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dyadic_security\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"dyadic_sec\",\"ukc_image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"dynatrace\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ruxit-managed-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"eastwind-networks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"eastwind-ixia-sensor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"egnyte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"egnyte-connect\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elasticbox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"elasticbox-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"electric-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"electricflowce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"elfiqnetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"emercoin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"emercoin\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprise-ethereum-alliance\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"quorum-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"enterprisedb-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"edb-postgres-ark\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"equalum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"equalum-vm-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"esdenera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"esdenera-firewall-3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ethereum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ethereum-studio\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"evostream-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ems-for-template\",\"ems-test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"exasol\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"exasol-analytics-database-byol\",\"exasolution-analytic-database\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"falconstorsoftware\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"fss-v9\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"f5-networks\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"f5-big-ip-adc\",\"\ - f5-big-ip-advanced-waf\",\"f5-big-ip-best\",\"f5-big-ip-better\",\"f5-big-ip-byol\"\ - ,\"f5-big-ip-good\",\"f5-big-ip-per-app-ve\",\"f5-big-iq\",\"f5-web-application-firewall\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"filecatalyst\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - filecatalyst-direct-per-hr-billing\",\"filecatalyst-direct-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"firehost\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"firehost_armor\",\"\ - firehost_armor_ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flexify-io\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"single-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"flashgrid-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"flashgrid-racnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"foghorn-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"foghorn-edge-device-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forcepoint-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"forcepoint-ngfw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"forscene\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"forscene-edgeserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortycloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"fortycloud-gw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"fortinet\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fortinet-fortianalyzer\",\"fortinet-fortimanager\",\"fortinet_fortigate-vm_v5\"\ - ,\"fortinet_fortimail\",\"fortinet_fortivoice\",\"fortinet_fortiweb-vm_v5\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"fujitsu_fast\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - fep10-rh7-test\",\"feptest\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"gemalto-safenet\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"safenet-keysecure-k170v\",\"safenet-protectv\",\"safenet-protectv-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gigamon-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gigamon-fm-5_3_01\"\ - ,\"gigamon-fm-5_3_01_hourly\",\"gigamon-fm-5_4_00\",\"gigamon-fm-5_4_00_hourly\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gitlab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gitlab-ce\"\ - ,\"gitlab-ee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"GitHub\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"GitHub-Enterprise\",\"githubenterprise-test-publishing\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"great-software-laboratory-private-limited\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"xid\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"greensql\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"greensql-database-security\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"gridgain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gridgain-vm\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"guardicore\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"guardicorecentra\"\ - ,\"infection_monkey\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"haivision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"haivision-media-gateway-1-2\",\"haivision-media-gateway-1-5\",\"haivision-media-gateway-1-6-2\"\ - ,\"media-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"h2o-ai\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"h2o-driverles-ai\",\"h2o-driverless-ai\",\"h2o-vm\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"haproxy-technologies\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hapee-rhel\",\"hapee-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"harpaitalia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mcuboenergy\"\ - ,\"yg\",\"yougreen_trial\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hcl-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hcl17cp1104\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"heimdall-data\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"heimdall-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"help-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"goanywheremftubuntulinux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hewlett-packard\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"hpe-helion-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hillstone-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudedge-virtual-ngfw-advanced-edition\",\"cloudedge-virtual-ngfw-standard-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hortonworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbreak-for-hortonworks-data-platform\"\ - ,\"hortonworks-sandbox\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"hitachi-solutions\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"credeon-sfs-and-kms-for-sharepoint-online\",\"credeonsecurefull-textsearch1_0\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hpe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storeoncevsa\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"huawei\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"euleros-v2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hyperglance\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperglance-dynamic-topology\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hypergrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperform\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"hytrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hytrust-keycontrol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"ibm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ibm-security-guardium-multi-cloud\"\ - ,\"qradar_security_analytics\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iaansys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iaansys-magento\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"iboss\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"iboss-14600-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"imaginecommunications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloudxtream-cdvr\",\"cloudxtream-dai-vms\",\"telurio-aim\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"imperva\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"imperva-dam-v13\"\ - ,\"securesphere-waf\",\"securesphere-waf-for-azr\",\"securesphere-waf-v12\"\ - ,\"securesphere-waf-v13\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"infoblox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"infoblox-vnios-te-v1420\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"informatica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"bdm10-1-1-u2\",\"big-data-management-10-2\",\"big-data-management-10-2-1\"\ - ,\"data_accelerator_for_azure_byol\",\"data_quality_10_1_1_rhel_7_3_byol\"\ - ,\"eic\",\"ics-byol\",\"ics-payg-ubuntu\",\"platform_10_1_1_multi_node_domain_rhel-7-3_byol\"\ - ,\"platform_10_2_hf1_domain_rhel-7-3_byol\",\"powercenter-v10-domain-image-ubuntu14-04-3\"\ - ,\"powercenter-v10-update1-domain-image-ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"informationbuilders\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"iway-big-data-vm\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ingrammicro\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ingrammicroensimcentostrial\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"lustre-cloud-edition-gs-image\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"intel-bigdl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bigdl-0815\"\ - ,\"bigdl__vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intel-fpga\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"quartus_pro_opencl_sdk\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intellicus-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intellicus_bi_server_100_user_linux\",\"intellicus_bi_server_10_user_linux\"\ - ,\"intellicus_bi_server_25_user_linux\",\"intellicus_bi_server_50_user_linux\"\ - ,\"intellicus_bi_server_5_user_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intersystems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"intersystems-iris-single-node\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"intigua\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"intigua-agent-manager-3_7_0-trial\",\"intigua-agent-manager-trial\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"iquest\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"keyhub\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ishlangu-load-balancer-adc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ishlangu-load-balancer-byol\"\ - ,\"ishlangu-load-balancer-is10\",\"ishlangu-load-balancer-is100\",\"ishlangu-load-balancer-is1000\"\ - ,\"ishlangu-load-balancer-is200\",\"ishlangu-load-balancer-is5000\",\"ishlangu-load-balancer-isbfg\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"issp-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ispocr\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"itelios\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"magento2-on-zendserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jamcracker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"4632d5b4-feb0-4332-8452-f2e66133672f\",\"jamcracker-cloudanalytics\"\ - ,\"jamcracker-cloudanalytics-version4\",\"jamcracker-cloudanalytics-version5\"\ - ,\"jamcracker-csb-service-provider\",\"jamcracker-csb-serviceprovider\",\"\ - jamcracker-csb-standard\",\"jamcracker-csb-standard-v3\",\"jamcracker-csb-standard-version4\"\ - ,\"jamcracker-hybrid-cloud-management-version4\",\"jamcracker_cloud_control_appliance_version4\"\ - ,\"jsdnapp_csb_serviceprovider-version4\",\"jsdnapp_hybrid\",\"jsdnapp_hybrid_v3\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jedox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jedox-for-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jelastic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jelastic-hybrid-paas-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"jetnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dvwa\"\ - ,\"jetnexus-application-load-balancer\",\"jetnexus-global-load-balancer\"\ - ,\"jetnexus-waf\",\"zap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jetware-srl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"caffe2\",\"caffe_python_cpu\",\"caffe_python_gpu\",\"cockroachdb\"\ - ,\"lamp_optimized\",\"lemp7_optimized\",\"memcached\",\"mongodb\",\"mxnet_python\"\ - ,\"mysql\",\"nodejs_nginx\",\"percona_mongodb\",\"percona_mysql\",\"postgresql\"\ - ,\"pytorch\",\"pytorch_cuda_notebook\",\"pytorch_cuda_production\",\"redis\"\ - ,\"redmine\",\"tensorflow_cpu_notebook\",\"tensorflow_cpu_production\",\"\ - tensorflow_cuda_notebook\",\"tensorflow_cuda_production\",\"tensorflow_python\"\ - ,\"theano_python\",\"wordpress4_lemp7\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jitterbit_integration\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"jitterbit-harmony-agent\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"jm-technology-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"smart-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"juniper-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vmx-services-gateway-byol\",\"vmx-services-gateway-byol-soltemp\"\ - ,\"vmx-virtual-router\",\"vsrx-next-generation-firewall\",\"vsrx-next-generation-firewall-payg\"\ - ,\"vsrx-next-generation-firewall-solution-templ-payg\",\"vsrx-next-generation-firewall-solution-template\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"kaazing\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"kaazing-kwic\"\ - ,\"kaazing-vpa\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kali-linux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"kali-linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kemptech\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kemp360central-byol\",\"vlm-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"kinetica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"kineticadbbyol\",\"kineticadbpayasyougo\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"kaspersky_lab\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"kaspersky_secure_mail_gateway\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"knime\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"knime-server-5-user_4-4-0\"\ - ,\"knime-server-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"krypc-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"krypccore\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leap-orbit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"leaporbitstoragebackedsftp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"leostream-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"connection-broker\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquid-files\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"liquidfiles\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"liquidware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stratusphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"literatu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"literatu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"loadbalancer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"loadbalancer-org-load-balancer-for-azure\",\"loadbalancer-org-load-balancer-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logsign\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logsignfocus\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"logtrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logtrust-log-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"looker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"looker-analytics-platform\"\ - ,\"looker-analytics-platform-326\",\"looker-analytics-platform-5_6\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"lti-lt-infotech\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"trade-finance-blockchain\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"luminate-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"luminate-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mapr-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"mapr52-base-dev\",\"mapr60-base\",\"mapr60-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mariadb\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mariadb-server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"marklogic\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"marklogic-9-byol\"\ - ,\"marklogic-developer-9\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"massiveanalytic-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"oscarap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mathworks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"matlab-ref-arch-18a-v1-linux-disk\",\"mps-ref-arch-18a-v1-linux-disk2\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"matillion\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"matillion-etl-snowflake\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mavinglobal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mavin-business-trial\"\ - ,\"mavin-enterprise-edition\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"meanio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"gitlab-enterprise-ready\",\"linnovate-open-source-sla-pro\",\"mean-machine-20\"\ - ,\"openideal3\",\"redash\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"media3-technologies-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cpan1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"memsql\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"memsql-community-single-vm\",\"memsql-enterprise-single-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mendix\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mendix-docker\",\"mendix-pro\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"mfe_azure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"atd-mcafee\"\ - ,\"mcafee_vnsp_controller_for_azure\",\"mcafee_vnsp_for_azure\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-ads\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"linux-data-science-vm\"\ - ,\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"micro-focus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"replication_environment\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-avere\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vfxt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-batch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"centos-container\",\"centos-container-rdma\",\"ubuntu-server-container\"\ - ,\"ubuntu-server-container-rdma\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-azure-compute\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureconfidentialcompute\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azureml\",\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftAzureSiteRecovery\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ASR-Hydration-VMs\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftOSTC\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - FreeBSD\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"MLServer-CentOS\",\"MLServer-RedHat\",\"MLServer-Ubuntu\",\"RServer-CentOS\"\ - ,\"RServer-Ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midfin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mf_neon_cgw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"midvision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ibm-datapower-virtual-edition-75\",\"ibm-datapower-virtual-edition-76\"\ - ,\"ibm-datapower-virtual-edition-77\",\"ibm-http-server\",\"ibm-websphere-portal-server-85\"\ - ,\"ibm-websphere-portal-server-90\",\"websphere-application-server-be\",\"\ - websphere-application-server-be-80\",\"websphere-application-server-be-85\"\ - ,\"websphere-application-server-be-90\",\"websphere-application-server-be-and-mq\"\ - ,\"websphere-application-server-lp\",\"websphere-application-server-lp-16\"\ - ,\"websphere-application-server-lp-17\",\"websphere-application-server-lp-18\"\ - ,\"websphere-application-server-nde\",\"websphere-application-server-nde-80\"\ - ,\"websphere-application-server-nde-85\",\"websphere-application-server-nde-90\"\ - ,\"websphere-mq\",\"websphere-mq-75\",\"websphere-mq-90\",\"websphere-mq-91\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"miraclelinux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - asianux-server-4-sp5\",\"asianux-server-4-sp6\",\"asianux-server-4-sp7\",\"\ - asianux-server-7-sp1\",\"asianux-server-7-sp2\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"miri-infotech-pvt-ltd\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wordpress\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mobilab\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"magento-wirecard-checkout\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moogsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moogsoft-aiops\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"moviemasher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moviemasher\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"SQL2017-RHEL7\",\"SQL2017-RHEL73\",\"SQL2017-SLES12SP2\",\"SQL2017-Ubuntu1604\"\ - ,\"SQL2019-RHEL7\",\"SQL2019-Ubuntu1604\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"mtnfog\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"idyl-e3-entity-extraction-engine\",\"prose-sentence-extraction-engine\"\ - ,\"renku-language-detection-engine\",\"sonnet-tokenization-engine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mxhero\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mail2cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"my-com\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tarantool\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"narrativescience\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"narratives-for-power-bi\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nasuni\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"nasuni-nmc\"\ - ,\"nasuni_edge_appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ncbi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - ncbi-blast-2-3-0\",\"ncbi-free-2-2-31\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nebbiolo-technologies-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fog-system-manager\",\"fogsm_basic\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"neo4j\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"neo4j-enterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netapp\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netapp-altavault-cloud-integrated-storage-solution\"\ - ,\"netapp-oncommand-cloud-manager\",\"netapp-ontap-cloud\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netgate\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netgate-pfsense-azure-fw-vpn-router\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netiq\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"replication_environment\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"netscout\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netscout_virtual_ngeniusone_with_vscout\"\ - ,\"netscout_vstream\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netmail\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"netmail-search\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netsweeper\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"netsweeper6-0-6\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"netx\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - simplehelp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"neusoft-neteye\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"neusoft-nisg-va-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nginxinc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nginx-plus-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nicepeopleatwork\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"youzana\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nodejsapi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"node-js-api\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"noobaa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"noobaa-hybrid-s3-archive-05\",\"noobaa-multi-cloud-deduplication\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"northbridge-secure\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netconnect1\",\"netconnectx\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"nubeva-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"controller\"\ - ,\"test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuco-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"aionnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nuxeo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nuxeo-6-lts\",\"nuxeo-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"nvidia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ngc_azure_17_11\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"o2mc-real-time-data-platform\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"o2mc-platform-app\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"oceanblue-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"obc-sdwan-solutions\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"omega-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ods_datastage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onyx-point-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"op-bnf-v1\",\"op-bnf1_6-v1\",\"op-bpnifi-v1\",\"op-bpnifi16-v1\"\ - ,\"op-scc-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"onapsis\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"osp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"op5\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - op5-monitor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"opencell\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"meveo\",\"meveo403sp2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"openvpn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openvpnas\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Oracle-Database-Ee\"\ - ,\"Oracle-Database-Se\",\"Oracle-Linux\",\"Oracle-WebLogic-Server\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"orientdb\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"orientdb-community-edition\"\ - ,\"orientdb-community-edition-2_2\",\"orientdb-enterprise-edition-2_2\",\"\ - orientdb-enterprise-edition-2_2_17\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osirium-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"osirium-pxm-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"osnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quantastorvsav4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"paloaltonetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"panorama\",\"vmseries1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"panzura-file-system\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"azura-freedom-filer-v7110\",\"panzura-cloud-filer\",\"panzura-freedom-filer-7140-13222\"\ - ,\"panzura-freedom-filer-716-13549\",\"panzura-freedom-filer-v7020\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"parasoft\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"parasoft-service-virtualization\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"passlogy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"passlogic\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"penta-security-systems-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"wapples\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"percona\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"percona-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"postgres-pro\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"postgres-pro-enterprise\",\"postgres-pro-enterprise-10\",\"postgres-pro-standard\"\ - ,\"postgres-pro-standard-10\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"plesk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"plesk-onyx-linux\",\"solution-server-business\",\"solution-server-wordpress\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"prestashop\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"prestashop16-lamp\"\ - ,\"ubuntu-base-for-prestashop\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"prime-strategy\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"kusanagi-77\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"pivotal-gpdb-vm\",\"pivotal-greenplum-images\",\"pivotal-ops-manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"process-one\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ejabberd-community-edition\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"profecia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"full_disk_encryption_vm\"\ - ,\"project_tools_vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"progelspa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"libra-esva-antispam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ptsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ptaf-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"pulse-secure\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pulse-connect-secure-vm\",\"pulse-virtual-traffic-manager\",\"\ - pulse-virtual-traffic-manager-with-waf\",\"pulse-virtual-traffic-manager-with-waf2\"\ - ,\"pulse-virtual-traffic-manager2\",\"pulse-virtual-web-application-firewall\"\ - ,\"pulse-virtual-web-application-firewall2\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"PuppetLabs\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"PuppetEnterprise\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"puppet\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"puppet-enterprise\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"pydio\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"pydio-enterprise\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"qore-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"qorus\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qualysguard\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qualys-virtual-firewall-appliance\",\"qualys-virtual-scanner-v23b\"\ - ,\"qualys-virtual-scanner-v24\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quasardb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"quasardb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"qubole-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"qubole-data-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"quest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"fve\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"racknap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"racknap-server\",\"racknap-server-linux\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"radware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radware-alteon-va\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"radiant-logic\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"radiantone-vms\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rancher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rancheros\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rapid7\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nexpose-scan-engine\",\"rapid7-vm-console\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"rapidminer\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"rapidminer_server_75\",\"rapidminer_server_76\"\ - ,\"rapidminer_server_80\",\"rapidminer_server_81\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"realm\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"realm-mobile-platform\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"reblaze\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"rbzr-image\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"RHEL\",\"rhel-byos\"\ - ,\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"relevance-lab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - rlcatalyst\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"remotelearner\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"fully-supported-moodle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"revolution-analytics\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"revolution-r-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"RightScaleLinux\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"RightImage-CentOS\",\"RightImage-Ubuntu\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RiverbedTechnology\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"steelapp_traffic_manager\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"riverbed\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"riverbed-sccm-5-5-1\"\ - ,\"riverbed-steelcentral-appinternals\",\"riverbed-steelhead-9-2\",\"riverbed-steelhead-9-5-0\"\ - ,\"riverbed-steelhead-9-6-0\",\"riverbed_steelconnect_gw\",\"riverbed_steelconnect_sh\"\ - ,\"steelapp_traffic_manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rocketsoftware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rocket-discover\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsa-security-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"rsa-nw-azure-arch\",\"rsa-nw-azure-broker\",\"rsa-nw-azure-con\"\ - ,\"rsa-nw-azure-esa\",\"rsa-nw-azure-ldec\",\"rsa-nw-azure-vlc\",\"rsa-nw-suite-11\"\ - ,\"rsa-nw-suite-11-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"rsk-labs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"rsk-bamboo-beta-node\",\"rsk-node-orchid\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"saama\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"fluidanalyticsengine\",\"insurancefraudanalytics\"\ - ,\"realworldevidence\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"saltstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos65saltstackenterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalearc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalearc-for-mysql-paygo\",\"scalearc-for-sql-server-pay-go\",\"scalearc_mysql-server\"\ - ,\"scalearc_sql_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scalegrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - hanaexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"scality\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"scalityconnecthourly\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"secureworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"scwx-azure-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"shadow-soft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"icinga\",\"icinga2-5\",\"icinga2-7\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"signal-sciences\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"signalscienceswpp\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"sightapps\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sightapps\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"silver-peak-systems\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"silver_peak_edgeconnect\"\ - ,\"silver_peak_vx\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"simmachinesinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"simmachines_vm_v2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sinefa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sinefa-probe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"skyarc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"mt6\",\"mta\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"smartmessage-autoflow\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"martmessage-autoflow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"snapt-adc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"snaptadc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"soasta\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloudtest-lite\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"softnas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"cloud_dev\",\"mp_ce\",\"mp_ent\",\"mp_nas_byol\",\"mp_nas_ep\",\"mp_nas_gp\"\ - ,\"mp_nas_hp\",\"mp_plat\",\"private_offerings\",\"softnas-cloud\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"solanolabs\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"solano-ci-private-beta\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"soha\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"soha-cloud\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"solar-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - solar-incode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sonicwall-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"sonicwall-nsz-azure\",\"waf\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"sophos\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"sophos-xg\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spagobi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"spagobi\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"spacecurve\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"spacecurve-quickstart\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"splunk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"splunk-enterprise-base-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"src-solution\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"pilot-things-onem2m-smart-network\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sqlstream\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"com\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sphere3d\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"snapcloud-byol\",\"snapcloud-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stackato-platform-as-a-service\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"activestate-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stackstorm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stackstorm-2015-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"startekfingerprintmatch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bioserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ - ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ - ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ - ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ - ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ - ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ - ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ - ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ - teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ - ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ - ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ - ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ - ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ - ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ - vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ - ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ - ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ - ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ - ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ - ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ - ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ - ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ - ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ - ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ - ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ - triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ - ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/6e87f6ee1518ae1d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e87f6ee1518ae1d\"\ - },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-04-01T22:23:59.788546Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"},{\"field\":\"location\"\ - ,\"in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.Batch/batchAccounts/poolAllocationMode\"\ - ,\"notIn\":[\"batchservice\",\"null\",\"\"]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74c98b59a6341488\"\ - },{\"properties\":{\"displayName\":\"nrms-subnet-require-nsg_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T19:34:01.1631389Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"tags['SkipNRMSNSG']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['SkipNRMSNSG']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ - },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ - :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ - },{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Network/virtualNetworks/subnets\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"false\"}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"789cfec91f9e1858\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-102_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:28.7454992Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7c066e9166289efb\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-subnet_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:27:19.9099766Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Subscriptions Excluded\",\"description\":\"Subscriptions excluded from\ - \ policy due to security exceptions\"}},\"resourceGroupExclusions\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Resource Groups Excluded\",\"description\"\ - :\"Any VNet in a resource group in this list will be ignored.\"},\"defaultValue\"\ - :[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"\ - Microsoft.Network/virtualNetworks/subnets\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"},{\"value\":\"[resourceGroup().name]\"\ - ,\"notIn\":\"[parameters('resourceGroupExclusions')]\"},{\"field\":\"name\"\ - ,\"notContains\":\"GatewaySubnet\"},{\"field\":\"tags['SkipNRMSNSG']\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags['SkipNRMSNSG']]\",\"\ - equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ - },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ - :[{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"notIn\":[\"null\",\"\"]}},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Authorization/policyAssignments\",\"name\":\"DoesNotExistBecauseThisIsToCauseDeployment\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json\"\ - ,\"contentVersion\":\"1.0.0.1\",\"parameters\":{\"fullSubnetName\":{\"type\"\ - :\"String\"},\"allowedLocations\":{\"type\":\"Array\"}},\"variables\":{\"\ - vnetName\":\"[first(split(parameters('fullSubnetName'),'/'))]\",\"subnetName\"\ - :\"[last(split(parameters('fullSubnetName'),'/'))]\",\"rawNsgName\":\"[concat(variables('vnetName'),'-',\ - \ variables('subnetName'), '-NRMS')]\",\"nsgName\":\"[if(greater(length(variables('rawNsgName')),75),substring(variables('rawNsgName'),0,75),variables('rawNsgName'))]\"\ - ,\"nsgUpdateJson\":{\"networkSecurityGroup\":{\"id\":\"[resourceId('Microsoft.Network/networkSecurityGroups',\ - \ variables('nsgName'))]\"}}},\"resources\":[{\"condition\":\"[contains(parameters('allowedLocations'),\ - \ resourceGroup().location)]\",\"type\":\"Microsoft.Network/networkSecurityGroups\"\ - ,\"name\":\"[variables('nsgName')]\",\"apiVersion\":\"2018-03-01\",\"location\"\ - :\"[resourceGroup().location]\",\"tags\":{\"Creator\":\"Automatically added\ - \ by NRMS Azure Policy\",\"NRMS-Info\":\"http://aka.ms/nrms\",\"NRMS-Version\"\ - :\"2019-03-20\"},\"properties\":{}},{\"type\":\"Microsoft.Resources/deployments\"\ - ,\"name\":\"NRMS-Update-Subnet-Without-NSG\",\"apiVersion\":\"2018-05-01\"\ - ,\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"apiVersion\":\"2018-11-01\"\ - ,\"type\":\"Microsoft.Network/virtualNetworks/subnets\",\"name\":\"[parameters('fullSubnetName')]\"\ - ,\"location\":\"[resourceGroup().location]\",\"properties\":\"[union(reference(resourceId('Microsoft.Network/virtualNetworks/subnets',\ - \ variables('vnetName'), variables('subnetName')), '2018-11-01'), variables('nsgUpdateJson'))]\"\ - }]}},\"dependsOn\":[\"[variables('nsgName')]\"]}]},\"parameters\":{\"fullSubnetName\"\ - :{\"value\":\"[field('fullName')]\"},\"allowedLocations\":{\"value\":\"[parameters('allowedLocations')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"852aeb0ee2c0a3a5\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-109_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:26.3856504Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8657a5b3e83f5307\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8657a5b3e83f5307\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for vmss_2.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-06-23T19:35:03.2379239Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname1\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"resourcegrouptagname2\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ - \ the resource group level\",\"description\":\"Rule is not deployed if this\ - \ tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription\ - \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ - \ Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\"\ - ,\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname1')]]\",\"equals\"\ - :\"\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname2')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ - ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"existenceCondition\"\ - :{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"VirtualMachineRuntimeService\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Compute\"}]}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ - :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ - :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{}}}]},\"parameters\":{\"\ - vmssName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/884fc572e38f5fe9\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"884fc572e38f5fe9\"\ - },{\"properties\":{\"displayName\":\"nrms-kubernet-require-azure-networkplugin_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:24.5730438Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerService/managedClusters\"},{\"field\":\"location\",\"\ - in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"equals\":\"azure\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/88adc7594e846097\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88adc7594e846097\"\ - },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_1.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:23.3819739Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"},{\"field\":\"location\"\ - ,\"in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.Batch/batchAccounts/poolAllocationMode\"\ - ,\"notIn\":[\"batchservice\",\"null\",\"\"]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/891d9369d047f6ac\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"891d9369d047f6ac\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-104_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:15.9708014Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8d69d8ee570b639\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8d69d8ee570b639\"\ - },{\"properties\":{\"displayName\":\"sqlads-auditifnotexists-auditing should\ - \ be enabled on advanced data security settings on sql server_1.0\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-06-10T02:12:36.9468814Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"tagname\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ - \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ - \ the SQL Server\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"},\"setting\":{\"type\":\"String\"}},\"policyRule\":{\"\ - if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Sql/servers\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagname'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"value\":\"[subscription().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"type\"\ - :\"Microsoft.Sql/servers/auditingSettings\",\"name\":\"default\",\"existenceCondition\"\ - :{\"field\":\"Microsoft.Sql/auditingSettings.state\",\"equals\":\"[parameters('setting')]\"\ - }}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fce770def99399\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fce770def99399\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-106_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:28.0710497Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fdec1516a77bbd6\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8fdec1516a77bbd6\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on existing vmss_1.4\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMSSs use password-only authentication for SSH\ - \ on existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-05-12T23:41:53.0207896Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ - }}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9135d7012c4033cb\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9135d7012c4033cb\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-105_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:42.3856221Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"91f42c0ca66ff7dd\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ append policy for vmss_1.1\",\"policyType\":\"Custom\",\"mode\":\"All\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-08-13T21:33:05.8939153Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"tagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\",\"\ - in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[', parameters('tagname'),\ - \ ']')]\",\"exists\":\"false\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ - ,\"notEquals\":\"GenevaMonitoring\"},{\"not\":{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ - ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ - field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ - ,\"value\":{\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"properties\"\ - :{\"publisher\":\"Microsoft.Azure.Geneva\",\"type\":\"GenevaMonitoring\",\"\ - typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ - :{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9534973cc57db387\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9534973cc57db387\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-subnet_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:09.005562Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Subscriptions Excluded\",\"description\":\"Subscriptions excluded from\ - \ policy due to security exceptions\"}},\"resourceGroupExclusions\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Resource Groups Excluded\",\"description\"\ - :\"Any VNet in a resource group in this list will be ignored.\"},\"defaultValue\"\ - :[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"\ - Microsoft.Network/virtualNetworks/subnets\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"},{\"value\":\"[resourceGroup().name]\"\ - ,\"notIn\":\"[parameters('resourceGroupExclusions')]\"},{\"field\":\"name\"\ - ,\"notContains\":\"GatewaySubnet\"},{\"field\":\"tags['SkipNRMSNSG']\",\"\ - exists\":\"false\"},{\"anyOf\":[{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"notIn\":[\"null\",\"\"]}},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Authorization/policyAssignments\",\"name\":\"DoesNotExistBecauseThisIsToCauseDeployment\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json\"\ - ,\"contentVersion\":\"1.0.0.1\",\"parameters\":{\"fullSubnetName\":{\"type\"\ - :\"String\"},\"allowedLocations\":{\"type\":\"Array\"}},\"variables\":{\"\ - vnetName\":\"[first(split(parameters('fullSubnetName'),'/'))]\",\"subnetName\"\ - :\"[last(split(parameters('fullSubnetName'),'/'))]\",\"rawNsgName\":\"[concat(variables('vnetName'),'-',\ - \ variables('subnetName'), '-NRMS')]\",\"nsgName\":\"[if(greater(length(variables('rawNsgName')),75),substring(variables('rawNsgName'),0,75),variables('rawNsgName'))]\"\ - ,\"nsgUpdateJson\":{\"networkSecurityGroup\":{\"id\":\"[resourceId('Microsoft.Network/networkSecurityGroups',\ - \ variables('nsgName'))]\"}}},\"resources\":[{\"condition\":\"[contains(parameters('allowedLocations'),\ - \ resourceGroup().location)]\",\"type\":\"Microsoft.Network/networkSecurityGroups\"\ - ,\"name\":\"[variables('nsgName')]\",\"apiVersion\":\"2018-03-01\",\"location\"\ - :\"[resourceGroup().location]\",\"tags\":{\"Creator\":\"Automatically added\ - \ by NRMS Azure Policy\",\"NRMS-Info\":\"http://aka.ms/nrms\",\"NRMS-Version\"\ - :\"2019-03-20\"},\"properties\":{}},{\"type\":\"Microsoft.Resources/deployments\"\ - ,\"name\":\"NRMS-Update-Subnet-Without-NSG\",\"apiVersion\":\"2018-05-01\"\ - ,\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"apiVersion\":\"2018-11-01\"\ - ,\"type\":\"Microsoft.Network/virtualNetworks/subnets\",\"name\":\"[parameters('fullSubnetName')]\"\ - ,\"location\":\"[resourceGroup().location]\",\"properties\":\"[union(reference(resourceId('Microsoft.Network/virtualNetworks/subnets',\ - \ variables('vnetName'), variables('subnetName')), '2018-11-01'), variables('nsgUpdateJson'))]\"\ - }]}},\"dependsOn\":[\"[variables('nsgName')]\"]}]},\"parameters\":{\"fullSubnetName\"\ - :{\"value\":\"[field('fullName')]\"},\"allowedLocations\":{\"value\":\"[parameters('allowedLocations')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9644d220df7c67a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9644d220df7c67a\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-105_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:26.1317211Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9aca16db50fb914c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9aca16db50fb914c\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-106_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:49.8100037Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9b8d76c443040b08\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-101_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:29:02.8942844Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9d78e6174e6e69be\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on existing vms_1.4\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMs use password-only authentication for SSH on\ - \ existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-05-12T23:41:51.7770777Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ - }}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9f778de970219a8a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9f778de970219a8a\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for vmss_2.1\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ + Microsoft.Batch/batchAccounts/privateEndpointConnections\",\"existenceCondition\"\ + :{\"field\":\"Microsoft.Batch/batchAccounts/privateEndpointConnections/privateLinkServiceConnectionState.status\"\ + ,\"equals\":\"Approved\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/009a0c92-f5b4-4776-9b66-4ed2b4775563\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"009a0c92-f5b4-4776-9b66-4ed2b4775563\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ only use allowed seccomp profiles\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ + \ only use allowed seccomp profiles in a Kubernetes cluster. This policy is\ + \ generally available for Kubernetes Service (AKS), and preview for AKS Engine\ + \ and Azure Arc enabled Kubernetes. For instructions on using this policy,\ + \ visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"2.0.1\"\ + ,\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit' allows\ + \ a non-compliant resource to be created or updated, but flags it as non-compliant.\ + \ 'Deny' blocks the non-compliant resource creation or update. 'Disabled'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]},\"allowedProfiles\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed seccomp profiles\",\"description\":\"The list\ + \ of seccomp profiles that containers are allowed to use. E.g. 'runtime/default;docker/default'.\ + \ Provide empty list as input to block everything.\"},\"defaultValue\":[]}},\"\ + policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-seccomp-profiles/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-seccomp-profiles/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedProfiles\":\"[parameters('allowedProfiles')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/975ce327-682c-4f2e-aa46-b9598289b86c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"975ce327-682c-4f2e-aa46-b9598289b86c\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pod hostPath volumes\ + \ should only use allowed host paths\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures pod hostPath\ + \ volumes can only use allowed host paths in a Kubernetes Cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]},\"allowedHostPaths\":{\"type\":\"\ + Object\",\"metadata\":{\"displayName\":\"Allowed host paths\",\"description\"\ + :\"The host paths allowed for pod hostPath volumes to use. Provide an empty\ + \ paths list to block all host paths.\",\"schema\":{\"type\":\"object\",\"\ + properties\":{\"paths\":{\"type\":\"array\",\"items\":{\"type\":\"object\"\ + ,\"properties\":{\"pathPrefix\":{\"type\":\"string\"},\"readOnly\":{\"type\"\ + :\"boolean\"}},\"required\":[\"pathPrefix\",\"readOnly\"],\"additionalProperties\"\ + :false}}},\"required\":[\"paths\"],\"additionalProperties\":false}},\"defaultValue\"\ + :{\"paths\":[]}}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS\ + \ Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-host-paths/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-host-paths/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedHostPaths\":\"[parameters('allowedHostPaths').paths]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/098fc59e-46c7-4d99-9b16-64990e543d75\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"098fc59e-46c7-4d99-9b16-64990e543d75\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pods should only use\ + \ allowed volume types\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy ensures pods can only use allowed volume types\ + \ in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]},\"allowedVolumeTypes\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Allowed volume types\",\"description\"\ + :\"The list of volume types that can be used by a pod. Provide empty list\ + \ as input to block everything.\"},\"defaultValue\":[]}},\"policyRule\":{\"\ + if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-volume-types/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-volume-types/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"volumes\":\"[parameters('allowedVolumeTypes')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/16697877-1118-4fb1-9b65-9898ec2509ec\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16697877-1118-4fb1-9b65-9898ec2509ec\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should have the\ + \ specified maximum validity period\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ + \ compliance requirements by specifying the maximum amount of time that a\ + \ certificate can be valid within your key vault.\",\"metadata\":{\"version\"\ + :\"2.1.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ + :{\"maximumValidityInMonths\":{\"type\":\"Integer\",\"metadata\":{\"displayName\"\ + :\"[Preview]: The maximum validity in months\",\"description\":\"The limit\ + \ to how long a certificate may be valid for. Certificates with lengthy validity\ + \ periods aren't best practice.\"},\"defaultValue\":12},\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created, but flags it as\ + \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ + \ the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\"\ + :\"audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.KeyVault.Data/vaults/certificates\"},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/properties.validityInMonths\"\ + ,\"greater\":\"[parameters('maximumValidityInMonths')]\"}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0a075868-4c26-42ef-914c-5bc007359560\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0a075868-4c26-42ef-914c-5bc007359560\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pods and containers\ + \ should only run with approved user and group IDs\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy controls\ + \ the user, primary group, supplemental group and file system group IDs that\ + \ pods and containers can use to run in a Kubernetes Cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]},\"runAsUserRule\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Run as user rule\",\"description\":\"The\ + \ 'RunAsUser' rule that containers are allowed to run with.\"},\"allowedValues\"\ + :[\"MustRunAs\",\"MustRunAsNonRoot\",\"RunAsAny\"],\"defaultValue\":\"MustRunAsNonRoot\"\ + },\"runAsUserRanges\":{\"type\":\"Object\",\"metadata\":{\"displayName\":\"\ + Allowed user ID ranges\",\"description\":\"The user ID ranges that are allowed\ + \ for containers to use.\",\"schema\":{\"type\":\"object\",\"properties\"\ + :{\"ranges\":{\"type\":\"array\",\"items\":{\"type\":\"object\",\"properties\"\ + :{\"min\":{\"type\":\"integer\"},\"max\":{\"type\":\"integer\"}},\"required\"\ + :[\"min\",\"max\"],\"additionalProperties\":false}}},\"required\":[\"ranges\"\ + ],\"additionalProperties\":false}},\"defaultValue\":{\"ranges\":[]}},\"runAsGroupRule\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Run as group rule\"\ + ,\"description\":\"The 'RunAsGroup' rule that containers are allowed to run\ + \ with.\"},\"allowedValues\":[\"MustRunAs\",\"MayRunAs\",\"RunAsAny\"],\"\ + defaultValue\":\"RunAsAny\"},\"runAsGroupRanges\":{\"type\":\"Object\",\"\ + metadata\":{\"displayName\":\"Allowed group ID ranges\",\"description\":\"\ + The group ID ranges that are allowed for containers to use.\",\"schema\":{\"\ + type\":\"object\",\"properties\":{\"ranges\":{\"type\":\"array\",\"items\"\ + :{\"type\":\"object\",\"properties\":{\"min\":{\"type\":\"integer\"},\"max\"\ + :{\"type\":\"integer\"}},\"required\":[\"min\",\"max\"],\"additionalProperties\"\ + :false}}},\"required\":[\"ranges\"],\"additionalProperties\":false}},\"defaultValue\"\ + :{\"ranges\":[]}},\"supplementalGroupsRule\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Supplemental group rule\",\"description\":\"The 'SupplementalGroups'\ + \ rule that containers are allowed to run with.\"},\"allowedValues\":[\"MustRunAs\"\ + ,\"MayRunAs\",\"RunAsAny\"],\"defaultValue\":\"RunAsAny\"},\"supplementalGroupsRanges\"\ + :{\"type\":\"Object\",\"metadata\":{\"displayName\":\"Allowed supplemental\ + \ group ID ranges\",\"description\":\"The supplemental group ID ranges that\ + \ are allowed for containers to use.\",\"schema\":{\"type\":\"object\",\"\ + properties\":{\"ranges\":{\"type\":\"array\",\"items\":{\"type\":\"object\"\ + ,\"properties\":{\"min\":{\"type\":\"integer\"},\"max\":{\"type\":\"integer\"\ + }},\"required\":[\"min\",\"max\"],\"additionalProperties\":false}}},\"required\"\ + :[\"ranges\"],\"additionalProperties\":false}},\"defaultValue\":{\"ranges\"\ + :[]}},\"fsGroupRule\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + File system group rule\",\"description\":\"The 'FSGroup' rule that containers\ + \ are allowed to run with.\"},\"allowedValues\":[\"MustRunAs\",\"MayRunAs\"\ + ,\"RunAsAny\"],\"defaultValue\":\"RunAsAny\"},\"fsGroupRanges\":{\"type\"\ + :\"Object\",\"metadata\":{\"displayName\":\"Allowed file system group ID ranges\"\ + ,\"description\":\"The file system group ranges that are allowed for pods\ + \ to use.\",\"schema\":{\"type\":\"object\",\"properties\":{\"ranges\":{\"\ + type\":\"array\",\"items\":{\"type\":\"object\",\"properties\":{\"min\":{\"\ + type\":\"integer\"},\"max\":{\"type\":\"integer\"}},\"required\":[\"min\"\ + ,\"max\"],\"additionalProperties\":false}}},\"required\":[\"ranges\"],\"additionalProperties\"\ + :false}},\"defaultValue\":{\"ranges\":[]}}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-users-groups/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-users-groups/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"runAsUser\":{\"rule\":\"[parameters('runAsUserRule')]\"\ + ,\"ranges\":\"[parameters('runAsUserRanges').ranges]\"},\"runAsGroup\":{\"\ + rule\":\"[parameters('runAsGroupRule')]\",\"ranges\":\"[parameters('runAsGroupRanges').ranges]\"\ + },\"supplementalGroups\":{\"rule\":\"[parameters('supplementalGroupsRule')]\"\ + ,\"ranges\":\"[parameters('supplementalGroupsRanges').ranges]\"},\"fsGroup\"\ + :{\"rule\":\"[parameters('fsGroupRule')]\",\"ranges\":\"[parameters('fsGroupRanges').ranges]\"\ + },\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/f06ddb64-5fa3-4b77-b166-acb36f7f6042\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f06ddb64-5fa3-4b77-b166-acb36f7f6042\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Kubernetes clusters should\ + \ disable automounting API credentials\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"Disable automounting API\ + \ credentials to prevent a potentially compromised Pod resource to run API\ + \ commands against Kubernetes clusters. For instructions on using this policy,\ + \ please go to https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"\ + 1.0.0-preview\",\"category\":\"Kubernetes\",\"preview\":true},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"'Audit' allows a non-compliant resource to be\ + \ created or updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Namespace\ + \ exclusions\",\"description\":\"List of Kubernetes namespaces to exclude\ + \ from policy evaluation.\"},\"defaultValue\":[\"kube-system\",\"gatekeeper-system\"\ + ,\"azure-arc\"]},\"namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Namespace inclusions\",\"description\":\"List of Kubernetes\ + \ namespaces to only include in policy evaluation. An empty list means the\ + \ policy is applied to all resources in all namespaces.\"},\"defaultValue\"\ + :[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"\ + Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-automount-token/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-automount-token/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/423dd1ba-798e-40e4-9c4d-b6902674b423\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"423dd1ba-798e-40e4-9c4d-b6902674b423\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ only use allowed ProcMountType\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ + \ only use allowed ProcMountType in a Kubernetes cluster. This policy is generally\ + \ available for Kubernetes Service (AKS), and preview for AKS Engine and Azure\ + \ Arc enabled Kubernetes. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"3.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]},\"procMountType\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"ProcMountType\",\"description\":\"\ + The ProcMountType that containers are allowed to use in the cluster.\"},\"\ + allowedValues\":[\"Unmasked\",\"Default\"],\"defaultValue\":\"Default\"}},\"\ + policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-proc-mount-types/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-proc-mount-types/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"procMount\":\"[parameters('procMountType')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/f85eb0dd-92ee-40e9-8a76-db25a507d6d3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f85eb0dd-92ee-40e9-8a76-db25a507d6d3\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Key Vault keys should have\ + \ an expiration date\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Cryptographic keys should have a defined expiration date\ + \ and not be permanent. Keys that are valid forever provide a potential attacker\ + \ with more time to compromise the key. It is a recommended security practice\ + \ to set expiration dates on cryptographic keys.\",\"metadata\":{\"version\"\ + :\"1.0.1-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"'Audit' allows a non-compliant resource to be\ + \ created, but flags it as non-compliant. 'Deny' blocks the resource creation.\ + \ 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\"\ + ,\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"},{\"\ + field\":\"Microsoft.KeyVault.Data/vaults/keys/attributes.expiresOn\",\"exists\"\ + :false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/152b15f7-8e1f-4c1f-ab71-8c010ba5dbc0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"152b15f7-8e1f-4c1f-ab71-8c010ba5dbc0\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Key Vault secrets should have\ + \ an expiration date\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Secrets should have a defined expiration date and not be\ + \ permanent. Secrets that are valid forever provide a potential attacker with\ + \ more time to compromise them. It is a recommended security practice to set\ + \ expiration dates on secrets.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ + ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created, but flags it as\ + \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ + \ the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ + :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.KeyVault.Data/vaults/secrets\"},{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn\"\ + ,\"exists\":false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/98728c90-32c7-4049-8429-847dc0f4fe37\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"98728c90-32c7-4049-8429-847dc0f4fe37\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Kubernetes clusters should\ + \ not use the default namespace\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"Prevent usage of the default namespace in Kubernetes clusters\ + \ to protect against unauthorized access for ConfigMap, Pod, Secret, Service,\ + \ and ServiceAccount resource types. For instructions on using this policy,\ + \ please go to https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"\ + 1.0.0-preview\",\"category\":\"Kubernetes\",\"preview\":true},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"'Audit' allows a non-compliant resource to be\ + \ created or updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Namespace\ + \ exclusions\",\"description\":\"List of Kubernetes namespaces to exclude\ + \ from policy evaluation.\"},\"defaultValue\":[\"kube-system\",\"gatekeeper-system\"\ + ,\"azure-arc\"]},\"namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Namespace inclusions\",\"description\":\"List of Kubernetes\ + \ namespaces to only include in policy evaluation. An empty list means the\ + \ policy is applied to all resources in all namespaces.\"},\"defaultValue\"\ + :[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"\ + Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-default-namespace/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-default-namespace/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/9f061a12-e40d-4183-a00e-171812443373\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"9f061a12-e40d-4183-a00e-171812443373\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ not share host process ID or host IPC namespace\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy blocks\ + \ pod containers from sharing the host process ID namespace and host IPC namespace\ + \ in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc/.\"\ + ,\"metadata\":{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-host-namespace/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/block-host-namespace/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/47a1ee2f-2a2a-4576-bf2a-e0e36709c2b8\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"47a1ee2f-2a2a-4576-bf2a-e0e36709c2b8\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ only use allowed capabilities\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy ensures containers only use allowed capabilities\ + \ in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]},\"allowedCapabilities\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Allowed capabilities\",\"description\"\ + :\"The list of capabilities that are allowed to be added to a container. Provide\ + \ empty list as input to block everything.\"},\"defaultValue\":[]},\"requiredDropCapabilities\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Required drop capabilities\"\ + ,\"description\":\"The list of capabilities that must be dropped by a container.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-capabilities/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-capabilities/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedCapabilities\":\"[parameters('allowedCapabilities')]\"\ + ,\"requiredDropCapabilities\":\"[parameters('requiredDropCapabilities')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/c26596ff-4d70-4e6a-9a30-c2506bd2f80c\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c26596ff-4d70-4e6a-9a30-c2506bd2f80c\"\ + },{\"properties\":{\"displayName\":\"Ensure only allowed container images\ + \ in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy ensures only allowed container images are running\ + \ in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"allowedContainerImagesRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Allowed container images regex\",\"description\":\"The RegEx rule used\ + \ to match allowed container images in a Kubernetes cluster. For example,\ + \ to allow any Azure Container Registry image by matching partial path: ^.+azurecr.io/.+$\"\ + }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-images/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-images/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedContainerImagesRegex\"\ + :\"[parameters('allowedContainerImagesRegex')]\",\"excludedNamespaces\":\"\ + [parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/febd0533-8e55-448f-b837-bd0e06f16469\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"febd0533-8e55-448f-b837-bd0e06f16469\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ only use allowed AppArmor profiles\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ + \ only use allowed AppArmor profiles in a Kubernetes cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]},\"allowedProfiles\":{\"type\":\"\ + Array\",\"metadata\":{\"displayName\":\"Allowed AppArmor profiles\",\"description\"\ + :\"The list of AppArmor profiles that containers are allowed to use. E.g.\ + \ 'runtime/default;docker/default'. Provide empty list as input to block everything.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/enforce-apparmor-profile/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/enforce-apparmor-profile/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedProfiles\":\"[parameters('allowedProfiles')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/511f5417-5d12-434d-ab2e-816901e72a5e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"511f5417-5d12-434d-ab2e-816901e72a5e\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Kubernetes clusters should\ + \ not use specific security capabilities\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"Prevent specific security\ + \ capabilities in Kubernetes clusters to prevent ungranted privileges on the\ + \ Pod resource. For instructions on using this policy, please visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Kubernetes\",\"\ + preview\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created or updated, but flags it as non-compliant.\ + \ 'Deny' blocks the non-compliant resource creation or update. 'Disabled'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"[Preview]: Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]},\"disallowedCapabilities\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Blocked capabilities\"\ + ,\"description\":\"List of capabilities that containers are not able to use\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-disallowed-capabilities/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-disallowed-capabilities/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + ,\"disallowedCapabilities\":\"[parameters('disallowedCapabilities')]\"}}}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/a27c700f-8a22-44ec-961c-41625264370b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a27c700f-8a22-44ec-961c-41625264370b\"\ + },{\"properties\":{\"displayName\":\"Ensure container CPU and memory resource\ + \ limits do not exceed the specified limits in Kubernetes cluster\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This\ + \ policy ensures container CPU and memory resource limits are defined and\ + \ do not exceed the specified limits in a Kubernetes cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"cpuLimit\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Max allowed CPU units\",\"description\"\ + :\"The maximum CPU units allowed for a container. E.g. 200m. For more information,\ + \ please refer https://aka.ms/k8s-policy-pod-limits\"}},\"memoryLimit\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Max allowed memory bytes\"\ + ,\"description\":\"The maximum memory bytes allowed for a container. E.g.\ + \ 1Gi. For more information, please refer https://aka.ms/k8s-policy-pod-limits\"\ + }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-resource-limits/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-resource-limits/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"cpuLimit\":\"[parameters('cpuLimit')]\"\ + ,\"memoryLimit\":\"[parameters('memoryLimit')]\",\"excludedNamespaces\":\"\ + [parameters('excludedNamespaces')]\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e345eecc-fa47-480f-9e88-67dcc122b164\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e345eecc-fa47-480f-9e88-67dcc122b164\"\ + },{\"properties\":{\"displayName\":\"Do not allow privileged containers in\ + \ Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy does not allow privileged containers creation\ + \ in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/95edb821-ddaf-4404-9732-666045e056b4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"95edb821-ddaf-4404-9732-666045e056b4\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pod FlexVolume volumes\ + \ should only use allowed drivers\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures pod FlexVolume\ + \ volumes only use allowed drivers in a Kubernetes cluster. This policy is\ + \ generally available for Kubernetes Service (AKS), and preview for AKS Engine\ + \ and Azure Arc enabled Kubernetes. For instructions on using this policy,\ + \ visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\":\"2.0.1\"\ + ,\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit' allows\ + \ a non-compliant resource to be created or updated, but flags it as non-compliant.\ + \ 'Deny' blocks the non-compliant resource creation or update. 'Disabled'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]},\"allowedFlexVolumeDrivers\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Allowed FlexVolume drivers\",\"description\"\ + :\"The list of drivers that FlexVolume volumes are allowed to use. Provide\ + \ empty list as input to block everything.\"},\"defaultValue\":[]}},\"policyRule\"\ + :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/flexvolume-drivers/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/flexvolume-drivers/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedFlexVolumeDrivers\":\"\ + [parameters('allowedFlexVolumeDrivers')]\",\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f4a8fce0-2dd5-4c21-9a36-8f0ec809d663\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f4a8fce0-2dd5-4c21-9a36-8f0ec809d663\"\ + },{\"properties\":{\"displayName\":\"Ensure containers listen only on allowed\ + \ ports in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy enforces containers to listen only on allowed\ + \ ports in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"allowedContainerPortsList\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed container ports list\",\"description\":\"The list of container\ + \ ports allowed in a Kubernetes cluster.\"}},\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit' allows\ + \ a non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-ports/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-allowed-ports/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedContainerPorts\":\"[parameters('allowedContainerPortsList')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/440b515e-a580-421e-abeb-b159a61ddcbc\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"440b515e-a580-421e-abeb-b159a61ddcbc\"\ + },{\"properties\":{\"displayName\":\"Kubernetes clusters should not allow\ + \ container privilege escalation\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Microsoft.Kubernetes.Data\",\"description\":\"This policy does not allow containers\ + \ to use privilege escalation in a Kubernetes cluster. This policy is generally\ + \ available for Kubernetes Service (AKS), and preview for AKS Engine and Azure\ + \ Arc enabled Kubernetes. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created or\ + \ updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege-escalation/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-no-privilege-escalation/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1c6e92c9-99f0-4e55-9cf2-0c234dc48f99\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1c6e92c9-99f0-4e55-9cf2-0c234dc48f99\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ not use forbidden sysctl interfaces\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ + \ do not use forbidden sysctl interfaces in a Kubernetes cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"3.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]},\"forbiddenSysctls\":{\"type\":\"\ + Array\",\"metadata\":{\"displayName\":\"Forbidden sysctls\",\"description\"\ + :\"The list of plain sysctl names or sysctl patterns which end with *. The\ + \ string * matches all sysctls. For more information, visit https://aka.ms/k8s-policy-sysctl-interfaces.\"\ + }}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/forbidden-sysctl-interfaces/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/forbidden-sysctl-interfaces/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"forbiddenSysctls\":\"[parameters('forbiddenSysctls')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/56d0a13f-712f-466b-8416-56fb354fb823\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"56d0a13f-712f-466b-8416-56fb354fb823\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pods should only use\ + \ approved host network and port range\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy controls pod\ + \ access to the host network and the allowable host port range in a Kubernetes\ + \ cluster. This policy is generally available for Kubernetes Service (AKS),\ + \ and preview for AKS Engine and Azure Arc enabled Kubernetes. For instructions\ + \ on using this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\"\ + :{\"version\":\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created or updated, but flags\ + \ it as non-compliant. 'Deny' blocks the non-compliant resource creation or\ + \ update. 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\"\ + ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]},\"allowHostNetwork\":{\"type\"\ + :\"Boolean\",\"metadata\":{\"displayName\":\"Allow host network usage\",\"\ + description\":\"Set this value to true if pod is allowed to use host network\ + \ otherwise false.\"},\"defaultValue\":false},\"minPort\":{\"type\":\"Integer\"\ + ,\"metadata\":{\"displayName\":\"Min host port\",\"description\":\"The minimum\ + \ value in the allowable host port range that pods can use in the host network\ + \ namespace.\"},\"defaultValue\":0},\"maxPort\":{\"type\":\"Integer\",\"metadata\"\ + :{\"displayName\":\"Max host port\",\"description\":\"The maximum value in\ + \ the allowable host port range that pods can use in the host network namespace.\"\ + },\"defaultValue\":0}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ + AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/host-network-ports/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/host-network-ports/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowHostNetwork\":\"[parameters('allowHostNetwork')]\"\ + ,\"minPort\":\"[parameters('minPort')]\",\"maxPort\":\"[parameters('maxPort')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/82985f06-dc18-4a48-bc1c-b9f4f0098cfe\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82985f06-dc18-4a48-bc1c-b9f4f0098cfe\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce unique ingress\ + \ hostnames across namespaces in Kubernetes cluster\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy enforces\ + \ unique ingress hostnames across namespaces in a Kubernetes cluster. For\ + \ instructions on using this policy, please go to https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"4.0.1-deprecated\",\"category\":\"Kubernetes\"\ + ,\"deprecated\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"'Audit' allows\ + \ a non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Deprecated]: Namespace\ + \ exclusions\",\"description\":\"List of Kubernetes namespaces to exclude\ + \ from policy evaluation.\"},\"defaultValue\":[\"kube-system\",\"gatekeeper-system\"\ + ,\"azure-arc\"]},\"namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Namespace inclusions\",\"description\":\"List of Kubernetes\ + \ namespaces to only include in policy evaluation. An empty list means the\ + \ policy is applied to all resources in all namespaces.\"},\"defaultValue\"\ + :[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"\ + Microsoft.Kubernetes/connectedClusters\"]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-hostnames-conflict/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-hostnames-conflict/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b2fd3e59-6390-4f2b-8247-ea676bd03e2d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b2fd3e59-6390-4f2b-8247-ea676bd03e2d\"\ + },{\"properties\":{\"displayName\":\"Kubernetes clusters should be accessible\ + \ only over HTTPS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"Use of HTTPS ensures authentication and protects data in\ + \ transit from network layer eavesdropping attacks. This capability is currently\ + \ generally available for Kubernetes Service (AKS), and in preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For more info, visit https://aka.ms/kubepolicydoc\"\ + ,\"metadata\":{\"version\":\"5.0.2\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-https-only/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/ingress-https-only/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1a5b4dca-0b6f-4cf5-907c-56316bc1bf3d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1a5b4dca-0b6f-4cf5-907c-56316bc1bf3d\"\ + },{\"properties\":{\"displayName\":\"Enforce internal load balancers in Kubernetes\ + \ cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy enforces load balancers do not have public\ + \ IPs in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"\ + ],\"defaultValue\":\"deny\"},\"excludedNamespaces\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"Namespace exclusions\",\"description\":\"List\ + \ of Kubernetes namespaces to exclude from policy evaluation.\"},\"defaultValue\"\ + :[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\",\"\ + description\":\"List of Kubernetes namespaces to only include in policy evaluation.\ + \ An empty list means the policy is applied to all resources in all namespaces.\"\ + },\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\"\ + :[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/load-balancer-no-public-ips/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/load-balancer-no-public-ips/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3fc4dc25-5baf-40d8-9b05-7fe74c1bc64e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3fc4dc25-5baf-40d8-9b05-7fe74c1bc64e\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster pods and containers\ + \ should only use allowed SELinux options\",\"policyType\":\"BuiltIn\",\"\ + mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures\ + \ pods and containers only use allowed SELinux options in a Kubernetes cluster.\ + \ This policy is generally available for Kubernetes Service (AKS), and preview\ + \ for AKS Engine and Azure Arc enabled Kubernetes. For instructions on using\ + \ this policy, visit https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"3.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]},\"allowedSELinuxOptions\":{\"type\"\ + :\"Object\",\"metadata\":{\"displayName\":\"Allowed SELinux options\",\"description\"\ + :\"The allowed configurations for pod and container level SELinux Options.\ + \ Provide empty options list as input to block everything.\",\"schema\":{\"\ + type\":\"object\",\"properties\":{\"options\":{\"type\":\"array\",\"items\"\ + :{\"type\":\"object\",\"properties\":{\"level\":{\"type\":\"string\"},\"role\"\ + :{\"type\":\"string\"},\"type\":{\"type\":\"string\"},\"user\":{\"type\":\"\ + string\"}},\"additionalProperties\":false}}},\"required\":[\"options\"],\"\ + additionalProperties\":false}},\"defaultValue\":{\"options\":[]}}},\"policyRule\"\ + :{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/selinux/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/selinux/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + ,\"allowedSELinuxOptions\":\"[parameters('allowedSELinuxOptions').options]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e1e6c427-07d9-46ab-9689-bfa85431e636\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e1e6c427-07d9-46ab-9689-bfa85431e636\"\ + },{\"properties\":{\"displayName\":\"Enforce labels on pods in Kubernetes\ + \ cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy enforces the specified labels are provided\ + \ for pods in a Kubernetes cluster. This policy is generally available for\ + \ Kubernetes Service (AKS), and preview for AKS Engine and Azure Arc enabled\ + \ Kubernetes. For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"labelsList\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"List\ + \ of labels\",\"description\":\"The list of labels to be specified on Pods\ + \ in a Kubernetes cluster.\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"'Audit' allows a non-compliant\ + \ resource to be created, but flags it as non-compliant. 'Deny' blocks the\ + \ resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/pod-enforce-labels/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/pod-enforce-labels/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"labels\":\"[parameters('labelsList')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/46592696-4c7b-4bf3-9e45-6c2763bdc0a6\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"46592696-4c7b-4bf3-9e45-6c2763bdc0a6\"\ + },{\"properties\":{\"displayName\":\"Ensure services listen only on allowed\ + \ ports in Kubernetes cluster\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.Kubernetes.Data\"\ + ,\"description\":\"This policy enforces services to listen only on allowed\ + \ ports in a Kubernetes cluster. This policy is generally available for Kubernetes\ + \ Service (AKS), and preview for AKS Engine and Azure Arc enabled Kubernetes.\ + \ For instructions on using this policy, visit https://aka.ms/kubepolicydoc.\"\ + ,\"metadata\":{\"version\":\"5.0.1\",\"category\":\"Kubernetes\"},\"parameters\"\ + :{\"allowedServicePortsList\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed service ports list\",\"description\":\"The list of service ports\ + \ allowed in a Kubernetes cluster.\"}},\"effect\":{\"type\":\"String\",\"\ + metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"deny\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to exclude from policy evaluation.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace\ + \ inclusions\",\"description\":\"List of Kubernetes namespaces to only include\ + \ in policy evaluation. An empty list means the policy is applied to all resources\ + \ in all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/service-allowed-ports/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/service-allowed-ports/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"allowedServicePorts\":\"[parameters('allowedServicePortsList')]\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/233a2a17-77ca-4fb1-9b6b-69223d272a44\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"233a2a17-77ca-4fb1-9b6b-69223d272a44\"\ + },{\"properties\":{\"displayName\":\"Kubernetes cluster containers should\ + \ run with a read only root file system\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"This policy ensures containers\ + \ run with a read only root file system in a Kubernetes cluster. This policy\ + \ is generally available for Kubernetes Service (AKS), and preview for AKS\ + \ Engine and Azure Arc enabled Kubernetes. For instructions on using this\ + \ policy, visit https://aka.ms/kubepolicydoc/.\",\"metadata\":{\"version\"\ + :\"2.0.1\",\"category\":\"Kubernetes\"},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created or updated, but flags it as\ + \ non-compliant. 'Deny' blocks the non-compliant resource creation or update.\ + \ 'Disabled' turns off the policy.\"},\"allowedValues\":[\"audit\",\"deny\"\ + ,\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Namespace exclusions\",\"description\"\ + :\"List of Kubernetes namespaces to exclude from policy evaluation.\"},\"\ + defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Namespace inclusions\"\ + ,\"description\":\"List of Kubernetes namespaces to only include in policy\ + \ evaluation. An empty list means the policy is applied to all resources in\ + \ all namespaces.\"},\"defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\"\ + :\"type\",\"in\":[\"AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\"\ + ,\"Microsoft.ContainerService/managedClusters\"]},\"then\":{\"effect\":\"\ + [parameters('effect')]\",\"details\":{\"constraintTemplate\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/read-only-root-filesystem/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/read-only-root-filesystem/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/df49d893-a74c-421d-bc95-c663042e5b80\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"df49d893-a74c-421d-bc95-c663042e5b80\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce internal load balancers\ + \ in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy enforces load balancers do not have public\ + \ IPs in an Azure Kubernetes Service cluster. This policy is deprecated, please\ + \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ + \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ + :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"\ + description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ + :\"LoadBalancersInternal\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/loadbalancer-no-publicips/limited-preview/gatekeeperpolicy.rego\"\ + }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a74d8f00-2fd9-4ce4-968e-0ee1eb821698\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a74d8f00-2fd9-4ce4-968e-0ee1eb821698\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Do not allow privileged\ + \ containers in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy does not allow privileged containers creation\ + \ in an Azure Kubernetes Service cluster. This policy is deprecated, please\ + \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ + \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ + :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"effect\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Effect\",\"\ + description\":\"Enable or disable the execution of the policy\"},\"allowedValues\"\ + :[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"\ + }},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ + :\"ContainerNoPrivilege\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-no-privilege/limited-preview/gatekeeperpolicy.rego\"\ + }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/7ce7ac02-a5c6-45d6-8d1b-844feb1c1531\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7ce7ac02-a5c6-45d6-8d1b-844feb1c1531\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure CPU and memory resource\ + \ limits defined on containers in AKS\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.ContainerService.Data\",\"description\":\"This policy ensures\ + \ CPU and memory resource limits are defined on containers in an Azure Kubernetes\ + \ Service cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ + \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ + :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ + defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ + type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ + :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"ContainerResourceLimits\"\ + ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-resource-limits/limited-preview/gatekeeperpolicy.rego\"\ + }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a2d3ed81-8d11-4079-80a5-1faadc0024f4\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a2d3ed81-8d11-4079-80a5-1faadc0024f4\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce labels on pods\ + \ in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy enforces the specified labels are provided\ + \ for pods in an Azure Kubernetes Service cluster. This policy is deprecated,\ + \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ + \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ + category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ + commaSeparatedListOfLabels\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Comma-separated list of labels\",\"description\":\"A comma-separated\ + \ list of labels to be specified on Pods in Kubernetes cluster. E.g. test1,test2\"\ + }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]:\ + \ Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"defaultValue\"\ + :\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"type\",\"equals\"\ + :\"Microsoft.ContainerService/managedClusters\"},\"then\":{\"effect\":\"[parameters('effect')]\"\ + ,\"details\":{\"policyId\":\"PodEnforceLabels\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/pod-enforce-labels/limited-preview/gatekeeperpolicy.rego\"\ + ,\"policyParameters\":{\"commaSeparatedListOfLabels\":\"[parameters('commaSeparatedListOfLabels')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/16c6ca72-89d2-4798-b87e-496f9de7fcb7\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"16c6ca72-89d2-4798-b87e-496f9de7fcb7\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce HTTPS ingress in\ + \ AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy enforces HTTPS ingress in an Azure Kubernetes\ + \ Service cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ + \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ + :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ + defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ + type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ + :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"HttpsIngressOnly\"\ + ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/ingress-https-only/limited-preview/gatekeeperpolicy.rego\"\ + }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/2fbff515-eecc-4b7e-9b63-fcc7138b7dc3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2fbff515-eecc-4b7e-9b63-fcc7138b7dc3\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure only allowed container\ + \ images in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy ensures only allowed container images are running\ + \ in an Azure Kubernetes Service cluster. This policy is deprecated, please\ + \ visit https://aka.ms/kubepolicydoc for instructions on using new Kubernetes\ + \ policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"category\"\ + :\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"allowedContainerImagesRegex\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Deprecated]: Allowed\ + \ container images regex\",\"description\":\"Regex representing container\ + \ images allowed in Kubernetes cluster. E.g. Regex of azure container registry\ + \ images is ^.+azurecr.io/.+$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ + ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ + if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ + :\"ContainerAllowedImages\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-allowed-images/limited-preview/gatekeeperpolicy.rego\"\ + ,\"policyParameters\":{\"allowedContainerImagesRegex\":\"[parameters('allowedContainerImagesRegex')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5f86cb6e-c4da-441b-807c-44bd0cc14e66\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5f86cb6e-c4da-441b-807c-44bd0cc14e66\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Enforce unique ingress\ + \ hostnames across namespaces in AKS\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.ContainerService.Data\",\"description\":\"This policy enforces\ + \ unique ingress hostnames across namespaces in an Azure Kubernetes Service\ + \ cluster. This policy is deprecated, please visit https://aka.ms/kubepolicydoc\ + \ for instructions on using new Kubernetes policies.\",\"metadata\":{\"version\"\ + :\"1.0.1-deprecated\",\"category\":\"Kubernetes service\",\"deprecated\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Effect\",\"description\":\"Enable or disable the execution\ + \ of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\",\"Disabled\"],\"\ + defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"if\":{\"field\":\"\ + type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"},\"then\"\ + :{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\":\"UniqueIngressHostnames\"\ + ,\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/ingress-hostnames-conflict/limited-preview/gatekeeperpolicy.rego\"\ + }}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d011d9f7-ba32-4005-b727-b3d09371ca60\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d011d9f7-ba32-4005-b727-b3d09371ca60\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure containers listen\ + \ only on allowed ports in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy enforces containers to listen only on allowed\ + \ ports in an Azure Kubernetes Service cluster. This policy is deprecated,\ + \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ + \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ + category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ + allowedContainerPortsRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Allowed container ports regex\",\"description\":\"Regex representing\ + \ container ports allowed in Kubernetes cluster. E.g. Regex for allowing ports\ + \ 443,446 is ^(443|446)$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ + ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ + if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ + :\"ContainerAllowedPorts\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/container-allowed-ports/limited-preview/gatekeeperpolicy.rego\"\ + ,\"policyParameters\":{\"allowedContainerPortsRegex\":\"[parameters('allowedContainerPortsRegex')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/0f636243-1b1c-4d50-880f-310f6199f2cb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"0f636243-1b1c-4d50-880f-310f6199f2cb\"\ + },{\"properties\":{\"displayName\":\"[Deprecated]: Ensure services listen\ + \ only on allowed ports in AKS\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.ContainerService.Data\"\ + ,\"description\":\"This policy enforces services to listen only on allowed\ + \ ports in an Azure Kubernetes Service cluster. This policy is deprecated,\ + \ please visit https://aka.ms/kubepolicydoc for instructions on using new\ + \ Kubernetes policies.\",\"metadata\":{\"version\":\"1.0.1-deprecated\",\"\ + category\":\"Kubernetes service\",\"deprecated\":true},\"parameters\":{\"\ + allowedServicePortsRegex\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Deprecated]: Allowed service ports regex\",\"description\":\"Regex representing\ + \ service ports allowed in Kubernetes cluster. E.g. Regex for allowing ports\ + \ 443,446 is ^(443|446)$\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Deprecated]: Effect\",\"description\":\"Enable or disable\ + \ the execution of the policy\"},\"allowedValues\":[\"EnforceRegoPolicy\"\ + ,\"Disabled\"],\"defaultValue\":\"EnforceRegoPolicy\"}},\"policyRule\":{\"\ + if\":{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"policyId\"\ + :\"ServiceAllowedPorts\",\"policy\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/KubernetesService/service-allowed-ports/limited-preview/gatekeeperpolicy.rego\"\ + ,\"policyParameters\":{\"allowedServicePortsRegex\":\"[parameters('allowedServicePortsRegex')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/25dee3db-6ce0-4c02-ab5d-245887b24077\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"25dee3db-6ce0-4c02-ab5d-245887b24077\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed registries\ + \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\"This\ + \ policy helps provide registries that are allowed in specified Azure Machine\ + \ Learning computes and can be assigned at the workspace. For more information,\ + \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ + ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ + \ where Azure ML jobs run\",\"description\":\"List of compute names where\ + \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ + \ is provided to this parameter then policy is applicable to all computes.\"\ + },\"defaultValue\":[]},\"allowedACRs\":{\"type\":\"Array\",\"metadata\":{\"\ + displayName\":\"[Preview]: Azure Container Registries\",\"description\":\"\ + List of Azure Container Registries that can be used with Azure ML. Ex. amlrepo.azurecr.io;amlrepo.azurecr.io/foo\"\ + },\"defaultValue\":[]},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ + \ the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\"\ + :\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"allowedACRs\",\"value\":\"[parameters('allowedACRs')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5853517a-63de-11ea-bc55-0242ac130003\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5853517a-63de-11ea-bc55-0242ac130003\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed module authors\ + \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\"This\ + \ policy helps provide allowed module authors in specified Azure Machine Learning\ + \ computes and can be assigned at the workspace. For more information, visit\ + \ https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.1-preview\"\ + ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ + \ where Azure ML jobs run\",\"description\":\"List of compute names where\ + \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ + \ is provided to this parameter then policy is applicable to all computes.\"\ + },\"defaultValue\":[]},\"allowedModuleAuthors\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Allowed module authors\",\"description\":\"\ + List of allowed module authors.\"},\"defaultValue\":[]},\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ + :\"Enable or disable the execution of the policy.\"},\"allowedValues\":[\"\ + enforceSetting\",\"disabled\"],\"defaultValue\":\"enforceSetting\"}},\"policyRule\"\ + :{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"allowedModuleAuthors\",\"value\":\"[parameters('allowedModuleAuthors')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/53c70b02-63dd-11ea-bc55-0242ac130003\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"53c70b02-63dd-11ea-bc55-0242ac130003\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure allowed Python packages\ + \ for specified Azure Machine Learning computes\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\":\" This\ + \ policy helps provide allowed Python packages in specified Azure Machine\ + \ Learning computes and can be assigned at the workspace. For more information,\ + \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ + ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ + \ where Azure ML jobs run\",\"description\":\"List of compute names where\ + \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ + \ is provided to this parameter then policy is applicable to all computes.\"\ + },\"defaultValue\":[]},\"allowedPythonPackageChannels\":{\"type\":\"Array\"\ + ,\"metadata\":{\"displayName\":\"[Preview]: Allowed Python package indexes\"\ + ,\"description\":\"List of allowed Python package indexes. Ex. http://somepythonindex.org\ + \ \"},\"defaultValue\":[]},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"[Preview]: Effect\",\"description\":\"Enable or disable the\ + \ execution of the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"\ + ],\"defaultValue\":\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\"\ + :[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"allowedPythonPackageChannels\",\"value\":\"[parameters('allowedPythonPackageChannels')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/77eeea86-7e81-4a7d-9067-de844d096752\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"77eeea86-7e81-4a7d-9067-de844d096752\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure log filter expressions\ + \ and datastore to be used for full logs for specified Azure Machine Learning\ + \ computes\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\"\ + ,\"description\":\"This policy helps provide log filter expression and datastore\ + \ to be used for full logs in specified Azure Machine Learning computes and\ + \ can be assigned at the workspace. For more information, visit https://aka.ms/amlpolicydoc.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Machine Learning\"\ + ,\"preview\":true},\"parameters\":{\"computeNames\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"[Preview]: Compute names where Azure ML jobs\ + \ run\",\"description\":\"List of compute names where this policy should be\ + \ applied. Ex. cpu-cluster;gpu-cluster. If no value is provided to this parameter\ + \ then policy is applicable to all computes.\"},\"defaultValue\":[]},\"logFilters\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Log filter\ + \ expressions\",\"description\":\"List of log filter expressions used to filter\ + \ logs. Ex. ^prefix1.*$\"},\"defaultValue\":[]},\"datastore\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"[Preview]: Datastore\",\"description\"\ + :\"Datastore used to store filtered logs. Ex. LogsDatastore which is configured\ + \ in AML.\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"Enable or disable the execution of\ + \ the policy.\"},\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\"\ + :\"enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"logFilter\",\"value\":{\"filters\":\"[parameters('logFilters')]\"\ + ,\"datastore\":\"[parameters('datastore')]\"}}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1d413020-63de-11ea-bc55-0242ac130003\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1d413020-63de-11ea-bc55-0242ac130003\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure an approval endpoint\ + \ called prior to jobs running for specified Azure Machine Learning computes\"\ + ,\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\"\ + ,\"description\":\"This policy helps configure an approval endpoint called\ + \ prior to jobs running for specified Azure Machine Learning computes and\ + \ can be assigned at the workspace. For more information. For more information,\ + \ visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ + ,\"category\":\"Machine Learning\",\"preview\":true},\"parameters\":{\"computeNames\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Compute names\ + \ where Azure ML jobs run\",\"description\":\"List of compute names where\ + \ this policy should be applied. Ex. cpu-cluster;gpu-cluster. If no value\ + \ is provided to this parameter then policy is applicable to all computes.\"\ + },\"defaultValue\":[]},\"approvalEndpoint\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Approval endpoint\",\"description\":\"Approval\ + \ endpoint that needs to be called before an Azure ML job is run. Ex. http://amlrunapproval/approve\"\ + }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"Enable or disable the execution of the policy.\"\ + },\"allowedValues\":[\"enforceSetting\",\"disabled\"],\"defaultValue\":\"\ + enforceSetting\"}},\"policyRule\":{\"if\":{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"approvalEndpoint\",\"value\":\"[parameters('approvalEndpoint')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/3948394e-63de-11ea-bc55-0242ac130003\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3948394e-63de-11ea-bc55-0242ac130003\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Configure code signing for\ + \ training code for specified Azure Machine Learning computes\",\"policyType\"\ + :\"BuiltIn\",\"mode\":\"Microsoft.MachineLearningServices.Data\",\"description\"\ + :\"This policy helps provide code signing for training code in specified Azure\ + \ Machine Learning computes and can be assigned at the workspace. For more\ + \ information, visit https://aka.ms/amlpolicydoc.\",\"metadata\":{\"version\"\ + :\"1.0.0-preview\",\"category\":\"Machine Learning\",\"preview\":true},\"\ + parameters\":{\"computeNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Compute names where Azure Machine Learning jobs run\",\"description\"\ + :\"List of compute names where this policy should be applied. Example: 'cpu-cluster;gpu-cluster'.\ + \ If no value is provided to this parameter, policy is applicable to all computes.\"\ + },\"defaultValue\":[]},\"signingKey\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"[Preview]: PGP public key\",\"description\":\"Public key text\ + \ in PGP public key format, with newline characters encoded as string literals\ + \ \\\"\\\\r\\\" and \\\"\\\\n\\\".\"}},\"effect\":{\"type\":\"String\",\"\ + metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy.\"},\"allowedValues\":[\"enforceSetting\"\ + ,\"disabled\"],\"defaultValue\":\"enforceSetting\"}},\"policyRule\":{\"if\"\ + :{\"anyOf\":[{\"field\":\"Microsoft.MachineLearningServices.Data/workspaces/computes/name\"\ + ,\"in\":\"[parameters('computeNames')]\"},{\"value\":\"[length(parameters('computeNames'))]\"\ + ,\"equals\":0}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"setting\":{\"name\":\"signingKey\",\"value\":\"[parameters('signingKey')]\"\ + }}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/6a6f7384-63de-11ea-bc55-0242ac130003\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6a6f7384-63de-11ea-bc55-0242ac130003\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates using elliptic\ + \ curve cryptography should have allowed curve names\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage the allowed\ + \ elliptic curve names for ECC Certificates stored in key vault. More information\ + \ can be found at https://aka.ms/akvpolicy.\",\"metadata\":{\"version\":\"\ + 2.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ + :{\"allowedECNames\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ + [Preview]: Allowed elliptic curve names\",\"description\":\"The list of allowed\ + \ curve names for elliptic curve cryptography certificates.\"},\"allowedValues\"\ + :[\"P-256\",\"P-256K\",\"P-384\",\"P-521\"],\"defaultValue\":[\"P-256\",\"\ + P-256K\",\"P-384\",\"P-521\"]},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ + ,\"in\":[\"EC\",\"EC-HSM\"]},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.ellipticCurveName\"\ + ,\"notIn\":\"[parameters('allowedECNames')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/bd78111f-4953-4367-9fd5-7e08808b54bf\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bd78111f-4953-4367-9fd5-7e08808b54bf\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should use allowed\ + \ key types\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Manage your organizational compliance requirements by restricting\ + \ the key types allowed for certificates.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ + ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"allowedKeyTypes\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Allowed key\ + \ types\",\"description\":\"The list of allowed certificate key types.\"},\"\ + allowedValues\":[\"RSA\",\"RSA-HSM\",\"EC\",\"EC-HSM\"],\"defaultValue\":[\"\ + RSA\",\"RSA-HSM\"]},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ + \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ + \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"audit\"\ + ,\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ + ,\"notIn\":\"[parameters('allowedKeyTypes')]\"}]},\"then\":{\"effect\":\"\ + [parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/1151cede-290b-4ba0-8b38-0ad145ac888f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1151cede-290b-4ba0-8b38-0ad145ac888f\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should not expire\ + \ within the specified number of days\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.KeyVault.Data\",\"description\":\"Manage certificates that will\ + \ expire within a specified number of days to ensure your organization has\ + \ sufficient time to rotate the certificate prior to expiration.\",\"metadata\"\ + :{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"\ + parameters\":{\"daysToExpire\":{\"type\":\"Integer\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Days to expire\",\"description\":\"The number of days for a\ + \ certificate to expire.\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/attributes.expiresOn\"\ + ,\"lessOrEquals\":\"[addDays(utcNow(), parameters('daysToExpire'))]\"}]},\"\ + then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/f772fb64-8e40-40ad-87bc-7706e1949427\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f772fb64-8e40-40ad-87bc-7706e1949427\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should be issued\ + \ by the specified non-integrated certificate authority\",\"policyType\":\"\ + BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your\ + \ organizational compliance requirements by specifying the custom or internal\ + \ certificate authorities that can issue certificates in your key vault.\"\ + ,\"metadata\":{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"\ + preview\":true},\"parameters\":{\"caCommonName\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: The common name of the certificate authority\"\ + ,\"description\":\"The common name (CN) of the Certificate Authority (CA)\ + \ provider. For example, for an issuer CN = Contoso, OU = .., DC = .., you\ + \ can specify Contoso\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant\ + \ resource to be created, but flags it as non-compliant. 'Deny' blocks the\ + \ resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/issuer.commonName\"\ + ,\"notContains\":\"[parameters('caCommonName')]\"}]},\"then\":{\"effect\"\ + :\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/a22f4a40-01d3-4c7d-8071-da157eeff341\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a22f4a40-01d3-4c7d-8071-da157eeff341\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should be issued\ + \ by the specified integrated certificate authority\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ + \ compliance requirements by specifying the Azure integrated certificate authorities\ + \ that can issue certificates in your key vault such as Digicert or GlobalSign.\"\ + ,\"metadata\":{\"version\":\"2.0.0-preview\",\"category\":\"Key Vault\",\"\ + preview\":true},\"parameters\":{\"allowedCAs\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Allowed Azure Key Vault Supported CAs\",\"\ + description\":\"The list of allowed certificate authorities supported by Azure\ + \ Key Vault.\"},\"allowedValues\":[\"DigiCert\",\"GlobalSign\"],\"defaultValue\"\ + :[\"DigiCert\",\"GlobalSign\"]},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/issuer.name\",\"\ + notIn\":\"[parameters('allowedCAs')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/8e826246-c976-48f6-b03e-619bb92b3d82\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8e826246-c976-48f6-b03e-619bb92b3d82\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates should have the\ + \ specified lifetime action triggers\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ + \ compliance requirements by specifying whether a certificate lifetime action\ + \ is triggered at a specific percentage of its lifetime or at a certain number\ + \ of days prior to its expiration.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ + ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"maximumPercentageLife\"\ + :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: The maximum\ + \ lifetime percentage\",\"description\":\"Enter the percentage of lifetime\ + \ of the certificate when you want to trigger the policy action. For example,\ + \ to trigger a policy action at 80% of the certificate's valid life, enter\ + \ '80'.\"}},\"minimumDaysBeforeExpiry\":{\"type\":\"Integer\",\"metadata\"\ + :{\"displayName\":\"[Preview]: The minimum days before expiry\",\"description\"\ + :\"Enter the days before expiration of the certificate when you want to trigger\ + \ the policy action. For example, to trigger a policy action 90 days before\ + \ the certificate's expiration, enter '90'.\"}},\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created, but flags it as non-compliant.\ + \ 'Deny' blocks the resource creation. 'Disable' turns off the policy.\"},\"\ + allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.daysBeforeExpiry\"\ + ,\"exists\":true},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.daysBeforeExpiry\"\ + ,\"less\":\"[parameters('minimumDaysBeforeExpiry')]\"}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.lifetimePercentage\"\ + ,\"exists\":true},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/lifetimeAction.lifetimePercentage\"\ + ,\"greater\":\"[parameters('maximumPercentageLife')]\"}]}]}]},\"then\":{\"\ + effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/12ef42cb-9903-4e39-9c26-422d29570417\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"12ef42cb-9903-4e39-9c26-422d29570417\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys should not be active\ + \ for longer than the specified number of days\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Specify the number\ + \ of days that a key should be active. Keys that are used for an extended\ + \ period of time increase the probability that an attacker could compromise\ + \ the key. As a good security practice, make sure that your keys have not\ + \ been active longer than two years.\",\"metadata\":{\"version\":\"1.0.0-preview\"\ + ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"maximumValidityInDays\"\ + :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: The maximum\ + \ validity period in days\",\"description\":\"Specify the maximum number of\ + \ days a key can be valid for after activation.\"}},\"effect\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created, but flags it as\ + \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ + \ the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ + :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.KeyVault.Data/vaults/keys\"},{\"value\":\"[utcNow()]\",\"greater\"\ + :\"[addDays(if(empty(field('Microsoft.KeyVault.Data/vaults/keys/attributes.notBefore')),\ + \ field('Microsoft.KeyVault.Data/vaults/keys/attributes.createdOn'), field('Microsoft.KeyVault.Data/vaults/keys/attributes.notBefore')),\ + \ parameters('maximumValidityInDays'))]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/c26e4b24-cf98-4c67-b48b-5a25c4c69eb9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c26e4b24-cf98-4c67-b48b-5a25c4c69eb9\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys should be the specified\ + \ cryptographic type RSA or EC\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Some applications require the use of keys backed by a specific\ + \ cryptographic type. Enforce a particular cryptographic key type, RSA or\ + \ EC, in your environment.\",\"metadata\":{\"version\":\"1.0.0-preview\",\"\ + category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"allowedKeyTypes\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Allowed key\ + \ types\",\"description\":\"The list of allowed key types\"},\"allowedValues\"\ + :[\"RSA\",\"RSA-HSM\",\"EC\",\"EC-HSM\"],\"defaultValue\":[\"RSA\",\"RSA-HSM\"\ + ,\"EC\",\"EC-HSM\"]},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ + \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ + \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\"\ + ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/keyType\",\"notIn\":\"\ + [parameters('allowedKeyTypes')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75c4f823-d65c-4f29-a733-01d0077fdbcb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75c4f823-d65c-4f29-a733-01d0077fdbcb\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Certificates using RSA cryptography\ + \ should have the specified minimum key size\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Manage your organizational\ + \ compliance requirements by specifying a minimum key size for RSA certificates\ + \ stored in your key vault.\",\"metadata\":{\"version\":\"2.0.0-preview\"\ + ,\"category\":\"Key Vault\",\"preview\":true},\"parameters\":{\"minimumRSAKeySize\"\ + :{\"type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: Minimum\ + \ RSA key size\",\"description\":\"The minimum key size for RSA certificates.\"\ + },\"allowedValues\":[2048,3072,4096]},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/certificates\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keyType\"\ + ,\"in\":[\"RSA\",\"RSA-HSM\"]},{\"field\":\"Microsoft.KeyVault.Data/vaults/certificates/keyProperties.keySize\"\ + ,\"less\":\"[parameters('minimumRSAKeySize')]\"}]},\"then\":{\"effect\":\"\ + [parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/cee51871-e572-4576-855c-047c820360f0\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cee51871-e572-4576-855c-047c820360f0\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys using elliptic curve\ + \ cryptography should have the specified curve names\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Keys backed by elliptic\ + \ curve cryptography can have different curve names. Some applications are\ + \ only compatible with specific elliptic curve keys. Enforce the types of\ + \ elliptic curve keys that are allowed to be created in your environment.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"\ + preview\":true},\"parameters\":{\"allowedECNames\":{\"type\":\"Array\",\"\ + metadata\":{\"displayName\":\"[Preview]: Allowed elliptic curve names\",\"\ + description\":\"The list of allowed curve names for elliptic curve cryptography\ + \ certificates.\"},\"allowedValues\":[\"P-256\",\"P-256K\",\"P-384\",\"P-521\"\ + ],\"defaultValue\":[\"P-256\",\"P-256K\",\"P-384\",\"P-521\"]},\"effect\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ + ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"},{\"field\":\"\ + Microsoft.KeyVault.Data/vaults/keys/keyType\",\"in\":[\"EC\",\"EC-HSM\"]},{\"\ + field\":\"Microsoft.KeyVault.Data/vaults/keys/ellipticCurveName\",\"notIn\"\ + :\"[parameters('allowedECNames')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/ff25f3c8-b739-4538-9d07-3d6d25cfb255\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ff25f3c8-b739-4538-9d07-3d6d25cfb255\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys should have more than\ + \ the specified number of days before expiration\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"If a key is too close\ + \ to expiration, an organizational delay to rotate the key may result in an\ + \ outage. Keys should be rotated at a specified number of days prior to expiration\ + \ to provide sufficient time to react to a failure.\",\"metadata\":{\"version\"\ + :\"1.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"parameters\"\ + :{\"minimumDaysBeforeExpiration\":{\"type\":\"Integer\",\"metadata\":{\"displayName\"\ + :\"[Preview]: The minimum days before expiration\",\"description\":\"Specify\ + \ the minimum number of days that a key should remain usable prior to expiration.\"\ + }},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"'Audit' allows a non-compliant resource to be\ + \ created, but flags it as non-compliant. 'Deny' blocks the resource creation.\ + \ 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\"\ + ,\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"},{\"\ + field\":\"Microsoft.KeyVault.Data/vaults/keys/attributes.expiresOn\",\"exists\"\ + :true},{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/attributes.expiresOn\"\ + ,\"less\":\"[addDays(utcNow(), parameters('minimumDaysBeforeExpiration'))]\"\ + }]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/5ff38825-c5d8-47c5-b70e-069a21955146\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5ff38825-c5d8-47c5-b70e-069a21955146\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys should have the specified\ + \ maximum validity period\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Manage your organizational compliance requirements by specifying\ + \ the maximum amount of time in days that a key can be valid within your key\ + \ vault.\",\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Key\ + \ Vault\",\"preview\":true},\"parameters\":{\"maximumValidityInDays\":{\"\ + type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: The maximum\ + \ validity period in days\",\"description\":\"Specify the maximum number of\ + \ days a key can be valid for. Keys should be ephemeral. Using a key with\ + \ a long validity period is not recommended.\"}},\"effect\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit'\ + \ allows a non-compliant resource to be created, but flags it as non-compliant.\ + \ 'Deny' blocks the resource creation. 'Disable' turns off the policy.\"},\"\ + allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"\ + },{\"anyOf\":[{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/attributes.expiresOn\"\ + ,\"exists\":false},{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/attributes.expiresOn\"\ + ,\"greater\":\"[addDays(field('Microsoft.KeyVault.Data/vaults/keys/attributes.createdOn'),\ + \ parameters('maximumValidityInDays'))]\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/49a22571-d204-4c91-a7b6-09b1a586fbc9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"49a22571-d204-4c91-a7b6-09b1a586fbc9\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys using RSA cryptography\ + \ should have a specified minimum key size\",\"policyType\":\"BuiltIn\",\"\ + mode\":\"Microsoft.KeyVault.Data\",\"description\":\"Set the minimum allowed\ + \ key size for use with your key vaults. Use of RSA keys with small key sizes\ + \ is not a secure practice and doesn't meet many industry certification requirements.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"\ + preview\":true},\"parameters\":{\"minimumRSAKeySize\":{\"type\":\"Integer\"\ + ,\"metadata\":{\"displayName\":\"[Preview]: Minimum RSA key size\",\"description\"\ + :\"The minimum key size for RSA keys.\"},\"allowedValues\":[2048,3072,4096]},\"\ + effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\"\ + ,\"description\":\"'Audit' allows a non-compliant resource to be created,\ + \ but flags it as non-compliant. 'Deny' blocks the resource creation. 'Disable'\ + \ turns off the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"\ + ],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"},{\"field\":\"\ + Microsoft.KeyVault.Data/vaults/keys/keyType\",\"in\":[\"RSA\",\"RSA-HSM\"\ + ]},{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/keySize\",\"less\":\"\ + [parameters('minimumRSAKeySize')]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/82067dbb-e53b-4e06-b631-546d197452d9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"82067dbb-e53b-4e06-b631-546d197452d9\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Secrets should have more than\ + \ the specified number of days before expiration\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"If a secret is too\ + \ close to expiration, an organizational delay to rotate the secret may result\ + \ in an outage. Secrets should be rotated at a specified number of days prior\ + \ to expiration to provide sufficient time to react to a failure.\",\"metadata\"\ + :{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"\ + parameters\":{\"minimumDaysBeforeExpiration\":{\"type\":\"Integer\",\"metadata\"\ + :{\"displayName\":\"[Preview]: The minimum days before expiration\",\"description\"\ + :\"Specify the minimum number of days that a secret should remain usable prior\ + \ to expiration.\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ + \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ + \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\"\ + ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/secrets\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn\"\ + ,\"exists\":true},{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn\"\ + ,\"less\":\"[addDays(utcNow(), parameters('minimumDaysBeforeExpiration'))]\"\ + }]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/b0eb591a-5e70-4534-a8bf-04b9c489584a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b0eb591a-5e70-4534-a8bf-04b9c489584a\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Secrets should not be active\ + \ for longer than the specified number of days\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.KeyVault.Data\",\"description\":\"If your secrets were\ + \ created with an activation date set in the future, you must ensure that\ + \ your secrets have not been active for longer than the specified duration.\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"\ + preview\":true},\"parameters\":{\"maximumValidityInDays\":{\"type\":\"Integer\"\ + ,\"metadata\":{\"displayName\":\"[Preview]: The maximum validity period in\ + \ days\",\"description\":\"Specify the maximum number of days a secret can\ + \ be valid for after activation.\"}},\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"[Preview]: Effect\",\"description\":\"'Audit' allows a\ + \ non-compliant resource to be created, but flags it as non-compliant. 'Deny'\ + \ blocks the resource creation. 'Disable' turns off the policy.\"},\"allowedValues\"\ + :[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/secrets\"\ + },{\"value\":\"[utcNow()]\",\"greater\":\"[addDays(if(empty(field('Microsoft.KeyVault.Data/vaults/secrets/attributes.notBefore')),\ + \ field('Microsoft.KeyVault.Data/vaults/secrets/attributes.createdOn'), field('Microsoft.KeyVault.Data/vaults/secrets/attributes.notBefore')),\ + \ parameters('maximumValidityInDays'))]\"}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/e8d99835-8a06-45ae-a8e0-87a91941ccfe\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e8d99835-8a06-45ae-a8e0-87a91941ccfe\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Keys should be backed by a\ + \ hardware security module (HSM)\",\"policyType\":\"BuiltIn\",\"mode\":\"\ + Microsoft.KeyVault.Data\",\"description\":\"An HSM is a hardware security\ + \ module that stores keys. An HSM provides a physical layer of protection\ + \ for cryptographic keys. The cryptographic key cannot leave a physical HSM\ + \ which provides a greater level of security than a software key.\",\"metadata\"\ + :{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ + \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ + \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\"\ + ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/keys\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/keys/keyType\",\"notIn\":[\"\ + RSA-HSM\",\"EC-HSM\"]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Authorization/policyDefinitions/587c79fe-dd04-4a5e-9d0b-f89598c7261b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"587c79fe-dd04-4a5e-9d0b-f89598c7261b\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Secrets should have content\ + \ type set\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"A content type tag helps identify whether a secret is a\ + \ password, connection string, etc. Different secrets have different rotation\ + \ requirements. Content type tag should be set on secrets.\",\"metadata\"\ + :{\"version\":\"1.0.0-preview\",\"category\":\"Key Vault\",\"preview\":true},\"\ + parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"[Preview]: Effect\",\"description\":\"'Audit' allows a non-compliant resource\ + \ to be created, but flags it as non-compliant. 'Deny' blocks the resource\ + \ creation. 'Disable' turns off the policy.\"},\"allowedValues\":[\"Audit\"\ + ,\"Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"}},\"policyRule\":{\"if\"\ + :{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault.Data/vaults/secrets\"\ + },{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/contentType\",\"exists\"\ + :false}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/75262d3e-ba4a-4f43-85f8-9f72c090e5e3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"75262d3e-ba4a-4f43-85f8-9f72c090e5e3\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Secrets should have the specified\ + \ maximum validity period\",\"policyType\":\"BuiltIn\",\"mode\":\"Microsoft.KeyVault.Data\"\ + ,\"description\":\"Manage your organizational compliance requirements by specifying\ + \ the maximum amount of time in days that a secret can be valid within your\ + \ key vault.\",\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"\ + Key Vault\",\"preview\":true},\"parameters\":{\"maximumValidityInDays\":{\"\ + type\":\"Integer\",\"metadata\":{\"displayName\":\"[Preview]: The maximum\ + \ validity period in days\",\"description\":\"Specify the maximum number of\ + \ days a secret can be valid for. Secrets should be ephemeral. Using a secret\ + \ with a long validity period is not recommended.\"}},\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"[Preview]: Effect\",\"description\"\ + :\"'Audit' allows a non-compliant resource to be created, but flags it as\ + \ non-compliant. 'Deny' blocks the resource creation. 'Disable' turns off\ + \ the policy.\"},\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\"\ + :\"Audit\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.KeyVault.Data/vaults/secrets\"},{\"anyOf\":[{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn\"\ + ,\"exists\":false},{\"field\":\"Microsoft.KeyVault.Data/vaults/secrets/attributes.expiresOn\"\ + ,\"greater\":\"[addDays(field('Microsoft.KeyVault.Data/vaults/secrets/attributes.createdOn'),\ + \ parameters('maximumValidityInDays'))]\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/342e8053-e12e-4c44-be01-c3c2f318400f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"342e8053-e12e-4c44-be01-c3c2f318400f\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Kubernetes cluster services\ + \ should only use allowed external IPs\",\"policyType\":\"BuiltIn\",\"mode\"\ + :\"Microsoft.Kubernetes.Data\",\"description\":\"Use allowed external IPs\ + \ to avoid the potential attack(CVE-2020-8554) in a Kubernetes cluster. For\ + \ more information, see https://aka.ms/kubepolicydoc.\",\"metadata\":{\"version\"\ + :\"1.0.0-preview\",\"category\":\"Kubernetes\",\"preview\":true},\"parameters\"\ + :{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Effect\",\"description\":\"'Audit' allows a non-compliant resource to be\ + \ created or updated, but flags it as non-compliant. 'Deny' blocks the non-compliant\ + \ resource creation or update. 'Disabled' turns off the policy.\"},\"allowedValues\"\ + :[\"audit\",\"deny\",\"disabled\"],\"defaultValue\":\"audit\"},\"excludedNamespaces\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Namespace\ + \ exclusions\",\"description\":\"List of Kubernetes namespaces to exclude\ + \ from policy evaluation. Providing a value for this parameter is optional.\"\ + },\"defaultValue\":[\"kube-system\",\"gatekeeper-system\",\"azure-arc\"]},\"\ + namespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]:\ + \ Namespace inclusions\",\"description\":\"List of Kubernetes namespaces to\ + \ only include in policy evaluation. An empty list means the policy is applied\ + \ to all resources in all namespaces.\"},\"defaultValue\":[]},\"allowedExternalIPs\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"[Preview]: Allowed External\ + \ IPs\",\"description\":\"List of External IPs that services are allowed to\ + \ use. Empty array means all external IPs are disallowed.\"},\"defaultValue\"\ + :[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"AKS Engine\",\"\ + Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-external-ips/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/allowed-external-ips/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + ,\"allowedExternalIPs\":\"[parameters('allowedExternalIPs')]\"}}}}},\"id\"\ + :\"/providers/Microsoft.Authorization/policyDefinitions/d46c275d-1680-448d-b2ec-e495a3b6cc89\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d46c275d-1680-448d-b2ec-e495a3b6cc89\"\ + },{\"properties\":{\"displayName\":\"[Preview]: Kubernetes clusters should\ + \ not grant CAP_SYS_ADMIN security capabilities\",\"policyType\":\"BuiltIn\"\ + ,\"mode\":\"Microsoft.Kubernetes.Data\",\"description\":\"To reduce the attack\ + \ surface of your containers, restrict CAP_SYS_ADMIN Linux capabilities\"\ + ,\"metadata\":{\"version\":\"1.0.0-preview\",\"category\":\"Kubernetes\",\"\ + preview\":true},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Effect\",\"description\":\"'Audit' allows a non-compliant\ + \ resource to be created or updated, but flags it as non-compliant. 'Deny'\ + \ blocks the non-compliant resource creation or update. 'Disabled' turns off\ + \ the policy.\"},\"allowedValues\":[\"audit\",\"deny\",\"disabled\"],\"defaultValue\"\ + :\"audit\"},\"excludedNamespaces\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Namespace exclusions\",\"description\":\"List of Kubernetes namespaces\ + \ to exclude from policy evaluation.\"},\"defaultValue\":[\"kube-system\"\ + ,\"gatekeeper-system\",\"azure-arc\"]},\"namespaces\":{\"type\":\"Array\"\ + ,\"metadata\":{\"displayName\":\"Namespace inclusions\",\"description\":\"\ + List of Kubernetes namespaces to only include in policy evaluation. An empty\ + \ list means the policy is applied to all resources in all namespaces.\"},\"\ + defaultValue\":[]}},\"policyRule\":{\"if\":{\"field\":\"type\",\"in\":[\"\ + AKS Engine\",\"Microsoft.Kubernetes/connectedClusters\",\"Microsoft.ContainerService/managedClusters\"\ + ]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\":{\"constraintTemplate\"\ + :\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-disallowed-capabilities/template.yaml\"\ + ,\"constraint\":\"https://raw.githubusercontent.com/Azure/azure-policy/master/built-in-references/Kubernetes/container-disallowed-capabilities/constraint.yaml\"\ + ,\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\",\"namespaces\"\ + :\"[parameters('namespaces')]\",\"values\":{\"excludedNamespaces\":\"[parameters('excludedNamespaces')]\"\ + ,\"disallowedCapabilities\":\"CAP_SYS_ADMIN\"}}}}},\"id\":\"/providers/Microsoft.Authorization/policyDefinitions/d2e7ea85-6b44-4317-a0be-1b951587f626\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d2e7ea85-6b44-4317-a0be-1b951587f626\"\ + },{\"properties\":{\"displayName\":\"nrms-hdinsight-require-subnet_1.0\",\"\ + policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2019-04-01T22:24:01.1484325Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ + policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"not\":{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ + ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ + ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"11094169db59074f\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on new vms_1.5\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ + \ any Linux VMs use password-only authentication for SSH on new resources.\"\ ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-08-13T21:33:07.7274256Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + :\"2021-01-20T00:19:24.9145851Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ + :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"128t_networking_platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"4psa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + voipnow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"a10networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"a10-lightning-adc\",\"a10-vthunder-adc\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"accellion\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"kiteworks-by-accellion\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"abiquo\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"abiquo-hybrid-cloud-34\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"accops\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hysecure5050\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"actian_matrix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + actian_matrix\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"actifio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"actifio-sky\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"actian-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"vector-community\",\"vector-enterprise\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Acronis\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"storage\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"activeeon\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"activeeon-workload-scheduler\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"aerospike\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"aerospike-database-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"affinio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"platform\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"aiscaler-cache-control-ddos-and-url-rewriting-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aimobile-site-acceleration\",\"aiprotect-ddos-firewall\",\"aiscaler-traffic-manager-caching\"\ + ,\"aivideo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"akamai-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"enterprise-application-access\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"alces-flight-limited\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"alces-flight-compute-solo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"alertlogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"alert-logic-tm\",\"alert-logic-wsm\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"alienvault\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"unified-security-management-anywhere\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"alldigital-brevity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"alldigital-brevity-uploader\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"altair-engineering-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"altair_hwulva\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"altamira-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"lumify\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"antmedia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ams_community_edition\",\"ant_media_server_enterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"apigee\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"apigee-edge\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcara\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"app360v43-001\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcelerator\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appcelerator-arrow-azure-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"appex-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cloudexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"appistry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"genomepilot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"appscale-marketplace\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"appscale\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"arangodb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"arangodb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"arista-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"veos-router\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"array_networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"array-networks-vapv\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"astadia-1148316\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"astadia-ui-automation-tee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"atomicorp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"secure-os\",\"secure-ubuntu-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"audiocodes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"mediantsessionbordercontroller\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"auriq-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"essentia\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"awingu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"awingu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"aviatrix-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aviatrix-cloud-services\",\"aviatrix-companion-gateway\",\"aviatrix-companion-gateway-v2\"\ + ,\"aviatrix-vpn-gw\",\"aviatrix_multi_cloud_service\",\"aviatrix_openvpn_service\"\ + ,\"aviatrix_openvpn_service10\",\"aviatrix_openvpn_service25\",\"aviatrix_openvpn_service50\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"avi-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + avi-vantage-adc\",\"internal-avi-vantage-adc\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"axway\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"axway-mailgate-secure-collaboration-advanced\"\ + ,\"axway-mailgate-secure-collaboration-premium\",\"axway-mailgate-secure-collaboration-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"azul\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"azul-zulu-ubuntu-1804\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"azurecyclecloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + azure-cyclecloud-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"AzureDatabricks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Databricks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"baas-techbureau\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"b1327623-d29b-4cc1-b833-85067dcc7bce\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"baffle-io\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"baffle-application-data-protection\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"balabit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"balabit-shell-control-box\"\ + ,\"psm\",\"sps\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"barracudanetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"barracuda-app-sec-control-center\",\"barracuda-email-security-gateway\"\ + ,\"barracuda-ng-cc\",\"barracuda-ng-firewall\",\"waf\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"basho\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"riak-2-0-1\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"autodesk-maya-arnold-centos73\"\ + ,\"rendering-centos73\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"bdy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + buddy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"Bitnami\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + 3-4\",\"abantecart\",\"activemq\",\"akeneo\",\"alfrescocommunity\",\"apachesolr\"\ + ,\"artifactory\",\"canvaslms\",\"cassandra\",\"civicrm\",\"cmsmadesimple\"\ + ,\"codiad\",\"concrete5\",\"consul\",\"coppermine\",\"couchdb\",\"diaspora\"\ + ,\"discourse\",\"djangostack\",\"dokuwiki\",\"dolibarr\",\"DreamFactory\"\ + ,\"drupal\",\"elastic-search\",\"elk\",\"erpnext\",\"espocrm\",\"etcd\",\"\ + eXo-Platform\",\"exoplatform\",\"fatfreecrm\",\"ghost\",\"gitlab\",\"grafana\"\ + ,\"hadoop\",\"hhvmstack\",\"hordegroupwarewebmail\",\"jasperreports\",\"jenkins\"\ + ,\"joomla\",\"jrubystack\",\"kafka\",\"kong\",\"kubernetessandbox\",\"lampstack\"\ + ,\"lappstack\",\"letschat\",\"liferay\",\"limesurvey\",\"livehelperchat\"\ + ,\"magento\",\"mahara\",\"mantis\",\"mariadb\",\"mattermost\",\"mautic\",\"\ + mean\",\"mediawiki\",\"memcached\",\"modx\",\"mongodb\",\"moodle\",\"multicraft\"\ + ,\"mybb\",\"mysql\",\"nats\",\"neo4j\",\"neos\",\"nginxstack\",\"noalyss\"\ + ,\"nodejs\",\"ocportal\",\"odoo\",\"openatrium\",\"opencart\",\"openedx\"\ + ,\"openfire\",\"openproject\",\"orangehrm\",\"osclass\",\"owncloud\",\"oxid-eshop\"\ + ,\"parseserver\",\"phabricator\",\"phpbb\",\"phplist\",\"pimcore\",\"piwik\"\ + ,\"plone\",\"pootle\",\"postgresql\",\"prestashop\",\"processmakerenterprise\"\ + ,\"processmakeropensourceedition\",\"processwire\",\"publify\",\"rabbitmq\"\ + ,\"redash\",\"redis\",\"redmine\",\"redmineplusagile\",\"reportserver\",\"\ + reportserverenterprise\",\"resourcespace\",\"reviewboard\",\"reviewboardpowerpack\"\ + ,\"roundcube\",\"rubystack\",\"seopanel\",\"shopware\",\"silverstripe\",\"\ + simplemachinesforum\",\"sonarqube\",\"spree\",\"subversion\",\"suitecrm\"\ + ,\"tensorflowserving\",\"testlink\",\"tikiwikicmsgroupware\",\"tinytinyrss\"\ + ,\"tom-cat\",\"trac\",\"typo3\",\"weblate\",\"webmailpro\",\"wildfly\",\"\ + wordpress\",\"wordpress-multisite\",\"wordpresspro\",\"x2enginesalescrm\"\ + ,\"xoops\",\"youtrack\",\"zookeeper\",\"zurmo\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"black-duck-software\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blackduck_hub_vm\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"blk-technologies\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blk-io-erc-20-rest-service\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockapps\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"strato-blockchain-base-template-latest\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockstack-core-v14\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockchain-foundry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"syscoin-api\",\"syscoin-full-node\",\"syscoin-price-peg\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bloombase\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bloombase-storesafe-3_4_7_0_el7_x86_64\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"bluecat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluecat-bam-for-azure\"\ + ,\"bluecat-dns-for-azure\",\"bluecat-edge-service-point-vm-for-azure\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bluetalon\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluetalon\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"brocade_communications\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"brocade-virtual-traffic-manager\"\ + ,\"brocade-virtual-traffic-manager-with-waf-module\",\"brocade-virtual-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"bt-americas-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + diamondip-sapphire-ev10\",\"diamondip-sapphire-ev20\",\"diamondip-sapphire-v10\"\ + ,\"diamondip-sapphire-v20\",\"diamondip-sapphire-v5\",\"diamondip-sapphire-vcaa20\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"buddhalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sles_12_pci\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"carto\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cartobuilder2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cask\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cdap-cloud-sandbox\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"UbuntuServer\"\ + ,\"Ubuntu_Core\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cavirin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cavirin-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cautelalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"log_management\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"celum-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"celumdam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cds\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cds-data-migration-solution-for-legacy-to-cloud\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-6-v2-0-2-l1\"\ + ,\"cis-centos-7-v2-1-1-l1\",\"cis-oracle-linux-6-v1-0-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ + ,\"cis-rhel-6-v2-0-2-l1\",\"cis-rhel-7-v2-2-0-l1\",\"cis-suse-linux-11-v2-0-0-l1\"\ + ,\"cis-suse-linux-12-v2-0-0-l1\",\"cis-ubuntu-linux-1404-v2-0-0-l1\",\"cis-ubuntu-linux-1604-v1-0-0-l1\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"certivox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sso-test\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cfd-direct\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cfd-direct-from-the-cloud\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"chain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chain-core-developer-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"checkpoint\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"check-point-r77-10\"\ + ,\"check-point-vsec-r80\",\"check-point-vsec-r80-blink\",\"sg2\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"chef-software\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chef-automate-vm-image\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"circleci\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"circleci-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cires21\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"c21l-enc\"\ + ,\"c21l-mos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cisco\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cisco-asav\",\"cisco-csr-1000v\",\"cisco-ftdv\",\"cisco-meraki-vmx100\"\ + ,\"cisco-ngfwv-vm-test-unsupported\",\"cisco_cloud_vedge_17_2_4\",\"cos65\"\ + ,\"cos72\",\"cos72_main_dev\",\"uos14\",\"vwaas-azure\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"citrix\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"citrix-sd-wan-opt\",\"netscaler-ma-service-agent-120\"\ + ,\"netscaler-ma-service-agent-121\",\"netscaler-sd-wan\",\"netscaler-vpx\"\ + ,\"netscalervpx-120\",\"netscalervpx-121\",\"netscalervpx110-6531\",\"netscalervpx111\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"clear-linux-project\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"clear-linux-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"clouber\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cuber\",\"cws\",\"mcenter\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloud-cruiser\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-cruiser-16\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudbees\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"jenkins-enterprise\",\"jenkins-operations-center\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudbees-enterprise-jenkins\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbees-jenkins-enterprise\"\ + ,\"cloudbees-jenkins-operations-center\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudbolt-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudbolt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudboost\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"cloudboost\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudenablers-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"corestack\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"squid-proxy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloudera-altus-centos-os\",\"cloudera-centos-6\",\"cloudera-centos-os\"\ + ,\"test-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudlanes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"cloud-video-accelerator-nfs\",\"cloudlanes-cloud-backup-accelerator-vtl\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cloudlink\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudlink-securevm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cloudplan-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cloudplan_pcn_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"paladion_ondemand_nextgen_firewall\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudsoft\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudsoft-amp\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"clustrix\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"clustrixdb\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"codelathe\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codelathe-filecloud-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"codenvy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codenvy-on-prem\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cognosys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"1-click-secured-joomla-on-centos-7-3\"\ + ,\"1-click-secured-joomla-on-ubuntu-1404-lts\",\"1-click-secured-joomla-on-ubuntu-1604-lts\"\ + ,\"1-click-secured-joomla-on-ubuntu-1804-lts\",\"centos-6-9\",\"centos-7-3\"\ + ,\"centos-7-4\",\"centos-7-5\",\"deploy-a-secured-modx-on-ubuntu-14-04-lts\"\ + ,\"deploy-a-secured-silverstripe-on-ubuntu-14-04-lts\",\"hardened-mysql-5-6-on-centos-7-3\"\ + ,\"hardened-mysql-5-6-on-ubu-1404-lts\",\"hardened-mysql-5-7-on-centos-7-3\"\ + ,\"hardened-mysql-5-7-on-ubu-1404-lts\",\"hardened-postgresql-on-ubu-1404-lts\"\ + ,\"invoice-ninja-2-5-1-1-on-ubuntu-1404\",\"jruby-on-ubuntu-14-04-lts\",\"\ + low-latency-broadcasting-server-for-live-events\",\"owncloud-9-with-lamp-stack-on-ubuntu-1404\"\ + ,\"piwigogallerys-ubuntu_14-04_lts\",\"sec1011-dokuwiki-on-ubuntu-1404\",\"\ + sec1013-elasticsearch-on-ubuntu-1404\",\"sec1014-opencart-on-ubuntu-1404\"\ + ,\"sec1015-orangehrm-on-ubuntu-1404\",\"sec1016-nodejs-server-on-ubuntu-1404\"\ + ,\"sec1018-haproxy-on-ubuntu-1404\",\"sec1019-secured-tomcat-on-ubuntu-1404\"\ + ,\"sec1020-phpbb-on-hardened-ubuntu-1404\",\"sec1021-mybb-on-hardened-ubuntu-1404\"\ + ,\"sec1022-sugarcrm-on-ubuntu-1404\",\"sec1023-moodle-on-ubuntu-1404\",\"\ + sec1024_magento-on-ubuntu-1404\",\"sec1025-secured-drupal-on-ubuntu-1404\"\ + ,\"sec1027-secured-wordpress-on-ubuntu-1404\",\"sec1028-secured-lamp-sever-on-ubuntu-1404\"\ + ,\"sec1029-secured-mediawiki-on-ubuntu-1404\",\"sec1030-secured-subversion-on-ubuntu-1404\"\ + ,\"sec1031-secured-passenger-nginx-on-ubuntu-1404\",\"sec1033-secured-piwik-on-ubuntu-1404\"\ + ,\"sec1034-secured-pligg-on-ubuntu-1404\",\"sec1035-secured-jenkins-on-ubuntu-1404\"\ + ,\"sec1036-secured-postgresql-on-ubuntu-1404\",\"secure-cloud-lamp-ubuntu-1404\"\ + ,\"secured-abantecart-on-centos\",\"secured-abantecart-on-ubuntu-14-04-lts\"\ + ,\"secured-acquia-drupal-on-centos\",\"secured-acquiadurpal-on-ubuntu-14-04-lts\"\ + ,\"secured-apachesolr-on-centos\",\"secured-apachesolr-on-ubuntu-14-04-lts\"\ + ,\"secured-arartifactory-on-centos\",\"secured-artifactory-on-ubuntu-14-04-lts\"\ + ,\"secured-cakephp-on-centos\",\"secured-cakephp-on-ubuntu-14-04-lts\",\"\ + secured-cms-made-simple-on-centos\",\"secured-cms-made-simple-on-ubuntu-14-04-lts\"\ + ,\"secured-codiad-on-centos\",\"secured-codiad-on-ubuntu-14-04-lts\",\"secured-cogdam-on-centos\"\ + ,\"secured-cogdam-on-ubuntu-14-04-lts\",\"secured-concrete5-on-centos\",\"\ + secured-concrete5-on-ubuntu-14-04-lts\",\"secured-coppermine-on-centos\",\"\ + secured-coppermine-on-ubuntu-14-04-lts\",\"secured-crushftp-on-centos\",\"\ + secured-crushftp-on-ubuntu-14-04-lts\",\"secured-django-on-centos\",\"secured-django-on-ubuntu-14-04-lts\"\ + ,\"secured-dokuwiki-on-centos\",\"secured-dolibarr-on-centos\",\"secured-dolivbarr-on-ubuntu-14-04-lts\"\ + ,\"secured-drupal-on-centos\",\"secured-elasticsearch-on-centos\",\"secured-enterprise-nginx-varnish-haproxy-php\"\ + ,\"secured-espocrm-on-centos\",\"secured-espocrm-on-ubuntu-14-04-lts\",\"\ + secured-exoplatform-on-centos\",\"secured-exoplatform-on-ubuntu-14-04-lts\"\ + ,\"secured-ghost-on-centos\",\"secured-ghost-on-ubuntu-14-04-lts\",\"secured-gradle-on-centos\"\ + ,\"secured-gradle-on-ubuntu-14-04-lts\",\"secured-haproxy-on-centos\",\"secured-invoice-ninja-on-centos\"\ + ,\"secured-jboss-as-on-centos\",\"secured-jbossas-on-ubuntu-14-04-lts\",\"\ + secured-jenkins-on-centos\",\"secured-jruby-on-cento\",\"secured-lamp-on-centos\"\ + ,\"secured-lamp-on-centos-m10\",\"secured-lapp-on-centos\",\"secured-lapp-on-ubuntu-14-04-lts\"\ + ,\"secured-lemp-sever-on-ubuntu-1404\",\"secured-lime-survey-on-centos\",\"\ + secured-limesurvey-on-ubuntu-1404\",\"secured-live-helper-chat-on-centos\"\ + ,\"secured-livehelperchat-on-ubuntu-14-04-lts\",\"secured-magento-on-centos\"\ + ,\"secured-mahara-on-centos\",\"secured-mahara-on-ubuntu-14-04-lts\",\"secured-mantis-on-centos\"\ + ,\"secured-mantis-on-ubuntu-14-04-lts\",\"secured-mariadb-on-ubuntu-16-04\"\ + ,\"secured-mautic-on-centos\",\"secured-mautic-on-ubuntu-14-04-lts\",\"secured-media-wiki-on-centos\"\ + ,\"secured-modx-on-centos\",\"secured-moodle-on-centos\",\"secured-ngnix-on-centos-7-3\"\ + ,\"secured-ngnix-on-ubuntu-14-04-lts\",\"secured-ngnix-on-ubuntu-16-04-lts\"\ + ,\"secured-noalyss-on-centos\",\"secured-noalyss-on-ubuntu-14-04-lts\",\"\ + secured-nodejs-on-centos\",\"secured-occlass-on-ubuntu-14-04-lts\",\"secured-ocportal-on-ubuntu-14-04-lts\"\ + ,\"secured-open-cart-on-centos\",\"secured-orangehrm-on-centos\",\"secured-osclass-on-centos\"\ + ,\"secured-owncloud-on-centos\",\"secured-oxid-eshop-on-centos\",\"secured-oxideshop-on-ubuntu-14-04-lts\"\ + ,\"secured-passenger-nginx-on-centos\",\"secured-piwigo-gallery-on-centos\"\ + ,\"secured-plone-on-centos\",\"secured-plone-on-ubuntu-14-04-lts\",\"secured-prestashop-on-centos\"\ + ,\"secured-prestashop-on-ubuntu-14-04-lts\",\"secured-railo-on-ubuntu-14-04-lts\"\ + ,\"secured-redis-on-centos\",\"secured-redis-on-ubuntu-1404\",\"secured-redmine-on-centos\"\ + ,\"secured-redmine-on-ubuntu-14-04-lts\",\"secured-redmineagile-on-ubuntu-14-04-lts\"\ + ,\"secured-report-server-on-centos\",\"secured-reportserverent-on-ubuntu-14-04-lts\"\ + ,\"secured-resource-space-on-centos\",\"secured-resourcespace-on-ubuntu-14-04-lts\"\ + ,\"secured-round-cube-on-centos\",\"secured-roundcube-on-ubuntu-14-04-lts\"\ + ,\"secured-ruby-on-centos\",\"secured-ruby-on-ubuntu-14-04-lts\",\"secured-seopanel-on-centos\"\ + ,\"secured-seopanel-on-ubuntu-14-04-lts\",\"secured-silverstripe-on-centos\"\ + ,\"secured-simple-invoice-on-centos\",\"secured-simple-machines-on-centos\"\ + ,\"secured-simple-machines-on-ubuntu-14-04-lts\",\"secured-simpleinvoice-on-ubuntu-14-04-lts\"\ + ,\"secured-subversion-on-centos\",\"secured-suitecrm-on-centos\",\"secured-suitecrm-on-ubuntu-14-04-lts\"\ + ,\"secured-test-link-on-centos\",\"secured-testlink-on-ubuntu-14-04-lts\"\ + ,\"secured-thinkup-on-centos\",\"secured-thinkup-on-ubuntu-14-04-lts\",\"\ + secured-tikiwikicms-on-centos\",\"secured-tikiwikicms-on-ubuntu-14-04-lts\"\ + ,\"secured-tiny-tiny-rss-on-centos\",\"secured-tinytinyrss-on-ubuntu-14-04-lts\"\ + ,\"secured-tomcat-on-centos\",\"secured-trac-on-centos\",\"secured-trac-on-ubuntu-14-04-lts\"\ + ,\"secured-typo3-on-centos\",\"secured-typo3-on-ubuntu-14-04-lts\",\"secured-varnish-on-centos\"\ + ,\"secured-varnish-on-ubuntu-1404\",\"secured-wildfly-on-centos\",\"secured-wildfly-on-ubuntu-14-04-lts\"\ + ,\"secured-wordpress-on-centos-7-3\",\"secured-wordpress-on-ubuntu-16-04-lts\"\ + ,\"secured-x-cart-on-ubuntu-14-04-lts\",\"secured-xoops-on-centos\",\"secured-xoops-on-ubuntu-14-04-lts\"\ + ,\"secured-zurmo-on-centos\",\"secured-zurmo-on-ubuntu-14-04-lts\",\"suse15\"\ + ,\"ubuntu-14-04-lts\",\"ubuntu-16-04-lts\",\"ubuntu-17-04-high-performance-hardened-tcp-bbr\"\ + ,\"ubuntu-18-04\",\"ubuntu-18-04-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cohesity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cohesity-cloudtd-tool\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cohesive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"vns3_4x_network_security\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"confluentinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"confluentplatform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"consensys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"truffle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"convertigo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"convertigo-for-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"corda\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"corda\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"CoreOS\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"CoreOS\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"couchbase\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"couchbase-server-enterprise\",\"couchbase-sync-gateway-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cryptzone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appgate-appliance-3_2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cybernetica-as\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + uxp-securityserver-connector\",\"uxp-securityserver_vm\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cyxtera\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"appgatesdp-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"dataart\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"devicehive\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"databricks\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"spfqogzeculbhdh\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datalayer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datalayer-notebook\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datastax\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datastax-enterprise\"\ + ,\"datastax-enterprise-non-production-use-only\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"datasunrise\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"datasunrise-database-security-suite\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dataiku\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dataiku-data-science-studio\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datometry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyper-q\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dellemc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dell-emc-avamar-virtual-edition\"\ + ,\"dell-emc-datadomain-management-center\",\"dell-emc-datadomain-virtual-edition\"\ + ,\"dell-emc-datadomain-virtual-edition-v4\",\"dell-emc-networker-virtual-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"delphix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"delphix_dynamic_data_platform\"\ + ,\"omniosce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"denodo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"denodo-platform\",\"denodo-platform-7_0\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"denyall\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"denyall-rweb\",\"denyall-vulnerability-manager\",\"denyall-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dgsecure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dgsecure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"diladele\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"websafety\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dimensionalmechanics-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"neopulse-ai-studio\",\"neopulse-query-runtime\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"docker\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"docker-ce\",\"docker-ce-edge\"\ + ,\"docker-datacenter-custom\",\"docker-ee\",\"docker-ee-basic\",\"docker4azure\"\ + ,\"docker4azure-cs\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dome9\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"dome9ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"drizti\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"hpcbox-ansys-19-cluster-master\",\"hpcbox-cluster-compute-node\",\"hpcbox-cluster-cuda-node\"\ + ,\"hpcbox-cluster-gpu-node\",\"hpcbox-docker-cluster-master\",\"hpcbox-openfoam-cluster-master\"\ + ,\"hpcbox-su2-cluster-master\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"drone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"drone\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dyadic_security\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"dyadic_sec\",\"ukc_image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dynatrace\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ruxit-managed-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"eastwind-networks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"eastwind-ixia-sensor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"egnyte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"egnyte-connect\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"elasticbox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"elasticbox-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"electric-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"electricflowce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"elfiqnetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"emercoin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"emercoin\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"enterprise-ethereum-alliance\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"quorum-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"enterprisedb-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"edb-postgres-ark\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"equalum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"equalum-vm-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"esdenera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"esdenera-firewall-3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ethereum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ethereum-studio\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"evostream-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ems-for-template\",\"ems-test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"exasol\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"exasol-analytics-database-byol\",\"exasolution-analytic-database\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"falconstorsoftware\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"fss-v9\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"f5-networks\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"f5-big-ip-adc\",\"\ + f5-big-ip-advanced-waf\",\"f5-big-ip-best\",\"f5-big-ip-better\",\"f5-big-ip-byol\"\ + ,\"f5-big-ip-good\",\"f5-big-ip-per-app-ve\",\"f5-big-iq\",\"f5-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"filecatalyst\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + filecatalyst-direct-per-hr-billing\",\"filecatalyst-direct-server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"firehost\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"firehost_armor\",\"\ + firehost_armor_ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"flexify-io\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"single-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"flashgrid-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"flashgrid-racnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"foghorn-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"foghorn-edge-device-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"forcepoint-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"forcepoint-ngfw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"forscene\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"forscene-edgeserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"fortycloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"fortycloud-gw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"fortinet\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"fortinet-fortianalyzer\",\"fortinet-fortimanager\",\"fortinet_fortigate-vm_v5\"\ + ,\"fortinet_fortimail\",\"fortinet_fortivoice\",\"fortinet_fortiweb-vm_v5\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"fujitsu_fast\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + fep10-rh7-test\",\"feptest\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"gemalto-safenet\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"safenet-keysecure-k170v\",\"safenet-protectv\",\"safenet-protectv-manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gigamon-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gigamon-fm-5_3_01\"\ + ,\"gigamon-fm-5_3_01_hourly\",\"gigamon-fm-5_4_00\",\"gigamon-fm-5_4_00_hourly\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gitlab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gitlab-ce\"\ + ,\"gitlab-ee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"GitHub\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"GitHub-Enterprise\",\"githubenterprise-test-publishing\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"great-software-laboratory-private-limited\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"xid\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"greensql\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"greensql-database-security\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gridgain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gridgain-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"guardicore\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"guardicorecentra\"\ + ,\"infection_monkey\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"haivision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"haivision-media-gateway-1-2\",\"haivision-media-gateway-1-5\",\"haivision-media-gateway-1-6-2\"\ + ,\"media-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"h2o-ai\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"h2o-driverles-ai\",\"h2o-driverless-ai\",\"h2o-vm\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"haproxy-technologies\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hapee-rhel\",\"hapee-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"harpaitalia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mcuboenergy\"\ + ,\"yg\",\"yougreen_trial\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hcl-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"hcl17cp1104\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"heimdall-data\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"heimdall-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"help-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"goanywheremftubuntulinux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hewlett-packard\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"hpe-helion-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hillstone-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudedge-virtual-ngfw-advanced-edition\",\"cloudedge-virtual-ngfw-standard-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hortonworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbreak-for-hortonworks-data-platform\"\ + ,\"hortonworks-sandbox\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hitachi-solutions\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"credeon-sfs-and-kms-for-sharepoint-online\",\"credeonsecurefull-textsearch1_0\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hpe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storeoncevsa\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"huawei\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"euleros-v2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hyperglance\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperglance-dynamic-topology\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hypergrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperform\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hytrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hytrust-keycontrol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"ibm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ibm-security-guardium-multi-cloud\"\ + ,\"qradar_security_analytics\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"iaansys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"iaansys-magento\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"iboss\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"iboss-14600-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"imaginecommunications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudxtream-cdvr\",\"cloudxtream-dai-vms\",\"telurio-aim\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"imperva\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"imperva-dam-v13\"\ + ,\"securesphere-waf\",\"securesphere-waf-for-azr\",\"securesphere-waf-v12\"\ + ,\"securesphere-waf-v13\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"infoblox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"infoblox-vnios-te-v1420\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"informatica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"bdm10-1-1-u2\",\"big-data-management-10-2\",\"big-data-management-10-2-1\"\ + ,\"data_accelerator_for_azure_byol\",\"data_quality_10_1_1_rhel_7_3_byol\"\ + ,\"eic\",\"ics-byol\",\"ics-payg-ubuntu\",\"platform_10_1_1_multi_node_domain_rhel-7-3_byol\"\ + ,\"platform_10_2_hf1_domain_rhel-7-3_byol\",\"powercenter-v10-domain-image-ubuntu14-04-3\"\ + ,\"powercenter-v10-update1-domain-image-ubuntu\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"informationbuilders\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"iway-big-data-vm\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ingrammicro\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ingrammicroensimcentostrial\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"intel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"lustre-cloud-edition-gs-image\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"intel-bigdl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bigdl-0815\"\ + ,\"bigdl__vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intel-fpga\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"quartus_pro_opencl_sdk\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intellicus-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"intellicus_bi_server_100_user_linux\",\"intellicus_bi_server_10_user_linux\"\ + ,\"intellicus_bi_server_25_user_linux\",\"intellicus_bi_server_50_user_linux\"\ + ,\"intellicus_bi_server_5_user_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intersystems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"intersystems-iris-single-node\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intigua\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"intigua-agent-manager-3_7_0-trial\",\"intigua-agent-manager-trial\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"iquest\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"keyhub\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ishlangu-load-balancer-adc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ishlangu-load-balancer-byol\"\ + ,\"ishlangu-load-balancer-is10\",\"ishlangu-load-balancer-is100\",\"ishlangu-load-balancer-is1000\"\ + ,\"ishlangu-load-balancer-is200\",\"ishlangu-load-balancer-is5000\",\"ishlangu-load-balancer-isbfg\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"issp-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ispocr\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"itelios\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"magento2-on-zendserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jamcracker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"4632d5b4-feb0-4332-8452-f2e66133672f\",\"jamcracker-cloudanalytics\"\ + ,\"jamcracker-cloudanalytics-version4\",\"jamcracker-cloudanalytics-version5\"\ + ,\"jamcracker-csb-service-provider\",\"jamcracker-csb-serviceprovider\",\"\ + jamcracker-csb-standard\",\"jamcracker-csb-standard-v3\",\"jamcracker-csb-standard-version4\"\ + ,\"jamcracker-hybrid-cloud-management-version4\",\"jamcracker_cloud_control_appliance_version4\"\ + ,\"jsdnapp_csb_serviceprovider-version4\",\"jsdnapp_hybrid\",\"jsdnapp_hybrid_v3\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jedox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jedox-for-azure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jelastic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jelastic-hybrid-paas-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jetnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dvwa\"\ + ,\"jetnexus-application-load-balancer\",\"jetnexus-global-load-balancer\"\ + ,\"jetnexus-waf\",\"zap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jetware-srl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"caffe2\",\"caffe_python_cpu\",\"caffe_python_gpu\",\"cockroachdb\"\ + ,\"lamp_optimized\",\"lemp7_optimized\",\"memcached\",\"mongodb\",\"mxnet_python\"\ + ,\"mysql\",\"nodejs_nginx\",\"percona_mongodb\",\"percona_mysql\",\"postgresql\"\ + ,\"pytorch\",\"pytorch_cuda_notebook\",\"pytorch_cuda_production\",\"redis\"\ + ,\"redmine\",\"tensorflow_cpu_notebook\",\"tensorflow_cpu_production\",\"\ + tensorflow_cuda_notebook\",\"tensorflow_cuda_production\",\"tensorflow_python\"\ + ,\"theano_python\",\"wordpress4_lemp7\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jitterbit_integration\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"jitterbit-harmony-agent\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jm-technology-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"smart-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"juniper-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vmx-services-gateway-byol\",\"vmx-services-gateway-byol-soltemp\"\ + ,\"vmx-virtual-router\",\"vsrx-next-generation-firewall\",\"vsrx-next-generation-firewall-payg\"\ + ,\"vsrx-next-generation-firewall-solution-templ-payg\",\"vsrx-next-generation-firewall-solution-template\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"kaazing\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"kaazing-kwic\"\ + ,\"kaazing-vpa\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kali-linux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"kali-linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kemptech\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"kemp360central-byol\",\"vlm-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kinetica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"kineticadbbyol\",\"kineticadbpayasyougo\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"kaspersky_lab\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"kaspersky_secure_mail_gateway\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"knime\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"knime-server-5-user_4-4-0\"\ + ,\"knime-server-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"krypc-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"krypccore\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"leap-orbit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"leaporbitstoragebackedsftp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"leostream-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"connection-broker\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"liquid-files\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"liquidfiles\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"liquidware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stratusphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"literatu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"literatu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"loadbalancer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"loadbalancer-org-load-balancer-for-azure\",\"loadbalancer-org-load-balancer-for-azure-byol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"logsign\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logsignfocus\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"logtrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logtrust-log-management\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"looker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"looker-analytics-platform\"\ + ,\"looker-analytics-platform-326\",\"looker-analytics-platform-5_6\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"lti-lt-infotech\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"trade-finance-blockchain\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"luminate-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"luminate-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mapr-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"mapr52-base-dev\",\"mapr60-base\",\"mapr60-sandbox\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mariadb\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mariadb-server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"marklogic\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"marklogic-9-byol\"\ + ,\"marklogic-developer-9\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"massiveanalytic-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"oscarap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mathworks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"matlab-ref-arch-18a-v1-linux-disk\",\"mps-ref-arch-18a-v1-linux-disk2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"matillion\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"matillion-etl-snowflake\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"mavinglobal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mavin-business-trial\"\ + ,\"mavin-enterprise-edition\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"meanio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"gitlab-enterprise-ready\",\"linnovate-open-source-sla-pro\",\"mean-machine-20\"\ + ,\"openideal3\",\"redash\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"media3-technologies-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cpan1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"memsql\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"memsql-community-single-vm\",\"memsql-enterprise-single-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mendix\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mendix-docker\",\"mendix-pro\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"mfe_azure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"atd-mcafee\"\ + ,\"mcafee_vnsp_controller_for_azure\",\"mcafee_vnsp_for_azure\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-ads\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"linux-data-science-vm\"\ + ,\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"micro-focus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"replication_environment\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-avere\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vfxt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-azure-batch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"centos-container\",\"centos-container-rdma\",\"ubuntu-server-container\"\ + ,\"ubuntu-server-container-rdma\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-azure-compute\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azureconfidentialcompute\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azureml\",\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftAzureSiteRecovery\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ASR-Hydration-VMs\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftOSTC\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + FreeBSD\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"MLServer-CentOS\",\"MLServer-RedHat\",\"MLServer-Ubuntu\",\"RServer-CentOS\"\ + ,\"RServer-Ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"midfin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"mf_neon_cgw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"midvision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ibm-datapower-virtual-edition-75\",\"ibm-datapower-virtual-edition-76\"\ + ,\"ibm-datapower-virtual-edition-77\",\"ibm-http-server\",\"ibm-websphere-portal-server-85\"\ + ,\"ibm-websphere-portal-server-90\",\"websphere-application-server-be\",\"\ + websphere-application-server-be-80\",\"websphere-application-server-be-85\"\ + ,\"websphere-application-server-be-90\",\"websphere-application-server-be-and-mq\"\ + ,\"websphere-application-server-lp\",\"websphere-application-server-lp-16\"\ + ,\"websphere-application-server-lp-17\",\"websphere-application-server-lp-18\"\ + ,\"websphere-application-server-nde\",\"websphere-application-server-nde-80\"\ + ,\"websphere-application-server-nde-85\",\"websphere-application-server-nde-90\"\ + ,\"websphere-mq\",\"websphere-mq-75\",\"websphere-mq-90\",\"websphere-mq-91\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"miraclelinux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + asianux-server-4-sp5\",\"asianux-server-4-sp6\",\"asianux-server-4-sp7\",\"\ + asianux-server-7-sp1\",\"asianux-server-7-sp2\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"miri-infotech-pvt-ltd\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wordpress\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mobilab\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"magento-wirecard-checkout\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"moogsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moogsoft-aiops\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"moviemasher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moviemasher\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"SQL2017-RHEL7\",\"SQL2017-RHEL73\",\"SQL2017-SLES12SP2\",\"SQL2017-Ubuntu1604\"\ + ,\"SQL2019-RHEL7\",\"SQL2019-Ubuntu1604\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mtnfog\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"idyl-e3-entity-extraction-engine\",\"prose-sentence-extraction-engine\"\ + ,\"renku-language-detection-engine\",\"sonnet-tokenization-engine\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mxhero\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mail2cloud\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"my-com\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tarantool\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"narrativescience\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"narratives-for-power-bi\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"nasuni\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"nasuni-nmc\"\ + ,\"nasuni_edge_appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ncbi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + ncbi-blast-2-3-0\",\"ncbi-free-2-2-31\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nebbiolo-technologies-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"fog-system-manager\",\"fogsm_basic\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"neo4j\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"neo4j-enterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netapp\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netapp-altavault-cloud-integrated-storage-solution\"\ + ,\"netapp-oncommand-cloud-manager\",\"netapp-ontap-cloud\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netgate\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netgate-pfsense-azure-fw-vpn-router\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"netiq\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"replication_environment\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"netscout\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netscout_virtual_ngeniusone_with_vscout\"\ + ,\"netscout_vstream\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netmail\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"netmail-search\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netsweeper\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"netsweeper6-0-6\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netx\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + simplehelp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"neusoft-neteye\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"neusoft-nisg-va-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nginxinc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nginx-plus-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nicepeopleatwork\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"youzana\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nodejsapi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"node-js-api\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"noobaa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"noobaa-hybrid-s3-archive-05\",\"noobaa-multi-cloud-deduplication\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"northbridge-secure\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netconnect1\",\"netconnectx\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"nubeva-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"controller\"\ + ,\"test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nuco-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aionnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nuxeo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nuxeo-6-lts\",\"nuxeo-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nvidia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ngc_azure_17_11\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"o2mc-real-time-data-platform\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"o2mc-platform-app\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"oceanblue-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"obc-sdwan-solutions\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"omega-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ods_datastage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"onyx-point-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"op-bnf-v1\",\"op-bnf1_6-v1\",\"op-bpnifi-v1\",\"op-bpnifi16-v1\"\ + ,\"op-scc-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"onapsis\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"op5\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + op5-monitor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"opencell\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"meveo\",\"meveo403sp2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"openvpn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openvpnas\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Oracle-Database-Ee\"\ + ,\"Oracle-Database-Se\",\"Oracle-Linux\",\"Oracle-WebLogic-Server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"orientdb\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"orientdb-community-edition\"\ + ,\"orientdb-community-edition-2_2\",\"orientdb-enterprise-edition-2_2\",\"\ + orientdb-enterprise-edition-2_2_17\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"osirium-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"osirium-pxm-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"osnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"quantastorvsav4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"paloaltonetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"panorama\",\"vmseries1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"panzura-file-system\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azura-freedom-filer-v7110\",\"panzura-cloud-filer\",\"panzura-freedom-filer-7140-13222\"\ + ,\"panzura-freedom-filer-716-13549\",\"panzura-freedom-filer-v7020\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"parasoft\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"parasoft-service-virtualization\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"passlogy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"passlogic\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"penta-security-systems-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"wapples\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"percona\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"percona-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"postgres-pro\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"postgres-pro-enterprise\",\"postgres-pro-enterprise-10\",\"postgres-pro-standard\"\ + ,\"postgres-pro-standard-10\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"plesk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"plesk-onyx-linux\",\"solution-server-business\",\"solution-server-wordpress\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"prestashop\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"prestashop16-lamp\"\ + ,\"ubuntu-base-for-prestashop\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"prime-strategy\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"kusanagi-77\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"pivotal-gpdb-vm\",\"pivotal-greenplum-images\",\"pivotal-ops-manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"process-one\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ejabberd-community-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"profecia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"full_disk_encryption_vm\"\ + ,\"project_tools_vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"progelspa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"libra-esva-antispam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ptsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ptaf-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"pulse-secure\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"pulse-connect-secure-vm\",\"pulse-virtual-traffic-manager\",\"\ + pulse-virtual-traffic-manager-with-waf\",\"pulse-virtual-traffic-manager-with-waf2\"\ + ,\"pulse-virtual-traffic-manager2\",\"pulse-virtual-web-application-firewall\"\ + ,\"pulse-virtual-web-application-firewall2\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"PuppetLabs\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"PuppetEnterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"puppet\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"puppet-enterprise\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"pydio\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"pydio-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"qore-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"qorus\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"qualysguard\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"qualys-virtual-firewall-appliance\",\"qualys-virtual-scanner-v23b\"\ + ,\"qualys-virtual-scanner-v24\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"quasardb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"quasardb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"qubole-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"qubole-data-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"quest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"fve\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"racknap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"racknap-server\",\"racknap-server-linux\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"radware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"radware-alteon-va\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"radiant-logic\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"radiantone-vms\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rancher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"rancheros\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rapid7\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nexpose-scan-engine\",\"rapid7-vm-console\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"rapidminer\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"rapidminer_server_75\",\"rapidminer_server_76\"\ + ,\"rapidminer_server_80\",\"rapidminer_server_81\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"realm\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"realm-mobile-platform\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"reblaze\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"rbzr-image\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"RHEL\",\"rhel-byos\"\ + ,\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"relevance-lab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + rlcatalyst\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"remotelearner\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"fully-supported-moodle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"revolution-analytics\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"revolution-r-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RightScaleLinux\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"RightImage-CentOS\",\"RightImage-Ubuntu\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RiverbedTechnology\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"steelapp_traffic_manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"riverbed\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"riverbed-sccm-5-5-1\"\ + ,\"riverbed-steelcentral-appinternals\",\"riverbed-steelhead-9-2\",\"riverbed-steelhead-9-5-0\"\ + ,\"riverbed-steelhead-9-6-0\",\"riverbed_steelconnect_gw\",\"riverbed_steelconnect_sh\"\ + ,\"steelapp_traffic_manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rocketsoftware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"rocket-discover\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rsa-security-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"rsa-nw-azure-arch\",\"rsa-nw-azure-broker\",\"rsa-nw-azure-con\"\ + ,\"rsa-nw-azure-esa\",\"rsa-nw-azure-ldec\",\"rsa-nw-azure-vlc\",\"rsa-nw-suite-11\"\ + ,\"rsa-nw-suite-11-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rsk-labs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"rsk-bamboo-beta-node\",\"rsk-node-orchid\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"saama\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"fluidanalyticsengine\",\"insurancefraudanalytics\"\ + ,\"realworldevidence\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"saltstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos65saltstackenterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scalearc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"scalearc-for-mysql-paygo\",\"scalearc-for-sql-server-pay-go\",\"scalearc_mysql-server\"\ + ,\"scalearc_sql_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scalegrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + hanaexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scality\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"scalityconnecthourly\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"secureworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"scwx-azure-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"shadow-soft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"icinga\",\"icinga2-5\",\"icinga2-7\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"signal-sciences\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"signalscienceswpp\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"sightapps\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sightapps\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"silver-peak-systems\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"silver_peak_edgeconnect\"\ + ,\"silver_peak_vx\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"simmachinesinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"simmachines_vm_v2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sinefa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"sinefa-probe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"skyarc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"mt6\",\"mta\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"smartmessage-autoflow\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"martmessage-autoflow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"snapt-adc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"snaptadc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"soasta\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloudtest-lite\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"softnas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloud_dev\",\"mp_ce\",\"mp_ent\",\"mp_nas_byol\",\"mp_nas_ep\",\"mp_nas_gp\"\ + ,\"mp_nas_hp\",\"mp_plat\",\"private_offerings\",\"softnas-cloud\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"solanolabs\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"solano-ci-private-beta\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"soha\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"soha-cloud\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"solar-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + solar-incode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sonicwall-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"sonicwall-nsz-azure\",\"waf\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sophos\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"sophos-xg\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"spagobi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"spagobi\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"spacecurve\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"spacecurve-quickstart\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"splunk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"splunk-enterprise-base-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"src-solution\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"pilot-things-onem2m-smart-network\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sqlstream\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"com\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sphere3d\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"snapcloud-byol\",\"snapcloud-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"stackato-platform-as-a-service\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"activestate-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stackstorm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stackstorm-2015-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"startekfingerprintmatch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"bioserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ + ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ + ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ + ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ + ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ + ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ + ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ + ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ + teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ + ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ + ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ + ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ + ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ + ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ + vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ + ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ + ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ + ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ + ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ + ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ + ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ + ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ + ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ + ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ + ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ + triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ + ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/14aa400da6f9a869\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"14aa400da6f9a869\"\ + },{\"properties\":{\"displayName\":\"antimalware signature extension autoupdate\ + \ policy for iaas_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2020-11-09T17:52:48.7155803Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"tagname\"\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\",\"\ - in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[', parameters('tagname'),\ - \ ']')]\",\"exists\":\"false\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + \ Machine\"}},\"subscriptiontagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the subscription level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Subscription\"}}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"not\":{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ + :\"MicrosoftWindowsServer\"}]},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration.provisionVMAgent\"\ ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"name\"\ - :\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"existenceCondition\":{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + :{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"Microsoft.Azure.Security.AntimalwareSignature.AntimalwareConfiguration\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ + ,\"equals\":\"AntimalwareConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Security.AntimalwareSignature\"},{\"field\"\ + :\"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade\",\"\ + equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ - :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ - :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{}}}]},\"parameters\":{\"\ - vmssName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/a646ce8cd06eac96\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"a646ce8cd06eac96\"\ - },{\"properties\":{\"displayName\":\"sqlads-auditifnotexists-atp types should\ - \ be set to 'all' in sql server advanced data security settings_1.0\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-06-10T02:12:40.6774801Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"tagname\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ - \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ - \ the SQL Server\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2018-10-01\"\ + ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.Azure.Security.AntimalwareSignature.AntimalwareConfiguration')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ + [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Security.AntimalwareSignature\"\ + ,\"type\":\"AntimalwareConfiguration\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":true,\"settings\":{},\"protectedSettings\"\ + :{}}}]},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ + :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1617f211dede4300\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1617f211dede4300\"\ + },{\"properties\":{\"displayName\":\"nrms-hdinsight-require-subnet_1.2\",\"\ + policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-02-24T19:32:57.4990001Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Sql/servers\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('tagname'), ']')]\",\"exists\"\ - :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().tags[parameters('tagname')]]\"\ - ,\"equals\":\"\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\",\"name\":\"default\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/disabledAlerts[*]\"\ - ,\"equals\":\"\"}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ac3fc8ad361a9985\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ac3fc8ad361a9985\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ + policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"tags['NRMSVNetIntException']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['NRMSVNetIntException']]\",\"equals\":\"\"},{\"field\"\ + :\"tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ + false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ + equals\":\"\"},{\"not\":{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ + ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ + ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b0f9cd579f5f04a\"\ },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for iaas_1.0\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ + \ append policy for vmss_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-07-12T00:29:57.8179024Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + :\"2020-06-23T19:35:01.9059556Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname1\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"resourcegrouptagname2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\"\ + ,\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ + \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags[parameters('resourcegrouptagname1')]]\",\"equals\"\ + :\"\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname2')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ - name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2018-10-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{},\"protectedSettings\"\ - :{}}}]},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b1d9e961d02c54d5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b1d9e961d02c54d5\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-106_1.1\",\"policyType\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"VirtualMachineRuntimeService\"},{\"not\":{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ + field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ + ,\"value\":{\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"properties\"\ + :{\"publisher\":\"Microsoft.Azure.Geneva\",\"type\":\"GenevaMonitoring\",\"\ + typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ + :{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b5a57eabcce7d7d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"1b5a57eabcce7d7d\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-102_1.2\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:22.7538641Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2019-07-09T18:15:23.2021003Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -35510,12 +17026,13 @@ interactions: ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ + destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Port Number\",\"description\":\"Security rule port numbers must match these\ + \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ + \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ + protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ @@ -35544,9 +17061,9 @@ interactions: ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ @@ -35580,95 +17097,165 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b4482f205fb6bbc1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b4482f205fb6bbc1\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for iaas_1.1\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-08-13T21:33:07.0355992Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/21f42d11eb755867\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"21f42d11eb755867\"\ + },{\"properties\":{\"displayName\":\"azuremonitorlinuxagent extension autoupdate\ + \ policy for vmss_1.3\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-02-09T20:11:42.131772Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"tagname\"\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Compute/virtualMachines\"},{\"field\":\"location\",\"in\":\"\ - [parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[', parameters('tagname'),\ - \ ']')]\",\"exists\":\"false\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration.provisionVMAgent\"\ - ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"AzureMonitorLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitor\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2018-10-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{},\"protectedSettings\"\ - :{}}}]},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b70c6f621534db23\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b70c6f621534db23\"\ - },{\"properties\":{\"displayName\":\"nrms-hdinsight-require-subnet_1.0\",\"\ - policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-06-26T21:23:22.8439408Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"not\":{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.HDInsight/clusters\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet\"\ - ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b7a0969ff954eaf7\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b7a0969ff954eaf7\"\ - },{\"properties\":{\"displayName\":\"nrms-subnet-require-nsg_1.0\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-04-01T22:24:01.4784818Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ - },{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ + string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ + :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Monitor.AzureMonitorLinuxAgent')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Monitor\"\ + ,\"type\":\"AzureMonitorLinuxAgent\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":false,\"settings\":{\"GCS_AUTO_CONFIG\":true},\"\ + protectedSettings\":{}}}]},\"parameters\":{\"vmssName\":{\"value\":\"[field('name')]\"\ + },\"location\":{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/24c7d4ccd439d601\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"24c7d4ccd439d601\"\ + },{\"properties\":{\"displayName\":\"nrms-kubernet-require-azure-networkplugin_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-04-01T22:23:57.6004986Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ + :\"The list of locations that can be specified when deploying resources.\"\ + ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Network/virtualNetworks/subnets\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"false\"}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b8f1faa61cb41f92\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on new vms_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ - \ any Linux VMs use password-only authentication for SSH on new resources.\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-02-25T22:01:41.9137032Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ - displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + :\"Microsoft.ContainerService/managedClusters\"},{\"field\":\"location\",\"\ + in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ + ,\"equals\":\"azure\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"26db8d27b6fa91aa\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on existing resources_1.1\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ + \ audits whether any Linux VMs use password-only authentication for SSH on\ + \ existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2019-12-06T21:04:41.4787743Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ + \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ + \ group level\",\"description\":\"Rule is not deployed if this tag exists\ + \ on the Resource Group\"}}},\"policyRule\":{\"if\":{\"allof\":[{\"field\"\ + :\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ + \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\",\"notEquals\"\ + :\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ + ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/28b685eba93cc71f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"28b685eba93cc71f\"\ + },{\"properties\":{\"displayName\":\"require ssh key for authentication on\ + \ linux vmss_1.7\",\"policyType\":\"Custom\",\"mode\":\"All\",\"description\"\ + :\"This policy denies the creation of Linux VMSS which use password-only authentication\ + \ for SSH. Use of SSH key is more secure than passwords. To unblock, do not\ + \ use password for SSH authentication.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2021-01-07T02:55:13.5943489Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Policy exclusion Tag Name at the resource level\",\"description\":\"Rule\ + \ is not deployed if this tag exists on the Virtual Machine\"}},\"resourcegrouptagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Policy exclusion Tag\ + \ Name at the resource group level\",\"description\":\"Rule is not deployed\ + \ if this tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"\ + type\":\"String\",\"metadata\":{\"displayName\":\"Policy exclusion Tag Name\ + \ at the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ + :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ @@ -36825,12 +18412,147 @@ interactions: ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b9c65c79770e8c51\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"b9c65c79770e8c51\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-104_1.3\",\"policyType\"\ + :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"deny\"}}},\"id\"\ + :\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/2c943a16e7c448e2\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2c943a16e7c448e2\"\ + },{\"properties\":{\"displayName\":\"antimalware signature extension autoupdate\ + \ policy for vmss_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2020-11-09T17:52:50.9015805Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"subscriptiontagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the subscription level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Subscription\"}}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ + :{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"existenceCondition\"\ + :{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"AntimalwareConfiguration\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Security.AntimalwareSignature\"},{\"field\"\ + :\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ + ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"VirtualMachineRuntimeService\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Compute\"}]}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ + string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ + :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Security.AntimalwareSignature.AntimalwareConfiguration')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Security.AntimalwareSignature\"\ + ,\"type\":\"AntimalwareConfiguration\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":true,\"settings\":{}}}]},\"parameters\":{\"\ + vmssName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/2f07775c21cd6709\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"2f07775c21cd6709\"\ + },{\"properties\":{\"displayName\":\"azuresecuritylinuxagent extension autoupdate\ + \ policy for vmss_1.4\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-02-23T21:10:01.7361227Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"AzureSecurityLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Security.Monitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ + ,\"equals\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/provisioningState\"\ + ,\"in\":[\"Succeeded\",\"Provisioning succeeded\"]}]},\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ + string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ + :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Security.Monitoring\"\ + ,\"type\":\"AzureSecurityLinuxAgent\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":true,\"settings\":{\"enableGenevaUpload\"\ + :true},\"protectedSettings\":{}}}]},\"parameters\":{\"vmssName\":{\"value\"\ + :\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"}}}}}}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/333f0941c3c4e54b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"333f0941c3c4e54b\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-101_1.1\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:20.3270264Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2019-07-08T19:20:14.0863618Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -36838,13 +18560,12 @@ interactions: ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ + :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ + ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ + }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ @@ -36855,29 +18576,27 @@ interactions: String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ + \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ + ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ + ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ + SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ + ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ + :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ + ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ @@ -36911,31 +18630,31 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bac0fb65020410a4\"\ - },{\"properties\":{\"displayName\":\"deny creation of new linux vms with ssh\ - \ password auth_1.5\",\"policyType\":\"Custom\",\"mode\":\"All\",\"description\"\ - :\"This policy denied the creation of Linux VMs which use password-only authentication\ - \ for SSH.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-07-14T00:05:21.8198103Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ - metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ - }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ - ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/34612a1acdd0093\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"34612a1acdd0093\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on new vmss_1.5\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ + \ any Linux VMSSs use password-only authentication for SSH on new resources.\"\ + ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-01-20T00:19:26.7056996Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ + :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ @@ -38092,34 +19811,97 @@ interactions: ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"deny\"}}},\"id\"\ - :\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bfa798085e63e6b3\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"bfa798085e63e6b3\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on existing vms_1.3\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMs use password-only authentication for SSH on\ - \ existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-25T22:01:38.4305071Z\",\"updatedBy\":null,\"updatedOn\"\ + :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/39b5e567c27d8441\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"39b5e567c27d8441\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-103_1.4\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-02-24T21:27:38.9264536Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}}},\"policyRule\":{\"if\":{\"allof\":[{\"field\"\ - :\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ - },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c2f5d119c894ce34\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c2f5d119c894ce34\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-107_1.2\",\"policyType\"\ + }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ + ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ + :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ + ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ + destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Port Number\",\"description\":\"Security rule port numbers must match these\ + \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ + \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ + protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ + ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ + ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ + :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ + allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ + \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ + :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ + tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ + false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ + equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ + [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ + ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ + equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ + },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ + ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ + ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ + string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ + :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ + String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ + :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ + }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ + ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ + ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ + \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ + \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ + :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ + :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ + ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ + :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ + sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ + \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ + :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ + ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ + \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ + :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ + \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ + \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ + :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ + ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ + }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ + :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ + :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ + },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ + :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ + [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"3c07197392ad62f\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-105_1.1\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:32.278708Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2019-07-08T19:20:18.4394851Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -38127,13 +19909,12 @@ interactions: ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ + :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ + ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ + }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ @@ -38162,9 +19943,9 @@ interactions: ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ @@ -38198,58 +19979,13 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c4184f404efb2fe5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c4184f404efb2fe5\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for iaas_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-06-23T19:35:05.015959Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ - ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ - \ Machine\"}},\"resourcegrouptagname1\":{\"type\":\"String\",\"metadata\"\ - :{\"displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"resourcegrouptagname2\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ - \ the resource group level\",\"description\":\"Rule is not deployed if this\ - \ tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription\ - \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ - \ Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Compute/virtualMachines\"},{\"field\":\"location\"\ - ,\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname1')]]\",\"equals\"\ - :\"\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname2')]]\"\ - ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ - ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration.provisionVMAgent\"\ - ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ - :{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\"\ - ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ - },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2018-10-01\"\ - ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ - [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{},\"protectedSettings\"\ - :{}}}]},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"},\"location\"\ - :{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c6cc0ff730a1cb3c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c6cc0ff730a1cb3c\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on new vmss_1.3\",\"policyType\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/40879463350508de\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"40879463350508de\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on new vmss_1.4\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ \ any Linux VMSSs use password-only authentication for SSH on new resources.\"\ ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2020-02-25T22:01:43.9041265Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + :\"2020-05-12T23:41:52.0436302Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ :\"Allowed locations\",\"description\":\"The list of locations that can be\ \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ @@ -38257,10 +19993,14 @@ interactions: ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ - :\"Rule is not deployed if this tag exists on the Resource Group\"}}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ - exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ + :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ @@ -39421,52 +21161,227 @@ interactions: :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c901e756f9e2e56e\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"c901e756f9e2e56e\"\ - },{\"properties\":{\"displayName\":\"nrms-kubernet-require-azure-networkplugin_1.2\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2020-02-24T19:33:00.4442389Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/408b8964022134ba\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"408b8964022134ba\"\ + },{\"properties\":{\"displayName\":\"sqlads-auditifnotexists-vulnerability\ + \ assessment should be enabled on your sql servers_1.0\",\"policyType\":\"\ + Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-06-10T02:12:37.034264Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"tagname\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the SQL Server\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ + AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.Sql/servers\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"[concat('tags[', parameters('tagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"\ + equals\":\"\"},{\"value\":\"[subscription().tags[parameters('tagname')]]\"\ + ,\"equals\":\"\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ + :{\"type\":\"Microsoft.Sql/servers/vulnerabilityAssessments\",\"name\":\"\ + default\",\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/vulnerabilityAssessments/recurringScans.isEnabled\"\ + ,\"equals\":\"True\"}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/410c2966a1e1856e\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"410c2966a1e1856e\"\ + },{\"properties\":{\"displayName\":\"antimalware signature extension append\ + \ policy for vmss_1.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2020-11-09T17:52:49.9416607Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"subscriptiontagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the subscription level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Subscription\"}}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"tags['NRMSVNetIntException']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['NRMSVNetIntException']]\",\"equals\":\"\"},{\"field\"\ - :\"tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.ContainerService/managedClusters\"},{\"field\":\"location\",\"\ - in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ - ,\"equals\":\"azure\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cb9c916fd4b6c323\"\ - },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_2.0\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-08-08T22:25:06.8419431Z\"\ - ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ - :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ - \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ - type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ - :\"The list of locations that can be specified when deploying resources.\"\ - ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts/pools\"},{\"field\":\"\ - location\",\"in\":\"[parameters('allowedLocations')]\"},{\"anyOf\":[{\"field\"\ - :\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\",\"\ - exists\":\"false\"},{\"field\":\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\"\ - ,\"in\":[\"null\",\"\"]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cdd4d274005fb67b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"cdd4d274005fb67b\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-108_1.1\",\"policyType\"\ + field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"AntimalwareConfiguration\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"VirtualMachineRuntimeService\"},{\"not\":{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ + field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ + ,\"value\":{\"name\":\"Microsoft.Azure.Security.AntimalwareSignature.AntimalwareConfiguration\"\ + ,\"properties\":{\"publisher\":\"Microsoft.Azure.Security.AntimalwareSignature\"\ + ,\"type\":\"AntimalwareConfiguration\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"settings\":{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/427e2c6bc663a962\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"427e2c6bc663a962\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-103_1.1\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2019-07-08T19:20:16.1955196Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ + ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ + :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ + ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ + :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ + ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ + }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ + ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ + ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ + :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ + allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ + \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ + ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ + ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ + SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ + },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ + ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ + :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ + ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ + equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ + },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ + ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ + ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ + ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ + ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ + string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ + :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ + String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ + :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ + }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ + ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ + ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ + \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ + \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ + :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ + :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ + ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ + :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ + sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ + \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ + :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ + ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ + \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ + :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ + \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ + \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ + :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ + ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ + }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ + :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ + :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ + },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ + :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ + [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/42c70bae0daee0b3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"42c70bae0daee0b3\"\ + },{\"properties\":{\"displayName\":\"azuremonitorlinuxagent append policy\ + \ for vmss_1.4\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"metadata\"\ + :{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"\ + 2021-02-23T21:10:00.863114Z\",\"updatedBy\":null,\"updatedOn\":null},\"parameters\"\ + :{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ + Allowed locations\",\"description\":\"The list of locations that can be specified\ + \ when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"AzureMonitorLinuxAgent\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ + field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ + ,\"value\":{\"name\":\"Microsoft.Azure.Monitor.AzureMonitorLinuxAgent\",\"\ + properties\":{\"publisher\":\"Microsoft.Azure.Monitor\",\"type\":\"AzureMonitorLinuxAgent\"\ + ,\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ + :{\"GCS_AUTO_CONFIG\":true}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/440b823a6219927\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"440b823a6219927\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-108_1.3\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:25.3178329Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2020-02-24T21:28:59.0487626Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -39474,12 +21389,13 @@ interactions: ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ + destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Port Number\",\"description\":\"Security rule port numbers must match these\ + \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ + \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ + protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ @@ -39490,27 +21406,29 @@ interactions: String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ + \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ + :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ + tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ + false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ + equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ + [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ @@ -39544,49 +21462,50 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ce4b13eba037b5cc\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"ce4b13eba037b5cc\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on existing vmss_1.3\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMSSs use password-only authentication for SSH\ - \ on existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-25T22:01:41.6737137Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}}},\"policyRule\":{\"if\":{\"allof\":[{\"field\"\ - :\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration\"\ - ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ - ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/d950db6f06d4cd0c\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d950db6f06d4cd0c\"\ - },{\"properties\":{\"displayName\":\"audit ssh auth on new resources_1.1\"\ - ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ - \ audits whether any Linux VMs use password-only authentication for SSH on\ - \ new resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-12-06T21:04:41.4948364Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ - \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ - \ group level\",\"description\":\"Rule is not deployed if this tag exists\ - \ on the Resource Group\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ - :\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ - \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\",\"notEquals\"\ - :\"\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.adminPassword\"\ - ,\"exists\":\"True\"},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"532396f35af78946\"\ + },{\"properties\":{\"displayName\":\"audit soft delete enabled on key vault_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"description\":\"Audit Soft\ + \ Delete must be enabled on all key vaults\",\"metadata\":{\"version\":\"\ + 1.0.0\",\"category\":\"Key Vault\",\"preview\":false,\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-09-01T00:04:03.801713Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"audit\",\"Disabled\"],\"defaultValue\":\"audit\"},\"\ + allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed\ + \ locations\",\"description\":\"The list of locations that can be specified\ + \ when deploying resources.\",\"strongType\":\"location\"}}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.KeyVault/vaults\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + anyOf\":[{\"field\":\"Microsoft.KeyVault/vaults/enableSoftDelete\",\"exists\"\ + :\"false\"},{\"field\":\"Microsoft.KeyVault/vaults/softDeleteRetentionInDays\"\ + ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5353f06bfd8b6546\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5353f06bfd8b6546\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on new vms_1.4\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"description\":\"This policy audits whether\ + \ any Linux VMs use password-only authentication for SSH on new resources.\"\ + ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2020-05-12T23:41:56.0529781Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\"\ + :\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ @@ -40563,514 +22482,213 @@ interactions: ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ - ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ - ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ - ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ - ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ - Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ - Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ - ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ - ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ - ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ - teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ - ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ - ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ - ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ - ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ - ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ - vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ - :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ - field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ - ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ - ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ - ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ - ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ - in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ - ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ - ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ - ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ - ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ - ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ - equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ - ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ - ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ + :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ + :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ + :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ - triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ - field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ - :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ - :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ + :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ - allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ - },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ - ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ - z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ - ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ - ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ - :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/d974fab8daefe230\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"d974fab8daefe230\"\ - },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ - \ autoupdate policy for vmss_2.0\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ - ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ - :\"2019-07-12T00:29:56.9604539Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ - parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ - ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ - :\"MicrosoftWindowsServer\"}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ - ,\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"existenceCondition\"\ - :{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ - ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ - ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ - ,\"equals\":\"true\"}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ - ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ - $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ - string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ - :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ - ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ - :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ - ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ - :true,\"enableAutomaticUpgrade\":true,\"settings\":{}}}]},\"parameters\":{\"\ - vmssName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ - }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/dac4e4f8ad529fe5\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"dac4e4f8ad529fe5\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-109_1.3\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:28:52.5486159Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e0bc08af3bd773ff\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-103_1.2\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:24.0068177Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e24b2791c9576d86\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e24b2791c9576d86\"\ - },{\"properties\":{\"displayName\":\"sqlads-auditifnotexists-advanced data\ - \ security should be enabled on your sql servers_1.0\",\"policyType\":\"Custom\"\ - ,\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-06-10T02:12:35.0244464Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"tagname\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ - \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ - \ the SQL Server\"}},\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"AuditIfNotExists\",\"Disabled\"],\"defaultValue\":\"\ - AuditIfNotExists\"}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ - ,\"equals\":\"Microsoft.Sql/servers\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"field\":\"[concat('tags[', parameters('tagname'), ']')]\",\"exists\"\ - :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().tags[parameters('tagname')]]\"\ - ,\"equals\":\"\"}]},\"then\":{\"effect\":\"[parameters('effect')]\",\"details\"\ - :{\"type\":\"Microsoft.Sql/servers/securityAlertPolicies\",\"name\":\"Default\"\ - ,\"existenceCondition\":{\"field\":\"Microsoft.Sql/servers/securityAlertPolicies/state\"\ - ,\"equals\":\"Enabled\"}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e3cff6e23ce4018a\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e3cff6e23ce4018a\"\ - },{\"properties\":{\"displayName\":\"nrms-warning-non-c+ai-security-rules_1.0\"\ + :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ + ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ + ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ + ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ + ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ + ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ + ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ + ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ + teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ + ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ + ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ + ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ + ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ + ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ + vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ + ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ + ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ + ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ + ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ + ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ + ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ + ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ + ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ + ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ + ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ + triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ + ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/566405fe94cbf731\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"566405fe94cbf731\"\ + },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_2.1\"\ ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ - 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-04-01T22:23:58.9310187Z\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2020-02-24T19:32:58.4608022Z\"\ ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ - Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"priorities\":{\"type\"\ - :\"Array\",\"metadata\":{\"displayName\":\"Rule Priority\",\"description\"\ - :\"List of Rule Priority Numbers reserved for Security\"}},\"allowedLocations\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ - description\":\"The list of locations that can be specified when deploying\ - \ resources.\",\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\"\ - :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"In\":\"[parameters('priorities')]\"},{\"field\":\"location\",\"In\":\"\ - [parameters('allowedLocations')]\"},{\"allOf\":[{\"not\":{\"field\":\"name\"\ - ,\"contains\":\"Cleanuptool\"}},{\"not\":{\"field\":\"name\",\"contains\"\ - :\"NRMS-Rule-\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ - id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e695de0794b757d\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-102_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:16.2005161Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e788a85b5ac6ce0f\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"e788a85b5ac6ce0f\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-109_1.2\",\"policyType\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ + :\"The list of locations that can be specified when deploying resources.\"\ + ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts/pools\"},{\"field\":\"\ + location\",\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"tags['NRMSVNetIntException']\"\ + ,\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['NRMSVNetIntException']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ + },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\"\ + ,\"exists\":\"false\"},{\"field\":\"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId\"\ + ,\"in\":[\"null\",\"\"]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5aac1290d24c772d\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-101_1.2\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:36.1193587Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2019-07-09T18:15:18.6642999Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -41149,11 +22767,1558 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/eb9b3ba85853f934\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eb9b3ba85853f934\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-104_1.2\",\"policyType\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5d9c8a259a63a29b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5d9c8a259a63a29b\"\ + },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ + \ append policy for vmss_1.0\",\"policyType\":\"Custom\",\"mode\":\"All\"\ + ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2019-07-12T00:29:53.2880644Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"GenevaMonitoring\"}]},\"then\":{\"effect\":\"append\",\"\ + details\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ + ,\"value\":{\"name\":\"Microsoft.Azure.Geneva.GenevaMonitoring\",\"properties\"\ + :{\"publisher\":\"Microsoft.Azure.Geneva\",\"type\":\"GenevaMonitoring\",\"\ + typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\":true,\"settings\"\ + :{}}}}]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5e6e7d4c3e34256b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"5e6e7d4c3e34256b\"\ + },{\"properties\":{\"displayName\":\"vmvmssfirstpartyidentificationtag_1.3\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2021-01-20T00:19:27.751475Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"tagName\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"tagName\",\"description\":\"Opted\ + \ in for PKI\"},\"defaultValue\":\"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + },\"tagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"tagValue\"\ + ,\"description\":\"is this the first party VM?\"},\"defaultValue\":\"true\"\ + },\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ + Allowed locations\",\"description\":\"The list of locations that can be specified\ + \ when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"Microsoft.Compute/virtualMachineScaleSets\"\ + ]},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ + :[\"/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"operations\":[{\"operation\":\"add\",\"field\":\"[concat('tags[', parameters('tagName'),\ + \ ']')]\",\"value\":\"[parameters('tagValue')]\"}]}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/60291f79e633326b\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"60291f79e633326b\"\ + },{\"properties\":{\"displayName\":\"nrms-warning-non-c+ai-security-rules_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:29.4182093Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"priorities\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Rule Priority\",\"description\"\ + :\"List of Rule Priority Numbers reserved for Security\"}},\"allowedLocations\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ + description\":\"The list of locations that can be specified when deploying\ + \ resources.\",\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"Inbound\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"In\":\"[parameters('priorities')]\"},{\"field\":\"location\",\"In\":\"\ + [parameters('allowedLocations')]\"},{\"allOf\":[{\"not\":{\"field\":\"name\"\ + ,\"contains\":\"Cleanuptool\"}},{\"not\":{\"field\":\"name\",\"contains\"\ + :\"NRMS-Rule-\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/6221d088cd1bcdc3\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6221d088cd1bcdc3\"\ + },{\"properties\":{\"displayName\":\"azuresecuritylinuxagent extension append\ + \ policy for vmss_1.3\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-02-09T20:11:41.4287944Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"AzureSecurityLinuxAgent\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ + field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]\"\ + ,\"value\":{\"name\":\"Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent\"\ + ,\"properties\":{\"publisher\":\"Microsoft.Azure.Security.Monitoring\",\"\ + type\":\"AzureSecurityLinuxAgent\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"settings\":{\"enableGenevaUpload\":true},\"protectedSettings\":{}}}}]}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/670f727baca67e29\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"670f727baca67e29\"\ + },{\"properties\":{\"displayName\":\"nrms-warning-non-c+ai-security-rules_1.3\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2020-02-24T19:33:58.9010954Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"priorities\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Rule Priority\",\"description\"\ + :\"List of Rule Priority Numbers reserved for Security\"}},\"allowedLocations\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ + description\":\"The list of locations that can be specified when deploying\ + \ resources.\",\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ + ,\"equals\":\"Inbound\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"In\":\"[parameters('priorities')]\"},{\"field\":\"location\",\"In\":\"\ + [parameters('allowedLocations')]\"},{\"field\":\"tags['autopilotcluster']\"\ + ,\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ + false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ + equals\":\"\"},{\"allOf\":[{\"not\":{\"field\":\"name\",\"contains\":\"Cleanuptool\"\ + }},{\"not\":{\"field\":\"name\",\"contains\":\"NRMS-Rule-\"}}]}]},\"then\"\ + :{\"effect\":\"[parameters('effect')]\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"686f7311dc548f32\"\ + },{\"properties\":{\"displayName\":\"deny creation of new linux vmss with\ + \ ssh password auth_1.5\",\"policyType\":\"Custom\",\"mode\":\"All\",\"description\"\ + :\"This policy audits whether any Linux VMSSs use password-only authentication\ + \ for SSH on new resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-07-14T00:05:22.7366216Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ + \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ + \ group level\",\"description\":\"Rule is not deployed if this tag exists\ + \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ + metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ + }}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ + exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"anyof\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"exists\":\"False\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"equals\":\"false\"}]},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"7isolutions\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"sapp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"128technology\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"128t_networking_platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"4psa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + voipnow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"a10networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"a10-lightning-adc\",\"a10-vthunder-adc\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"accellion\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"kiteworks-by-accellion\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"abiquo\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"abiquo-hybrid-cloud-34\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"accops\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hysecure5050\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"actian_matrix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + actian_matrix\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"actifio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"actifio-sky\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"actian-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"vector-community\",\"vector-enterprise\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"Acronis\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"storage\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"activeeon\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"activeeon-workload-scheduler\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"aerospike\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"aerospike-database-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"affinio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"platform\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"aiscaler-cache-control-ddos-and-url-rewriting-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aimobile-site-acceleration\",\"aiprotect-ddos-firewall\",\"aiscaler-traffic-manager-caching\"\ + ,\"aivideo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"akamai-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"enterprise-application-access\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"alces-flight-limited\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"alces-flight-compute-solo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"alertlogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"alert-logic-tm\",\"alert-logic-wsm\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"alienvault\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"unified-security-management-anywhere\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"alldigital-brevity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"alldigital-brevity-uploader\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"altair-engineering-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"altair_hwulva\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"altamira-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"lumify\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"antmedia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ams_community_edition\",\"ant_media_server_enterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"apigee\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"apigee-edge\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcara\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"app360v43-001\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"appcelerator\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appcelerator-arrow-azure-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"appex-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cloudexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"appistry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"genomepilot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"appscale-marketplace\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"appscale\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"arangodb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"arangodb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"arista-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"veos-router\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"array_networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"array-networks-vapv\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"astadia-1148316\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"astadia-ui-automation-tee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"atomicorp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"secure-os\",\"secure-ubuntu-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"audiocodes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"mediantsessionbordercontroller\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"auriq-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"essentia\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"awingu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"awingu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"aviatrix-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aviatrix-cloud-services\",\"aviatrix-companion-gateway\",\"aviatrix-companion-gateway-v2\"\ + ,\"aviatrix-vpn-gw\",\"aviatrix_multi_cloud_service\",\"aviatrix_openvpn_service\"\ + ,\"aviatrix_openvpn_service10\",\"aviatrix_openvpn_service25\",\"aviatrix_openvpn_service50\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"avi-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + avi-vantage-adc\",\"internal-avi-vantage-adc\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"axway\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"axway-mailgate-secure-collaboration-advanced\"\ + ,\"axway-mailgate-secure-collaboration-premium\",\"axway-mailgate-secure-collaboration-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"azul\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"azul-zulu-ubuntu-1804\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"azurecyclecloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + azure-cyclecloud-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"AzureDatabricks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Databricks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"baas-techbureau\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"b1327623-d29b-4cc1-b833-85067dcc7bce\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"baffle-io\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"baffle-application-data-protection\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"balabit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"balabit-shell-control-box\"\ + ,\"psm\",\"sps\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"barracudanetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"barracuda-app-sec-control-center\",\"barracuda-email-security-gateway\"\ + ,\"barracuda-ng-cc\",\"barracuda-ng-firewall\",\"waf\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"basho\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"riak-2-0-1\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"batch\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"autodesk-maya-arnold-centos73\"\ + ,\"rendering-centos73\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"bdy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + buddy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"Bitnami\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + 3-4\",\"abantecart\",\"activemq\",\"akeneo\",\"alfrescocommunity\",\"apachesolr\"\ + ,\"artifactory\",\"canvaslms\",\"cassandra\",\"civicrm\",\"cmsmadesimple\"\ + ,\"codiad\",\"concrete5\",\"consul\",\"coppermine\",\"couchdb\",\"diaspora\"\ + ,\"discourse\",\"djangostack\",\"dokuwiki\",\"dolibarr\",\"DreamFactory\"\ + ,\"drupal\",\"elastic-search\",\"elk\",\"erpnext\",\"espocrm\",\"etcd\",\"\ + eXo-Platform\",\"exoplatform\",\"fatfreecrm\",\"ghost\",\"gitlab\",\"grafana\"\ + ,\"hadoop\",\"hhvmstack\",\"hordegroupwarewebmail\",\"jasperreports\",\"jenkins\"\ + ,\"joomla\",\"jrubystack\",\"kafka\",\"kong\",\"kubernetessandbox\",\"lampstack\"\ + ,\"lappstack\",\"letschat\",\"liferay\",\"limesurvey\",\"livehelperchat\"\ + ,\"magento\",\"mahara\",\"mantis\",\"mariadb\",\"mattermost\",\"mautic\",\"\ + mean\",\"mediawiki\",\"memcached\",\"modx\",\"mongodb\",\"moodle\",\"multicraft\"\ + ,\"mybb\",\"mysql\",\"nats\",\"neo4j\",\"neos\",\"nginxstack\",\"noalyss\"\ + ,\"nodejs\",\"ocportal\",\"odoo\",\"openatrium\",\"opencart\",\"openedx\"\ + ,\"openfire\",\"openproject\",\"orangehrm\",\"osclass\",\"owncloud\",\"oxid-eshop\"\ + ,\"parseserver\",\"phabricator\",\"phpbb\",\"phplist\",\"pimcore\",\"piwik\"\ + ,\"plone\",\"pootle\",\"postgresql\",\"prestashop\",\"processmakerenterprise\"\ + ,\"processmakeropensourceedition\",\"processwire\",\"publify\",\"rabbitmq\"\ + ,\"redash\",\"redis\",\"redmine\",\"redmineplusagile\",\"reportserver\",\"\ + reportserverenterprise\",\"resourcespace\",\"reviewboard\",\"reviewboardpowerpack\"\ + ,\"roundcube\",\"rubystack\",\"seopanel\",\"shopware\",\"silverstripe\",\"\ + simplemachinesforum\",\"sonarqube\",\"spree\",\"subversion\",\"suitecrm\"\ + ,\"tensorflowserving\",\"testlink\",\"tikiwikicmsgroupware\",\"tinytinyrss\"\ + ,\"tom-cat\",\"trac\",\"typo3\",\"weblate\",\"webmailpro\",\"wildfly\",\"\ + wordpress\",\"wordpress-multisite\",\"wordpresspro\",\"x2enginesalescrm\"\ + ,\"xoops\",\"youtrack\",\"zookeeper\",\"zurmo\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"black-duck-software\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blackduck_hub_vm\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"blk-technologies\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blk-io-erc-20-rest-service\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockapps\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"strato-blockchain-base-template-latest\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockstack-core-v14\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"blockchain-foundry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"syscoin-api\",\"syscoin-full-node\",\"syscoin-price-peg\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bloombase\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bloombase-storesafe-3_4_7_0_el7_x86_64\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"bluecat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluecat-bam-for-azure\"\ + ,\"bluecat-dns-for-azure\",\"bluecat-edge-service-point-vm-for-azure\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"bluetalon\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bluetalon\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"brocade_communications\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"brocade-virtual-traffic-manager\"\ + ,\"brocade-virtual-traffic-manager-with-waf-module\",\"brocade-virtual-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"bt-americas-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + diamondip-sapphire-ev10\",\"diamondip-sapphire-ev20\",\"diamondip-sapphire-v10\"\ + ,\"diamondip-sapphire-v20\",\"diamondip-sapphire-v5\",\"diamondip-sapphire-vcaa20\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"buddhalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sles_12_pci\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"carto\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cartobuilder2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cask\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cdap-cloud-sandbox\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"UbuntuServer\"\ + ,\"Ubuntu_Core\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cavirin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cavirin-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cautelalabs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"log_management\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"celum-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"celumdam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cds\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cds-data-migration-solution-for-legacy-to-cloud\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"center-for-internet-security-inc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cis-centos-6-v2-0-2-l1\"\ + ,\"cis-centos-7-v2-1-1-l1\",\"cis-oracle-linux-6-v1-0-0-l1\",\"cis-oracle-linux-7-v2-0-0-l1\"\ + ,\"cis-rhel-6-v2-0-2-l1\",\"cis-rhel-7-v2-2-0-l1\",\"cis-suse-linux-11-v2-0-0-l1\"\ + ,\"cis-suse-linux-12-v2-0-0-l1\",\"cis-ubuntu-linux-1404-v2-0-0-l1\",\"cis-ubuntu-linux-1604-v1-0-0-l1\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"certivox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sso-test\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cfd-direct\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cfd-direct-from-the-cloud\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"chain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chain-core-developer-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"checkpoint\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"check-point-r77-10\"\ + ,\"check-point-vsec-r80\",\"check-point-vsec-r80-blink\",\"sg2\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"chef-software\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"chef-automate-vm-image\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"circleci\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"circleci-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cires21\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"c21l-enc\"\ + ,\"c21l-mos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cisco\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cisco-asav\",\"cisco-csr-1000v\",\"cisco-ftdv\",\"cisco-meraki-vmx100\"\ + ,\"cisco-ngfwv-vm-test-unsupported\",\"cisco_cloud_vedge_17_2_4\",\"cos65\"\ + ,\"cos72\",\"cos72_main_dev\",\"uos14\",\"vwaas-azure\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"citrix\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"citrix-sd-wan-opt\",\"netscaler-ma-service-agent-120\"\ + ,\"netscaler-ma-service-agent-121\",\"netscaler-sd-wan\",\"netscaler-vpx\"\ + ,\"netscalervpx-120\",\"netscalervpx-121\",\"netscalervpx110-6531\",\"netscalervpx111\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"clear-linux-project\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"clear-linux-os\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"clouber\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cuber\",\"cws\",\"mcenter\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloud-cruiser\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-cruiser-16\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudbees\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"jenkins-enterprise\",\"jenkins-operations-center\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudbees-enterprise-jenkins\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbees-jenkins-enterprise\"\ + ,\"cloudbees-jenkins-operations-center\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudbolt-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudbolt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudboost\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"cloudboost\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudenablers-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"corestack\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloud-infrastructure-services\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"squid-proxy\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloudera-altus-centos-os\",\"cloudera-centos-6\",\"cloudera-centos-os\"\ + ,\"test-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudlanes\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"cloud-video-accelerator-nfs\",\"cloudlanes-cloud-backup-accelerator-vtl\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cloudlink\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudlink-securevm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cloudplan-gmbh\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cloudplan_pcn_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cloudsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"paladion_ondemand_nextgen_firewall\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"cloudsoft\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudsoft-amp\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"clustrix\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"clustrixdb\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"codelathe\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codelathe-filecloud-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"codenvy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"codenvy-on-prem\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cognosys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"1-click-secured-joomla-on-centos-7-3\"\ + ,\"1-click-secured-joomla-on-ubuntu-1404-lts\",\"1-click-secured-joomla-on-ubuntu-1604-lts\"\ + ,\"1-click-secured-joomla-on-ubuntu-1804-lts\",\"centos-6-9\",\"centos-7-3\"\ + ,\"centos-7-4\",\"centos-7-5\",\"deploy-a-secured-modx-on-ubuntu-14-04-lts\"\ + ,\"deploy-a-secured-silverstripe-on-ubuntu-14-04-lts\",\"hardened-mysql-5-6-on-centos-7-3\"\ + ,\"hardened-mysql-5-6-on-ubu-1404-lts\",\"hardened-mysql-5-7-on-centos-7-3\"\ + ,\"hardened-mysql-5-7-on-ubu-1404-lts\",\"hardened-postgresql-on-ubu-1404-lts\"\ + ,\"invoice-ninja-2-5-1-1-on-ubuntu-1404\",\"jruby-on-ubuntu-14-04-lts\",\"\ + low-latency-broadcasting-server-for-live-events\",\"owncloud-9-with-lamp-stack-on-ubuntu-1404\"\ + ,\"piwigogallerys-ubuntu_14-04_lts\",\"sec1011-dokuwiki-on-ubuntu-1404\",\"\ + sec1013-elasticsearch-on-ubuntu-1404\",\"sec1014-opencart-on-ubuntu-1404\"\ + ,\"sec1015-orangehrm-on-ubuntu-1404\",\"sec1016-nodejs-server-on-ubuntu-1404\"\ + ,\"sec1018-haproxy-on-ubuntu-1404\",\"sec1019-secured-tomcat-on-ubuntu-1404\"\ + ,\"sec1020-phpbb-on-hardened-ubuntu-1404\",\"sec1021-mybb-on-hardened-ubuntu-1404\"\ + ,\"sec1022-sugarcrm-on-ubuntu-1404\",\"sec1023-moodle-on-ubuntu-1404\",\"\ + sec1024_magento-on-ubuntu-1404\",\"sec1025-secured-drupal-on-ubuntu-1404\"\ + ,\"sec1027-secured-wordpress-on-ubuntu-1404\",\"sec1028-secured-lamp-sever-on-ubuntu-1404\"\ + ,\"sec1029-secured-mediawiki-on-ubuntu-1404\",\"sec1030-secured-subversion-on-ubuntu-1404\"\ + ,\"sec1031-secured-passenger-nginx-on-ubuntu-1404\",\"sec1033-secured-piwik-on-ubuntu-1404\"\ + ,\"sec1034-secured-pligg-on-ubuntu-1404\",\"sec1035-secured-jenkins-on-ubuntu-1404\"\ + ,\"sec1036-secured-postgresql-on-ubuntu-1404\",\"secure-cloud-lamp-ubuntu-1404\"\ + ,\"secured-abantecart-on-centos\",\"secured-abantecart-on-ubuntu-14-04-lts\"\ + ,\"secured-acquia-drupal-on-centos\",\"secured-acquiadurpal-on-ubuntu-14-04-lts\"\ + ,\"secured-apachesolr-on-centos\",\"secured-apachesolr-on-ubuntu-14-04-lts\"\ + ,\"secured-arartifactory-on-centos\",\"secured-artifactory-on-ubuntu-14-04-lts\"\ + ,\"secured-cakephp-on-centos\",\"secured-cakephp-on-ubuntu-14-04-lts\",\"\ + secured-cms-made-simple-on-centos\",\"secured-cms-made-simple-on-ubuntu-14-04-lts\"\ + ,\"secured-codiad-on-centos\",\"secured-codiad-on-ubuntu-14-04-lts\",\"secured-cogdam-on-centos\"\ + ,\"secured-cogdam-on-ubuntu-14-04-lts\",\"secured-concrete5-on-centos\",\"\ + secured-concrete5-on-ubuntu-14-04-lts\",\"secured-coppermine-on-centos\",\"\ + secured-coppermine-on-ubuntu-14-04-lts\",\"secured-crushftp-on-centos\",\"\ + secured-crushftp-on-ubuntu-14-04-lts\",\"secured-django-on-centos\",\"secured-django-on-ubuntu-14-04-lts\"\ + ,\"secured-dokuwiki-on-centos\",\"secured-dolibarr-on-centos\",\"secured-dolivbarr-on-ubuntu-14-04-lts\"\ + ,\"secured-drupal-on-centos\",\"secured-elasticsearch-on-centos\",\"secured-enterprise-nginx-varnish-haproxy-php\"\ + ,\"secured-espocrm-on-centos\",\"secured-espocrm-on-ubuntu-14-04-lts\",\"\ + secured-exoplatform-on-centos\",\"secured-exoplatform-on-ubuntu-14-04-lts\"\ + ,\"secured-ghost-on-centos\",\"secured-ghost-on-ubuntu-14-04-lts\",\"secured-gradle-on-centos\"\ + ,\"secured-gradle-on-ubuntu-14-04-lts\",\"secured-haproxy-on-centos\",\"secured-invoice-ninja-on-centos\"\ + ,\"secured-jboss-as-on-centos\",\"secured-jbossas-on-ubuntu-14-04-lts\",\"\ + secured-jenkins-on-centos\",\"secured-jruby-on-cento\",\"secured-lamp-on-centos\"\ + ,\"secured-lamp-on-centos-m10\",\"secured-lapp-on-centos\",\"secured-lapp-on-ubuntu-14-04-lts\"\ + ,\"secured-lemp-sever-on-ubuntu-1404\",\"secured-lime-survey-on-centos\",\"\ + secured-limesurvey-on-ubuntu-1404\",\"secured-live-helper-chat-on-centos\"\ + ,\"secured-livehelperchat-on-ubuntu-14-04-lts\",\"secured-magento-on-centos\"\ + ,\"secured-mahara-on-centos\",\"secured-mahara-on-ubuntu-14-04-lts\",\"secured-mantis-on-centos\"\ + ,\"secured-mantis-on-ubuntu-14-04-lts\",\"secured-mariadb-on-ubuntu-16-04\"\ + ,\"secured-mautic-on-centos\",\"secured-mautic-on-ubuntu-14-04-lts\",\"secured-media-wiki-on-centos\"\ + ,\"secured-modx-on-centos\",\"secured-moodle-on-centos\",\"secured-ngnix-on-centos-7-3\"\ + ,\"secured-ngnix-on-ubuntu-14-04-lts\",\"secured-ngnix-on-ubuntu-16-04-lts\"\ + ,\"secured-noalyss-on-centos\",\"secured-noalyss-on-ubuntu-14-04-lts\",\"\ + secured-nodejs-on-centos\",\"secured-occlass-on-ubuntu-14-04-lts\",\"secured-ocportal-on-ubuntu-14-04-lts\"\ + ,\"secured-open-cart-on-centos\",\"secured-orangehrm-on-centos\",\"secured-osclass-on-centos\"\ + ,\"secured-owncloud-on-centos\",\"secured-oxid-eshop-on-centos\",\"secured-oxideshop-on-ubuntu-14-04-lts\"\ + ,\"secured-passenger-nginx-on-centos\",\"secured-piwigo-gallery-on-centos\"\ + ,\"secured-plone-on-centos\",\"secured-plone-on-ubuntu-14-04-lts\",\"secured-prestashop-on-centos\"\ + ,\"secured-prestashop-on-ubuntu-14-04-lts\",\"secured-railo-on-ubuntu-14-04-lts\"\ + ,\"secured-redis-on-centos\",\"secured-redis-on-ubuntu-1404\",\"secured-redmine-on-centos\"\ + ,\"secured-redmine-on-ubuntu-14-04-lts\",\"secured-redmineagile-on-ubuntu-14-04-lts\"\ + ,\"secured-report-server-on-centos\",\"secured-reportserverent-on-ubuntu-14-04-lts\"\ + ,\"secured-resource-space-on-centos\",\"secured-resourcespace-on-ubuntu-14-04-lts\"\ + ,\"secured-round-cube-on-centos\",\"secured-roundcube-on-ubuntu-14-04-lts\"\ + ,\"secured-ruby-on-centos\",\"secured-ruby-on-ubuntu-14-04-lts\",\"secured-seopanel-on-centos\"\ + ,\"secured-seopanel-on-ubuntu-14-04-lts\",\"secured-silverstripe-on-centos\"\ + ,\"secured-simple-invoice-on-centos\",\"secured-simple-machines-on-centos\"\ + ,\"secured-simple-machines-on-ubuntu-14-04-lts\",\"secured-simpleinvoice-on-ubuntu-14-04-lts\"\ + ,\"secured-subversion-on-centos\",\"secured-suitecrm-on-centos\",\"secured-suitecrm-on-ubuntu-14-04-lts\"\ + ,\"secured-test-link-on-centos\",\"secured-testlink-on-ubuntu-14-04-lts\"\ + ,\"secured-thinkup-on-centos\",\"secured-thinkup-on-ubuntu-14-04-lts\",\"\ + secured-tikiwikicms-on-centos\",\"secured-tikiwikicms-on-ubuntu-14-04-lts\"\ + ,\"secured-tiny-tiny-rss-on-centos\",\"secured-tinytinyrss-on-ubuntu-14-04-lts\"\ + ,\"secured-tomcat-on-centos\",\"secured-trac-on-centos\",\"secured-trac-on-ubuntu-14-04-lts\"\ + ,\"secured-typo3-on-centos\",\"secured-typo3-on-ubuntu-14-04-lts\",\"secured-varnish-on-centos\"\ + ,\"secured-varnish-on-ubuntu-1404\",\"secured-wildfly-on-centos\",\"secured-wildfly-on-ubuntu-14-04-lts\"\ + ,\"secured-wordpress-on-centos-7-3\",\"secured-wordpress-on-ubuntu-16-04-lts\"\ + ,\"secured-x-cart-on-ubuntu-14-04-lts\",\"secured-xoops-on-centos\",\"secured-xoops-on-ubuntu-14-04-lts\"\ + ,\"secured-zurmo-on-centos\",\"secured-zurmo-on-ubuntu-14-04-lts\",\"suse15\"\ + ,\"ubuntu-14-04-lts\",\"ubuntu-16-04-lts\",\"ubuntu-17-04-high-performance-hardened-tcp-bbr\"\ + ,\"ubuntu-18-04\",\"ubuntu-18-04-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cohesity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cohesity-cloudtd-tool\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"cohesive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"vns3_4x_network_security\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"confluentinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"confluentplatform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"consensys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"truffle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"convertigo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"convertigo-for-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"corda\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"corda\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"CoreOS\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"CoreOS\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"couchbase\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"couchbase-server-enterprise\",\"couchbase-sync-gateway-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"credativ\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cryptzone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"appgate-appliance-3_2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"cybernetica-as\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + uxp-securityserver-connector\",\"uxp-securityserver_vm\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"cyxtera\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"appgatesdp-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"dataart\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"devicehive\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"databricks\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"spfqogzeculbhdh\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datalayer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datalayer-notebook\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datastax\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"datastax-enterprise\"\ + ,\"datastax-enterprise-non-production-use-only\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"datasunrise\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"datasunrise-database-security-suite\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dataiku\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dataiku-data-science-studio\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"datometry\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyper-q\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dellemc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dell-emc-avamar-virtual-edition\"\ + ,\"dell-emc-datadomain-management-center\",\"dell-emc-datadomain-virtual-edition\"\ + ,\"dell-emc-datadomain-virtual-edition-v4\",\"dell-emc-networker-virtual-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"delphix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"delphix_dynamic_data_platform\"\ + ,\"omniosce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"denodo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"denodo-platform\",\"denodo-platform-7_0\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"denyall\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"denyall-rweb\",\"denyall-vulnerability-manager\",\"denyall-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dgsecure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dgsecure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"diladele\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"websafety\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"dimensionalmechanics-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"neopulse-ai-studio\",\"neopulse-query-runtime\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"docker\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"docker-ce\",\"docker-ce-edge\"\ + ,\"docker-datacenter-custom\",\"docker-ee\",\"docker-ee-basic\",\"docker4azure\"\ + ,\"docker4azure-cs\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dome9\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"dome9ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"drizti\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"hpcbox-ansys-19-cluster-master\",\"hpcbox-cluster-compute-node\",\"hpcbox-cluster-cuda-node\"\ + ,\"hpcbox-cluster-gpu-node\",\"hpcbox-docker-cluster-master\",\"hpcbox-openfoam-cluster-master\"\ + ,\"hpcbox-su2-cluster-master\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"drone\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"drone\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dyadic_security\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"dyadic_sec\",\"ukc_image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"dynatrace\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ruxit-managed-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"eastwind-networks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"eastwind-ixia-sensor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"egnyte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"egnyte-connect\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"elasticbox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"elasticbox-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"electric-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"electricflowce\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"elfiqnetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"emercoin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"emercoin\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"enterprise-ethereum-alliance\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"quorum-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"enterprisedb-corp\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"edb-postgres-ark\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"equalum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"equalum-vm-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"esdenera\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"esdenera-firewall-3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ethereum\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ethereum-studio\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"evostream-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ems-for-template\",\"ems-test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"exasol\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"exasol-analytics-database-byol\",\"exasolution-analytic-database\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"falconstorsoftware\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"fss-v9\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"f5-networks\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"f5-big-ip-adc\",\"\ + f5-big-ip-advanced-waf\",\"f5-big-ip-best\",\"f5-big-ip-better\",\"f5-big-ip-byol\"\ + ,\"f5-big-ip-good\",\"f5-big-ip-per-app-ve\",\"f5-big-iq\",\"f5-web-application-firewall\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"filecatalyst\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + filecatalyst-direct-per-hr-billing\",\"filecatalyst-direct-server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"firehost\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"firehost_armor\",\"\ + firehost_armor_ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"flexify-io\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"single-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"flashgrid-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"flashgrid-racnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"foghorn-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"foghorn-edge-device-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"forcepoint-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"forcepoint-ngfw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"forscene\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"forscene-edgeserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"fortycloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"fortycloud-gw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"fortinet\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"fortinet-fortianalyzer\",\"fortinet-fortimanager\",\"fortinet_fortigate-vm_v5\"\ + ,\"fortinet_fortimail\",\"fortinet_fortivoice\",\"fortinet_fortiweb-vm_v5\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"fujitsu_fast\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + fep10-rh7-test\",\"feptest\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"gemalto-safenet\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"safenet-keysecure-k170v\",\"safenet-protectv\",\"safenet-protectv-manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gigamon-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gigamon-fm-5_3_01\"\ + ,\"gigamon-fm-5_3_01_hourly\",\"gigamon-fm-5_4_00\",\"gigamon-fm-5_4_00_hourly\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gitlab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gitlab-ce\"\ + ,\"gitlab-ee\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"GitHub\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"GitHub-Enterprise\",\"githubenterprise-test-publishing\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"great-software-laboratory-private-limited\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"xid\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"greensql\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"greensql-database-security\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"gridgain\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"gridgain-vm\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"guardicore\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"guardicorecentra\"\ + ,\"infection_monkey\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"haivision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"haivision-media-gateway-1-2\",\"haivision-media-gateway-1-5\",\"haivision-media-gateway-1-6-2\"\ + ,\"media-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"h2o-ai\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"h2o-driverles-ai\",\"h2o-driverless-ai\",\"h2o-vm\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"haproxy-technologies\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hapee-rhel\",\"hapee-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"harpaitalia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mcuboenergy\"\ + ,\"yg\",\"yougreen_trial\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hcl-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"hcl17cp1104\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"heimdall-data\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"heimdall-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"help-systems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"goanywheremftubuntulinux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hewlett-packard\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"hpe-helion-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hillstone-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudedge-virtual-ngfw-advanced-edition\",\"cloudedge-virtual-ngfw-standard-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hortonworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudbreak-for-hortonworks-data-platform\"\ + ,\"hortonworks-sandbox\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"hitachi-solutions\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"credeon-sfs-and-kms-for-sharepoint-online\",\"credeonsecurefull-textsearch1_0\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hpe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storeoncevsa\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"huawei\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"euleros-v2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hyperglance\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperglance-dynamic-topology\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hypergrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hyperform\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"hytrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"hytrust-keycontrol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"ibm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ibm-security-guardium-multi-cloud\"\ + ,\"qradar_security_analytics\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"iaansys\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"iaansys-magento\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"iboss\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"iboss-14600-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"imaginecommunications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloudxtream-cdvr\",\"cloudxtream-dai-vms\",\"telurio-aim\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"imperva\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"imperva-dam-v13\"\ + ,\"securesphere-waf\",\"securesphere-waf-for-azr\",\"securesphere-waf-v12\"\ + ,\"securesphere-waf-v13\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"infoblox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"infoblox-vnios-te-v1420\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"informatica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"bdm10-1-1-u2\",\"big-data-management-10-2\",\"big-data-management-10-2-1\"\ + ,\"data_accelerator_for_azure_byol\",\"data_quality_10_1_1_rhel_7_3_byol\"\ + ,\"eic\",\"ics-byol\",\"ics-payg-ubuntu\",\"platform_10_1_1_multi_node_domain_rhel-7-3_byol\"\ + ,\"platform_10_2_hf1_domain_rhel-7-3_byol\",\"powercenter-v10-domain-image-ubuntu14-04-3\"\ + ,\"powercenter-v10-update1-domain-image-ubuntu\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"informationbuilders\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"iway-big-data-vm\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ingrammicro\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ingrammicroensimcentostrial\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"intel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"lustre-cloud-edition-gs-image\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"intel-bigdl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"bigdl-0815\"\ + ,\"bigdl__vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intel-fpga\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"quartus_pro_opencl_sdk\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intellicus-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"intellicus_bi_server_100_user_linux\",\"intellicus_bi_server_10_user_linux\"\ + ,\"intellicus_bi_server_25_user_linux\",\"intellicus_bi_server_50_user_linux\"\ + ,\"intellicus_bi_server_5_user_linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intersystems\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"intersystems-iris-single-node\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"intigua\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"intigua-agent-manager-3_7_0-trial\",\"intigua-agent-manager-trial\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"iquest\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"keyhub\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ishlangu-load-balancer-adc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ishlangu-load-balancer-byol\"\ + ,\"ishlangu-load-balancer-is10\",\"ishlangu-load-balancer-is100\",\"ishlangu-load-balancer-is1000\"\ + ,\"ishlangu-load-balancer-is200\",\"ishlangu-load-balancer-is5000\",\"ishlangu-load-balancer-isbfg\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"issp-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ispocr\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"itelios\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"magento2-on-zendserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jamcracker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"4632d5b4-feb0-4332-8452-f2e66133672f\",\"jamcracker-cloudanalytics\"\ + ,\"jamcracker-cloudanalytics-version4\",\"jamcracker-cloudanalytics-version5\"\ + ,\"jamcracker-csb-service-provider\",\"jamcracker-csb-serviceprovider\",\"\ + jamcracker-csb-standard\",\"jamcracker-csb-standard-v3\",\"jamcracker-csb-standard-version4\"\ + ,\"jamcracker-hybrid-cloud-management-version4\",\"jamcracker_cloud_control_appliance_version4\"\ + ,\"jsdnapp_csb_serviceprovider-version4\",\"jsdnapp_hybrid\",\"jsdnapp_hybrid_v3\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jedox\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jedox-for-azure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jelastic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"jelastic-hybrid-paas-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"jetnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dvwa\"\ + ,\"jetnexus-application-load-balancer\",\"jetnexus-global-load-balancer\"\ + ,\"jetnexus-waf\",\"zap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jetware-srl\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"caffe2\",\"caffe_python_cpu\",\"caffe_python_gpu\",\"cockroachdb\"\ + ,\"lamp_optimized\",\"lemp7_optimized\",\"memcached\",\"mongodb\",\"mxnet_python\"\ + ,\"mysql\",\"nodejs_nginx\",\"percona_mongodb\",\"percona_mysql\",\"postgresql\"\ + ,\"pytorch\",\"pytorch_cuda_notebook\",\"pytorch_cuda_production\",\"redis\"\ + ,\"redmine\",\"tensorflow_cpu_notebook\",\"tensorflow_cpu_production\",\"\ + tensorflow_cuda_notebook\",\"tensorflow_cuda_production\",\"tensorflow_python\"\ + ,\"theano_python\",\"wordpress4_lemp7\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jitterbit_integration\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"jitterbit-harmony-agent\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"jm-technology-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"smart-gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"juniper-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vmx-services-gateway-byol\",\"vmx-services-gateway-byol-soltemp\"\ + ,\"vmx-virtual-router\",\"vsrx-next-generation-firewall\",\"vsrx-next-generation-firewall-payg\"\ + ,\"vsrx-next-generation-firewall-solution-templ-payg\",\"vsrx-next-generation-firewall-solution-template\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"kaazing\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"kaazing-kwic\"\ + ,\"kaazing-vpa\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kali-linux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"kali-linux\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kemptech\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"kemp360central-byol\",\"vlm-azure\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"kinetica\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"kineticadbbyol\",\"kineticadbpayasyougo\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"kaspersky_lab\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"kaspersky_secure_mail_gateway\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"knime\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"knime-server-5-user_4-4-0\"\ + ,\"knime-server-byol\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"krypc-technologies-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"krypccore\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"leap-orbit\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"leaporbitstoragebackedsftp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"leostream-corporation\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"connection-broker\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"liquid-files\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"liquidfiles\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"liquidware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stratusphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"literatu\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"literatu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"loadbalancer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"loadbalancer-org-load-balancer-for-azure\",\"loadbalancer-org-load-balancer-for-azure-byol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"logsign\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logsignfocus\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"logtrust\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"logtrust-log-management\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"looker\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"looker-analytics-platform\"\ + ,\"looker-analytics-platform-326\",\"looker-analytics-platform-5_6\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"lti-lt-infotech\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"trade-finance-blockchain\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"luminate-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"luminate-connector\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mapr-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"mapr52-base-dev\",\"mapr60-base\",\"mapr60-sandbox\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mariadb\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mariadb-server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"marklogic\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"marklogic-9-byol\"\ + ,\"marklogic-developer-9\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"massiveanalytic-\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"oscarap\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mathworks-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"matlab-ref-arch-18a-v1-linux-disk\",\"mps-ref-arch-18a-v1-linux-disk2\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"matillion\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"matillion-etl-snowflake\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"mavinglobal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mavin-business-trial\"\ + ,\"mavin-enterprise-edition\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"meanio\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"gitlab-enterprise-ready\",\"linnovate-open-source-sla-pro\",\"mean-machine-20\"\ + ,\"openideal3\",\"redash\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"media3-technologies-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cpan1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"memsql\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"memsql-community-single-vm\",\"memsql-enterprise-single-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mendix\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mendix-docker\",\"mendix-pro\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"mfe_azure\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"atd-mcafee\"\ + ,\"mcafee_vnsp_controller_for_azure\",\"mcafee_vnsp_for_azure\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"microsoft-ads\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"linux-data-science-vm\"\ + ,\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aks\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"micro-focus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"replication_environment\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-avere\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vfxt\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-azure-batch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"centos-container\",\"centos-container-rdma\",\"ubuntu-server-container\"\ + ,\"ubuntu-server-container-rdma\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-azure-compute\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azureconfidentialcompute\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"microsoft-dsvm\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azureml\",\"linux-data-science-vm-ubuntu\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"MicrosoftAzureSiteRecovery\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ASR-Hydration-VMs\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftOSTC\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + FreeBSD\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"MicrosoftRServer\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"MLServer-CentOS\",\"MLServer-RedHat\",\"MLServer-Ubuntu\",\"RServer-CentOS\"\ + ,\"RServer-Ubuntu\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"midfin\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"mf_neon_cgw\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"midvision\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ibm-datapower-virtual-edition-75\",\"ibm-datapower-virtual-edition-76\"\ + ,\"ibm-datapower-virtual-edition-77\",\"ibm-http-server\",\"ibm-websphere-portal-server-85\"\ + ,\"ibm-websphere-portal-server-90\",\"websphere-application-server-be\",\"\ + websphere-application-server-be-80\",\"websphere-application-server-be-85\"\ + ,\"websphere-application-server-be-90\",\"websphere-application-server-be-and-mq\"\ + ,\"websphere-application-server-lp\",\"websphere-application-server-lp-16\"\ + ,\"websphere-application-server-lp-17\",\"websphere-application-server-lp-18\"\ + ,\"websphere-application-server-nde\",\"websphere-application-server-nde-80\"\ + ,\"websphere-application-server-nde-85\",\"websphere-application-server-nde-90\"\ + ,\"websphere-mq\",\"websphere-mq-75\",\"websphere-mq-90\",\"websphere-mq-91\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"miraclelinux\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + asianux-server-4-sp5\",\"asianux-server-4-sp6\",\"asianux-server-4-sp7\",\"\ + asianux-server-7-sp1\",\"asianux-server-7-sp2\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"miri-infotech-pvt-ltd\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wordpress\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mobilab\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"magento-wirecard-checkout\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"moogsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moogsoft-aiops\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"moviemasher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"moviemasher\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftSQLServer\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"SQL2017-RHEL7\",\"SQL2017-RHEL73\",\"SQL2017-SLES12SP2\",\"SQL2017-Ubuntu1604\"\ + ,\"SQL2019-RHEL7\",\"SQL2019-Ubuntu1604\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"mtnfog\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"idyl-e3-entity-extraction-engine\",\"prose-sentence-extraction-engine\"\ + ,\"renku-language-detection-engine\",\"sonnet-tokenization-engine\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"mxhero\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"mail2cloud\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"my-com\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tarantool\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"narrativescience\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"narratives-for-power-bi\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"nasuni\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"nasuni-nmc\"\ + ,\"nasuni_edge_appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ncbi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + ncbi-blast-2-3-0\",\"ncbi-free-2-2-31\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nebbiolo-technologies-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"fog-system-manager\",\"fogsm_basic\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"neo4j\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"neo4j-enterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netapp\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netapp-altavault-cloud-integrated-storage-solution\"\ + ,\"netapp-oncommand-cloud-manager\",\"netapp-ontap-cloud\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"netgate\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netgate-pfsense-azure-fw-vpn-router\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"netiq\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"replication_environment\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"netscout\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netscout_virtual_ngeniusone_with_vscout\"\ + ,\"netscout_vstream\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netmail\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"netmail-search\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netsweeper\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"netsweeper6-0-6\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"netx\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + simplehelp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"neusoft-neteye\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"neusoft-nisg-va-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nginxinc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nginx-plus-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nicepeopleatwork\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"youzana\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nodejsapi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"node-js-api\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"noobaa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"noobaa-hybrid-s3-archive-05\",\"noobaa-multi-cloud-deduplication\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"northbridge-secure\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"netconnect1\",\"netconnectx\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"nubeva-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"controller\"\ + ,\"test\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nuco-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"aionnode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nuxeo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nuxeo-6-lts\",\"nuxeo-lts\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"nvidia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ngc_azure_17_11\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"o2mc-real-time-data-platform\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"o2mc-platform-app\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"oceanblue-cloud\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"obc-sdwan-solutions\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"omega-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ods_datastage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"onyx-point-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"op-bnf-v1\",\"op-bnf1_6-v1\",\"op-bpnifi-v1\",\"op-bpnifi16-v1\"\ + ,\"op-scc-v1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"onapsis\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osp\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"op5\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + op5-monitor\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"opencell\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"meveo\",\"meveo403sp2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"openvpn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openvpnas\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Oracle-Database-Ee\"\ + ,\"Oracle-Database-Se\",\"Oracle-Linux\",\"Oracle-WebLogic-Server\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"orientdb\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"orientdb-community-edition\"\ + ,\"orientdb-community-edition-2_2\",\"orientdb-enterprise-edition-2_2\",\"\ + orientdb-enterprise-edition-2_2_17\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"osirium-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"osirium-pxm-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"osnexus\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"quantastorvsav4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"paloaltonetworks\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"panorama\",\"vmseries1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"panzura-file-system\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"azura-freedom-filer-v7110\",\"panzura-cloud-filer\",\"panzura-freedom-filer-7140-13222\"\ + ,\"panzura-freedom-filer-716-13549\",\"panzura-freedom-filer-v7020\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"parasoft\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"parasoft-service-virtualization\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"passlogy\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"passlogic\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"penta-security-systems-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"wapples\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"percona\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"percona-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"postgres-pro\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"postgres-pro-enterprise\",\"postgres-pro-enterprise-10\",\"postgres-pro-standard\"\ + ,\"postgres-pro-standard-10\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"plesk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"plesk-onyx-linux\",\"solution-server-business\",\"solution-server-wordpress\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"prestashop\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"prestashop16-lamp\"\ + ,\"ubuntu-base-for-prestashop\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"prime-strategy\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"kusanagi-77\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"pivotal\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"pivotal-gpdb-vm\",\"pivotal-greenplum-images\",\"pivotal-ops-manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"process-one\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ejabberd-community-edition\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"profecia\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"full_disk_encryption_vm\"\ + ,\"project_tools_vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"progelspa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"libra-esva-antispam\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ptsecurity\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ptaf-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"pulse-secure\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"pulse-connect-secure-vm\",\"pulse-virtual-traffic-manager\",\"\ + pulse-virtual-traffic-manager-with-waf\",\"pulse-virtual-traffic-manager-with-waf2\"\ + ,\"pulse-virtual-traffic-manager2\",\"pulse-virtual-web-application-firewall\"\ + ,\"pulse-virtual-web-application-firewall2\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"PuppetLabs\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"PuppetEnterprise\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"puppet\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"puppet-enterprise\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"pydio\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"pydio-enterprise\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"qore-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"qorus\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"qualysguard\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"qualys-virtual-firewall-appliance\",\"qualys-virtual-scanner-v23b\"\ + ,\"qualys-virtual-scanner-v24\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"quasardb\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"quasardb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"qubole-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"qubole-data-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"quest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"fve\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"racknap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"racknap-server\",\"racknap-server-linux\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"radware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"radware-alteon-va\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"radiant-logic\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"radiantone-vms\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rancher\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"rancheros\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rapid7\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nexpose-scan-engine\",\"rapid7-vm-console\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"rapidminer\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"rapidminer_server_75\",\"rapidminer_server_76\"\ + ,\"rapidminer_server_80\",\"rapidminer_server_81\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"realm\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"realm-mobile-platform\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"reblaze\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"rbzr-image\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"RedHat\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osa\",\"RHEL\",\"rhel-byos\"\ + ,\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"relevance-lab\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + rlcatalyst\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"remotelearner\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"fully-supported-moodle\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"revolution-analytics\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"revolution-r-enterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RightScaleLinux\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"RightImage-CentOS\",\"RightImage-Ubuntu\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"RiverbedTechnology\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"steelapp_traffic_manager\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"riverbed\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"riverbed-sccm-5-5-1\"\ + ,\"riverbed-steelcentral-appinternals\",\"riverbed-steelhead-9-2\",\"riverbed-steelhead-9-5-0\"\ + ,\"riverbed-steelhead-9-6-0\",\"riverbed_steelconnect_gw\",\"riverbed_steelconnect_sh\"\ + ,\"steelapp_traffic_manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rocketsoftware\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"rocket-discover\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rsa-security-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"rsa-nw-azure-arch\",\"rsa-nw-azure-broker\",\"rsa-nw-azure-con\"\ + ,\"rsa-nw-azure-esa\",\"rsa-nw-azure-ldec\",\"rsa-nw-azure-vlc\",\"rsa-nw-suite-11\"\ + ,\"rsa-nw-suite-11-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"rsk-labs\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"rsk-bamboo-beta-node\",\"rsk-node-orchid\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"saama\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"fluidanalyticsengine\",\"insurancefraudanalytics\"\ + ,\"realworldevidence\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"saltstack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos65saltstackenterprise\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scalearc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"scalearc-for-mysql-paygo\",\"scalearc-for-sql-server-pay-go\",\"scalearc_mysql-server\"\ + ,\"scalearc_sql_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scalegrid\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sap\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + hanaexpress\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"scality\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"scalityconnecthourly\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"secureworks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"scwx-azure-vm\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"shadow-soft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"icinga\",\"icinga2-5\",\"icinga2-7\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"signal-sciences\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"signalscienceswpp\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"sightapps\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"sightapps\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"silver-peak-systems\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"silver_peak_edgeconnect\"\ + ,\"silver_peak_vx\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"simmachinesinc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"simmachines_vm_v2\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sinefa\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"sinefa-probe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"skyarc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"mt6\",\"mta\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"smartmessage-autoflow\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"martmessage-autoflow\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"snapt-adc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"snaptadc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"soasta\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloudtest-lite\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"softnas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"cloud_dev\",\"mp_ce\",\"mp_ent\",\"mp_nas_byol\",\"mp_nas_ep\",\"mp_nas_gp\"\ + ,\"mp_nas_hp\",\"mp_plat\",\"private_offerings\",\"softnas-cloud\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"solanolabs\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"solano-ci-private-beta\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"soha\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"soha-cloud\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"solar-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + solar-incode\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sonicwall-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"sonicwall-nsz-azure\",\"waf\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"sophos\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"sophos-xg\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"spagobi\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"spagobi\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"spacecurve\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"spacecurve-quickstart\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"splunk\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"splunk-enterprise-base-image\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"src-solution\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"pilot-things-onem2m-smart-network\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sqlstream\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"com\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"sphere3d\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"snapcloud-byol\",\"snapcloud-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"stackato-platform-as-a-service\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"activestate-stackato\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stackstorm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stackstorm-2015-1\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"startekfingerprintmatch\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"bioserver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"steelhive\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"steelhive_carbon\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stonefly\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"stonefly-cloud-drive\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"stormshield\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"stormshield-network-security-for-cloud\",\"stormshield-network-security-for-cloud-xl\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"storreduce\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"storreduce\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"stratumn\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"indigo-node\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"streamsets\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"streamsets-data-collector\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"striim\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"integrationforsqlserveronazure\"\ + ,\"integrationtoazurestorage\",\"integrationtoeventhub\",\"integrationtohdinsight\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"SUSE\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\"\ + ,\"SLES\",\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\"\ + ,\"SLES-SAP\",\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SUSE-CaaSP-Admin-BYOS\"\ + ,\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\",\"SUSE-Manager-Server-BYOS\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"symantectest1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + cwpsazure-beta-01\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"synack-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"synack-crowd-security-intelligence\"]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"synechron-technologies\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"blockchain_tradefinance_quorum\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"syte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"syteoffer\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tactic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tactic-workflow-v001\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"talari-networks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + talari-networks-virtual-appliance\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"talena-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"talena_inc\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tata_communications\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"netfoundry_cloud_gateway\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tavendo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"crossbar_on_azure_ubuntu1404\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techdivision\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"appserver-io-pe\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"techlatest\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"ethereumdevkit\",\"rippledevelopersuit\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"telepat\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"free\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tenable\"},{\"field\":\"\ + Microsoft.Compute/imageOffer\",\"in\":[\"tenable-nessus-6-byol\",\"tenable-nessus-professional\"\ + ,\"tenablecorenessus\",\"tenablecorewas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"teradata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"teradata-data-mover\",\"teradata-data-mover-agent\",\"teradata-data-mover-intellisphere\"\ + ,\"teradata-data-stream-controller\",\"teradata-database-1510\",\"teradata-database-1510-byol\"\ + ,\"teradata-database-1510-intellisphere\",\"teradata-database-1510-v2\",\"\ + teradata-database-1610-intellisphere\",\"teradata-database-1610-v2\",\"teradata-database-1620\"\ + ,\"teradata-database-1620-byol\",\"teradata-database-1620-intellisphere\"\ + ,\"teradata-database-enterprise\",\"teradata-database-v1610\",\"teradata-database-v1610-byol\"\ + ,\"teradata-ecosystem-manager\",\"teradata-querygrid-manager\",\"teradata-querygrid-manager-intellisphere\"\ + ,\"teradata-rest-services\",\"teradata-server-management\",\"teradata-viewpoint\"\ + ,\"teradata-viewpoint-intellisphere\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"thales-vormetric\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ciphertrust-ckm\",\"vormetric-dsm\",\"vormetric-dsm-6-1-0\",\"\ + vormetric-tokenization-server\",\"vts-2_2_0_2604\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"things-board\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"tb-pe-cassandra\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"thoughtspot-inc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"thoughtspotvirtualmachine\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tibco-software\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + grid-server-engine\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tig\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + backup-as-a-service\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tigergraph\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"tigergraph\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tmaxsoft\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"tmax-jeusee\",\"tmax-jeusse\",\"tmax-webtobse\"]}]},{\"allOf\":[{\"field\"\ + :\"Microsoft.Compute/imagePublisher\",\"equals\":\"tokyosystemhouse\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"osscobol151j-pg961-centos72\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"torusware\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"speedus-lite-ubuntu\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"totemo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"totemo-azr-tm6\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"townsend-security\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"alliance-key-manager\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"trendmicro\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"deep-security-vm\",\"deep-security-vm-byol\",\"iot-security-sdk\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"truestack\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"tsdc\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"tsa-public-service\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"ckan-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"tunnelbiz\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"centos70-min\",\"centos7optimizwithwordpress\",\"centos7phpoptimizing\"\ + ,\"centos7phpoptimizingnginx\",\"centos7phpoptimizwlaravel\",\"centos7phpoptimizwosticket\"\ + ,\"centos7webserverwithwaf\",\"centos7withaspdotnetcore2apache\",\"centos7withjoomla\"\ + ,\"debian_web_server\",\"fedora\",\"fusio\",\"linuxwithlimesurvey\",\"networkmonitoringsystem\"\ + ,\"rimauwaf_cloud\",\"ubuntu_server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"twistlock\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"twistlock\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"typesafe\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"typesafe-reactive-maps-demo\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ubeeko\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"hfactory-tools-for-hdinsight\",\"hfactory-tools-sandbox\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"ubercloud\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"ansys-17-2-fluids-structures\"\ + ,\"ansys_182_test\",\"comsol-multiphysics-v5-2\",\"openfoam-v2dot3-centos-v6\"\ + ,\"openfoam-v3dot0\",\"star-ccm-v10-04\",\"star-ccm-v10-06-heeds-mdo-v2015\"\ + ,\"star-ccm-v12-00\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"ulex\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + voximal\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"unifi-software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"unifi-data-catalog\",\"unifi-dataplatform-2-3-3-vm\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"unitrends\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unitrends-enterprise-backup-azure\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"usp\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"unified-streaming-vod-standard\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"varnish\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"varnish-cache_\"\ + ,\"varnish-custom-statistics\",\"varnish-plus-administration-and-statistics\"\ + ,\"varnish-plus-caching-engine-4\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vaultive-inc\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"cloud-security-platform\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vbot\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + vbot\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"\ + equals\":\"velocloud\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"velocloud-virtual-edge\",\"velocloud-virtual-edge-3x\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"vidispine\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"vidispine-content-management\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"veritas\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"cloudpoint-2-0-0\"\ + ,\"veritas-resiliency-platform-vhd-offer\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"veeam\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"veeamhubimage\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vigyanlabs-innovations-pvt-ltd\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ipm-plus-energy-saver\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"viptela\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"viptela-vedge-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vizixiotplatformretail001\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vizix-iot-platform-retail-005\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vmturbo\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"turbonomic\",\"vmturbo64-opsmgr-5_3\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vte\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + slashdb\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"vu-llc\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"vu-app-server\",\"vu-facerecogn\",\"vu-fraudanalysis\",\"vu-secureonboarding\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallarm\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallarm-ng-waf-offer-1\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"wallix\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"wallix-wabsuite\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"watchguard-technologies\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"vm-firebox-cloud\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"waves\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"waves\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"websense-apmailpe\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"ap-data-email-gateway\",\"forcepoint-email-security-85beta\",\"\ + triton-ap-data\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"wmspanel\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"nimble-streamer-centos\",\"nimble-streamer-ubuntu\"]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"wowza\"},{\"field\"\ + :\"Microsoft.Compute/imageOffer\",\"in\":[\"wowzastreamingengine\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xfinityinc\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"d3view-v5\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"xtremedata\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"dbx\"]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"yellowfin\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"yellowfin-for-azure-byol\"\ + ]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"xyzrd-group-ou\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + c73-zultys-mxvirtual\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"your-shop-online\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"herefordshire-enterprise-platform-drupal-7\",\"xenofile\"]}]},{\"\ + allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"zend\"\ + },{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"php-56-zend-server\"\ + ,\"php-zend-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"z1\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + z1-securehub\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zerodown_software\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"bcaasforazure\",\"stackbcaas\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zoomdata\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zoomdata-server\"]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"zscaler\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"zscaler-private-access\"]}]}]}]},\"then\":{\"effect\":\"audit\"}}},\"\ + id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/6e87f6ee1518ae1d\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"6e87f6ee1518ae1d\"\ + },{\"properties\":{\"displayName\":\"azsecpack nonprod tagging for vmss_1.1\"\ + ,\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"description\":\"Adds the\ + \ AzSecPack:nonprod tag to a Compute VMSS resource\",\"metadata\":{\"category\"\ + :\"azsecpack-msi\",\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2021-01-22T03:54:06.3997714Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"azSecPackTagName\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"AzSecPack Tag Name\",\"description\":\"This policy adds the specified tag\"\ + },\"defaultValue\":\"azsecpack\"},\"azSecPackTagValue\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"AzSecPack Tag Value\",\"description\":\"\ + This policy adds the specified tag value\"},\"defaultValue\":\"nonprod\"},\"\ + skipTagName1\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipASMAzSecPack\"},\"skipTagName2\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Exclusion Tag Name\",\"description\":\"Rule is not deployed\ + \ if this tag exists on the resource, resource group level, or subscription\ + \ level\"},\"defaultValue\":\"SkipASMAzSecPackAutoConfig\"},\"skipTagName3\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipWindowsAzSecPack\"\ + },\"skipResourceGroupTagName1\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Exclusion Tag Name at the resource group level\",\"description\":\"Rule\ + \ is not deployed if this tag exists on the Resource Group\"},\"defaultValue\"\ + :\"autopilotcluster\"},\"skipResourceGroupTagName2\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotenvironment\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('azSecPackTagName'), ']')]\",\"notEquals\"\ + :\"[parameters('azSecPackTagValue')]\"},{\"field\":\"[concat('tags[', parameters('skipTagName1'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName1'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName1'))]\",\"equals\":\"false\"},{\"field\":\"[concat('tags[',\ + \ parameters('skipTagName2'), ']')]\",\"exists\":\"false\"},{\"value\":\"\ + [contains(resourceGroup().tags, parameters('skipTagName2'))]\",\"equals\"\ + :\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName2'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName3'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName3'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName3'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type\"\ + ,\"notEquals\":\"VirtualMachineRuntimeService\"}]},\"then\":{\"effect\":\"\ + modify\",\"details\":{\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ + \ parameters('azSecPackTagName'), ']')]\",\"value\":\"[parameters('azSecPackTagValue')]\"\ + }]}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/71f8559f28de5992\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"71f8559f28de5992\"\ + },{\"properties\":{\"displayName\":\"azuremonitorlinuxagent extension autoupdate\ + \ policy for vmss_1.4\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-02-23T21:10:01.6737942Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\"\ + ,\"existenceCondition\":{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"AzureMonitorLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitor\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ + ,\"equals\":\"true\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/provisioningState\"\ + ,\"in\":[\"Succeeded\",\"Provisioning succeeded\"]}]},\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ + string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ + :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Monitor.AzureMonitorLinuxAgent')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Monitor\"\ + ,\"type\":\"AzureMonitorLinuxAgent\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":true,\"settings\":{\"GCS_AUTO_CONFIG\":true},\"\ + protectedSettings\":{}}}]},\"parameters\":{\"vmssName\":{\"value\":\"[field('name')]\"\ + },\"location\":{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/73d4d2856cfcab45\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"73d4d2856cfcab45\"\ + },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-04-01T22:23:59.788546Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ + :\"The list of locations that can be specified when deploying resources.\"\ + ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"},{\"field\":\"location\"\ + ,\"in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.Batch/batchAccounts/poolAllocationMode\"\ + ,\"notIn\":[\"batchservice\",\"null\",\"\"]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"74c98b59a6341488\"\ + },{\"properties\":{\"displayName\":\"nrms-subnet-require-nsg_1.3\",\"policyType\"\ + :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2020-02-24T19:34:01.1631389Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ + },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ + Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ + policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"tags['SkipNRMSNSG']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['SkipNRMSNSG']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ + },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ + :[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ + },{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ + ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.Network/virtualNetworks/subnets\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ + ,\"exists\":\"false\"}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"789cfec91f9e1858\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-102_1.3\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:24.2401173Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2020-02-24T21:28:28.7454992Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -41178,22 +24343,24 @@ interactions: String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ + \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ + :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ + :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ + tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ + ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ + false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ + equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ + [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ @@ -41232,195 +24399,184 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/eed6a81371f5e28b\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"eed6a81371f5e28b\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-107_1.1\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-08T19:20:24.6068273Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ - \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ - :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ - :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ - ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ - }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"allowedValues\":[\"NA\",\"NRMSException\"\ - ,\"SkipNRMSCorp\",\"nrmsskipcorpnetsaw\",\"SkipNRMSSAW\",\"SkipNRMSDatabricks\"\ - ,\"SkipNRMSRDPSSH\",\"SkipNRMSMgmt\",\"SkipNRMSHigh\",\"SkipNRMSVNet\",\"\ - SkipNRMSLoadBal\",\"SkipNRMSDB\",\"SkipNRMSMedium\"],\"defaultValue\":\"NA\"\ - }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\":\"[subscription().subscriptionId]\"\ - ,\"notIn\":\"[parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\"\ - :\"deployIfNotExists\",\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ - ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/f0e3de3e84e21226\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f0e3de3e84e21226\"\ - },{\"properties\":{\"displayName\":\"nrms-subnet-require-nsg_1.0\",\"policyType\"\ - :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-06-26T21:23:26.5935651Z\",\"updatedBy\":null,\"updatedOn\"\ - :null},\"parameters\":{\"effect\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"Effect\",\"description\":\"Enable or disable the execution of the policy\"\ - },\"allowedValues\":[\"Audit\",\"Deny\",\"Disabled\"],\"defaultValue\":\"\ - Audit\"},\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7c066e9166289efb\"\ + },{\"properties\":{\"displayName\":\"azuremonitorlinuxagent extension autoupdate\ + \ policy for iaas_1.3\",\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"\ + metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2021-02-09T20:11:39.7056976Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ :\"Allowed locations\",\"description\":\"The list of locations that can be\ - \ specified when deploying resources.\",\"strongType\":\"location\"}}},\"\ - policyRule\":{\"if\":{\"allOf\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ - },{\"anyOf\":[{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/virtualNetworks/subnets\"\ - },{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ - :\"Microsoft.Network/virtualNetworks/subnets\"},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ - ,\"exists\":\"false\"}]}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ - }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/f828e370e4aad7e8\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"f828e370e4aad7e8\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-107_1.3\",\"policyType\"\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"skipTagName1\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"\ + },\"skipTagName2\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('skipTagName1'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipResourceGroupTagName1'))]\",\"equals\":\"false\"},{\"value\"\ + :\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"},{\"not\":{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.provisionVMAgent\"\ + ,\"equals\":\"false\"}},{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Canonical\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"UbuntuServer\",\"0001-com-ubuntu-server-focal\",\"0001-com-ubuntu-server-eoan\"\ + ,\"0001-com-ubuntu-server-focal-daily\",\"0001-com-ubuntu-pro-bionic\",\"\ + 0001-com-ubuntu-pro-focal\",\"0003-com-ubuntu-server-trusted-vm\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"16.04*LTS\"},{\"field\"\ + :\"Microsoft.Compute/imageSKU\",\"like\":\"18.04*LTS\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"20_04-lts*\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"OpenLogic\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"\ + in\":[\"CentOS\",\"CentOS-CI\",\"CentOS-HPC\",\"CentOS-LVM\",\"CentOS-SRIOV\"\ + ]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"\ + field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"credativ\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"Debian\"]},{\"anyOf\":[{\"\ + field\":\"Microsoft.Compute/imageSKU\",\"equals\":\"8\"},{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"equals\":\"9\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"Debian\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"Debian-10\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"\ + equals\":\"10\"}]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\"\ + ,\"equals\":\"RedHat\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\"\ + :[\"osa\",\"RHEL\",\"rhel-byos\",\"rhel-ocp-marketplace\",\"RHEL-SAP\",\"\ + RHEL-SAP-HA\",\"RHEL-HA\",\"RHEL-SAP-APPS\",\"RHEL-SAP-HANA\"]},{\"anyOf\"\ + :[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"},{\"field\":\"\ + Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\":[{\"field\":\"\ + Microsoft.Compute/imagePublisher\",\"equals\":\"Oracle\"},{\"field\":\"Microsoft.Compute/imageOffer\"\ + ,\"in\":[\"Oracle-Database-Ee\",\"Oracle-Database-Se\",\"Oracle-Linux\",\"\ + Oracle-Linux-7\",\"Oracle-WebLogic-Server\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"7.*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"7*\"\ + },{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"8*\"}]}]},{\"allOf\"\ + :[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\":\"SUSE\"},{\"\ + field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"openSUSE-Leap\",\"SLES\"\ + ,\"SLES-BYOS\",\"SLES-HPC\",\"SLES-HPC-Priority\",\"SLES-Priority\",\"SLES-SAP\"\ + ,\"SLES-SAP-BYOS\",\"SLES-SAPCAL\",\"SLES-Standard\",\"SLES-12-SP5\",\"SLES-15-SP2\"\ + ,\"SUSE-CaaSP-Admin-BYOS\",\"SUSE-CaaSP-Cluster-BYOS\",\"SUSE-Manager-Proxy-BYOS\"\ + ,\"SUSE-Manager-Server-BYOS\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\"\ + ,\"like\":\"12*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"gen*\"\ + }]}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"microsoft-aks\"},{\"field\":\"Microsoft.Compute/imageOffer\",\"in\":[\"\ + aks\"]},{\"anyOf\":[{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-ubuntu-1804-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\":\"\ + aks-engine-ubuntu-1604-*\"},{\"field\":\"Microsoft.Compute/imageSKU\",\"like\"\ + :\"aks-engine-ubuntu-1804-*\"}]}]}]}]},\"then\":{\"effect\":\"deployIfNotExists\"\ + ,\"details\":{\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"\ + name\":\"Microsoft.Azure.Monitor.AzureMonitorLinuxAgent\",\"existenceCondition\"\ + :{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachines/extensions/type\"\ + ,\"equals\":\"AzureMonitorLinuxAgent\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Monitor\"},{\"field\":\"Microsoft.Compute/virtualMachines/extensions/provisioningState\"\ + ,\"in\":[\"Succeeded\",\"Provisioning succeeded\"]}]},\"roleDefinitionIds\"\ + :[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmName\":{\"type\":\"string\"\ + },\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\":\"2018-10-01\"\ + ,\"name\":\"[concat(parameters('vmName'), '/Microsoft.Azure.Monitor.AzureMonitorLinuxAgent')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachines/extensions\",\"location\":\"\ + [parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Monitor\"\ + ,\"type\":\"AzureMonitorLinuxAgent\",\"typeHandlerVersion\":\"1.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":false,\"settings\":{\"GCS_AUTO_CONFIG\":true},\"\ + protectedSettings\":{}}}]},\"parameters\":{\"vmName\":{\"value\":\"[field('name')]\"\ + },\"location\":{\"value\":\"[field('location')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7d3105ed79114b05\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7d3105ed79114b05\"\ + },{\"properties\":{\"displayName\":\"vmvmssfirstpartyidentificationtag_1.5\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2021-02-05T18:34:12.5830102Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"tagName\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"tagName\",\"description\":\"Opted\ + \ in for PKI\"},\"defaultValue\":\"platformsettings.host_environment.service.platform_optedin_for_rootcerts\"\ + },\"tagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"tagValue\"\ + ,\"description\":\"is this the first party VM?\"},\"defaultValue\":\"true\"\ + },\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\":\"\ + Allowed locations\",\"description\":\"The list of locations that can be specified\ + \ when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname\":{\"type\":\"String\",\"metadata\":{\"\ + displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"subscriptiontagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the subscription level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"\ + field\":\"type\",\"in\":[\"Microsoft.Compute/virtualMachines\",\"Microsoft.Compute/virtualMachineScaleSets\"\ + ]},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"exists\"\ + :\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"[concat('tags[', parameters('tagName'), ']')]\"\ + ,\"exists\":\"false\"}]},\"then\":{\"effect\":\"append\",\"details\":[{\"\ + field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"value\":\"[parameters('tagValue')]\"\ + }]}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7e64acbfa5b2bcc9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"7e64acbfa5b2bcc9\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-subnet_1.2\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2020-02-24T21:29:08.0100184Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2020-02-24T21:27:19.9099766Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ - }},\"ruleNo\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Priority\"\ - ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ - :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ - ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ - ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ - ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ - :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ - ,\"Service Tag\",\"App Security Group\"]},\"sourceValue\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"sourceValue\",\"description\":null}},\"actionValue\"\ - :{\"type\":\"String\",\"metadata\":{\"displayName\":\"actionValue\",\"description\"\ - :null},\"allowedValues\":[\"Allow\",\"Deny\"]},\"direction\":{\"type\":\"\ - String\",\"metadata\":{\"displayName\":\"direction\",\"description\":null},\"\ - allowedValues\":[\"Inbound\",\"Outbound\"]},\"tagname\":{\"type\":\"String\"\ - ,\"metadata\":{\"displayName\":\"Tag Name\",\"description\":\"Rule is not\ - \ deployed if this tag exists on the NSG\"},\"defaultValue\":\"NA\"}},\"policyRule\"\ - :{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Network/networkSecurityGroups\"\ - },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ - field\":\"[concat('tags[', parameters('tagName'), ']')]\",\"exists\":\"false\"\ - },{\"value\":\"[resourceGroup().tags[parameters('tagname')]]\",\"equals\"\ - :\"\"},{\"field\":\"tags['SkipNRMSAll']\",\"exists\":\"false\"},{\"value\"\ - :\"[resourceGroup().tags['SkipNRMSAll']]\",\"equals\":\"\"},{\"field\":\"\ - tags['autopilotcluster']\",\"exists\":\"false\"},{\"value\":\"[resourceGroup().tags['autopilotcluster']]\"\ - ,\"equals\":\"\"},{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"\ - false\"},{\"value\":\"[resourceGroup().tags['autopilotenvironment']]\",\"\ - equals\":\"\"},{\"value\":\"[subscription().subscriptionId]\",\"notIn\":\"\ - [parameters('subscriptionExclusions')]\"}]},\"then\":{\"effect\":\"deployIfNotExists\"\ - ,\"details\":{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\"\ + }},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Subscriptions Excluded\",\"description\":\"Subscriptions excluded from\ + \ policy due to security exceptions\"}},\"resourceGroupExclusions\":{\"type\"\ + :\"Array\",\"metadata\":{\"displayName\":\"Resource Groups Excluded\",\"description\"\ + :\"Any VNet in a resource group in this list will be ignored.\"},\"defaultValue\"\ + :[]}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"\ + Microsoft.Network/virtualNetworks/subnets\"},{\"value\":\"[subscription().subscriptionId]\"\ + ,\"notIn\":\"[parameters('subscriptionExclusions')]\"},{\"value\":\"[resourceGroup().name]\"\ + ,\"notIn\":\"[parameters('resourceGroupExclusions')]\"},{\"field\":\"name\"\ + ,\"notContains\":\"GatewaySubnet\"},{\"field\":\"tags['SkipNRMSNSG']\",\"\ + exists\":\"false\"},{\"value\":\"[resourceGroup().tags['SkipNRMSNSG']]\",\"\ + equals\":\"\"},{\"field\":\"tags['autopilotcluster']\",\"exists\":\"false\"\ + },{\"value\":\"[resourceGroup().tags['autopilotcluster']]\",\"equals\":\"\"\ + },{\"field\":\"tags['autopilotenvironment']\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags['autopilotenvironment']]\",\"equals\":\"\"},{\"anyOf\"\ + :[{\"not\":{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ + ,\"notIn\":[\"null\",\"\"]}},{\"field\":\"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id\"\ + ,\"exists\":\"false\"}]}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ + :{\"type\":\"Microsoft.Authorization/policyAssignments\",\"name\":\"DoesNotExistBecauseThisIsToCauseDeployment\"\ ,\"roleDefinitionIds\":[\"/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7\"\ - ],\"existenceCondition\":{\"anyOf\":[{\"allOf\":[{\"field\":\"fullName\",\"\ - equals\":\"[concat(field('name'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - },{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"[parameters('ruleno')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ - ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ - ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ - ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ - ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ - ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"fullName\":{\"type\":\"\ - string\"},\"ruleNo\":{\"type\":\"String\"},\"destinationPortRanges\":{\"type\"\ - :\"Array\"},\"protocol\":{\"type\":\"String\"},\"sourceType\":{\"type\":\"\ - String\"},\"sourceValue\":{\"type\":\"String\"},\"actionValue\":{\"type\"\ - :\"String\"},\"direction\":{\"type\":\"String\"},\"info\":{\"type\":\"String\"\ - }},\"variables\":{\"SourceArr\":\"[split(parameters('sourceValue'),',')]\"\ - ,\"appSecGroups\":{\"copy\":[{\"name\":\"values\",\"count\":\"[length(variables('SourceArr'))]\"\ - ,\"input\":{\"id\":\"[if(equals(parameters('sourceType'),'App Security Group'),if(contains(variables('SourceArr')[copyindex('values')],'subscriptions'),\ - \ variables('SourceArr')[copyindex('values')],resourceId('Microsoft.Network/applicationSecurityGroups',\ - \ variables('SourceArr')[copyindex('values')])), '')]\"}}]}},\"resources\"\ - :[{\"type\":\"Microsoft.Network/networkSecurityGroups/securityRules\",\"name\"\ - :\"[concat(parameters('fullName'),'/','NRMS-Rule-', parameters('ruleNo'))]\"\ - ,\"apiVersion\":\"2017-10-01\",\"scale\":null,\"properties\":{\"protocol\"\ - :\"[parameters('protocol')]\",\"description\":\"[parameters('info')]\",\"\ - sourcePortRange\":\"*\",\"sourceAddressPrefix\":\"[if(equals(parameters('sourceType'),'Service\ - \ Tag'),parameters('sourceValue'),json('null'))]\",\"sourceAddressPrefixes\"\ - :\"[if(equals(parameters('sourceType'),'IP Addresses'),variables('SourceArr'),json('null'))]\"\ - ,\"sourceApplicationSecurityGroups\":\"[if(equals(parameters('sourceType'),'App\ - \ Security Group'),variables('appSecGroups').values,json('null'))]\",\"destinationPortRanges\"\ - :\"[if (equals(1,length(parameters('destinationPortRanges'))), json('null'),\ - \ parameters('destinationPortRanges'))]\",\"destinationPortRange\":\"[if (equals(1,length(parameters('destinationPortRanges'))),\ - \ parameters('destinationPortRanges')[0], json('null'))]\",\"destinationAddressPrefix\"\ - :\"*\",\"destinationApplicationSecurityGroups\":[],\"access\":\"[parameters('actionValue')]\"\ - ,\"priority\":\"[parameters('ruleNo')]\",\"direction\":\"[parameters('direction')]\"\ - }}]},\"parameters\":{\"fullName\":{\"value\":\"[field('fullName')]\"},\"ruleNo\"\ - :{\"value\":\"[parameters('ruleNo')]\"},\"destinationPortRanges\":{\"value\"\ - :\"[parameters('destinationPortRanges')]\"},\"protocol\":{\"value\":\"[parameters('protocol')]\"\ - },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ - :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ - [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fb6de85c9e746cf1\"\ - },{\"properties\":{\"displayName\":\"nrms-nsg-rule-108_1.2\",\"policyType\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json\"\ + ,\"contentVersion\":\"1.0.0.1\",\"parameters\":{\"fullSubnetName\":{\"type\"\ + :\"String\"},\"allowedLocations\":{\"type\":\"Array\"}},\"variables\":{\"\ + vnetName\":\"[first(split(parameters('fullSubnetName'),'/'))]\",\"subnetName\"\ + :\"[last(split(parameters('fullSubnetName'),'/'))]\",\"rawNsgName\":\"[concat(variables('vnetName'),'-',\ + \ variables('subnetName'), '-NRMS')]\",\"nsgName\":\"[if(greater(length(variables('rawNsgName')),75),substring(variables('rawNsgName'),0,75),variables('rawNsgName'))]\"\ + ,\"nsgUpdateJson\":{\"networkSecurityGroup\":{\"id\":\"[resourceId('Microsoft.Network/networkSecurityGroups',\ + \ variables('nsgName'))]\"}}},\"resources\":[{\"condition\":\"[contains(parameters('allowedLocations'),\ + \ resourceGroup().location)]\",\"type\":\"Microsoft.Network/networkSecurityGroups\"\ + ,\"name\":\"[variables('nsgName')]\",\"apiVersion\":\"2018-03-01\",\"location\"\ + :\"[resourceGroup().location]\",\"tags\":{\"Creator\":\"Automatically added\ + \ by NRMS Azure Policy\",\"NRMS-Info\":\"http://aka.ms/nrms\",\"NRMS-Version\"\ + :\"2019-03-20\"},\"properties\":{}},{\"type\":\"Microsoft.Resources/deployments\"\ + ,\"name\":\"NRMS-Update-Subnet-Without-NSG\",\"apiVersion\":\"2018-05-01\"\ + ,\"properties\":{\"mode\":\"Incremental\",\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"resources\":[{\"apiVersion\":\"2018-11-01\"\ + ,\"type\":\"Microsoft.Network/virtualNetworks/subnets\",\"name\":\"[parameters('fullSubnetName')]\"\ + ,\"location\":\"[resourceGroup().location]\",\"properties\":\"[union(reference(resourceId('Microsoft.Network/virtualNetworks/subnets',\ + \ variables('vnetName'), variables('subnetName')), '2018-11-01'), variables('nsgUpdateJson'))]\"\ + }]}},\"dependsOn\":[\"[variables('nsgName')]\"]}]},\"parameters\":{\"fullSubnetName\"\ + :{\"value\":\"[field('fullName')]\"},\"allowedLocations\":{\"value\":\"[parameters('allowedLocations')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"852aeb0ee2c0a3a5\"\ + },{\"properties\":{\"displayName\":\"nrms-nsg-rule-109_1.1\",\"policyType\"\ :\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ - ,\"createdOn\":\"2019-07-09T18:15:32.8982907Z\",\"updatedBy\":null,\"updatedOn\"\ + ,\"createdOn\":\"2019-07-08T19:20:26.3856504Z\",\"updatedBy\":null,\"updatedOn\"\ :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ @@ -41428,13 +24584,12 @@ interactions: ,\"description\":\"The priority slot for the new rule\"},\"allowedValues\"\ :[\"100\",\"101\",\"102\",\"103\",\"104\",\"105\",\"106\",\"107\",\"108\"\ ,\"109\"]},\"info\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ - Description\",\"description\":\"A description\"},\"defaultValue\":\"\"},\"\ - destinationPortRanges\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ - :\"Port Number\",\"description\":\"Security rule port numbers must match these\ - \ numbers\"}},\"subscriptionExclusions\":{\"type\":\"Array\",\"metadata\"\ - :{\"displayName\":\"Subscriptions Excluded\",\"description\":\"Subscriptions\ - \ excluded from policy due to security exceptions\"},\"defaultValue\":[]},\"\ - protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ + Description\",\"description\":\"A description\"}},\"destinationPortRanges\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Port Number\",\"description\"\ + :\"Security rule port numbers must match these numbers\"}},\"subscriptionExclusions\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Subscriptions Excluded\"\ + ,\"description\":\"Subscriptions excluded from policy due to security exceptions\"\ + }},\"protocol\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"protocol\"\ ,\"description\":\"Protocol for the rule\"},\"allowedValues\":[\"*\",\"Tcp\"\ ,\"Udp\"]},\"sourceType\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ :\"sourceType\",\"description\":null},\"allowedValues\":[\"IP Addresses\"\ @@ -41463,9 +24618,9 @@ interactions: ,\"equals\":\"[parameters('sourceValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"[parameters('actionValue')]\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"[parameters('direction')]\"}]},{\"allOf\":[{\"field\":\"fullName\"\ - ,\"contains\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ + ,\"equals\":\"Cleanuptool-Deny-103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/priority\"\ ,\"equals\":\"103\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix\"\ - ,\"in\":[\"Any\",\"*\"]},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ + ,\"equals\":\"Any\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/access\"\ ,\"equals\":\"Deny\"},{\"field\":\"Microsoft.Network/networkSecurityGroups/securityRules/direction\"\ ,\"equals\":\"Inbound\"}]}]},\"deployment\":{\"properties\":{\"mode\":\"incremental\"\ ,\"template\":{\"$schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ @@ -41499,18 +24654,1157 @@ interactions: },\"sourceType\":{\"value\":\"[parameters('sourceType')]\"},\"sourceValue\"\ :{\"value\":\"[parameters('sourceValue')]\"},\"actionValue\":{\"value\":\"\ [parameters('actionValue')]\"},\"direction\":{\"value\":\"[parameters('direction')]\"\ - },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fc84f507da5fe442\"\ - ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"fc84f507da5fe442\"\ - }]}" + },\"info\":{\"value\":\"[parameters('info')]\"}}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8657a5b3e83f5307\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"8657a5b3e83f5307\"\ + },{\"properties\":{\"displayName\":\"linux azsecpack nonprod tagging for iaas_1.3\"\ + ,\"policyType\":\"Custom\",\"mode\":\"Indexed\",\"metadata\":{\"createdBy\"\ + :\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2021-02-09T20:11:40.7362398Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"allowedLocations\"\ + :{\"type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"\ + description\":\"The list of locations that can be specified when deploying\ + \ resources.\",\"strongType\":\"location\"}},\"azSecPackTagName\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"AzSecPack Tag Name\",\"description\"\ + :\"This policy adds the specified tag\"},\"defaultValue\":\"azsecpack\"},\"\ + azSecPackTagValue\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"\ + AzSecPack Tag Value\",\"description\":\"This policy adds the specified tag\ + \ value\"},\"defaultValue\":\"nonprod\"},\"skipTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name\",\"description\":\"Rule\ + \ is not deployed if this tag exists on the resource, resource group level,\ + \ or subscription level\"},\"defaultValue\":\"SkipASMAzSecPack\"},\"skipTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the resource,\ + \ resource group level, or subscription level\"},\"defaultValue\":\"SkipASMAzSecPackAutoConfig\"\ + },\"skipTagName3\":{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion\ + \ Tag Name\",\"description\":\"Rule is not deployed if this tag exists on\ + \ the resource, resource group level, or subscription level\"},\"defaultValue\"\ + :\"SkipLinuxAzSecPack\"},\"skipResourceGroupTagName1\":{\"type\":\"String\"\ + ,\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource group\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Resource Group\"},\"defaultValue\":\"autopilotcluster\"},\"skipResourceGroupTagName2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"},\"defaultValue\":\"autopilotenvironment\"\ + }},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile\",\"containsKey\"\ + :\"linuxConfiguration\"},{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"[concat('tags[', parameters('azSecPackTagName'), ']')]\",\"\ + notEquals\":\"[parameters('azSecPackTagValue')]\"},{\"field\":\"[concat('tags[',\ + \ parameters('skipTagName1'), ']')]\",\"exists\":\"false\"},{\"value\":\"\ + [contains(resourceGroup().tags, parameters('skipTagName1'))]\",\"equals\"\ + :\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName1'))]\"\ + ,\"equals\":\"false\"},{\"field\":\"[concat('tags[', parameters('skipTagName2'),\ + \ ']')]\",\"exists\":\"false\"},{\"value\":\"[contains(resourceGroup().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"value\":\"[contains(subscription().tags,\ + \ parameters('skipTagName2'))]\",\"equals\":\"false\"},{\"field\":\"[concat('tags[',\ + \ parameters('skipTagName3'), ']')]\",\"exists\":\"false\"},{\"value\":\"\ + [contains(resourceGroup().tags, parameters('skipTagName3'))]\",\"equals\"\ + :\"false\"},{\"value\":\"[contains(subscription().tags, parameters('skipTagName3'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName1'))]\"\ + ,\"equals\":\"false\"},{\"value\":\"[contains(resourceGroup().tags, parameters('skipResourceGroupTagName2'))]\"\ + ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"modify\",\"details\":{\"roleDefinitionIds\"\ + :[\"/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"operations\":[{\"operation\":\"addOrReplace\",\"field\":\"[concat('tags[',\ + \ parameters('azSecPackTagName'), ']')]\",\"value\":\"[parameters('azSecPackTagValue')]\"\ + }]}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/880bf73fd544d948\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"880bf73fd544d948\"\ + },{\"properties\":{\"displayName\":\"geneva monitoring extension and azsecpack\ + \ autoupdate policy for vmss_2.2\",\"policyType\":\"Custom\",\"mode\":\"Indexed\"\ + ,\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\"\ + :\"2020-06-23T19:35:03.2379239Z\",\"updatedBy\":null,\"updatedOn\":null},\"\ + parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\":{\"displayName\"\ + :\"Allowed locations\",\"description\":\"The list of locations that can be\ + \ specified when deploying resources.\",\"strongType\":\"location\"}},\"resourcetagname\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Virtual\ + \ Machine\"}},\"resourcegrouptagname1\":{\"type\":\"String\",\"metadata\"\ + :{\"displayName\":\"Exclusion Tag Name at the resource group level\",\"description\"\ + :\"Rule is not deployed if this tag exists on the Resource Group\"}},\"resourcegrouptagname2\"\ + :{\"type\":\"String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at\ + \ the resource group level\",\"description\":\"Rule is not deployed if this\ + \ tag exists on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription\ + \ level\",\"description\":\"Rule is not deployed if this tag exists on the\ + \ Subscription\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\":\"type\"\ + ,\"equals\":\"Microsoft.Compute/virtualMachineScaleSets\"},{\"field\":\"location\"\ + ,\"in\":\"[parameters('allowedLocations')]\"},{\"field\":\"[concat('tags[',\ + \ parameters('resourcetagname'), ']')]\",\"exists\":\"false\"},{\"value\"\ + :\"[resourceGroup().tags[parameters('resourcegrouptagname1')]]\",\"equals\"\ + :\"\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname2')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"anyOf\":[{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration\"\ + ,\"exists\":\"true\"},{\"field\":\"Microsoft.Compute/imagePublisher\",\"equals\"\ + :\"MicrosoftWindowsServer\"}]},{\"field\":\"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent\"\ + ,\"equals\":\"true\"}]},\"then\":{\"effect\":\"deployIfNotExists\",\"details\"\ + :{\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"existenceCondition\"\ + :{\"anyOf\":[{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"GenevaMonitoring\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Azure.Geneva\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade\"\ + ,\"equals\":\"true\"}]},{\"allOf\":[{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/type\"\ + ,\"equals\":\"VirtualMachineRuntimeService\"},{\"field\":\"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher\"\ + ,\"equals\":\"Microsoft.Compute\"}]}]},\"roleDefinitionIds\":[\"/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c\"\ + ],\"deployment\":{\"properties\":{\"mode\":\"incremental\",\"template\":{\"\ + $schema\":\"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#\"\ + ,\"contentVersion\":\"1.0.0.0\",\"parameters\":{\"vmssName\":{\"type\":\"\ + string\"},\"location\":{\"type\":\"string\"}},\"resources\":[{\"apiVersion\"\ + :\"2018-10-01\",\"name\":\"[concat(parameters('vmssName'), '/Microsoft.Azure.Geneva.GenevaMonitoring')]\"\ + ,\"type\":\"Microsoft.Compute/virtualMachineScaleSets/extensions\",\"location\"\ + :\"[parameters('location')]\",\"properties\":{\"publisher\":\"Microsoft.Azure.Geneva\"\ + ,\"type\":\"GenevaMonitoring\",\"typeHandlerVersion\":\"2.0\",\"autoUpgradeMinorVersion\"\ + :true,\"enableAutomaticUpgrade\":true,\"settings\":{}}}]},\"parameters\":{\"\ + vmssName\":{\"value\":\"[field('name')]\"},\"location\":{\"value\":\"[field('location')]\"\ + }}}}}}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/884fc572e38f5fe9\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"884fc572e38f5fe9\"\ + },{\"properties\":{\"displayName\":\"nrms-kubernet-require-azure-networkplugin_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:24.5730438Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ + :\"The list of locations that can be specified when deploying resources.\"\ + ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"anyOf\":[{\"allOf\"\ + :[{\"field\":\"type\",\"equals\":\"Microsoft.ContainerService/managedClusters\"\ + },{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"},{\"\ + not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ + ,\"notIn\":[\"null\",\"\"]}}]},{\"allOf\":[{\"field\":\"type\",\"equals\"\ + :\"Microsoft.ContainerService/managedClusters\"},{\"field\":\"location\",\"\ + in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin\"\ + ,\"equals\":\"azure\"}}]}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/88adc7594e846097\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"88adc7594e846097\"\ + },{\"properties\":{\"displayName\":\"audit ssh auth on existing vms_1.5\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"description\":\"This policy\ + \ audits whether any Linux VMs use password-only authentication for SSH on\ + \ existing resources.\",\"metadata\":{\"createdBy\":\"1f75b9dd-4f1d-4e80-9521-321a8b1f5764\"\ + ,\"createdOn\":\"2021-01-20T00:20:21.2746349Z\",\"updatedBy\":null,\"updatedOn\"\ + :null},\"parameters\":{\"allowedLocations\":{\"type\":\"Array\",\"metadata\"\ + :{\"displayName\":\"Allowed locations\",\"description\":\"The list of locations\ + \ that can be specified when deploying resources.\",\"strongType\":\"location\"\ + }},\"resourcetagname\":{\"type\":\"String\",\"metadata\":{\"displayName\"\ + :\"Exclusion Tag Name\",\"description\":\"Rule is not deployed if this tag\ + \ exists on the Virtual Machine\"}},\"resourcegrouptagname\":{\"type\":\"\ + String\",\"metadata\":{\"displayName\":\"Exclusion Tag Name at the resource\ + \ group level\",\"description\":\"Rule is not deployed if this tag exists\ + \ on the Resource Group\"}},\"subscriptiontagname\":{\"type\":\"String\",\"\ + metadata\":{\"displayName\":\"Exclusion Tag Name at the subscription level\"\ + ,\"description\":\"Rule is not deployed if this tag exists on the Subscription\"\ + }}},\"policyRule\":{\"if\":{\"allof\":[{\"field\":\"location\",\"in\":\"[parameters('allowedLocations')]\"\ + },{\"field\":\"[concat('tags[', parameters('resourcetagname'), ']')]\",\"\ + exists\":\"false\"},{\"value\":\"[resourceGroup().tags[parameters('resourcegrouptagname')]]\"\ + ,\"equals\":\"\"},{\"value\":\"[subscription().tags[parameters('subscriptiontagname')]]\"\ + ,\"equals\":\"\"},{\"field\":\"type\",\"equals\":\"Microsoft.Compute/virtualMachines\"\ + },{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration\"\ + ,\"exists\":\"True\"},{\"field\":\"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication\"\ + ,\"equals\":\"false\"}]},\"then\":{\"effect\":\"audit\"}}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/891765f460fe4214\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"891765f460fe4214\"\ + },{\"properties\":{\"displayName\":\"nrms-batch-require-user-subscription-mode_1.0\"\ + ,\"policyType\":\"Custom\",\"mode\":\"All\",\"metadata\":{\"createdBy\":\"\ + 1f75b9dd-4f1d-4e80-9521-321a8b1f5764\",\"createdOn\":\"2019-06-26T21:23:23.3819739Z\"\ + ,\"updatedBy\":null,\"updatedOn\":null},\"parameters\":{\"effect\":{\"type\"\ + :\"String\",\"metadata\":{\"displayName\":\"Effect\",\"description\":\"Enable\ + \ or disable the execution of the policy\"},\"allowedValues\":[\"Audit\",\"\ + Deny\",\"Disabled\"],\"defaultValue\":\"Audit\"},\"allowedLocations\":{\"\ + type\":\"Array\",\"metadata\":{\"displayName\":\"Allowed locations\",\"description\"\ + :\"The list of locations that can be specified when deploying resources.\"\ + ,\"strongType\":\"location\"}}},\"policyRule\":{\"if\":{\"allOf\":[{\"field\"\ + :\"type\",\"equals\":\"Microsoft.Batch/batchAccounts\"},{\"field\":\"location\"\ + ,\"in\":\"[parameters('allowedLocations')]\"},{\"not\":{\"field\":\"Microsoft.Batch/batchAccounts/poolAllocationMode\"\ + ,\"notIn\":[\"batchservice\",\"null\",\"\"]}}]},\"then\":{\"effect\":\"[parameters('effect')]\"\ + }}},\"id\":\"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/891d9369d047f6ac\"\ + ,\"type\":\"Microsoft.Authorization/policyDefinitions\",\"name\":\"891d9369d047f6ac\"\ + }],\"nextLink\":\"https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVDdXN0b21EZWZpbml0aW9uIiwibmV4dFBhcnRpdGlvbktleSI6IjEhOCFNREF4UXpVLSIsIm5leHRSb3dLZXkiOiIxITE1MiFOekpHT1RnNFFrWTROa1l4TkRGQlJqa3hRVUl5UkRkRFJEQXhNVVJDTkRkZk5qSTBNamd6UkRFeFF6TTVSalF6T1RsQ01rSTRNek0yUXpsRU5VRkZORFJETXpCQ09UbEJOVFl4UVRrek9UUXlOVFJFTVRnd1JFVTNPRE5EUkVGQk9DMDRSRFk1UkRoRlJUVTNNRUkyTXprLSIsIm5leHRTY29wZSI6InByb3ZpZGVycy9NaWNyb3NvZnQuTWFuYWdlbWVudC9tYW5hZ2VtZW50R3JvdXBzLzQ4ZmVkM2ExLTA4MTQtNDg0Ny04OGNlLWI3NjYxNTVmMjc5Mi8ifQ%253D%253D\"\ + }" + headers: + cache-control: + - no-cache + content-length: + - '1269213' + content-type: + - application/json; charset=utf-8 + date: + - Fri, 26 Feb 2021 07:40:17 GMT + expires: + - '-1' + pragma: + - no-cache + strict-transport-security: + - max-age=31536000; includeSubDomains + transfer-encoding: + - chunked + vary: + - Accept-Encoding,Accept-Encoding + x-content-type-options: + - nosniff + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + method: GET + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions?api-version=2020-09-01&%24skiptoken=eyJuZXh0UG9saWN5U3RvcmUiOiJDb250cm9sUGxhbmVDdXN0b21EZWZpbml0aW9uIiwibmV4dFBhcnRpdGlvbktleSI6IjEhOCFNREF4UXpVLSIsIm5leHRSb3dLZXkiOiIxITE1MiFOekpHT1RnNFFrWTROa1l4TkRGQlJqa3hRVUl5UkRkRFJEQXhNVVJDTkRkZk5qSTBNamd6UkRFeFF6TTVSalF6T1RsQ01rSTRNek0yUXpsRU5VRkZORFJETXpCQ09UbEJOVFl4UVRrek9UUXlOVFJFTVRnd1JFVTNPRE5EUkVGQk9DMDRSRFk1UkRoRlJUVTNNRUkyTXprLSIsIm5leHRTY29wZSI6InByb3ZpZGVycy9NaWNyb3NvZnQuTWFuYWdlbWVudC9tYW5hZ2VtZW50R3JvdXBzLzQ4ZmVkM2ExLTA4MTQtNDg0Ny04OGNlLWI3NjYxNTVmMjc5Mi8ifQ%253D%253D + response: + body: + string: '{"value":[{"properties":{"displayName":"nrms-nsg-rule-104_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:15.9708014Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"}},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","equals":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Any"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8d69d8ee570b639","type":"Microsoft.Authorization/policyDefinitions","name":"8d69d8ee570b639"},{"properties":{"displayName":"sqlads-auditifnotexists-auditing + should be enabled on advanced data security settings on sql server_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:36.9468814Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the SQL + Server"}},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"},"setting":{"type":"String"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''tagname'')]]","equals":""}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/auditingSettings","name":"default","existenceCondition":{"field":"Microsoft.Sql/auditingSettings.state","equals":"[parameters(''setting'')]"}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fce770def99399","type":"Microsoft.Authorization/policyDefinitions","name":"8fce770def99399"},{"properties":{"displayName":"nrms-nsg-rule-106_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:28.0710497Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fdec1516a77bbd6","type":"Microsoft.Authorization/policyDefinitions","name":"8fdec1516a77bbd6"},{"properties":{"displayName":"audit + ssh auth on existing vmss_1.4","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMSSs use password-only authentication for + SSH on existing resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:41:53.0207896Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allof":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration","exists":"True"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9135d7012c4033cb","type":"Microsoft.Authorization/policyDefinitions","name":"9135d7012c4033cb"},{"properties":{"displayName":"nrms-nsg-rule-105_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:42.3856221Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd","type":"Microsoft.Authorization/policyDefinitions","name":"91f42c0ca66ff7dd"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack append policy for vmss_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-08-13T21:33:05.8939153Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]},{"field":"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile","exists":"true"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type","notEquals":"GenevaMonitoring"},{"not":{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent","equals":"false"}}]},"then":{"effect":"append","details":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]","value":{"name":"Microsoft.Azure.Geneva.GenevaMonitoring","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"settings":{}}}}]}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9534973cc57db387","type":"Microsoft.Authorization/policyDefinitions","name":"9534973cc57db387"},{"properties":{"displayName":"vmvmssfirstpartyidentificationtag_1.4","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-25T21:13:07.4439514Z","updatedBy":null,"updatedOn":null},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"tagName","description":"Opted + in for PKI"},"defaultValue":"platformsettings.host_environment.service.platform_optedin_for_rootcerts"},"tagValue":{"type":"String","metadata":{"displayName":"tagValue","description":"is + this the first party VM?"},"defaultValue":"true"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/95f9c4eadac531e","type":"Microsoft.Authorization/policyDefinitions","name":"95f9c4eadac531e"},{"properties":{"displayName":"nrms-nsg-subnet_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:09.005562Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"resourceGroupExclusions":{"type":"Array","metadata":{"displayName":"Resource + Groups Excluded","description":"Any VNet in a resource group in this list + will be ignored."},"defaultValue":[]}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"},{"value":"[resourceGroup().name]","notIn":"[parameters(''resourceGroupExclusions'')]"},{"field":"name","notContains":"GatewaySubnet"},{"field":"tags[''SkipNRMSNSG'']","exists":"false"},{"anyOf":[{"not":{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","notIn":["null",""]}},{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","exists":"false"}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Authorization/policyAssignments","name":"DoesNotExistBecauseThisIsToCauseDeployment","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json","contentVersion":"1.0.0.1","parameters":{"fullSubnetName":{"type":"String"},"allowedLocations":{"type":"Array"}},"variables":{"vnetName":"[first(split(parameters(''fullSubnetName''),''/''))]","subnetName":"[last(split(parameters(''fullSubnetName''),''/''))]","rawNsgName":"[concat(variables(''vnetName''),''-'', + variables(''subnetName''), ''-NRMS'')]","nsgName":"[if(greater(length(variables(''rawNsgName'')),75),substring(variables(''rawNsgName''),0,75),variables(''rawNsgName''))]","nsgUpdateJson":{"networkSecurityGroup":{"id":"[resourceId(''Microsoft.Network/networkSecurityGroups'', + variables(''nsgName''))]"}}},"resources":[{"condition":"[contains(parameters(''allowedLocations''), + resourceGroup().location)]","type":"Microsoft.Network/networkSecurityGroups","name":"[variables(''nsgName'')]","apiVersion":"2018-03-01","location":"[resourceGroup().location]","tags":{"Creator":"Automatically + added by NRMS Azure Policy","NRMS-Info":"http://aka.ms/nrms","NRMS-Version":"2019-03-20"},"properties":{}},{"type":"Microsoft.Resources/deployments","name":"NRMS-Update-Subnet-Without-NSG","apiVersion":"2018-05-01","properties":{"mode":"Incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","resources":[{"apiVersion":"2018-11-01","type":"Microsoft.Network/virtualNetworks/subnets","name":"[parameters(''fullSubnetName'')]","location":"[resourceGroup().location]","properties":"[union(reference(resourceId(''Microsoft.Network/virtualNetworks/subnets'', + variables(''vnetName''), variables(''subnetName'')), ''2018-11-01''), variables(''nsgUpdateJson''))]"}]}},"dependsOn":["[variables(''nsgName'')]"]}]},"parameters":{"fullSubnetName":{"value":"[field(''fullName'')]"},"allowedLocations":{"value":"[parameters(''allowedLocations'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9644d220df7c67a","type":"Microsoft.Authorization/policyDefinitions","name":"9644d220df7c67a"},{"properties":{"displayName":"nrms-nsg-rule-105_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:26.1317211Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9aca16db50fb914c","type":"Microsoft.Authorization/policyDefinitions","name":"9aca16db50fb914c"},{"properties":{"displayName":"audit + ssh auth on existing vmss_1.5","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMSSs use password-only authentication for + SSH on existing resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-20T00:20:16.9840774Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allof":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration","exists":"True"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9aeca05794bdcf50","type":"Microsoft.Authorization/policyDefinitions","name":"9aeca05794bdcf50"},{"properties":{"displayName":"nrms-nsg-rule-106_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:49.8100037Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08","type":"Microsoft.Authorization/policyDefinitions","name":"9b8d76c443040b08"},{"properties":{"displayName":"azuresecuritylinuxagent + extension autoupdate policy for iaas_1.3","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-09T20:11:40.3898154Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"not":{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.provisionVMAgent","equals":"false"}},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal","0001-com-ubuntu-server-eoan","0001-com-ubuntu-server-focal-daily","0001-com-ubuntu-pro-bionic","0001-com-ubuntu-pro-focal","0003-com-ubuntu-server-trusted-vm"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"20_04-lts*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"8"},{"field":"Microsoft.Compute/imageSKU","equals":"9"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Debian"},{"field":"Microsoft.Compute/imageOffer","in":["Debian-10"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-HA","RHEL-HA","RHEL-SAP-APPS","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-Linux-7","Oracle-WebLogic-Server"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SLES-12-SP5","SLES-15-SP2","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"gen*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1804-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1804-*"}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"AzureSecurityLinuxAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Security.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","in":["Succeeded","Provisioning + succeeded"]}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Security.Monitoring","type":"AzureSecurityLinuxAgent","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":false,"settings":{"enableGenevaUpload":true},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d378be231749f73","type":"Microsoft.Authorization/policyDefinitions","name":"9d378be231749f73"},{"properties":{"displayName":"nrms-nsg-rule-101_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:02.8942844Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be","type":"Microsoft.Authorization/policyDefinitions","name":"9d78e6174e6e69be"},{"properties":{"displayName":"audit + ssh auth on existing vms_1.4","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMs use password-only authentication for SSH + on existing resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:41:51.7770777Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allof":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"True"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9f778de970219a8a","type":"Microsoft.Authorization/policyDefinitions","name":"9f778de970219a8a"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack autoupdate policy for vmss_2.1","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-08-13T21:33:07.7274256Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]},{"not":{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration.provisionVMAgent","equals":"false"}}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","name":"Microsoft.Azure.Geneva.GenevaMonitoring","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"GenevaMonitoring"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Geneva"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade","equals":"true"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmssName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmssName''), + ''/Microsoft.Azure.Geneva.GenevaMonitoring'')]","type":"Microsoft.Compute/virtualMachineScaleSets/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{}}}]},"parameters":{"vmssName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/a646ce8cd06eac96","type":"Microsoft.Authorization/policyDefinitions","name":"a646ce8cd06eac96"},{"properties":{"displayName":"azuremonitorlinuxagent + extension autoupdate policy for iaas_1.4","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:10:00.159649Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"not":{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.provisionVMAgent","equals":"false"}},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal","0001-com-ubuntu-server-eoan","0001-com-ubuntu-server-focal-daily","0001-com-ubuntu-pro-bionic","0001-com-ubuntu-pro-focal","0003-com-ubuntu-server-trusted-vm"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"20_04-lts*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"8"},{"field":"Microsoft.Compute/imageSKU","equals":"9"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Debian"},{"field":"Microsoft.Compute/imageOffer","in":["Debian-10"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-HA","RHEL-HA","RHEL-SAP-APPS","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-Linux-7","Oracle-WebLogic-Server"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SLES-12-SP5","SLES-15-SP2","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"gen*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1804-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1804-*"}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Monitor.AzureMonitorLinuxAgent","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"AzureMonitorLinuxAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Monitor"},{"field":"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade","equals":"true"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","in":["Succeeded","Provisioning + succeeded"]}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Monitor.AzureMonitorLinuxAgent'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Monitor","type":"AzureMonitorLinuxAgent","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{"GCS_AUTO_CONFIG":true},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/a755252fb6baf40a","type":"Microsoft.Authorization/policyDefinitions","name":"a755252fb6baf40a"},{"properties":{"displayName":"azsecpack + msi policy for vmss_1.0","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:09:59.8276906Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPackAutoConfig"},"skipTagName3":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipTagName4":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipWindowsAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"value":"[requestContext().apiVersion]","greaterOrEquals":"2018-10-01"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.linuxConfiguration","exists":"false"},{"allOf":[{"field":"[concat(''tags['', + parameters(''skipTagName3''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName3''))]","equals":"false"}]}]},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.linuxConfiguration","exists":"true"},{"allOf":[{"field":"[concat(''tags['', + parameters(''skipTagName4''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName4''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName4''))]","equals":"false"}]}]},{"anyOf":[{"field":"identity.type","notContains":"UserAssigned"},{"value":"[contains(intersection(if(equals(string(field(''identity.userAssignedIdentities'')), + ''''), createObject(), field(''identity.userAssignedIdentities'')), createObject(concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location'')), createObject())), concat(''/subscriptions/'', subscription().subscriptionId, + ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location'')))]","equals":"false"}]},{"anyOf":[{"field":"tags[''AzSecPackAutoConfigReady'']","equals":"true"},{"value":"[resourceGroup().tags[''AzSecPackAutoConfigReady'']]","equals":"true"},{"value":"[subscription().tags[''AzSecPackAutoConfigReady'']]","equals":"true"},{"not":{"allOf":[{"field":"identity.type","equals":"UserAssigned"},{"value":"[string(length(field(''identity.userAssignedIdentities'')))]","equals":"1"}]}}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets","name":"[field(''name'')]","deploymentScope":"subscription","existenceCondition":{"allOf":[{"field":"identity.type","contains":"UserAssigned"},{"field":"identity.userAssignedIdentities","containsKey":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location''))]"}]},"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/fd6e57ea-fe3c-4f21-bd1e-de170a9a4971"],"deployment":{"location":"eastus","properties":{"mode":"incremental","parameters":{"resourceGroup":{"value":"[resourceGroup().name]"},"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.1","parameters":{"resourceGroup":{"type":"string"},"location":{"type":"string"},"resourceName":{"type":"string"}},"variables":{"subscriptionId":"[subscription().subscriptionId]","defaultAzSecPackRGName":"AzSecPackAutoConfigRG","defaultAzSecPackRGLocation":"eastus","azSecPackUALocation":"[parameters(''location'')]","resourceId":"[concat(''/subscriptions/'', + variables(''subscriptionId''), ''/resourceGroups/'', parameters(''resourceGroup''), + ''/providers/Microsoft.Compute/virtualMachineScaleSets/'', parameters(''resourceName''))]","uaName":"[concat(''AzSecPackAutoConfigUA-'', + variables(''azSecPackUALocation''))]","uaId":"[concat(''/subscriptions/'', + variables(''subscriptionId''), ''/resourceGroups/'', variables(''defaultAzSecPackRGName''), + ''/providers/Microsoft.ManagedIdentity/userAssignedIdentities/'', variables(''uaName''))]","deployUAName":"[concat(''deployUAName-'', + uniqueString(deployment().name))]","deployGetResourceProperties":"[concat(''deployGetResourceProperties-'', + uniqueString(deployment().name))]","deployAddUAName":"[concat(''deployAddUAName-'', + uniqueString(deployment().name))]"},"resources":[{"type":"Microsoft.Resources/resourceGroups","apiVersion":"2020-06-01","name":"[variables(''defaultAzSecPackRGName'')]","location":"[variables(''defaultAzSecPackRGLocation'')]"},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[variables(''deployUAName'')]","resourceGroup":"[variables(''defaultAzSecPackRGName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]"],"properties":{"mode":"Incremental","expressionEvaluationOptions":{"scope":"inner"},"parameters":{"uaName":{"value":"[variables(''uaName'')]"},"location":{"value":"[variables(''azSecPackUALocation'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"uaName":{"type":"string"},"location":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.ManagedIdentity/userAssignedIdentities","name":"[parameters(''uaName'')]","apiVersion":"2018-11-30","location":"[parameters(''location'')]"},{"type":"Microsoft.ManagedIdentity/userAssignedIdentities/providers/locks","apiVersion":"2016-09-01","name":"[concat(parameters(''uaName''), + ''/Microsoft.Authorization/'', ''CanNotDeleteLock-'', parameters(''uaName''))]","dependsOn":["[parameters(''uaName'')]"],"properties":{"level":"CanNotDelete","notes":"Please + do not delete this User Assigned Identity in the AzSecPackAutoConfigRG resource + group as AzSecPack AutoConfig depends on this."}}]}}},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[variables(''deployGetResourceProperties'')]","location":"eastus","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]","[variables(''deployUAName'')]"],"properties":{"mode":"Incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","resources":[],"outputs":{"resource":{"type":"object","value":"[reference(variables(''resourceId''), + ''2019-07-01'', ''Full'')]"}}}}},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[concat(variables(''deployAddUAName''))]","resourceGroup":"[parameters(''resourceGroup'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]","[variables(''deployUAName'')]","[variables(''deployGetResourceProperties'')]"],"properties":{"mode":"Incremental","expressionEvaluationOptions":{"scope":"inner"},"parameters":{"resourceName":{"value":"[parameters(''resourceName'')]"},"location":{"value":"[variables(''azSecPackUALocation'')]"},"uaId":{"value":"[variables(''uaId'')]"},"identityType":{"value":"[if(contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value, + ''identity''), reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity.type, + '''')]"},"identityUserAssignedIdentities":{"value":"[if(and(contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value, + ''identity''), contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity, + ''userAssignedIdentities'')), reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity.userAssignedIdentities, + createObject())]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"uaId":{"type":"string"},"identityType":{"type":"string"},"identityUserAssignedIdentities":{"type":"object"}},"variables":{"identityTypeValue":"[if(contains(parameters(''identityType''), + ''SystemAssigned''), ''SystemAssigned,UserAssigned'', ''UserAssigned'')]","identityUserAssignedIdentitiesValue":"[union(parameters(''identityUserAssignedIdentities''), + createObject(parameters(''uaId''), createObject()))]"},"resources":[{"apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachineScaleSets","name":"[parameters(''resourceName'')]","location":"[parameters(''location'')]","identity":{"type":"[variables(''identityTypeValue'')]","userAssignedIdentities":"[variables(''identityUserAssignedIdentitiesValue'')]"}}]}}}]}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/aba6242cbeff9e0d","type":"Microsoft.Authorization/policyDefinitions","name":"aba6242cbeff9e0d"},{"properties":{"displayName":"sqlads-auditifnotexists-atp + types should be set to ''all'' in sql server advanced data security settings_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:40.6774801Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the SQL + Server"}},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''tagname'')]]","equals":""}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/disabledAlerts[*]","equals":""}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ac3fc8ad361a9985","type":"Microsoft.Authorization/policyDefinitions","name":"ac3fc8ad361a9985"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack autoupdate policy for iaas_1.0","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-12T00:29:57.8179024Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Geneva.GenevaMonitoring","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"GenevaMonitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Geneva"},{"field":"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade","equals":"true"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Geneva.GenevaMonitoring'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b1d9e961d02c54d5","type":"Microsoft.Authorization/policyDefinitions","name":"b1d9e961d02c54d5"},{"properties":{"displayName":"azuresecuritylinuxagent + extension autoupdate policy for iaas_1.4","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:10:00.9476677Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"not":{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.provisionVMAgent","equals":"false"}},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal","0001-com-ubuntu-server-eoan","0001-com-ubuntu-server-focal-daily","0001-com-ubuntu-pro-bionic","0001-com-ubuntu-pro-focal","0003-com-ubuntu-server-trusted-vm"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"20_04-lts*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"8"},{"field":"Microsoft.Compute/imageSKU","equals":"9"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Debian"},{"field":"Microsoft.Compute/imageOffer","in":["Debian-10"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-HA","RHEL-HA","RHEL-SAP-APPS","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-Linux-7","Oracle-WebLogic-Server"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SLES-12-SP5","SLES-15-SP2","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"gen*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1804-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1804-*"}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"AzureSecurityLinuxAgent"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Security.Monitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade","equals":"true"},{"field":"Microsoft.Compute/virtualMachines/extensions/provisioningState","in":["Succeeded","Provisioning + succeeded"]}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Security.Monitoring","type":"AzureSecurityLinuxAgent","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{"enableGenevaUpload":true},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b312c4b92f1576fc","type":"Microsoft.Authorization/policyDefinitions","name":"b312c4b92f1576fc"},{"properties":{"displayName":"vmvmssfirstpartyidentificationtag_1.5","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-05T18:34:14.0822Z","updatedBy":null,"updatedOn":null},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"tagName","description":"Opted + in for PKI"},"defaultValue":"platformsettings.host_environment"},"tagValue":{"type":"String","metadata":{"displayName":"tagValue","description":"Tenant + Update Flag"},"defaultValue":"false"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b35071d70a31160f","type":"Microsoft.Authorization/policyDefinitions","name":"b35071d70a31160f"},{"properties":{"displayName":"azsecpack + msi policy for vm_1.0","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:09:59.0752593Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPackAutoConfig"},"skipTagName3":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipTagName4":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipWindowsAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"value":"[requestContext().apiVersion]","greaterOrEquals":"2018-10-01"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile","notContainsKey":"linuxConfiguration"},{"allOf":[{"field":"[concat(''tags['', + parameters(''skipTagName3''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName3''))]","equals":"false"}]}]},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile","containsKey":"linuxConfiguration"},{"allOf":[{"field":"[concat(''tags['', + parameters(''skipTagName4''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName4''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName4''))]","equals":"false"}]}]},{"anyOf":[{"field":"identity.type","notContains":"UserAssigned"},{"value":"[contains(intersection(if(equals(string(field(''identity.userAssignedIdentities'')), + ''''), createObject(), field(''identity.userAssignedIdentities'')), createObject(concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location'')), createObject())), concat(''/subscriptions/'', subscription().subscriptionId, + ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location'')))]","equals":"false"}]},{"anyOf":[{"field":"tags[''AzSecPackAutoConfigReady'']","equals":"true"},{"value":"[resourceGroup().tags[''AzSecPackAutoConfigReady'']]","equals":"true"},{"value":"[subscription().tags[''AzSecPackAutoConfigReady'']]","equals":"true"},{"not":{"allOf":[{"field":"identity.type","equals":"UserAssigned"},{"value":"[string(length(field(''identity.userAssignedIdentities'')))]","equals":"1"}]}}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines","name":"[field(''name'')]","deploymentScope":"subscription","existenceCondition":{"allOf":[{"field":"identity.type","contains":"UserAssigned"},{"field":"identity.userAssignedIdentities","containsKey":"[concat(''/subscriptions/'', + subscription().subscriptionId, ''/resourceGroups/AzSecPackAutoConfigRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/AzSecPackAutoConfigUA-'', + field(''location''))]"}]},"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/fd6e57ea-fe3c-4f21-bd1e-de170a9a4971"],"deployment":{"location":"eastus","properties":{"mode":"incremental","parameters":{"resourceGroup":{"value":"[resourceGroup().name]"},"location":{"value":"[field(''location'')]"},"resourceName":{"value":"[field(''name'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#","contentVersion":"1.0.0.1","parameters":{"resourceGroup":{"type":"string"},"location":{"type":"string"},"resourceName":{"type":"string"}},"variables":{"subscriptionId":"[subscription().subscriptionId]","defaultAzSecPackRGName":"AzSecPackAutoConfigRG","defaultAzSecPackRGLocation":"eastus","azSecPackUALocation":"[parameters(''location'')]","resourceId":"[concat(''/subscriptions/'', + variables(''subscriptionId''), ''/resourceGroups/'', parameters(''resourceGroup''), + ''/providers/Microsoft.Compute/virtualMachines/'', parameters(''resourceName''))]","uaName":"[concat(''AzSecPackAutoConfigUA-'', + variables(''azSecPackUALocation''))]","uaId":"[concat(''/subscriptions/'', + variables(''subscriptionId''), ''/resourceGroups/'', variables(''defaultAzSecPackRGName''), + ''/providers/Microsoft.ManagedIdentity/userAssignedIdentities/'', variables(''uaName''))]","deployUAName":"[concat(''deployUAName-'', + uniqueString(deployment().name))]","deployGetResourceProperties":"[concat(''deployGetResourceProperties-'', + uniqueString(deployment().name))]","deployAddUAName":"[concat(''deployAddUAName-'', + uniqueString(deployment().name))]"},"resources":[{"type":"Microsoft.Resources/resourceGroups","apiVersion":"2020-06-01","name":"[variables(''defaultAzSecPackRGName'')]","location":"[variables(''defaultAzSecPackRGLocation'')]"},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[variables(''deployUAName'')]","resourceGroup":"[variables(''defaultAzSecPackRGName'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]"],"properties":{"mode":"Incremental","expressionEvaluationOptions":{"scope":"inner"},"parameters":{"uaName":{"value":"[variables(''uaName'')]"},"location":{"value":"[variables(''azSecPackUALocation'')]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"uaName":{"type":"string"},"location":{"type":"string"}},"variables":{},"resources":[{"type":"Microsoft.ManagedIdentity/userAssignedIdentities","name":"[parameters(''uaName'')]","apiVersion":"2018-11-30","location":"[parameters(''location'')]"},{"type":"Microsoft.ManagedIdentity/userAssignedIdentities/providers/locks","apiVersion":"2016-09-01","name":"[concat(parameters(''uaName''), + ''/Microsoft.Authorization/'', ''CanNotDeleteLock-'', parameters(''uaName''))]","dependsOn":["[parameters(''uaName'')]"],"properties":{"level":"CanNotDelete","notes":"Please + do not delete this User Assigned Identity in the AzSecPackAutoConfigRG resource + group as AzSecPack AutoConfig depends on this."}}]}}},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[variables(''deployGetResourceProperties'')]","location":"eastus","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]","[variables(''deployUAName'')]"],"properties":{"mode":"Incremental","template":{"$schema":"http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","resources":[],"outputs":{"resource":{"type":"object","value":"[reference(variables(''resourceId''), + ''2019-07-01'', ''Full'')]"}}}}},{"type":"Microsoft.Resources/deployments","apiVersion":"2020-06-01","name":"[concat(variables(''deployAddUAName''))]","resourceGroup":"[parameters(''resourceGroup'')]","dependsOn":["[resourceId(''Microsoft.Resources/resourceGroups'', + variables(''defaultAzSecPackRGName''))]","[variables(''deployUAName'')]","[variables(''deployGetResourceProperties'')]"],"properties":{"mode":"Incremental","expressionEvaluationOptions":{"scope":"inner"},"parameters":{"resourceName":{"value":"[parameters(''resourceName'')]"},"location":{"value":"[variables(''azSecPackUALocation'')]"},"uaId":{"value":"[variables(''uaId'')]"},"identityType":{"value":"[if(contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value, + ''identity''), reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity.type, + '''')]"},"identityUserAssignedIdentities":{"value":"[if(and(contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value, + ''identity''), contains(reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity, + ''userAssignedIdentities'')), reference(variables(''deployGetResourceProperties'')).outputs.resource.value.identity.userAssignedIdentities, + createObject())]"}},"template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"resourceName":{"type":"string"},"location":{"type":"string"},"uaId":{"type":"string"},"identityType":{"type":"string"},"identityUserAssignedIdentities":{"type":"object"}},"variables":{"identityTypeValue":"[if(contains(parameters(''identityType''), + ''SystemAssigned''), ''SystemAssigned,UserAssigned'', ''UserAssigned'')]","identityUserAssignedIdentitiesValue":"[union(parameters(''identityUserAssignedIdentities''), + createObject(parameters(''uaId''), createObject()))]"},"resources":[{"apiVersion":"2019-07-01","type":"Microsoft.Compute/virtualMachines","name":"[parameters(''resourceName'')]","location":"[parameters(''location'')]","identity":{"type":"[variables(''identityTypeValue'')]","userAssignedIdentities":"[variables(''identityUserAssignedIdentitiesValue'')]"}}]}}}]}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b3dcd36019b33cc8","type":"Microsoft.Authorization/policyDefinitions","name":"b3dcd36019b33cc8"},{"properties":{"displayName":"nrms-nsg-rule-106_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:22.7538641Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"}},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","equals":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Any"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b4482f205fb6bbc1","type":"Microsoft.Authorization/policyDefinitions","name":"b4482f205fb6bbc1"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack autoupdate policy for iaas_1.1","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-08-13T21:33:07.0355992Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]},{"not":{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration.provisionVMAgent","equals":"false"}}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Geneva.GenevaMonitoring","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"GenevaMonitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Geneva"},{"field":"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade","equals":"true"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Geneva.GenevaMonitoring'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b70c6f621534db23","type":"Microsoft.Authorization/policyDefinitions","name":"b70c6f621534db23"},{"properties":{"displayName":"nrms-hdinsight-require-subnet_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-06-26T21:23:22.8439408Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.HDInsight/clusters"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"not":{"field":"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet","notIn":["null",""]}}]},{"allOf":[{"field":"type","equals":"Microsoft.HDInsight/clusters"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"Microsoft.HDInsight/clusters/computeProfile.roles[*].virtualNetworkProfile.subnet","exists":"false"}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b7a0969ff954eaf7","type":"Microsoft.Authorization/policyDefinitions","name":"b7a0969ff954eaf7"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.4784818Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"not":{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","notIn":["null",""]}}]},{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","exists":"false"}]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92","type":"Microsoft.Authorization/policyDefinitions","name":"b8f1faa61cb41f92"},{"properties":{"displayName":"audit + ssh auth on new vms_1.3","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMs use password-only authentication for SSH + on new resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-25T22:01:41.9137032Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"anyof":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","exists":"False"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"7isolutions"},{"field":"Microsoft.Compute/imageOffer","in":["sapp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"128technology"},{"field":"Microsoft.Compute/imageOffer","in":["128t_networking_platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"4psa"},{"field":"Microsoft.Compute/imageOffer","in":["voipnow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"a10networks"},{"field":"Microsoft.Compute/imageOffer","in":["a10-lightning-adc","a10-vthunder-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accellion"},{"field":"Microsoft.Compute/imageOffer","in":["kiteworks-by-accellion"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"abiquo"},{"field":"Microsoft.Compute/imageOffer","in":["abiquo-hybrid-cloud-34"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accops"},{"field":"Microsoft.Compute/imageOffer","in":["hysecure5050"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian_matrix"},{"field":"Microsoft.Compute/imageOffer","in":["actian_matrix"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actifio"},{"field":"Microsoft.Compute/imageOffer","in":["actifio-sky"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian-corp"},{"field":"Microsoft.Compute/imageOffer","in":["vector-community","vector-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Acronis"},{"field":"Microsoft.Compute/imageOffer","in":["storage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"activeeon"},{"field":"Microsoft.Compute/imageOffer","in":["activeeon-workload-scheduler"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aerospike"},{"field":"Microsoft.Compute/imageOffer","in":["aerospike-database-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"affinio"},{"field":"Microsoft.Compute/imageOffer","in":["platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aiscaler-cache-control-ddos-and-url-rewriting-"},{"field":"Microsoft.Compute/imageOffer","in":["aimobile-site-acceleration","aiprotect-ddos-firewall","aiscaler-traffic-manager-caching","aivideo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"akamai-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["enterprise-application-access"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alces-flight-limited"},{"field":"Microsoft.Compute/imageOffer","in":["alces-flight-compute-solo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alertlogic"},{"field":"Microsoft.Compute/imageOffer","in":["alert-logic-tm","alert-logic-wsm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alienvault"},{"field":"Microsoft.Compute/imageOffer","in":["unified-security-management-anywhere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alldigital-brevity"},{"field":"Microsoft.Compute/imageOffer","in":["alldigital-brevity-uploader"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altair-engineering-inc"},{"field":"Microsoft.Compute/imageOffer","in":["altair_hwulva"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altamira-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["lumify"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"antmedia"},{"field":"Microsoft.Compute/imageOffer","in":["ams_community_edition","ant_media_server_enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"apigee"},{"field":"Microsoft.Compute/imageOffer","in":["apigee-edge"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcara"},{"field":"Microsoft.Compute/imageOffer","in":["app360v43-001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcelerator"},{"field":"Microsoft.Compute/imageOffer","in":["appcelerator-arrow-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appex-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appistry"},{"field":"Microsoft.Compute/imageOffer","in":["genomepilot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appscale-marketplace"},{"field":"Microsoft.Compute/imageOffer","in":["appscale"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arangodb"},{"field":"Microsoft.Compute/imageOffer","in":["arangodb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arista-networks"},{"field":"Microsoft.Compute/imageOffer","in":["veos-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"array_networks"},{"field":"Microsoft.Compute/imageOffer","in":["array-networks-vapv"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"astadia-1148316"},{"field":"Microsoft.Compute/imageOffer","in":["astadia-ui-automation-tee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"atomicorp"},{"field":"Microsoft.Compute/imageOffer","in":["secure-os","secure-ubuntu-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"audiocodes"},{"field":"Microsoft.Compute/imageOffer","in":["mediantsessionbordercontroller"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"auriq-systems"},{"field":"Microsoft.Compute/imageOffer","in":["essentia"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"awingu"},{"field":"Microsoft.Compute/imageOffer","in":["awingu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aviatrix-systems"},{"field":"Microsoft.Compute/imageOffer","in":["aviatrix-cloud-services","aviatrix-companion-gateway","aviatrix-companion-gateway-v2","aviatrix-vpn-gw","aviatrix_multi_cloud_service","aviatrix_openvpn_service","aviatrix_openvpn_service10","aviatrix_openvpn_service25","aviatrix_openvpn_service50"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"avi-networks"},{"field":"Microsoft.Compute/imageOffer","in":["avi-vantage-adc","internal-avi-vantage-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"axway"},{"field":"Microsoft.Compute/imageOffer","in":["axway-mailgate-secure-collaboration-advanced","axway-mailgate-secure-collaboration-premium","axway-mailgate-secure-collaboration-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azul"},{"field":"Microsoft.Compute/imageOffer","in":["azul-zulu-ubuntu-1804"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azurecyclecloud"},{"field":"Microsoft.Compute/imageOffer","in":["azure-cyclecloud-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"AzureDatabricks"},{"field":"Microsoft.Compute/imageOffer","in":["Databricks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baas-techbureau"},{"field":"Microsoft.Compute/imageOffer","in":["b1327623-d29b-4cc1-b833-85067dcc7bce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baffle-io"},{"field":"Microsoft.Compute/imageOffer","in":["baffle-application-data-protection"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"balabit"},{"field":"Microsoft.Compute/imageOffer","in":["balabit-shell-control-box","psm","sps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"barracudanetworks"},{"field":"Microsoft.Compute/imageOffer","in":["barracuda-app-sec-control-center","barracuda-email-security-gateway","barracuda-ng-cc","barracuda-ng-firewall","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"basho"},{"field":"Microsoft.Compute/imageOffer","in":["riak-2-0-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","in":["autodesk-maya-arnold-centos73","rendering-centos73"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bdy"},{"field":"Microsoft.Compute/imageOffer","in":["buddy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Bitnami"},{"field":"Microsoft.Compute/imageOffer","in":["3-4","abantecart","activemq","akeneo","alfrescocommunity","apachesolr","artifactory","canvaslms","cassandra","civicrm","cmsmadesimple","codiad","concrete5","consul","coppermine","couchdb","diaspora","discourse","djangostack","dokuwiki","dolibarr","DreamFactory","drupal","elastic-search","elk","erpnext","espocrm","etcd","eXo-Platform","exoplatform","fatfreecrm","ghost","gitlab","grafana","hadoop","hhvmstack","hordegroupwarewebmail","jasperreports","jenkins","joomla","jrubystack","kafka","kong","kubernetessandbox","lampstack","lappstack","letschat","liferay","limesurvey","livehelperchat","magento","mahara","mantis","mariadb","mattermost","mautic","mean","mediawiki","memcached","modx","mongodb","moodle","multicraft","mybb","mysql","nats","neo4j","neos","nginxstack","noalyss","nodejs","ocportal","odoo","openatrium","opencart","openedx","openfire","openproject","orangehrm","osclass","owncloud","oxid-eshop","parseserver","phabricator","phpbb","phplist","pimcore","piwik","plone","pootle","postgresql","prestashop","processmakerenterprise","processmakeropensourceedition","processwire","publify","rabbitmq","redash","redis","redmine","redmineplusagile","reportserver","reportserverenterprise","resourcespace","reviewboard","reviewboardpowerpack","roundcube","rubystack","seopanel","shopware","silverstripe","simplemachinesforum","sonarqube","spree","subversion","suitecrm","tensorflowserving","testlink","tikiwikicmsgroupware","tinytinyrss","tom-cat","trac","typo3","weblate","webmailpro","wildfly","wordpress","wordpress-multisite","wordpresspro","x2enginesalescrm","xoops","youtrack","zookeeper","zurmo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"black-duck-software"},{"field":"Microsoft.Compute/imageOffer","in":["blackduck_hub_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blk-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blk-io-erc-20-rest-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockapps"},{"field":"Microsoft.Compute/imageOffer","in":["strato-blockchain-base-template-latest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockstack"},{"field":"Microsoft.Compute/imageOffer","in":["blockstack-core-v14"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockchain-foundry"},{"field":"Microsoft.Compute/imageOffer","in":["syscoin-api","syscoin-full-node","syscoin-price-peg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bloombase"},{"field":"Microsoft.Compute/imageOffer","in":["bloombase-storesafe-3_4_7_0_el7_x86_64"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluecat"},{"field":"Microsoft.Compute/imageOffer","in":["bluecat-bam-for-azure","bluecat-dns-for-azure","bluecat-edge-service-point-vm-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluetalon"},{"field":"Microsoft.Compute/imageOffer","in":["bluetalon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"brocade_communications"},{"field":"Microsoft.Compute/imageOffer","in":["brocade-virtual-traffic-manager","brocade-virtual-traffic-manager-with-waf-module","brocade-virtual-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bt-americas-inc"},{"field":"Microsoft.Compute/imageOffer","in":["diamondip-sapphire-ev10","diamondip-sapphire-ev20","diamondip-sapphire-v10","diamondip-sapphire-v20","diamondip-sapphire-v5","diamondip-sapphire-vcaa20"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"buddhalabs"},{"field":"Microsoft.Compute/imageOffer","in":["sles_12_pci"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"carto"},{"field":"Microsoft.Compute/imageOffer","in":["cartobuilder2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cask"},{"field":"Microsoft.Compute/imageOffer","in":["cdap-cloud-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","Ubuntu_Core"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cavirin"},{"field":"Microsoft.Compute/imageOffer","in":["cavirin-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cautelalabs"},{"field":"Microsoft.Compute/imageOffer","in":["log_management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"celum-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["celumdam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cds"},{"field":"Microsoft.Compute/imageOffer","in":["cds-data-migration-solution-for-legacy-to-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-6-v2-0-2-l1","cis-centos-7-v2-1-1-l1","cis-oracle-linux-6-v1-0-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-rhel-6-v2-0-2-l1","cis-rhel-7-v2-2-0-l1","cis-suse-linux-11-v2-0-0-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1404-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"certivox"},{"field":"Microsoft.Compute/imageOffer","in":["sso-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cfd-direct"},{"field":"Microsoft.Compute/imageOffer","in":["cfd-direct-from-the-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chain"},{"field":"Microsoft.Compute/imageOffer","in":["chain-core-developer-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"checkpoint"},{"field":"Microsoft.Compute/imageOffer","in":["check-point-r77-10","check-point-vsec-r80","check-point-vsec-r80-blink","sg2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chef-software"},{"field":"Microsoft.Compute/imageOffer","in":["chef-automate-vm-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"circleci"},{"field":"Microsoft.Compute/imageOffer","in":["circleci-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cires21"},{"field":"Microsoft.Compute/imageOffer","in":["c21l-enc","c21l-mos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cisco"},{"field":"Microsoft.Compute/imageOffer","in":["cisco-asav","cisco-csr-1000v","cisco-ftdv","cisco-meraki-vmx100","cisco-ngfwv-vm-test-unsupported","cisco_cloud_vedge_17_2_4","cos65","cos72","cos72_main_dev","uos14","vwaas-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"citrix"},{"field":"Microsoft.Compute/imageOffer","in":["citrix-sd-wan-opt","netscaler-ma-service-agent-120","netscaler-ma-service-agent-121","netscaler-sd-wan","netscaler-vpx","netscalervpx-120","netscalervpx-121","netscalervpx110-6531","netscalervpx111"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clear-linux-project"},{"field":"Microsoft.Compute/imageOffer","in":["clear-linux-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clouber"},{"field":"Microsoft.Compute/imageOffer","in":["cuber","cws","mcenter"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-cruiser"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-cruiser-16"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees"},{"field":"Microsoft.Compute/imageOffer","in":["jenkins-enterprise","jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees-enterprise-jenkins"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbees-jenkins-enterprise","cloudbees-jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbolt-software"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbolt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudboost"},{"field":"Microsoft.Compute/imageOffer","in":["cloudboost"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudenablers-inc"},{"field":"Microsoft.Compute/imageOffer","in":["corestack"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","in":["squid-proxy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","in":["cloudera-altus-centos-os","cloudera-centos-6","cloudera-centos-os","test-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlanes"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-video-accelerator-nfs","cloudlanes-cloud-backup-accelerator-vtl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlink"},{"field":"Microsoft.Compute/imageOffer","in":["cloudlink-securevm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudplan-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["cloudplan_pcn_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["paladion_ondemand_nextgen_firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsoft"},{"field":"Microsoft.Compute/imageOffer","in":["cloudsoft-amp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clustrix"},{"field":"Microsoft.Compute/imageOffer","in":["clustrixdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codelathe"},{"field":"Microsoft.Compute/imageOffer","in":["codelathe-filecloud-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codenvy"},{"field":"Microsoft.Compute/imageOffer","in":["codenvy-on-prem"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cognosys"},{"field":"Microsoft.Compute/imageOffer","in":["1-click-secured-joomla-on-centos-7-3","1-click-secured-joomla-on-ubuntu-1404-lts","1-click-secured-joomla-on-ubuntu-1604-lts","1-click-secured-joomla-on-ubuntu-1804-lts","centos-6-9","centos-7-3","centos-7-4","centos-7-5","deploy-a-secured-modx-on-ubuntu-14-04-lts","deploy-a-secured-silverstripe-on-ubuntu-14-04-lts","hardened-mysql-5-6-on-centos-7-3","hardened-mysql-5-6-on-ubu-1404-lts","hardened-mysql-5-7-on-centos-7-3","hardened-mysql-5-7-on-ubu-1404-lts","hardened-postgresql-on-ubu-1404-lts","invoice-ninja-2-5-1-1-on-ubuntu-1404","jruby-on-ubuntu-14-04-lts","low-latency-broadcasting-server-for-live-events","owncloud-9-with-lamp-stack-on-ubuntu-1404","piwigogallerys-ubuntu_14-04_lts","sec1011-dokuwiki-on-ubuntu-1404","sec1013-elasticsearch-on-ubuntu-1404","sec1014-opencart-on-ubuntu-1404","sec1015-orangehrm-on-ubuntu-1404","sec1016-nodejs-server-on-ubuntu-1404","sec1018-haproxy-on-ubuntu-1404","sec1019-secured-tomcat-on-ubuntu-1404","sec1020-phpbb-on-hardened-ubuntu-1404","sec1021-mybb-on-hardened-ubuntu-1404","sec1022-sugarcrm-on-ubuntu-1404","sec1023-moodle-on-ubuntu-1404","sec1024_magento-on-ubuntu-1404","sec1025-secured-drupal-on-ubuntu-1404","sec1027-secured-wordpress-on-ubuntu-1404","sec1028-secured-lamp-sever-on-ubuntu-1404","sec1029-secured-mediawiki-on-ubuntu-1404","sec1030-secured-subversion-on-ubuntu-1404","sec1031-secured-passenger-nginx-on-ubuntu-1404","sec1033-secured-piwik-on-ubuntu-1404","sec1034-secured-pligg-on-ubuntu-1404","sec1035-secured-jenkins-on-ubuntu-1404","sec1036-secured-postgresql-on-ubuntu-1404","secure-cloud-lamp-ubuntu-1404","secured-abantecart-on-centos","secured-abantecart-on-ubuntu-14-04-lts","secured-acquia-drupal-on-centos","secured-acquiadurpal-on-ubuntu-14-04-lts","secured-apachesolr-on-centos","secured-apachesolr-on-ubuntu-14-04-lts","secured-arartifactory-on-centos","secured-artifactory-on-ubuntu-14-04-lts","secured-cakephp-on-centos","secured-cakephp-on-ubuntu-14-04-lts","secured-cms-made-simple-on-centos","secured-cms-made-simple-on-ubuntu-14-04-lts","secured-codiad-on-centos","secured-codiad-on-ubuntu-14-04-lts","secured-cogdam-on-centos","secured-cogdam-on-ubuntu-14-04-lts","secured-concrete5-on-centos","secured-concrete5-on-ubuntu-14-04-lts","secured-coppermine-on-centos","secured-coppermine-on-ubuntu-14-04-lts","secured-crushftp-on-centos","secured-crushftp-on-ubuntu-14-04-lts","secured-django-on-centos","secured-django-on-ubuntu-14-04-lts","secured-dokuwiki-on-centos","secured-dolibarr-on-centos","secured-dolivbarr-on-ubuntu-14-04-lts","secured-drupal-on-centos","secured-elasticsearch-on-centos","secured-enterprise-nginx-varnish-haproxy-php","secured-espocrm-on-centos","secured-espocrm-on-ubuntu-14-04-lts","secured-exoplatform-on-centos","secured-exoplatform-on-ubuntu-14-04-lts","secured-ghost-on-centos","secured-ghost-on-ubuntu-14-04-lts","secured-gradle-on-centos","secured-gradle-on-ubuntu-14-04-lts","secured-haproxy-on-centos","secured-invoice-ninja-on-centos","secured-jboss-as-on-centos","secured-jbossas-on-ubuntu-14-04-lts","secured-jenkins-on-centos","secured-jruby-on-cento","secured-lamp-on-centos","secured-lamp-on-centos-m10","secured-lapp-on-centos","secured-lapp-on-ubuntu-14-04-lts","secured-lemp-sever-on-ubuntu-1404","secured-lime-survey-on-centos","secured-limesurvey-on-ubuntu-1404","secured-live-helper-chat-on-centos","secured-livehelperchat-on-ubuntu-14-04-lts","secured-magento-on-centos","secured-mahara-on-centos","secured-mahara-on-ubuntu-14-04-lts","secured-mantis-on-centos","secured-mantis-on-ubuntu-14-04-lts","secured-mariadb-on-ubuntu-16-04","secured-mautic-on-centos","secured-mautic-on-ubuntu-14-04-lts","secured-media-wiki-on-centos","secured-modx-on-centos","secured-moodle-on-centos","secured-ngnix-on-centos-7-3","secured-ngnix-on-ubuntu-14-04-lts","secured-ngnix-on-ubuntu-16-04-lts","secured-noalyss-on-centos","secured-noalyss-on-ubuntu-14-04-lts","secured-nodejs-on-centos","secured-occlass-on-ubuntu-14-04-lts","secured-ocportal-on-ubuntu-14-04-lts","secured-open-cart-on-centos","secured-orangehrm-on-centos","secured-osclass-on-centos","secured-owncloud-on-centos","secured-oxid-eshop-on-centos","secured-oxideshop-on-ubuntu-14-04-lts","secured-passenger-nginx-on-centos","secured-piwigo-gallery-on-centos","secured-plone-on-centos","secured-plone-on-ubuntu-14-04-lts","secured-prestashop-on-centos","secured-prestashop-on-ubuntu-14-04-lts","secured-railo-on-ubuntu-14-04-lts","secured-redis-on-centos","secured-redis-on-ubuntu-1404","secured-redmine-on-centos","secured-redmine-on-ubuntu-14-04-lts","secured-redmineagile-on-ubuntu-14-04-lts","secured-report-server-on-centos","secured-reportserverent-on-ubuntu-14-04-lts","secured-resource-space-on-centos","secured-resourcespace-on-ubuntu-14-04-lts","secured-round-cube-on-centos","secured-roundcube-on-ubuntu-14-04-lts","secured-ruby-on-centos","secured-ruby-on-ubuntu-14-04-lts","secured-seopanel-on-centos","secured-seopanel-on-ubuntu-14-04-lts","secured-silverstripe-on-centos","secured-simple-invoice-on-centos","secured-simple-machines-on-centos","secured-simple-machines-on-ubuntu-14-04-lts","secured-simpleinvoice-on-ubuntu-14-04-lts","secured-subversion-on-centos","secured-suitecrm-on-centos","secured-suitecrm-on-ubuntu-14-04-lts","secured-test-link-on-centos","secured-testlink-on-ubuntu-14-04-lts","secured-thinkup-on-centos","secured-thinkup-on-ubuntu-14-04-lts","secured-tikiwikicms-on-centos","secured-tikiwikicms-on-ubuntu-14-04-lts","secured-tiny-tiny-rss-on-centos","secured-tinytinyrss-on-ubuntu-14-04-lts","secured-tomcat-on-centos","secured-trac-on-centos","secured-trac-on-ubuntu-14-04-lts","secured-typo3-on-centos","secured-typo3-on-ubuntu-14-04-lts","secured-varnish-on-centos","secured-varnish-on-ubuntu-1404","secured-wildfly-on-centos","secured-wildfly-on-ubuntu-14-04-lts","secured-wordpress-on-centos-7-3","secured-wordpress-on-ubuntu-16-04-lts","secured-x-cart-on-ubuntu-14-04-lts","secured-xoops-on-centos","secured-xoops-on-ubuntu-14-04-lts","secured-zurmo-on-centos","secured-zurmo-on-ubuntu-14-04-lts","suse15","ubuntu-14-04-lts","ubuntu-16-04-lts","ubuntu-17-04-high-performance-hardened-tcp-bbr","ubuntu-18-04","ubuntu-18-04-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesity"},{"field":"Microsoft.Compute/imageOffer","in":["cohesity-cloudtd-tool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesive"},{"field":"Microsoft.Compute/imageOffer","in":["vns3_4x_network_security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"confluentinc"},{"field":"Microsoft.Compute/imageOffer","in":["confluentplatform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"consensys"},{"field":"Microsoft.Compute/imageOffer","in":["truffle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"convertigo"},{"field":"Microsoft.Compute/imageOffer","in":["convertigo-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"corda"},{"field":"Microsoft.Compute/imageOffer","in":["corda"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"CoreOS"},{"field":"Microsoft.Compute/imageOffer","in":["CoreOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"couchbase"},{"field":"Microsoft.Compute/imageOffer","in":["couchbase-server-enterprise","couchbase-sync-gateway-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cryptzone"},{"field":"Microsoft.Compute/imageOffer","in":["appgate-appliance-3_2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cybernetica-as"},{"field":"Microsoft.Compute/imageOffer","in":["uxp-securityserver-connector","uxp-securityserver_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cyxtera"},{"field":"Microsoft.Compute/imageOffer","in":["appgatesdp-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataart"},{"field":"Microsoft.Compute/imageOffer","in":["devicehive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"databricks"},{"field":"Microsoft.Compute/imageOffer","in":["spfqogzeculbhdh"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datalayer"},{"field":"Microsoft.Compute/imageOffer","in":["datalayer-notebook"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datastax"},{"field":"Microsoft.Compute/imageOffer","in":["datastax-enterprise","datastax-enterprise-non-production-use-only"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datasunrise"},{"field":"Microsoft.Compute/imageOffer","in":["datasunrise-database-security-suite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataiku"},{"field":"Microsoft.Compute/imageOffer","in":["dataiku-data-science-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datometry"},{"field":"Microsoft.Compute/imageOffer","in":["hyper-q"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dellemc"},{"field":"Microsoft.Compute/imageOffer","in":["dell-emc-avamar-virtual-edition","dell-emc-datadomain-management-center","dell-emc-datadomain-virtual-edition","dell-emc-datadomain-virtual-edition-v4","dell-emc-networker-virtual-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"delphix"},{"field":"Microsoft.Compute/imageOffer","in":["delphix_dynamic_data_platform","omniosce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denodo"},{"field":"Microsoft.Compute/imageOffer","in":["denodo-platform","denodo-platform-7_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denyall"},{"field":"Microsoft.Compute/imageOffer","in":["denyall-rweb","denyall-vulnerability-manager","denyall-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dgsecure"},{"field":"Microsoft.Compute/imageOffer","in":["dgsecure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"diladele"},{"field":"Microsoft.Compute/imageOffer","in":["websafety"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dimensionalmechanics-inc"},{"field":"Microsoft.Compute/imageOffer","in":["neopulse-ai-studio","neopulse-query-runtime"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"docker"},{"field":"Microsoft.Compute/imageOffer","in":["docker-ce","docker-ce-edge","docker-datacenter-custom","docker-ee","docker-ee-basic","docker4azure","docker4azure-cs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dome9"},{"field":"Microsoft.Compute/imageOffer","in":["dome9ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drizti"},{"field":"Microsoft.Compute/imageOffer","in":["hpcbox-ansys-19-cluster-master","hpcbox-cluster-compute-node","hpcbox-cluster-cuda-node","hpcbox-cluster-gpu-node","hpcbox-docker-cluster-master","hpcbox-openfoam-cluster-master","hpcbox-su2-cluster-master"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drone"},{"field":"Microsoft.Compute/imageOffer","in":["drone"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dyadic_security"},{"field":"Microsoft.Compute/imageOffer","in":["dyadic_sec","ukc_image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dynatrace"},{"field":"Microsoft.Compute/imageOffer","in":["ruxit-managed-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"eastwind-networks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["eastwind-ixia-sensor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"egnyte"},{"field":"Microsoft.Compute/imageOffer","in":["egnyte-connect"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elasticbox"},{"field":"Microsoft.Compute/imageOffer","in":["elasticbox-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"electric-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["electricflowce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elfiqnetworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"emercoin"},{"field":"Microsoft.Compute/imageOffer","in":["emercoin"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprise-ethereum-alliance"},{"field":"Microsoft.Compute/imageOffer","in":["quorum-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprisedb-corp"},{"field":"Microsoft.Compute/imageOffer","in":["edb-postgres-ark"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"equalum"},{"field":"Microsoft.Compute/imageOffer","in":["equalum-vm-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"esdenera"},{"field":"Microsoft.Compute/imageOffer","in":["esdenera-firewall-3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ethereum"},{"field":"Microsoft.Compute/imageOffer","in":["ethereum-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"evostream-inc"},{"field":"Microsoft.Compute/imageOffer","in":["ems-for-template","ems-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"exasol"},{"field":"Microsoft.Compute/imageOffer","in":["exasol-analytics-database-byol","exasolution-analytic-database"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"falconstorsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["fss-v9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"f5-networks"},{"field":"Microsoft.Compute/imageOffer","in":["f5-big-ip-adc","f5-big-ip-advanced-waf","f5-big-ip-best","f5-big-ip-better","f5-big-ip-byol","f5-big-ip-good","f5-big-ip-per-app-ve","f5-big-iq","f5-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"filecatalyst"},{"field":"Microsoft.Compute/imageOffer","in":["filecatalyst-direct-per-hr-billing","filecatalyst-direct-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"firehost"},{"field":"Microsoft.Compute/imageOffer","in":["firehost_armor","firehost_armor_ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flexify-io"},{"field":"Microsoft.Compute/imageOffer","in":["single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flashgrid-inc"},{"field":"Microsoft.Compute/imageOffer","in":["flashgrid-racnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"foghorn-systems"},{"field":"Microsoft.Compute/imageOffer","in":["foghorn-edge-device-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forcepoint-llc"},{"field":"Microsoft.Compute/imageOffer","in":["forcepoint-ngfw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forscene"},{"field":"Microsoft.Compute/imageOffer","in":["forscene-edgeserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortycloud"},{"field":"Microsoft.Compute/imageOffer","in":["fortycloud-gw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortinet"},{"field":"Microsoft.Compute/imageOffer","in":["fortinet-fortianalyzer","fortinet-fortimanager","fortinet_fortigate-vm_v5","fortinet_fortimail","fortinet_fortivoice","fortinet_fortiweb-vm_v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fujitsu_fast"},{"field":"Microsoft.Compute/imageOffer","in":["fep10-rh7-test","feptest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gemalto-safenet"},{"field":"Microsoft.Compute/imageOffer","in":["safenet-keysecure-k170v","safenet-protectv","safenet-protectv-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gigamon-inc"},{"field":"Microsoft.Compute/imageOffer","in":["gigamon-fm-5_3_01","gigamon-fm-5_3_01_hourly","gigamon-fm-5_4_00","gigamon-fm-5_4_00_hourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gitlab"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-ce","gitlab-ee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"GitHub"},{"field":"Microsoft.Compute/imageOffer","in":["GitHub-Enterprise","githubenterprise-test-publishing"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"great-software-laboratory-private-limited"},{"field":"Microsoft.Compute/imageOffer","in":["xid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"greensql"},{"field":"Microsoft.Compute/imageOffer","in":["greensql-database-security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gridgain"},{"field":"Microsoft.Compute/imageOffer","in":["gridgain-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"guardicore"},{"field":"Microsoft.Compute/imageOffer","in":["guardicorecentra","infection_monkey"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haivision"},{"field":"Microsoft.Compute/imageOffer","in":["haivision-media-gateway-1-2","haivision-media-gateway-1-5","haivision-media-gateway-1-6-2","media-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"h2o-ai"},{"field":"Microsoft.Compute/imageOffer","in":["h2o-driverles-ai","h2o-driverless-ai","h2o-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haproxy-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hapee-rhel","hapee-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"harpaitalia"},{"field":"Microsoft.Compute/imageOffer","in":["mcuboenergy","yg","yougreen_trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hcl-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hcl17cp1104"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"heimdall-data"},{"field":"Microsoft.Compute/imageOffer","in":["heimdall-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"help-systems"},{"field":"Microsoft.Compute/imageOffer","in":["goanywheremftubuntulinux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hewlett-packard"},{"field":"Microsoft.Compute/imageOffer","in":["hpe-helion-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hillstone-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudedge-virtual-ngfw-advanced-edition","cloudedge-virtual-ngfw-standard-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hortonworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbreak-for-hortonworks-data-platform","hortonworks-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hitachi-solutions"},{"field":"Microsoft.Compute/imageOffer","in":["credeon-sfs-and-kms-for-sharepoint-online","credeonsecurefull-textsearch1_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hpe"},{"field":"Microsoft.Compute/imageOffer","in":["storeoncevsa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"huawei"},{"field":"Microsoft.Compute/imageOffer","in":["euleros-v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hyperglance"},{"field":"Microsoft.Compute/imageOffer","in":["hyperglance-dynamic-topology"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hypergrid"},{"field":"Microsoft.Compute/imageOffer","in":["hyperform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hytrust"},{"field":"Microsoft.Compute/imageOffer","in":["hytrust-keycontrol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ibm"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-security-guardium-multi-cloud","qradar_security_analytics"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iaansys"},{"field":"Microsoft.Compute/imageOffer","in":["iaansys-magento"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iboss"},{"field":"Microsoft.Compute/imageOffer","in":["iboss-14600-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imaginecommunications"},{"field":"Microsoft.Compute/imageOffer","in":["cloudxtream-cdvr","cloudxtream-dai-vms","telurio-aim"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imperva"},{"field":"Microsoft.Compute/imageOffer","in":["imperva-dam-v13","securesphere-waf","securesphere-waf-for-azr","securesphere-waf-v12","securesphere-waf-v13"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"infoblox"},{"field":"Microsoft.Compute/imageOffer","in":["infoblox-vnios-te-v1420"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informatica"},{"field":"Microsoft.Compute/imageOffer","in":["bdm10-1-1-u2","big-data-management-10-2","big-data-management-10-2-1","data_accelerator_for_azure_byol","data_quality_10_1_1_rhel_7_3_byol","eic","ics-byol","ics-payg-ubuntu","platform_10_1_1_multi_node_domain_rhel-7-3_byol","platform_10_2_hf1_domain_rhel-7-3_byol","powercenter-v10-domain-image-ubuntu14-04-3","powercenter-v10-update1-domain-image-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informationbuilders"},{"field":"Microsoft.Compute/imageOffer","in":["iway-big-data-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ingrammicro"},{"field":"Microsoft.Compute/imageOffer","in":["ingrammicroensimcentostrial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel"},{"field":"Microsoft.Compute/imageOffer","in":["lustre-cloud-edition-gs-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-bigdl"},{"field":"Microsoft.Compute/imageOffer","in":["bigdl-0815","bigdl__vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-fpga"},{"field":"Microsoft.Compute/imageOffer","in":["quartus_pro_opencl_sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intellicus-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["intellicus_bi_server_100_user_linux","intellicus_bi_server_10_user_linux","intellicus_bi_server_25_user_linux","intellicus_bi_server_50_user_linux","intellicus_bi_server_5_user_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intersystems"},{"field":"Microsoft.Compute/imageOffer","in":["intersystems-iris-single-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intigua"},{"field":"Microsoft.Compute/imageOffer","in":["intigua-agent-manager-3_7_0-trial","intigua-agent-manager-trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iquest"},{"field":"Microsoft.Compute/imageOffer","in":["keyhub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ishlangu-load-balancer-adc"},{"field":"Microsoft.Compute/imageOffer","in":["ishlangu-load-balancer-byol","ishlangu-load-balancer-is10","ishlangu-load-balancer-is100","ishlangu-load-balancer-is1000","ishlangu-load-balancer-is200","ishlangu-load-balancer-is5000","ishlangu-load-balancer-isbfg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"issp-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["ispocr"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"itelios"},{"field":"Microsoft.Compute/imageOffer","in":["magento2-on-zendserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jamcracker"},{"field":"Microsoft.Compute/imageOffer","in":["4632d5b4-feb0-4332-8452-f2e66133672f","jamcracker-cloudanalytics","jamcracker-cloudanalytics-version4","jamcracker-cloudanalytics-version5","jamcracker-csb-service-provider","jamcracker-csb-serviceprovider","jamcracker-csb-standard","jamcracker-csb-standard-v3","jamcracker-csb-standard-version4","jamcracker-hybrid-cloud-management-version4","jamcracker_cloud_control_appliance_version4","jsdnapp_csb_serviceprovider-version4","jsdnapp_hybrid","jsdnapp_hybrid_v3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jedox"},{"field":"Microsoft.Compute/imageOffer","in":["jedox-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jelastic"},{"field":"Microsoft.Compute/imageOffer","in":["jelastic-hybrid-paas-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetnexus"},{"field":"Microsoft.Compute/imageOffer","in":["dvwa","jetnexus-application-load-balancer","jetnexus-global-load-balancer","jetnexus-waf","zap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetware-srl"},{"field":"Microsoft.Compute/imageOffer","in":["caffe2","caffe_python_cpu","caffe_python_gpu","cockroachdb","lamp_optimized","lemp7_optimized","memcached","mongodb","mxnet_python","mysql","nodejs_nginx","percona_mongodb","percona_mysql","postgresql","pytorch","pytorch_cuda_notebook","pytorch_cuda_production","redis","redmine","tensorflow_cpu_notebook","tensorflow_cpu_production","tensorflow_cuda_notebook","tensorflow_cuda_production","tensorflow_python","theano_python","wordpress4_lemp7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jitterbit_integration"},{"field":"Microsoft.Compute/imageOffer","in":["jitterbit-harmony-agent"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jm-technology-inc"},{"field":"Microsoft.Compute/imageOffer","in":["smart-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"juniper-networks"},{"field":"Microsoft.Compute/imageOffer","in":["vmx-services-gateway-byol","vmx-services-gateway-byol-soltemp","vmx-virtual-router","vsrx-next-generation-firewall","vsrx-next-generation-firewall-payg","vsrx-next-generation-firewall-solution-templ-payg","vsrx-next-generation-firewall-solution-template"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaazing"},{"field":"Microsoft.Compute/imageOffer","in":["kaazing-kwic","kaazing-vpa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kali-linux"},{"field":"Microsoft.Compute/imageOffer","in":["kali-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kemptech"},{"field":"Microsoft.Compute/imageOffer","in":["kemp360central-byol","vlm-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kinetica"},{"field":"Microsoft.Compute/imageOffer","in":["kineticadbbyol","kineticadbpayasyougo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaspersky_lab"},{"field":"Microsoft.Compute/imageOffer","in":["kaspersky_secure_mail_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"knime"},{"field":"Microsoft.Compute/imageOffer","in":["knime-server-5-user_4-4-0","knime-server-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"krypc-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["krypccore"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leap-orbit"},{"field":"Microsoft.Compute/imageOffer","in":["leaporbitstoragebackedsftp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leostream-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["connection-broker"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquid-files"},{"field":"Microsoft.Compute/imageOffer","in":["liquidfiles"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquidware"},{"field":"Microsoft.Compute/imageOffer","in":["stratusphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"literatu"},{"field":"Microsoft.Compute/imageOffer","in":["literatu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"loadbalancer"},{"field":"Microsoft.Compute/imageOffer","in":["loadbalancer-org-load-balancer-for-azure","loadbalancer-org-load-balancer-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logsign"},{"field":"Microsoft.Compute/imageOffer","in":["logsignfocus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logtrust"},{"field":"Microsoft.Compute/imageOffer","in":["logtrust-log-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"looker"},{"field":"Microsoft.Compute/imageOffer","in":["looker-analytics-platform","looker-analytics-platform-326","looker-analytics-platform-5_6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"lti-lt-infotech"},{"field":"Microsoft.Compute/imageOffer","in":["trade-finance-blockchain"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"luminate-security"},{"field":"Microsoft.Compute/imageOffer","in":["luminate-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mapr-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["mapr52-base-dev","mapr60-base","mapr60-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mariadb"},{"field":"Microsoft.Compute/imageOffer","in":["mariadb-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"marklogic"},{"field":"Microsoft.Compute/imageOffer","in":["marklogic-9-byol","marklogic-developer-9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"massiveanalytic-"},{"field":"Microsoft.Compute/imageOffer","in":["oscarap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mathworks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["matlab-ref-arch-18a-v1-linux-disk","mps-ref-arch-18a-v1-linux-disk2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"matillion"},{"field":"Microsoft.Compute/imageOffer","in":["matillion-etl-snowflake"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mavinglobal"},{"field":"Microsoft.Compute/imageOffer","in":["mavin-business-trial","mavin-enterprise-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"meanio"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-enterprise-ready","linnovate-open-source-sla-pro","mean-machine-20","openideal3","redash"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"media3-technologies-llc"},{"field":"Microsoft.Compute/imageOffer","in":["cpan1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"memsql"},{"field":"Microsoft.Compute/imageOffer","in":["memsql-community-single-vm","memsql-enterprise-single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mendix"},{"field":"Microsoft.Compute/imageOffer","in":["mendix-docker","mendix-pro"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mfe_azure"},{"field":"Microsoft.Compute/imageOffer","in":["atd-mcafee","mcafee_vnsp_controller_for_azure","mcafee_vnsp_for_azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"micro-focus"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-avere"},{"field":"Microsoft.Compute/imageOffer","in":["vfxt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-batch"},{"field":"Microsoft.Compute/imageOffer","in":["centos-container","centos-container-rdma","ubuntu-server-container","ubuntu-server-container-rdma"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-compute"},{"field":"Microsoft.Compute/imageOffer","in":["azureconfidentialcompute"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["azureml","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftAzureSiteRecovery"},{"field":"Microsoft.Compute/imageOffer","in":["ASR-Hydration-VMs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftOSTC"},{"field":"Microsoft.Compute/imageOffer","in":["FreeBSD"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","in":["MLServer-CentOS","MLServer-RedHat","MLServer-Ubuntu","RServer-CentOS","RServer-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midfin"},{"field":"Microsoft.Compute/imageOffer","in":["mf_neon_cgw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midvision"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-datapower-virtual-edition-75","ibm-datapower-virtual-edition-76","ibm-datapower-virtual-edition-77","ibm-http-server","ibm-websphere-portal-server-85","ibm-websphere-portal-server-90","websphere-application-server-be","websphere-application-server-be-80","websphere-application-server-be-85","websphere-application-server-be-90","websphere-application-server-be-and-mq","websphere-application-server-lp","websphere-application-server-lp-16","websphere-application-server-lp-17","websphere-application-server-lp-18","websphere-application-server-nde","websphere-application-server-nde-80","websphere-application-server-nde-85","websphere-application-server-nde-90","websphere-mq","websphere-mq-75","websphere-mq-90","websphere-mq-91"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miraclelinux"},{"field":"Microsoft.Compute/imageOffer","in":["asianux-server-4-sp5","asianux-server-4-sp6","asianux-server-4-sp7","asianux-server-7-sp1","asianux-server-7-sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miri-infotech-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mobilab"},{"field":"Microsoft.Compute/imageOffer","in":["magento-wirecard-checkout"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moogsoft"},{"field":"Microsoft.Compute/imageOffer","in":["moogsoft-aiops"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moviemasher"},{"field":"Microsoft.Compute/imageOffer","in":["moviemasher"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","in":["SQL2017-RHEL7","SQL2017-RHEL73","SQL2017-SLES12SP2","SQL2017-Ubuntu1604","SQL2019-RHEL7","SQL2019-Ubuntu1604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mtnfog"},{"field":"Microsoft.Compute/imageOffer","in":["idyl-e3-entity-extraction-engine","prose-sentence-extraction-engine","renku-language-detection-engine","sonnet-tokenization-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mxhero"},{"field":"Microsoft.Compute/imageOffer","in":["mail2cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"my-com"},{"field":"Microsoft.Compute/imageOffer","in":["tarantool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"narrativescience"},{"field":"Microsoft.Compute/imageOffer","in":["narratives-for-power-bi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nasuni"},{"field":"Microsoft.Compute/imageOffer","in":["nasuni-nmc","nasuni_edge_appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ncbi"},{"field":"Microsoft.Compute/imageOffer","in":["ncbi-blast-2-3-0","ncbi-free-2-2-31"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nebbiolo-technologies-inc"},{"field":"Microsoft.Compute/imageOffer","in":["fog-system-manager","fogsm_basic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neo4j"},{"field":"Microsoft.Compute/imageOffer","in":["neo4j-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netapp"},{"field":"Microsoft.Compute/imageOffer","in":["netapp-altavault-cloud-integrated-storage-solution","netapp-oncommand-cloud-manager","netapp-ontap-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netgate"},{"field":"Microsoft.Compute/imageOffer","in":["netgate-pfsense-azure-fw-vpn-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netiq"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netscout"},{"field":"Microsoft.Compute/imageOffer","in":["netscout_virtual_ngeniusone_with_vscout","netscout_vstream"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netmail"},{"field":"Microsoft.Compute/imageOffer","in":["netmail-search"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netsweeper"},{"field":"Microsoft.Compute/imageOffer","in":["netsweeper6-0-6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netx"},{"field":"Microsoft.Compute/imageOffer","in":["simplehelp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neusoft-neteye"},{"field":"Microsoft.Compute/imageOffer","in":["neusoft-nisg-va-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nginxinc"},{"field":"Microsoft.Compute/imageOffer","in":["nginx-plus-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nicepeopleatwork"},{"field":"Microsoft.Compute/imageOffer","in":["youzana"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nodejsapi"},{"field":"Microsoft.Compute/imageOffer","in":["node-js-api"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"noobaa"},{"field":"Microsoft.Compute/imageOffer","in":["noobaa-hybrid-s3-archive-05","noobaa-multi-cloud-deduplication"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"northbridge-secure"},{"field":"Microsoft.Compute/imageOffer","in":["netconnect1","netconnectx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nubeva-inc"},{"field":"Microsoft.Compute/imageOffer","in":["controller","test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuco-networks"},{"field":"Microsoft.Compute/imageOffer","in":["aionnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuxeo"},{"field":"Microsoft.Compute/imageOffer","in":["nuxeo-6-lts","nuxeo-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nvidia"},{"field":"Microsoft.Compute/imageOffer","in":["ngc_azure_17_11"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"o2mc-real-time-data-platform"},{"field":"Microsoft.Compute/imageOffer","in":["o2mc-platform-app"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"oceanblue-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["obc-sdwan-solutions"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"omega-software"},{"field":"Microsoft.Compute/imageOffer","in":["ods_datastage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onyx-point-inc"},{"field":"Microsoft.Compute/imageOffer","in":["op-bnf-v1","op-bnf1_6-v1","op-bpnifi-v1","op-bpnifi16-v1","op-scc-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onapsis"},{"field":"Microsoft.Compute/imageOffer","in":["osp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"op5"},{"field":"Microsoft.Compute/imageOffer","in":["op5-monitor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"opencell"},{"field":"Microsoft.Compute/imageOffer","in":["meveo","meveo403sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"openvpn"},{"field":"Microsoft.Compute/imageOffer","in":["openvpnas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-WebLogic-Server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"orientdb"},{"field":"Microsoft.Compute/imageOffer","in":["orientdb-community-edition","orientdb-community-edition-2_2","orientdb-enterprise-edition-2_2","orientdb-enterprise-edition-2_2_17"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osirium-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["osirium-pxm-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osnexus"},{"field":"Microsoft.Compute/imageOffer","in":["quantastorvsav4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"paloaltonetworks"},{"field":"Microsoft.Compute/imageOffer","in":["panorama","vmseries1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"panzura-file-system"},{"field":"Microsoft.Compute/imageOffer","in":["azura-freedom-filer-v7110","panzura-cloud-filer","panzura-freedom-filer-7140-13222","panzura-freedom-filer-716-13549","panzura-freedom-filer-v7020"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"parasoft"},{"field":"Microsoft.Compute/imageOffer","in":["parasoft-service-virtualization"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"passlogy"},{"field":"Microsoft.Compute/imageOffer","in":["passlogic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"penta-security-systems-inc"},{"field":"Microsoft.Compute/imageOffer","in":["wapples"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"percona"},{"field":"Microsoft.Compute/imageOffer","in":["percona-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"postgres-pro"},{"field":"Microsoft.Compute/imageOffer","in":["postgres-pro-enterprise","postgres-pro-enterprise-10","postgres-pro-standard","postgres-pro-standard-10"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"plesk"},{"field":"Microsoft.Compute/imageOffer","in":["plesk-onyx-linux","solution-server-business","solution-server-wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prestashop"},{"field":"Microsoft.Compute/imageOffer","in":["prestashop16-lamp","ubuntu-base-for-prestashop"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prime-strategy"},{"field":"Microsoft.Compute/imageOffer","in":["kusanagi-77"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","in":["pivotal-gpdb-vm","pivotal-greenplum-images","pivotal-ops-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"process-one"},{"field":"Microsoft.Compute/imageOffer","in":["ejabberd-community-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"profecia"},{"field":"Microsoft.Compute/imageOffer","in":["full_disk_encryption_vm","project_tools_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"progelspa"},{"field":"Microsoft.Compute/imageOffer","in":["libra-esva-antispam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ptsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["ptaf-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pulse-secure"},{"field":"Microsoft.Compute/imageOffer","in":["pulse-connect-secure-vm","pulse-virtual-traffic-manager","pulse-virtual-traffic-manager-with-waf","pulse-virtual-traffic-manager-with-waf2","pulse-virtual-traffic-manager2","pulse-virtual-web-application-firewall","pulse-virtual-web-application-firewall2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"PuppetLabs"},{"field":"Microsoft.Compute/imageOffer","in":["PuppetEnterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"puppet"},{"field":"Microsoft.Compute/imageOffer","in":["puppet-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pydio"},{"field":"Microsoft.Compute/imageOffer","in":["pydio-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qore-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["qorus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qualysguard"},{"field":"Microsoft.Compute/imageOffer","in":["qualys-virtual-firewall-appliance","qualys-virtual-scanner-v23b","qualys-virtual-scanner-v24"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quasardb"},{"field":"Microsoft.Compute/imageOffer","in":["quasardb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qubole-inc"},{"field":"Microsoft.Compute/imageOffer","in":["qubole-data-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quest"},{"field":"Microsoft.Compute/imageOffer","in":["fve"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"racknap"},{"field":"Microsoft.Compute/imageOffer","in":["racknap-server","racknap-server-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radware"},{"field":"Microsoft.Compute/imageOffer","in":["radware-alteon-va"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radiant-logic"},{"field":"Microsoft.Compute/imageOffer","in":["radiantone-vms"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rancher"},{"field":"Microsoft.Compute/imageOffer","in":["rancheros"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapid7"},{"field":"Microsoft.Compute/imageOffer","in":["nexpose-scan-engine","rapid7-vm-console"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapidminer"},{"field":"Microsoft.Compute/imageOffer","in":["rapidminer_server_75","rapidminer_server_76","rapidminer_server_80","rapidminer_server_81"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"realm"},{"field":"Microsoft.Compute/imageOffer","in":["realm-mobile-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"reblaze"},{"field":"Microsoft.Compute/imageOffer","in":["rbzr-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HANA"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"relevance-lab"},{"field":"Microsoft.Compute/imageOffer","in":["rlcatalyst"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"remotelearner"},{"field":"Microsoft.Compute/imageOffer","in":["fully-supported-moodle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"revolution-analytics"},{"field":"Microsoft.Compute/imageOffer","in":["revolution-r-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RightScaleLinux"},{"field":"Microsoft.Compute/imageOffer","in":["RightImage-CentOS","RightImage-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RiverbedTechnology"},{"field":"Microsoft.Compute/imageOffer","in":["steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"riverbed"},{"field":"Microsoft.Compute/imageOffer","in":["riverbed-sccm-5-5-1","riverbed-steelcentral-appinternals","riverbed-steelhead-9-2","riverbed-steelhead-9-5-0","riverbed-steelhead-9-6-0","riverbed_steelconnect_gw","riverbed_steelconnect_sh","steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rocketsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["rocket-discover"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsa-security-llc"},{"field":"Microsoft.Compute/imageOffer","in":["rsa-nw-azure-arch","rsa-nw-azure-broker","rsa-nw-azure-con","rsa-nw-azure-esa","rsa-nw-azure-ldec","rsa-nw-azure-vlc","rsa-nw-suite-11","rsa-nw-suite-11-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsk-labs"},{"field":"Microsoft.Compute/imageOffer","in":["rsk-bamboo-beta-node","rsk-node-orchid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saama"},{"field":"Microsoft.Compute/imageOffer","in":["fluidanalyticsengine","insurancefraudanalytics","realworldevidence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saltstack"},{"field":"Microsoft.Compute/imageOffer","in":["centos65saltstackenterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalearc"},{"field":"Microsoft.Compute/imageOffer","in":["scalearc-for-mysql-paygo","scalearc-for-sql-server-pay-go","scalearc_mysql-server","scalearc_sql_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalegrid"},{"field":"Microsoft.Compute/imageOffer","in":["centos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sap"},{"field":"Microsoft.Compute/imageOffer","in":["hanaexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scality"},{"field":"Microsoft.Compute/imageOffer","in":["scalityconnecthourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"secureworks"},{"field":"Microsoft.Compute/imageOffer","in":["scwx-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"shadow-soft"},{"field":"Microsoft.Compute/imageOffer","in":["icinga","icinga2-5","icinga2-7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"signal-sciences"},{"field":"Microsoft.Compute/imageOffer","in":["signalscienceswpp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sightapps"},{"field":"Microsoft.Compute/imageOffer","in":["sightapps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"silver-peak-systems"},{"field":"Microsoft.Compute/imageOffer","in":["silver_peak_edgeconnect","silver_peak_vx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"simmachinesinc"},{"field":"Microsoft.Compute/imageOffer","in":["simmachines_vm_v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sinefa"},{"field":"Microsoft.Compute/imageOffer","in":["sinefa-probe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"skyarc"},{"field":"Microsoft.Compute/imageOffer","in":["mt6","mta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"smartmessage-autoflow"},{"field":"Microsoft.Compute/imageOffer","in":["martmessage-autoflow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"snapt-adc"},{"field":"Microsoft.Compute/imageOffer","in":["snaptadc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soasta"},{"field":"Microsoft.Compute/imageOffer","in":["cloudtest-lite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"softnas"},{"field":"Microsoft.Compute/imageOffer","in":["cloud_dev","mp_ce","mp_ent","mp_nas_byol","mp_nas_ep","mp_nas_gp","mp_nas_hp","mp_plat","private_offerings","softnas-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solanolabs"},{"field":"Microsoft.Compute/imageOffer","in":["solano-ci-private-beta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soha"},{"field":"Microsoft.Compute/imageOffer","in":["soha-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solar-security"},{"field":"Microsoft.Compute/imageOffer","in":["solar-incode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sonicwall-inc"},{"field":"Microsoft.Compute/imageOffer","in":["sonicwall-nsz-azure","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sophos"},{"field":"Microsoft.Compute/imageOffer","in":["sophos-xg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spagobi"},{"field":"Microsoft.Compute/imageOffer","in":["spagobi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spacecurve"},{"field":"Microsoft.Compute/imageOffer","in":["spacecurve-quickstart"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"splunk"},{"field":"Microsoft.Compute/imageOffer","in":["splunk-enterprise-base-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"src-solution"},{"field":"Microsoft.Compute/imageOffer","in":["pilot-things-onem2m-smart-network"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sqlstream"},{"field":"Microsoft.Compute/imageOffer","in":["com"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sphere3d"},{"field":"Microsoft.Compute/imageOffer","in":["snapcloud-byol","snapcloud-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackato-platform-as-a-service"},{"field":"Microsoft.Compute/imageOffer","in":["activestate-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackstorm"},{"field":"Microsoft.Compute/imageOffer","in":["stackstorm-2015-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"startekfingerprintmatch"},{"field":"Microsoft.Compute/imageOffer","in":["bioserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"steelhive"},{"field":"Microsoft.Compute/imageOffer","in":["steelhive_carbon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stonefly"},{"field":"Microsoft.Compute/imageOffer","in":["stonefly-cloud-drive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stormshield"},{"field":"Microsoft.Compute/imageOffer","in":["stormshield-network-security-for-cloud","stormshield-network-security-for-cloud-xl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"storreduce"},{"field":"Microsoft.Compute/imageOffer","in":["storreduce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stratumn"},{"field":"Microsoft.Compute/imageOffer","in":["indigo-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"streamsets"},{"field":"Microsoft.Compute/imageOffer","in":["streamsets-data-collector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"striim"},{"field":"Microsoft.Compute/imageOffer","in":["integrationforsqlserveronazure","integrationtoazurestorage","integrationtoeventhub","integrationtohdinsight"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"symantectest1"},{"field":"Microsoft.Compute/imageOffer","in":["cwpsazure-beta-01"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synack-inc"},{"field":"Microsoft.Compute/imageOffer","in":["synack-crowd-security-intelligence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synechron-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blockchain_tradefinance_quorum"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"syte"},{"field":"Microsoft.Compute/imageOffer","in":["syteoffer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tactic"},{"field":"Microsoft.Compute/imageOffer","in":["tactic-workflow-v001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talari-networks"},{"field":"Microsoft.Compute/imageOffer","in":["talari-networks-virtual-appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talena-inc"},{"field":"Microsoft.Compute/imageOffer","in":["talena_inc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tata_communications"},{"field":"Microsoft.Compute/imageOffer","in":["netfoundry_cloud_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tavendo"},{"field":"Microsoft.Compute/imageOffer","in":["crossbar_on_azure_ubuntu1404"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techdivision"},{"field":"Microsoft.Compute/imageOffer","in":["appserver-io-pe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techlatest"},{"field":"Microsoft.Compute/imageOffer","in":["ethereumdevkit","rippledevelopersuit"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"telepat"},{"field":"Microsoft.Compute/imageOffer","in":["free"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tenable"},{"field":"Microsoft.Compute/imageOffer","in":["tenable-nessus-6-byol","tenable-nessus-professional","tenablecorenessus","tenablecorewas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"teradata"},{"field":"Microsoft.Compute/imageOffer","in":["teradata-data-mover","teradata-data-mover-agent","teradata-data-mover-intellisphere","teradata-data-stream-controller","teradata-database-1510","teradata-database-1510-byol","teradata-database-1510-intellisphere","teradata-database-1510-v2","teradata-database-1610-intellisphere","teradata-database-1610-v2","teradata-database-1620","teradata-database-1620-byol","teradata-database-1620-intellisphere","teradata-database-enterprise","teradata-database-v1610","teradata-database-v1610-byol","teradata-ecosystem-manager","teradata-querygrid-manager","teradata-querygrid-manager-intellisphere","teradata-rest-services","teradata-server-management","teradata-viewpoint","teradata-viewpoint-intellisphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thales-vormetric"},{"field":"Microsoft.Compute/imageOffer","in":["ciphertrust-ckm","vormetric-dsm","vormetric-dsm-6-1-0","vormetric-tokenization-server","vts-2_2_0_2604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"things-board"},{"field":"Microsoft.Compute/imageOffer","in":["tb-pe-cassandra"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thoughtspot-inc"},{"field":"Microsoft.Compute/imageOffer","in":["thoughtspotvirtualmachine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tibco-software"},{"field":"Microsoft.Compute/imageOffer","in":["grid-server-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tig"},{"field":"Microsoft.Compute/imageOffer","in":["backup-as-a-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tigergraph"},{"field":"Microsoft.Compute/imageOffer","in":["tigergraph"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tmaxsoft"},{"field":"Microsoft.Compute/imageOffer","in":["tmax-jeusee","tmax-jeusse","tmax-webtobse"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tokyosystemhouse"},{"field":"Microsoft.Compute/imageOffer","in":["osscobol151j-pg961-centos72"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"torusware"},{"field":"Microsoft.Compute/imageOffer","in":["speedus-lite-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"totemo"},{"field":"Microsoft.Compute/imageOffer","in":["totemo-azr-tm6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"townsend-security"},{"field":"Microsoft.Compute/imageOffer","in":["alliance-key-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"trendmicro"},{"field":"Microsoft.Compute/imageOffer","in":["deep-security-vm","deep-security-vm-byol","iot-security-sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"truestack"},{"field":"Microsoft.Compute/imageOffer","in":["tsdc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tsa-public-service"},{"field":"Microsoft.Compute/imageOffer","in":["ckan-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tunnelbiz"},{"field":"Microsoft.Compute/imageOffer","in":["centos70-min","centos7optimizwithwordpress","centos7phpoptimizing","centos7phpoptimizingnginx","centos7phpoptimizwlaravel","centos7phpoptimizwosticket","centos7webserverwithwaf","centos7withaspdotnetcore2apache","centos7withjoomla","debian_web_server","fedora","fusio","linuxwithlimesurvey","networkmonitoringsystem","rimauwaf_cloud","ubuntu_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"twistlock"},{"field":"Microsoft.Compute/imageOffer","in":["twistlock"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"typesafe"},{"field":"Microsoft.Compute/imageOffer","in":["typesafe-reactive-maps-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubeeko"},{"field":"Microsoft.Compute/imageOffer","in":["hfactory-tools-for-hdinsight","hfactory-tools-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubercloud"},{"field":"Microsoft.Compute/imageOffer","in":["ansys-17-2-fluids-structures","ansys_182_test","comsol-multiphysics-v5-2","openfoam-v2dot3-centos-v6","openfoam-v3dot0","star-ccm-v10-04","star-ccm-v10-06-heeds-mdo-v2015","star-ccm-v12-00"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ulex"},{"field":"Microsoft.Compute/imageOffer","in":["voximal"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unifi-software"},{"field":"Microsoft.Compute/imageOffer","in":["unifi-data-catalog","unifi-dataplatform-2-3-3-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unitrends"},{"field":"Microsoft.Compute/imageOffer","in":["unitrends-enterprise-backup-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"usp"},{"field":"Microsoft.Compute/imageOffer","in":["unified-streaming-vod-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"varnish"},{"field":"Microsoft.Compute/imageOffer","in":["varnish-cache_","varnish-custom-statistics","varnish-plus-administration-and-statistics","varnish-plus-caching-engine-4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vaultive-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-security-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vbot"},{"field":"Microsoft.Compute/imageOffer","in":["vbot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"velocloud"},{"field":"Microsoft.Compute/imageOffer","in":["velocloud-virtual-edge","velocloud-virtual-edge-3x"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vidispine"},{"field":"Microsoft.Compute/imageOffer","in":["vidispine-content-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veritas"},{"field":"Microsoft.Compute/imageOffer","in":["cloudpoint-2-0-0","veritas-resiliency-platform-vhd-offer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veeam"},{"field":"Microsoft.Compute/imageOffer","in":["veeamhubimage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vigyanlabs-innovations-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["ipm-plus-energy-saver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"viptela"},{"field":"Microsoft.Compute/imageOffer","in":["viptela-vedge-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vizixiotplatformretail001"},{"field":"Microsoft.Compute/imageOffer","in":["vizix-iot-platform-retail-005"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vmturbo"},{"field":"Microsoft.Compute/imageOffer","in":["turbonomic","vmturbo64-opsmgr-5_3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vte"},{"field":"Microsoft.Compute/imageOffer","in":["slashdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vu-llc"},{"field":"Microsoft.Compute/imageOffer","in":["vu-app-server","vu-facerecogn","vu-fraudanalysis","vu-secureonboarding"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallarm"},{"field":"Microsoft.Compute/imageOffer","in":["wallarm-ng-waf-offer-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallix"},{"field":"Microsoft.Compute/imageOffer","in":["wallix-wabsuite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"watchguard-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["vm-firebox-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"waves"},{"field":"Microsoft.Compute/imageOffer","in":["waves"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"websense-apmailpe"},{"field":"Microsoft.Compute/imageOffer","in":["ap-data-email-gateway","forcepoint-email-security-85beta","triton-ap-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wmspanel"},{"field":"Microsoft.Compute/imageOffer","in":["nimble-streamer-centos","nimble-streamer-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wowza"},{"field":"Microsoft.Compute/imageOffer","in":["wowzastreamingengine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xfinityinc"},{"field":"Microsoft.Compute/imageOffer","in":["d3view-v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xtremedata"},{"field":"Microsoft.Compute/imageOffer","in":["dbx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"yellowfin"},{"field":"Microsoft.Compute/imageOffer","in":["yellowfin-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xyzrd-group-ou"},{"field":"Microsoft.Compute/imageOffer","in":["c73-zultys-mxvirtual"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"your-shop-online"},{"field":"Microsoft.Compute/imageOffer","in":["herefordshire-enterprise-platform-drupal-7","xenofile"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zend"},{"field":"Microsoft.Compute/imageOffer","in":["php-56-zend-server","php-zend-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"z1"},{"field":"Microsoft.Compute/imageOffer","in":["z1-securehub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zerodown_software"},{"field":"Microsoft.Compute/imageOffer","in":["bcaasforazure","stackbcaas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zoomdata"},{"field":"Microsoft.Compute/imageOffer","in":["zoomdata-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zscaler"},{"field":"Microsoft.Compute/imageOffer","in":["zscaler-private-access"]}]}]}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b9c65c79770e8c51","type":"Microsoft.Authorization/policyDefinitions","name":"b9c65c79770e8c51"},{"properties":{"displayName":"nrms-nsg-rule-104_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:20.3270264Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4","type":"Microsoft.Authorization/policyDefinitions","name":"bac0fb65020410a4"},{"properties":{"displayName":"linux + azsecpack nonprod tagging for vmss_1.3","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-09T20:11:41.9819552Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"azSecPackTagName":{"type":"String","metadata":{"displayName":"AzSecPack + Tag Name","description":"This policy adds the specified tag"},"defaultValue":"azsecpack"},"azSecPackTagValue":{"type":"String","metadata":{"displayName":"AzSecPack + Tag Value","description":"This policy adds the specified tag value"},"defaultValue":"nonprod"},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPackAutoConfig"},"skipTagName3":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile","exists":"true"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.linuxConfiguration","exists":"true"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''azSecPackTagName''), '']'')]","notEquals":"[parameters(''azSecPackTagValue'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName3''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''azSecPackTagName''), '']'')]","value":"[parameters(''azSecPackTagValue'')]"}]}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/be8ca7b286fcda62","type":"Microsoft.Authorization/policyDefinitions","name":"be8ca7b286fcda62"},{"properties":{"displayName":"deny + creation of new linux vms with ssh password auth_1.5","policyType":"Custom","mode":"All","description":"This + policy denied the creation of Linux VMs which use password-only authentication + for SSH.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-07-14T00:05:21.8198103Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"anyof":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","exists":"False"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"7isolutions"},{"field":"Microsoft.Compute/imageOffer","in":["sapp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"128technology"},{"field":"Microsoft.Compute/imageOffer","in":["128t_networking_platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"4psa"},{"field":"Microsoft.Compute/imageOffer","in":["voipnow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"a10networks"},{"field":"Microsoft.Compute/imageOffer","in":["a10-lightning-adc","a10-vthunder-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accellion"},{"field":"Microsoft.Compute/imageOffer","in":["kiteworks-by-accellion"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"abiquo"},{"field":"Microsoft.Compute/imageOffer","in":["abiquo-hybrid-cloud-34"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accops"},{"field":"Microsoft.Compute/imageOffer","in":["hysecure5050"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian_matrix"},{"field":"Microsoft.Compute/imageOffer","in":["actian_matrix"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actifio"},{"field":"Microsoft.Compute/imageOffer","in":["actifio-sky"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian-corp"},{"field":"Microsoft.Compute/imageOffer","in":["vector-community","vector-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Acronis"},{"field":"Microsoft.Compute/imageOffer","in":["storage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"activeeon"},{"field":"Microsoft.Compute/imageOffer","in":["activeeon-workload-scheduler"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aerospike"},{"field":"Microsoft.Compute/imageOffer","in":["aerospike-database-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"affinio"},{"field":"Microsoft.Compute/imageOffer","in":["platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aiscaler-cache-control-ddos-and-url-rewriting-"},{"field":"Microsoft.Compute/imageOffer","in":["aimobile-site-acceleration","aiprotect-ddos-firewall","aiscaler-traffic-manager-caching","aivideo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"akamai-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["enterprise-application-access"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alces-flight-limited"},{"field":"Microsoft.Compute/imageOffer","in":["alces-flight-compute-solo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alertlogic"},{"field":"Microsoft.Compute/imageOffer","in":["alert-logic-tm","alert-logic-wsm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alienvault"},{"field":"Microsoft.Compute/imageOffer","in":["unified-security-management-anywhere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alldigital-brevity"},{"field":"Microsoft.Compute/imageOffer","in":["alldigital-brevity-uploader"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altair-engineering-inc"},{"field":"Microsoft.Compute/imageOffer","in":["altair_hwulva"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altamira-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["lumify"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"antmedia"},{"field":"Microsoft.Compute/imageOffer","in":["ams_community_edition","ant_media_server_enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"apigee"},{"field":"Microsoft.Compute/imageOffer","in":["apigee-edge"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcara"},{"field":"Microsoft.Compute/imageOffer","in":["app360v43-001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcelerator"},{"field":"Microsoft.Compute/imageOffer","in":["appcelerator-arrow-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appex-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appistry"},{"field":"Microsoft.Compute/imageOffer","in":["genomepilot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appscale-marketplace"},{"field":"Microsoft.Compute/imageOffer","in":["appscale"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arangodb"},{"field":"Microsoft.Compute/imageOffer","in":["arangodb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arista-networks"},{"field":"Microsoft.Compute/imageOffer","in":["veos-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"array_networks"},{"field":"Microsoft.Compute/imageOffer","in":["array-networks-vapv"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"astadia-1148316"},{"field":"Microsoft.Compute/imageOffer","in":["astadia-ui-automation-tee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"atomicorp"},{"field":"Microsoft.Compute/imageOffer","in":["secure-os","secure-ubuntu-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"audiocodes"},{"field":"Microsoft.Compute/imageOffer","in":["mediantsessionbordercontroller"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"auriq-systems"},{"field":"Microsoft.Compute/imageOffer","in":["essentia"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"awingu"},{"field":"Microsoft.Compute/imageOffer","in":["awingu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aviatrix-systems"},{"field":"Microsoft.Compute/imageOffer","in":["aviatrix-cloud-services","aviatrix-companion-gateway","aviatrix-companion-gateway-v2","aviatrix-vpn-gw","aviatrix_multi_cloud_service","aviatrix_openvpn_service","aviatrix_openvpn_service10","aviatrix_openvpn_service25","aviatrix_openvpn_service50"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"avi-networks"},{"field":"Microsoft.Compute/imageOffer","in":["avi-vantage-adc","internal-avi-vantage-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"axway"},{"field":"Microsoft.Compute/imageOffer","in":["axway-mailgate-secure-collaboration-advanced","axway-mailgate-secure-collaboration-premium","axway-mailgate-secure-collaboration-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azul"},{"field":"Microsoft.Compute/imageOffer","in":["azul-zulu-ubuntu-1804"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azurecyclecloud"},{"field":"Microsoft.Compute/imageOffer","in":["azure-cyclecloud-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"AzureDatabricks"},{"field":"Microsoft.Compute/imageOffer","in":["Databricks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baas-techbureau"},{"field":"Microsoft.Compute/imageOffer","in":["b1327623-d29b-4cc1-b833-85067dcc7bce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baffle-io"},{"field":"Microsoft.Compute/imageOffer","in":["baffle-application-data-protection"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"balabit"},{"field":"Microsoft.Compute/imageOffer","in":["balabit-shell-control-box","psm","sps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"barracudanetworks"},{"field":"Microsoft.Compute/imageOffer","in":["barracuda-app-sec-control-center","barracuda-email-security-gateway","barracuda-ng-cc","barracuda-ng-firewall","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"basho"},{"field":"Microsoft.Compute/imageOffer","in":["riak-2-0-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","in":["autodesk-maya-arnold-centos73","rendering-centos73"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bdy"},{"field":"Microsoft.Compute/imageOffer","in":["buddy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Bitnami"},{"field":"Microsoft.Compute/imageOffer","in":["3-4","abantecart","activemq","akeneo","alfrescocommunity","apachesolr","artifactory","canvaslms","cassandra","civicrm","cmsmadesimple","codiad","concrete5","consul","coppermine","couchdb","diaspora","discourse","djangostack","dokuwiki","dolibarr","DreamFactory","drupal","elastic-search","elk","erpnext","espocrm","etcd","eXo-Platform","exoplatform","fatfreecrm","ghost","gitlab","grafana","hadoop","hhvmstack","hordegroupwarewebmail","jasperreports","jenkins","joomla","jrubystack","kafka","kong","kubernetessandbox","lampstack","lappstack","letschat","liferay","limesurvey","livehelperchat","magento","mahara","mantis","mariadb","mattermost","mautic","mean","mediawiki","memcached","modx","mongodb","moodle","multicraft","mybb","mysql","nats","neo4j","neos","nginxstack","noalyss","nodejs","ocportal","odoo","openatrium","opencart","openedx","openfire","openproject","orangehrm","osclass","owncloud","oxid-eshop","parseserver","phabricator","phpbb","phplist","pimcore","piwik","plone","pootle","postgresql","prestashop","processmakerenterprise","processmakeropensourceedition","processwire","publify","rabbitmq","redash","redis","redmine","redmineplusagile","reportserver","reportserverenterprise","resourcespace","reviewboard","reviewboardpowerpack","roundcube","rubystack","seopanel","shopware","silverstripe","simplemachinesforum","sonarqube","spree","subversion","suitecrm","tensorflowserving","testlink","tikiwikicmsgroupware","tinytinyrss","tom-cat","trac","typo3","weblate","webmailpro","wildfly","wordpress","wordpress-multisite","wordpresspro","x2enginesalescrm","xoops","youtrack","zookeeper","zurmo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"black-duck-software"},{"field":"Microsoft.Compute/imageOffer","in":["blackduck_hub_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blk-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blk-io-erc-20-rest-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockapps"},{"field":"Microsoft.Compute/imageOffer","in":["strato-blockchain-base-template-latest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockstack"},{"field":"Microsoft.Compute/imageOffer","in":["blockstack-core-v14"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockchain-foundry"},{"field":"Microsoft.Compute/imageOffer","in":["syscoin-api","syscoin-full-node","syscoin-price-peg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bloombase"},{"field":"Microsoft.Compute/imageOffer","in":["bloombase-storesafe-3_4_7_0_el7_x86_64"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluecat"},{"field":"Microsoft.Compute/imageOffer","in":["bluecat-bam-for-azure","bluecat-dns-for-azure","bluecat-edge-service-point-vm-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluetalon"},{"field":"Microsoft.Compute/imageOffer","in":["bluetalon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"brocade_communications"},{"field":"Microsoft.Compute/imageOffer","in":["brocade-virtual-traffic-manager","brocade-virtual-traffic-manager-with-waf-module","brocade-virtual-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bt-americas-inc"},{"field":"Microsoft.Compute/imageOffer","in":["diamondip-sapphire-ev10","diamondip-sapphire-ev20","diamondip-sapphire-v10","diamondip-sapphire-v20","diamondip-sapphire-v5","diamondip-sapphire-vcaa20"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"buddhalabs"},{"field":"Microsoft.Compute/imageOffer","in":["sles_12_pci"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"carto"},{"field":"Microsoft.Compute/imageOffer","in":["cartobuilder2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cask"},{"field":"Microsoft.Compute/imageOffer","in":["cdap-cloud-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","Ubuntu_Core"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cavirin"},{"field":"Microsoft.Compute/imageOffer","in":["cavirin-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cautelalabs"},{"field":"Microsoft.Compute/imageOffer","in":["log_management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"celum-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["celumdam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cds"},{"field":"Microsoft.Compute/imageOffer","in":["cds-data-migration-solution-for-legacy-to-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-6-v2-0-2-l1","cis-centos-7-v2-1-1-l1","cis-oracle-linux-6-v1-0-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-rhel-6-v2-0-2-l1","cis-rhel-7-v2-2-0-l1","cis-suse-linux-11-v2-0-0-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1404-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"certivox"},{"field":"Microsoft.Compute/imageOffer","in":["sso-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cfd-direct"},{"field":"Microsoft.Compute/imageOffer","in":["cfd-direct-from-the-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chain"},{"field":"Microsoft.Compute/imageOffer","in":["chain-core-developer-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"checkpoint"},{"field":"Microsoft.Compute/imageOffer","in":["check-point-r77-10","check-point-vsec-r80","check-point-vsec-r80-blink","sg2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chef-software"},{"field":"Microsoft.Compute/imageOffer","in":["chef-automate-vm-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"circleci"},{"field":"Microsoft.Compute/imageOffer","in":["circleci-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cires21"},{"field":"Microsoft.Compute/imageOffer","in":["c21l-enc","c21l-mos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cisco"},{"field":"Microsoft.Compute/imageOffer","in":["cisco-asav","cisco-csr-1000v","cisco-ftdv","cisco-meraki-vmx100","cisco-ngfwv-vm-test-unsupported","cisco_cloud_vedge_17_2_4","cos65","cos72","cos72_main_dev","uos14","vwaas-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"citrix"},{"field":"Microsoft.Compute/imageOffer","in":["citrix-sd-wan-opt","netscaler-ma-service-agent-120","netscaler-ma-service-agent-121","netscaler-sd-wan","netscaler-vpx","netscalervpx-120","netscalervpx-121","netscalervpx110-6531","netscalervpx111"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clear-linux-project"},{"field":"Microsoft.Compute/imageOffer","in":["clear-linux-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clouber"},{"field":"Microsoft.Compute/imageOffer","in":["cuber","cws","mcenter"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-cruiser"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-cruiser-16"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees"},{"field":"Microsoft.Compute/imageOffer","in":["jenkins-enterprise","jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees-enterprise-jenkins"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbees-jenkins-enterprise","cloudbees-jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbolt-software"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbolt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudboost"},{"field":"Microsoft.Compute/imageOffer","in":["cloudboost"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudenablers-inc"},{"field":"Microsoft.Compute/imageOffer","in":["corestack"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","in":["squid-proxy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","in":["cloudera-altus-centos-os","cloudera-centos-6","cloudera-centos-os","test-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlanes"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-video-accelerator-nfs","cloudlanes-cloud-backup-accelerator-vtl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlink"},{"field":"Microsoft.Compute/imageOffer","in":["cloudlink-securevm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudplan-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["cloudplan_pcn_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["paladion_ondemand_nextgen_firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsoft"},{"field":"Microsoft.Compute/imageOffer","in":["cloudsoft-amp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clustrix"},{"field":"Microsoft.Compute/imageOffer","in":["clustrixdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codelathe"},{"field":"Microsoft.Compute/imageOffer","in":["codelathe-filecloud-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codenvy"},{"field":"Microsoft.Compute/imageOffer","in":["codenvy-on-prem"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cognosys"},{"field":"Microsoft.Compute/imageOffer","in":["1-click-secured-joomla-on-centos-7-3","1-click-secured-joomla-on-ubuntu-1404-lts","1-click-secured-joomla-on-ubuntu-1604-lts","1-click-secured-joomla-on-ubuntu-1804-lts","centos-6-9","centos-7-3","centos-7-4","centos-7-5","deploy-a-secured-modx-on-ubuntu-14-04-lts","deploy-a-secured-silverstripe-on-ubuntu-14-04-lts","hardened-mysql-5-6-on-centos-7-3","hardened-mysql-5-6-on-ubu-1404-lts","hardened-mysql-5-7-on-centos-7-3","hardened-mysql-5-7-on-ubu-1404-lts","hardened-postgresql-on-ubu-1404-lts","invoice-ninja-2-5-1-1-on-ubuntu-1404","jruby-on-ubuntu-14-04-lts","low-latency-broadcasting-server-for-live-events","owncloud-9-with-lamp-stack-on-ubuntu-1404","piwigogallerys-ubuntu_14-04_lts","sec1011-dokuwiki-on-ubuntu-1404","sec1013-elasticsearch-on-ubuntu-1404","sec1014-opencart-on-ubuntu-1404","sec1015-orangehrm-on-ubuntu-1404","sec1016-nodejs-server-on-ubuntu-1404","sec1018-haproxy-on-ubuntu-1404","sec1019-secured-tomcat-on-ubuntu-1404","sec1020-phpbb-on-hardened-ubuntu-1404","sec1021-mybb-on-hardened-ubuntu-1404","sec1022-sugarcrm-on-ubuntu-1404","sec1023-moodle-on-ubuntu-1404","sec1024_magento-on-ubuntu-1404","sec1025-secured-drupal-on-ubuntu-1404","sec1027-secured-wordpress-on-ubuntu-1404","sec1028-secured-lamp-sever-on-ubuntu-1404","sec1029-secured-mediawiki-on-ubuntu-1404","sec1030-secured-subversion-on-ubuntu-1404","sec1031-secured-passenger-nginx-on-ubuntu-1404","sec1033-secured-piwik-on-ubuntu-1404","sec1034-secured-pligg-on-ubuntu-1404","sec1035-secured-jenkins-on-ubuntu-1404","sec1036-secured-postgresql-on-ubuntu-1404","secure-cloud-lamp-ubuntu-1404","secured-abantecart-on-centos","secured-abantecart-on-ubuntu-14-04-lts","secured-acquia-drupal-on-centos","secured-acquiadurpal-on-ubuntu-14-04-lts","secured-apachesolr-on-centos","secured-apachesolr-on-ubuntu-14-04-lts","secured-arartifactory-on-centos","secured-artifactory-on-ubuntu-14-04-lts","secured-cakephp-on-centos","secured-cakephp-on-ubuntu-14-04-lts","secured-cms-made-simple-on-centos","secured-cms-made-simple-on-ubuntu-14-04-lts","secured-codiad-on-centos","secured-codiad-on-ubuntu-14-04-lts","secured-cogdam-on-centos","secured-cogdam-on-ubuntu-14-04-lts","secured-concrete5-on-centos","secured-concrete5-on-ubuntu-14-04-lts","secured-coppermine-on-centos","secured-coppermine-on-ubuntu-14-04-lts","secured-crushftp-on-centos","secured-crushftp-on-ubuntu-14-04-lts","secured-django-on-centos","secured-django-on-ubuntu-14-04-lts","secured-dokuwiki-on-centos","secured-dolibarr-on-centos","secured-dolivbarr-on-ubuntu-14-04-lts","secured-drupal-on-centos","secured-elasticsearch-on-centos","secured-enterprise-nginx-varnish-haproxy-php","secured-espocrm-on-centos","secured-espocrm-on-ubuntu-14-04-lts","secured-exoplatform-on-centos","secured-exoplatform-on-ubuntu-14-04-lts","secured-ghost-on-centos","secured-ghost-on-ubuntu-14-04-lts","secured-gradle-on-centos","secured-gradle-on-ubuntu-14-04-lts","secured-haproxy-on-centos","secured-invoice-ninja-on-centos","secured-jboss-as-on-centos","secured-jbossas-on-ubuntu-14-04-lts","secured-jenkins-on-centos","secured-jruby-on-cento","secured-lamp-on-centos","secured-lamp-on-centos-m10","secured-lapp-on-centos","secured-lapp-on-ubuntu-14-04-lts","secured-lemp-sever-on-ubuntu-1404","secured-lime-survey-on-centos","secured-limesurvey-on-ubuntu-1404","secured-live-helper-chat-on-centos","secured-livehelperchat-on-ubuntu-14-04-lts","secured-magento-on-centos","secured-mahara-on-centos","secured-mahara-on-ubuntu-14-04-lts","secured-mantis-on-centos","secured-mantis-on-ubuntu-14-04-lts","secured-mariadb-on-ubuntu-16-04","secured-mautic-on-centos","secured-mautic-on-ubuntu-14-04-lts","secured-media-wiki-on-centos","secured-modx-on-centos","secured-moodle-on-centos","secured-ngnix-on-centos-7-3","secured-ngnix-on-ubuntu-14-04-lts","secured-ngnix-on-ubuntu-16-04-lts","secured-noalyss-on-centos","secured-noalyss-on-ubuntu-14-04-lts","secured-nodejs-on-centos","secured-occlass-on-ubuntu-14-04-lts","secured-ocportal-on-ubuntu-14-04-lts","secured-open-cart-on-centos","secured-orangehrm-on-centos","secured-osclass-on-centos","secured-owncloud-on-centos","secured-oxid-eshop-on-centos","secured-oxideshop-on-ubuntu-14-04-lts","secured-passenger-nginx-on-centos","secured-piwigo-gallery-on-centos","secured-plone-on-centos","secured-plone-on-ubuntu-14-04-lts","secured-prestashop-on-centos","secured-prestashop-on-ubuntu-14-04-lts","secured-railo-on-ubuntu-14-04-lts","secured-redis-on-centos","secured-redis-on-ubuntu-1404","secured-redmine-on-centos","secured-redmine-on-ubuntu-14-04-lts","secured-redmineagile-on-ubuntu-14-04-lts","secured-report-server-on-centos","secured-reportserverent-on-ubuntu-14-04-lts","secured-resource-space-on-centos","secured-resourcespace-on-ubuntu-14-04-lts","secured-round-cube-on-centos","secured-roundcube-on-ubuntu-14-04-lts","secured-ruby-on-centos","secured-ruby-on-ubuntu-14-04-lts","secured-seopanel-on-centos","secured-seopanel-on-ubuntu-14-04-lts","secured-silverstripe-on-centos","secured-simple-invoice-on-centos","secured-simple-machines-on-centos","secured-simple-machines-on-ubuntu-14-04-lts","secured-simpleinvoice-on-ubuntu-14-04-lts","secured-subversion-on-centos","secured-suitecrm-on-centos","secured-suitecrm-on-ubuntu-14-04-lts","secured-test-link-on-centos","secured-testlink-on-ubuntu-14-04-lts","secured-thinkup-on-centos","secured-thinkup-on-ubuntu-14-04-lts","secured-tikiwikicms-on-centos","secured-tikiwikicms-on-ubuntu-14-04-lts","secured-tiny-tiny-rss-on-centos","secured-tinytinyrss-on-ubuntu-14-04-lts","secured-tomcat-on-centos","secured-trac-on-centos","secured-trac-on-ubuntu-14-04-lts","secured-typo3-on-centos","secured-typo3-on-ubuntu-14-04-lts","secured-varnish-on-centos","secured-varnish-on-ubuntu-1404","secured-wildfly-on-centos","secured-wildfly-on-ubuntu-14-04-lts","secured-wordpress-on-centos-7-3","secured-wordpress-on-ubuntu-16-04-lts","secured-x-cart-on-ubuntu-14-04-lts","secured-xoops-on-centos","secured-xoops-on-ubuntu-14-04-lts","secured-zurmo-on-centos","secured-zurmo-on-ubuntu-14-04-lts","suse15","ubuntu-14-04-lts","ubuntu-16-04-lts","ubuntu-17-04-high-performance-hardened-tcp-bbr","ubuntu-18-04","ubuntu-18-04-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesity"},{"field":"Microsoft.Compute/imageOffer","in":["cohesity-cloudtd-tool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesive"},{"field":"Microsoft.Compute/imageOffer","in":["vns3_4x_network_security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"confluentinc"},{"field":"Microsoft.Compute/imageOffer","in":["confluentplatform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"consensys"},{"field":"Microsoft.Compute/imageOffer","in":["truffle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"convertigo"},{"field":"Microsoft.Compute/imageOffer","in":["convertigo-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"corda"},{"field":"Microsoft.Compute/imageOffer","in":["corda"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"CoreOS"},{"field":"Microsoft.Compute/imageOffer","in":["CoreOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"couchbase"},{"field":"Microsoft.Compute/imageOffer","in":["couchbase-server-enterprise","couchbase-sync-gateway-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cryptzone"},{"field":"Microsoft.Compute/imageOffer","in":["appgate-appliance-3_2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cybernetica-as"},{"field":"Microsoft.Compute/imageOffer","in":["uxp-securityserver-connector","uxp-securityserver_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cyxtera"},{"field":"Microsoft.Compute/imageOffer","in":["appgatesdp-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataart"},{"field":"Microsoft.Compute/imageOffer","in":["devicehive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"databricks"},{"field":"Microsoft.Compute/imageOffer","in":["spfqogzeculbhdh"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datalayer"},{"field":"Microsoft.Compute/imageOffer","in":["datalayer-notebook"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datastax"},{"field":"Microsoft.Compute/imageOffer","in":["datastax-enterprise","datastax-enterprise-non-production-use-only"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datasunrise"},{"field":"Microsoft.Compute/imageOffer","in":["datasunrise-database-security-suite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataiku"},{"field":"Microsoft.Compute/imageOffer","in":["dataiku-data-science-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datometry"},{"field":"Microsoft.Compute/imageOffer","in":["hyper-q"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dellemc"},{"field":"Microsoft.Compute/imageOffer","in":["dell-emc-avamar-virtual-edition","dell-emc-datadomain-management-center","dell-emc-datadomain-virtual-edition","dell-emc-datadomain-virtual-edition-v4","dell-emc-networker-virtual-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"delphix"},{"field":"Microsoft.Compute/imageOffer","in":["delphix_dynamic_data_platform","omniosce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denodo"},{"field":"Microsoft.Compute/imageOffer","in":["denodo-platform","denodo-platform-7_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denyall"},{"field":"Microsoft.Compute/imageOffer","in":["denyall-rweb","denyall-vulnerability-manager","denyall-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dgsecure"},{"field":"Microsoft.Compute/imageOffer","in":["dgsecure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"diladele"},{"field":"Microsoft.Compute/imageOffer","in":["websafety"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dimensionalmechanics-inc"},{"field":"Microsoft.Compute/imageOffer","in":["neopulse-ai-studio","neopulse-query-runtime"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"docker"},{"field":"Microsoft.Compute/imageOffer","in":["docker-ce","docker-ce-edge","docker-datacenter-custom","docker-ee","docker-ee-basic","docker4azure","docker4azure-cs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dome9"},{"field":"Microsoft.Compute/imageOffer","in":["dome9ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drizti"},{"field":"Microsoft.Compute/imageOffer","in":["hpcbox-ansys-19-cluster-master","hpcbox-cluster-compute-node","hpcbox-cluster-cuda-node","hpcbox-cluster-gpu-node","hpcbox-docker-cluster-master","hpcbox-openfoam-cluster-master","hpcbox-su2-cluster-master"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drone"},{"field":"Microsoft.Compute/imageOffer","in":["drone"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dyadic_security"},{"field":"Microsoft.Compute/imageOffer","in":["dyadic_sec","ukc_image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dynatrace"},{"field":"Microsoft.Compute/imageOffer","in":["ruxit-managed-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"eastwind-networks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["eastwind-ixia-sensor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"egnyte"},{"field":"Microsoft.Compute/imageOffer","in":["egnyte-connect"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elasticbox"},{"field":"Microsoft.Compute/imageOffer","in":["elasticbox-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"electric-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["electricflowce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elfiqnetworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"emercoin"},{"field":"Microsoft.Compute/imageOffer","in":["emercoin"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprise-ethereum-alliance"},{"field":"Microsoft.Compute/imageOffer","in":["quorum-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprisedb-corp"},{"field":"Microsoft.Compute/imageOffer","in":["edb-postgres-ark"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"equalum"},{"field":"Microsoft.Compute/imageOffer","in":["equalum-vm-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"esdenera"},{"field":"Microsoft.Compute/imageOffer","in":["esdenera-firewall-3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ethereum"},{"field":"Microsoft.Compute/imageOffer","in":["ethereum-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"evostream-inc"},{"field":"Microsoft.Compute/imageOffer","in":["ems-for-template","ems-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"exasol"},{"field":"Microsoft.Compute/imageOffer","in":["exasol-analytics-database-byol","exasolution-analytic-database"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"falconstorsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["fss-v9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"f5-networks"},{"field":"Microsoft.Compute/imageOffer","in":["f5-big-ip-adc","f5-big-ip-advanced-waf","f5-big-ip-best","f5-big-ip-better","f5-big-ip-byol","f5-big-ip-good","f5-big-ip-per-app-ve","f5-big-iq","f5-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"filecatalyst"},{"field":"Microsoft.Compute/imageOffer","in":["filecatalyst-direct-per-hr-billing","filecatalyst-direct-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"firehost"},{"field":"Microsoft.Compute/imageOffer","in":["firehost_armor","firehost_armor_ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flexify-io"},{"field":"Microsoft.Compute/imageOffer","in":["single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flashgrid-inc"},{"field":"Microsoft.Compute/imageOffer","in":["flashgrid-racnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"foghorn-systems"},{"field":"Microsoft.Compute/imageOffer","in":["foghorn-edge-device-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forcepoint-llc"},{"field":"Microsoft.Compute/imageOffer","in":["forcepoint-ngfw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forscene"},{"field":"Microsoft.Compute/imageOffer","in":["forscene-edgeserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortycloud"},{"field":"Microsoft.Compute/imageOffer","in":["fortycloud-gw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortinet"},{"field":"Microsoft.Compute/imageOffer","in":["fortinet-fortianalyzer","fortinet-fortimanager","fortinet_fortigate-vm_v5","fortinet_fortimail","fortinet_fortivoice","fortinet_fortiweb-vm_v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fujitsu_fast"},{"field":"Microsoft.Compute/imageOffer","in":["fep10-rh7-test","feptest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gemalto-safenet"},{"field":"Microsoft.Compute/imageOffer","in":["safenet-keysecure-k170v","safenet-protectv","safenet-protectv-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gigamon-inc"},{"field":"Microsoft.Compute/imageOffer","in":["gigamon-fm-5_3_01","gigamon-fm-5_3_01_hourly","gigamon-fm-5_4_00","gigamon-fm-5_4_00_hourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gitlab"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-ce","gitlab-ee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"GitHub"},{"field":"Microsoft.Compute/imageOffer","in":["GitHub-Enterprise","githubenterprise-test-publishing"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"great-software-laboratory-private-limited"},{"field":"Microsoft.Compute/imageOffer","in":["xid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"greensql"},{"field":"Microsoft.Compute/imageOffer","in":["greensql-database-security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gridgain"},{"field":"Microsoft.Compute/imageOffer","in":["gridgain-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"guardicore"},{"field":"Microsoft.Compute/imageOffer","in":["guardicorecentra","infection_monkey"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haivision"},{"field":"Microsoft.Compute/imageOffer","in":["haivision-media-gateway-1-2","haivision-media-gateway-1-5","haivision-media-gateway-1-6-2","media-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"h2o-ai"},{"field":"Microsoft.Compute/imageOffer","in":["h2o-driverles-ai","h2o-driverless-ai","h2o-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haproxy-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hapee-rhel","hapee-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"harpaitalia"},{"field":"Microsoft.Compute/imageOffer","in":["mcuboenergy","yg","yougreen_trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hcl-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hcl17cp1104"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"heimdall-data"},{"field":"Microsoft.Compute/imageOffer","in":["heimdall-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"help-systems"},{"field":"Microsoft.Compute/imageOffer","in":["goanywheremftubuntulinux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hewlett-packard"},{"field":"Microsoft.Compute/imageOffer","in":["hpe-helion-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hillstone-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudedge-virtual-ngfw-advanced-edition","cloudedge-virtual-ngfw-standard-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hortonworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbreak-for-hortonworks-data-platform","hortonworks-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hitachi-solutions"},{"field":"Microsoft.Compute/imageOffer","in":["credeon-sfs-and-kms-for-sharepoint-online","credeonsecurefull-textsearch1_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hpe"},{"field":"Microsoft.Compute/imageOffer","in":["storeoncevsa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"huawei"},{"field":"Microsoft.Compute/imageOffer","in":["euleros-v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hyperglance"},{"field":"Microsoft.Compute/imageOffer","in":["hyperglance-dynamic-topology"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hypergrid"},{"field":"Microsoft.Compute/imageOffer","in":["hyperform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hytrust"},{"field":"Microsoft.Compute/imageOffer","in":["hytrust-keycontrol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ibm"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-security-guardium-multi-cloud","qradar_security_analytics"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iaansys"},{"field":"Microsoft.Compute/imageOffer","in":["iaansys-magento"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iboss"},{"field":"Microsoft.Compute/imageOffer","in":["iboss-14600-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imaginecommunications"},{"field":"Microsoft.Compute/imageOffer","in":["cloudxtream-cdvr","cloudxtream-dai-vms","telurio-aim"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imperva"},{"field":"Microsoft.Compute/imageOffer","in":["imperva-dam-v13","securesphere-waf","securesphere-waf-for-azr","securesphere-waf-v12","securesphere-waf-v13"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"infoblox"},{"field":"Microsoft.Compute/imageOffer","in":["infoblox-vnios-te-v1420"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informatica"},{"field":"Microsoft.Compute/imageOffer","in":["bdm10-1-1-u2","big-data-management-10-2","big-data-management-10-2-1","data_accelerator_for_azure_byol","data_quality_10_1_1_rhel_7_3_byol","eic","ics-byol","ics-payg-ubuntu","platform_10_1_1_multi_node_domain_rhel-7-3_byol","platform_10_2_hf1_domain_rhel-7-3_byol","powercenter-v10-domain-image-ubuntu14-04-3","powercenter-v10-update1-domain-image-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informationbuilders"},{"field":"Microsoft.Compute/imageOffer","in":["iway-big-data-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ingrammicro"},{"field":"Microsoft.Compute/imageOffer","in":["ingrammicroensimcentostrial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel"},{"field":"Microsoft.Compute/imageOffer","in":["lustre-cloud-edition-gs-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-bigdl"},{"field":"Microsoft.Compute/imageOffer","in":["bigdl-0815","bigdl__vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-fpga"},{"field":"Microsoft.Compute/imageOffer","in":["quartus_pro_opencl_sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intellicus-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["intellicus_bi_server_100_user_linux","intellicus_bi_server_10_user_linux","intellicus_bi_server_25_user_linux","intellicus_bi_server_50_user_linux","intellicus_bi_server_5_user_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intersystems"},{"field":"Microsoft.Compute/imageOffer","in":["intersystems-iris-single-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intigua"},{"field":"Microsoft.Compute/imageOffer","in":["intigua-agent-manager-3_7_0-trial","intigua-agent-manager-trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iquest"},{"field":"Microsoft.Compute/imageOffer","in":["keyhub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ishlangu-load-balancer-adc"},{"field":"Microsoft.Compute/imageOffer","in":["ishlangu-load-balancer-byol","ishlangu-load-balancer-is10","ishlangu-load-balancer-is100","ishlangu-load-balancer-is1000","ishlangu-load-balancer-is200","ishlangu-load-balancer-is5000","ishlangu-load-balancer-isbfg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"issp-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["ispocr"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"itelios"},{"field":"Microsoft.Compute/imageOffer","in":["magento2-on-zendserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jamcracker"},{"field":"Microsoft.Compute/imageOffer","in":["4632d5b4-feb0-4332-8452-f2e66133672f","jamcracker-cloudanalytics","jamcracker-cloudanalytics-version4","jamcracker-cloudanalytics-version5","jamcracker-csb-service-provider","jamcracker-csb-serviceprovider","jamcracker-csb-standard","jamcracker-csb-standard-v3","jamcracker-csb-standard-version4","jamcracker-hybrid-cloud-management-version4","jamcracker_cloud_control_appliance_version4","jsdnapp_csb_serviceprovider-version4","jsdnapp_hybrid","jsdnapp_hybrid_v3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jedox"},{"field":"Microsoft.Compute/imageOffer","in":["jedox-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jelastic"},{"field":"Microsoft.Compute/imageOffer","in":["jelastic-hybrid-paas-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetnexus"},{"field":"Microsoft.Compute/imageOffer","in":["dvwa","jetnexus-application-load-balancer","jetnexus-global-load-balancer","jetnexus-waf","zap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetware-srl"},{"field":"Microsoft.Compute/imageOffer","in":["caffe2","caffe_python_cpu","caffe_python_gpu","cockroachdb","lamp_optimized","lemp7_optimized","memcached","mongodb","mxnet_python","mysql","nodejs_nginx","percona_mongodb","percona_mysql","postgresql","pytorch","pytorch_cuda_notebook","pytorch_cuda_production","redis","redmine","tensorflow_cpu_notebook","tensorflow_cpu_production","tensorflow_cuda_notebook","tensorflow_cuda_production","tensorflow_python","theano_python","wordpress4_lemp7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jitterbit_integration"},{"field":"Microsoft.Compute/imageOffer","in":["jitterbit-harmony-agent"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jm-technology-inc"},{"field":"Microsoft.Compute/imageOffer","in":["smart-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"juniper-networks"},{"field":"Microsoft.Compute/imageOffer","in":["vmx-services-gateway-byol","vmx-services-gateway-byol-soltemp","vmx-virtual-router","vsrx-next-generation-firewall","vsrx-next-generation-firewall-payg","vsrx-next-generation-firewall-solution-templ-payg","vsrx-next-generation-firewall-solution-template"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaazing"},{"field":"Microsoft.Compute/imageOffer","in":["kaazing-kwic","kaazing-vpa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kali-linux"},{"field":"Microsoft.Compute/imageOffer","in":["kali-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kemptech"},{"field":"Microsoft.Compute/imageOffer","in":["kemp360central-byol","vlm-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kinetica"},{"field":"Microsoft.Compute/imageOffer","in":["kineticadbbyol","kineticadbpayasyougo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaspersky_lab"},{"field":"Microsoft.Compute/imageOffer","in":["kaspersky_secure_mail_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"knime"},{"field":"Microsoft.Compute/imageOffer","in":["knime-server-5-user_4-4-0","knime-server-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"krypc-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["krypccore"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leap-orbit"},{"field":"Microsoft.Compute/imageOffer","in":["leaporbitstoragebackedsftp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leostream-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["connection-broker"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquid-files"},{"field":"Microsoft.Compute/imageOffer","in":["liquidfiles"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquidware"},{"field":"Microsoft.Compute/imageOffer","in":["stratusphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"literatu"},{"field":"Microsoft.Compute/imageOffer","in":["literatu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"loadbalancer"},{"field":"Microsoft.Compute/imageOffer","in":["loadbalancer-org-load-balancer-for-azure","loadbalancer-org-load-balancer-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logsign"},{"field":"Microsoft.Compute/imageOffer","in":["logsignfocus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logtrust"},{"field":"Microsoft.Compute/imageOffer","in":["logtrust-log-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"looker"},{"field":"Microsoft.Compute/imageOffer","in":["looker-analytics-platform","looker-analytics-platform-326","looker-analytics-platform-5_6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"lti-lt-infotech"},{"field":"Microsoft.Compute/imageOffer","in":["trade-finance-blockchain"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"luminate-security"},{"field":"Microsoft.Compute/imageOffer","in":["luminate-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mapr-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["mapr52-base-dev","mapr60-base","mapr60-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mariadb"},{"field":"Microsoft.Compute/imageOffer","in":["mariadb-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"marklogic"},{"field":"Microsoft.Compute/imageOffer","in":["marklogic-9-byol","marklogic-developer-9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"massiveanalytic-"},{"field":"Microsoft.Compute/imageOffer","in":["oscarap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mathworks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["matlab-ref-arch-18a-v1-linux-disk","mps-ref-arch-18a-v1-linux-disk2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"matillion"},{"field":"Microsoft.Compute/imageOffer","in":["matillion-etl-snowflake"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mavinglobal"},{"field":"Microsoft.Compute/imageOffer","in":["mavin-business-trial","mavin-enterprise-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"meanio"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-enterprise-ready","linnovate-open-source-sla-pro","mean-machine-20","openideal3","redash"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"media3-technologies-llc"},{"field":"Microsoft.Compute/imageOffer","in":["cpan1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"memsql"},{"field":"Microsoft.Compute/imageOffer","in":["memsql-community-single-vm","memsql-enterprise-single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mendix"},{"field":"Microsoft.Compute/imageOffer","in":["mendix-docker","mendix-pro"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mfe_azure"},{"field":"Microsoft.Compute/imageOffer","in":["atd-mcafee","mcafee_vnsp_controller_for_azure","mcafee_vnsp_for_azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"micro-focus"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-avere"},{"field":"Microsoft.Compute/imageOffer","in":["vfxt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-batch"},{"field":"Microsoft.Compute/imageOffer","in":["centos-container","centos-container-rdma","ubuntu-server-container","ubuntu-server-container-rdma"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-compute"},{"field":"Microsoft.Compute/imageOffer","in":["azureconfidentialcompute"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["azureml","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftAzureSiteRecovery"},{"field":"Microsoft.Compute/imageOffer","in":["ASR-Hydration-VMs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftOSTC"},{"field":"Microsoft.Compute/imageOffer","in":["FreeBSD"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","in":["MLServer-CentOS","MLServer-RedHat","MLServer-Ubuntu","RServer-CentOS","RServer-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midfin"},{"field":"Microsoft.Compute/imageOffer","in":["mf_neon_cgw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midvision"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-datapower-virtual-edition-75","ibm-datapower-virtual-edition-76","ibm-datapower-virtual-edition-77","ibm-http-server","ibm-websphere-portal-server-85","ibm-websphere-portal-server-90","websphere-application-server-be","websphere-application-server-be-80","websphere-application-server-be-85","websphere-application-server-be-90","websphere-application-server-be-and-mq","websphere-application-server-lp","websphere-application-server-lp-16","websphere-application-server-lp-17","websphere-application-server-lp-18","websphere-application-server-nde","websphere-application-server-nde-80","websphere-application-server-nde-85","websphere-application-server-nde-90","websphere-mq","websphere-mq-75","websphere-mq-90","websphere-mq-91"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miraclelinux"},{"field":"Microsoft.Compute/imageOffer","in":["asianux-server-4-sp5","asianux-server-4-sp6","asianux-server-4-sp7","asianux-server-7-sp1","asianux-server-7-sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miri-infotech-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mobilab"},{"field":"Microsoft.Compute/imageOffer","in":["magento-wirecard-checkout"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moogsoft"},{"field":"Microsoft.Compute/imageOffer","in":["moogsoft-aiops"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moviemasher"},{"field":"Microsoft.Compute/imageOffer","in":["moviemasher"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","in":["SQL2017-RHEL7","SQL2017-RHEL73","SQL2017-SLES12SP2","SQL2017-Ubuntu1604","SQL2019-RHEL7","SQL2019-Ubuntu1604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mtnfog"},{"field":"Microsoft.Compute/imageOffer","in":["idyl-e3-entity-extraction-engine","prose-sentence-extraction-engine","renku-language-detection-engine","sonnet-tokenization-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mxhero"},{"field":"Microsoft.Compute/imageOffer","in":["mail2cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"my-com"},{"field":"Microsoft.Compute/imageOffer","in":["tarantool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"narrativescience"},{"field":"Microsoft.Compute/imageOffer","in":["narratives-for-power-bi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nasuni"},{"field":"Microsoft.Compute/imageOffer","in":["nasuni-nmc","nasuni_edge_appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ncbi"},{"field":"Microsoft.Compute/imageOffer","in":["ncbi-blast-2-3-0","ncbi-free-2-2-31"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nebbiolo-technologies-inc"},{"field":"Microsoft.Compute/imageOffer","in":["fog-system-manager","fogsm_basic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neo4j"},{"field":"Microsoft.Compute/imageOffer","in":["neo4j-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netapp"},{"field":"Microsoft.Compute/imageOffer","in":["netapp-altavault-cloud-integrated-storage-solution","netapp-oncommand-cloud-manager","netapp-ontap-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netgate"},{"field":"Microsoft.Compute/imageOffer","in":["netgate-pfsense-azure-fw-vpn-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netiq"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netscout"},{"field":"Microsoft.Compute/imageOffer","in":["netscout_virtual_ngeniusone_with_vscout","netscout_vstream"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netmail"},{"field":"Microsoft.Compute/imageOffer","in":["netmail-search"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netsweeper"},{"field":"Microsoft.Compute/imageOffer","in":["netsweeper6-0-6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netx"},{"field":"Microsoft.Compute/imageOffer","in":["simplehelp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neusoft-neteye"},{"field":"Microsoft.Compute/imageOffer","in":["neusoft-nisg-va-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nginxinc"},{"field":"Microsoft.Compute/imageOffer","in":["nginx-plus-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nicepeopleatwork"},{"field":"Microsoft.Compute/imageOffer","in":["youzana"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nodejsapi"},{"field":"Microsoft.Compute/imageOffer","in":["node-js-api"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"noobaa"},{"field":"Microsoft.Compute/imageOffer","in":["noobaa-hybrid-s3-archive-05","noobaa-multi-cloud-deduplication"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"northbridge-secure"},{"field":"Microsoft.Compute/imageOffer","in":["netconnect1","netconnectx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nubeva-inc"},{"field":"Microsoft.Compute/imageOffer","in":["controller","test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuco-networks"},{"field":"Microsoft.Compute/imageOffer","in":["aionnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuxeo"},{"field":"Microsoft.Compute/imageOffer","in":["nuxeo-6-lts","nuxeo-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nvidia"},{"field":"Microsoft.Compute/imageOffer","in":["ngc_azure_17_11"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"o2mc-real-time-data-platform"},{"field":"Microsoft.Compute/imageOffer","in":["o2mc-platform-app"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"oceanblue-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["obc-sdwan-solutions"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"omega-software"},{"field":"Microsoft.Compute/imageOffer","in":["ods_datastage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onyx-point-inc"},{"field":"Microsoft.Compute/imageOffer","in":["op-bnf-v1","op-bnf1_6-v1","op-bpnifi-v1","op-bpnifi16-v1","op-scc-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onapsis"},{"field":"Microsoft.Compute/imageOffer","in":["osp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"op5"},{"field":"Microsoft.Compute/imageOffer","in":["op5-monitor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"opencell"},{"field":"Microsoft.Compute/imageOffer","in":["meveo","meveo403sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"openvpn"},{"field":"Microsoft.Compute/imageOffer","in":["openvpnas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-WebLogic-Server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"orientdb"},{"field":"Microsoft.Compute/imageOffer","in":["orientdb-community-edition","orientdb-community-edition-2_2","orientdb-enterprise-edition-2_2","orientdb-enterprise-edition-2_2_17"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osirium-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["osirium-pxm-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osnexus"},{"field":"Microsoft.Compute/imageOffer","in":["quantastorvsav4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"paloaltonetworks"},{"field":"Microsoft.Compute/imageOffer","in":["panorama","vmseries1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"panzura-file-system"},{"field":"Microsoft.Compute/imageOffer","in":["azura-freedom-filer-v7110","panzura-cloud-filer","panzura-freedom-filer-7140-13222","panzura-freedom-filer-716-13549","panzura-freedom-filer-v7020"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"parasoft"},{"field":"Microsoft.Compute/imageOffer","in":["parasoft-service-virtualization"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"passlogy"},{"field":"Microsoft.Compute/imageOffer","in":["passlogic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"penta-security-systems-inc"},{"field":"Microsoft.Compute/imageOffer","in":["wapples"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"percona"},{"field":"Microsoft.Compute/imageOffer","in":["percona-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"postgres-pro"},{"field":"Microsoft.Compute/imageOffer","in":["postgres-pro-enterprise","postgres-pro-enterprise-10","postgres-pro-standard","postgres-pro-standard-10"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"plesk"},{"field":"Microsoft.Compute/imageOffer","in":["plesk-onyx-linux","solution-server-business","solution-server-wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prestashop"},{"field":"Microsoft.Compute/imageOffer","in":["prestashop16-lamp","ubuntu-base-for-prestashop"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prime-strategy"},{"field":"Microsoft.Compute/imageOffer","in":["kusanagi-77"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","in":["pivotal-gpdb-vm","pivotal-greenplum-images","pivotal-ops-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"process-one"},{"field":"Microsoft.Compute/imageOffer","in":["ejabberd-community-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"profecia"},{"field":"Microsoft.Compute/imageOffer","in":["full_disk_encryption_vm","project_tools_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"progelspa"},{"field":"Microsoft.Compute/imageOffer","in":["libra-esva-antispam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ptsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["ptaf-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pulse-secure"},{"field":"Microsoft.Compute/imageOffer","in":["pulse-connect-secure-vm","pulse-virtual-traffic-manager","pulse-virtual-traffic-manager-with-waf","pulse-virtual-traffic-manager-with-waf2","pulse-virtual-traffic-manager2","pulse-virtual-web-application-firewall","pulse-virtual-web-application-firewall2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"PuppetLabs"},{"field":"Microsoft.Compute/imageOffer","in":["PuppetEnterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"puppet"},{"field":"Microsoft.Compute/imageOffer","in":["puppet-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pydio"},{"field":"Microsoft.Compute/imageOffer","in":["pydio-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qore-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["qorus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qualysguard"},{"field":"Microsoft.Compute/imageOffer","in":["qualys-virtual-firewall-appliance","qualys-virtual-scanner-v23b","qualys-virtual-scanner-v24"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quasardb"},{"field":"Microsoft.Compute/imageOffer","in":["quasardb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qubole-inc"},{"field":"Microsoft.Compute/imageOffer","in":["qubole-data-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quest"},{"field":"Microsoft.Compute/imageOffer","in":["fve"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"racknap"},{"field":"Microsoft.Compute/imageOffer","in":["racknap-server","racknap-server-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radware"},{"field":"Microsoft.Compute/imageOffer","in":["radware-alteon-va"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radiant-logic"},{"field":"Microsoft.Compute/imageOffer","in":["radiantone-vms"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rancher"},{"field":"Microsoft.Compute/imageOffer","in":["rancheros"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapid7"},{"field":"Microsoft.Compute/imageOffer","in":["nexpose-scan-engine","rapid7-vm-console"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapidminer"},{"field":"Microsoft.Compute/imageOffer","in":["rapidminer_server_75","rapidminer_server_76","rapidminer_server_80","rapidminer_server_81"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"realm"},{"field":"Microsoft.Compute/imageOffer","in":["realm-mobile-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"reblaze"},{"field":"Microsoft.Compute/imageOffer","in":["rbzr-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HANA"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"relevance-lab"},{"field":"Microsoft.Compute/imageOffer","in":["rlcatalyst"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"remotelearner"},{"field":"Microsoft.Compute/imageOffer","in":["fully-supported-moodle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"revolution-analytics"},{"field":"Microsoft.Compute/imageOffer","in":["revolution-r-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RightScaleLinux"},{"field":"Microsoft.Compute/imageOffer","in":["RightImage-CentOS","RightImage-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RiverbedTechnology"},{"field":"Microsoft.Compute/imageOffer","in":["steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"riverbed"},{"field":"Microsoft.Compute/imageOffer","in":["riverbed-sccm-5-5-1","riverbed-steelcentral-appinternals","riverbed-steelhead-9-2","riverbed-steelhead-9-5-0","riverbed-steelhead-9-6-0","riverbed_steelconnect_gw","riverbed_steelconnect_sh","steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rocketsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["rocket-discover"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsa-security-llc"},{"field":"Microsoft.Compute/imageOffer","in":["rsa-nw-azure-arch","rsa-nw-azure-broker","rsa-nw-azure-con","rsa-nw-azure-esa","rsa-nw-azure-ldec","rsa-nw-azure-vlc","rsa-nw-suite-11","rsa-nw-suite-11-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsk-labs"},{"field":"Microsoft.Compute/imageOffer","in":["rsk-bamboo-beta-node","rsk-node-orchid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saama"},{"field":"Microsoft.Compute/imageOffer","in":["fluidanalyticsengine","insurancefraudanalytics","realworldevidence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saltstack"},{"field":"Microsoft.Compute/imageOffer","in":["centos65saltstackenterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalearc"},{"field":"Microsoft.Compute/imageOffer","in":["scalearc-for-mysql-paygo","scalearc-for-sql-server-pay-go","scalearc_mysql-server","scalearc_sql_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalegrid"},{"field":"Microsoft.Compute/imageOffer","in":["centos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sap"},{"field":"Microsoft.Compute/imageOffer","in":["hanaexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scality"},{"field":"Microsoft.Compute/imageOffer","in":["scalityconnecthourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"secureworks"},{"field":"Microsoft.Compute/imageOffer","in":["scwx-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"shadow-soft"},{"field":"Microsoft.Compute/imageOffer","in":["icinga","icinga2-5","icinga2-7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"signal-sciences"},{"field":"Microsoft.Compute/imageOffer","in":["signalscienceswpp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sightapps"},{"field":"Microsoft.Compute/imageOffer","in":["sightapps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"silver-peak-systems"},{"field":"Microsoft.Compute/imageOffer","in":["silver_peak_edgeconnect","silver_peak_vx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"simmachinesinc"},{"field":"Microsoft.Compute/imageOffer","in":["simmachines_vm_v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sinefa"},{"field":"Microsoft.Compute/imageOffer","in":["sinefa-probe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"skyarc"},{"field":"Microsoft.Compute/imageOffer","in":["mt6","mta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"smartmessage-autoflow"},{"field":"Microsoft.Compute/imageOffer","in":["martmessage-autoflow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"snapt-adc"},{"field":"Microsoft.Compute/imageOffer","in":["snaptadc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soasta"},{"field":"Microsoft.Compute/imageOffer","in":["cloudtest-lite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"softnas"},{"field":"Microsoft.Compute/imageOffer","in":["cloud_dev","mp_ce","mp_ent","mp_nas_byol","mp_nas_ep","mp_nas_gp","mp_nas_hp","mp_plat","private_offerings","softnas-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solanolabs"},{"field":"Microsoft.Compute/imageOffer","in":["solano-ci-private-beta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soha"},{"field":"Microsoft.Compute/imageOffer","in":["soha-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solar-security"},{"field":"Microsoft.Compute/imageOffer","in":["solar-incode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sonicwall-inc"},{"field":"Microsoft.Compute/imageOffer","in":["sonicwall-nsz-azure","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sophos"},{"field":"Microsoft.Compute/imageOffer","in":["sophos-xg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spagobi"},{"field":"Microsoft.Compute/imageOffer","in":["spagobi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spacecurve"},{"field":"Microsoft.Compute/imageOffer","in":["spacecurve-quickstart"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"splunk"},{"field":"Microsoft.Compute/imageOffer","in":["splunk-enterprise-base-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"src-solution"},{"field":"Microsoft.Compute/imageOffer","in":["pilot-things-onem2m-smart-network"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sqlstream"},{"field":"Microsoft.Compute/imageOffer","in":["com"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sphere3d"},{"field":"Microsoft.Compute/imageOffer","in":["snapcloud-byol","snapcloud-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackato-platform-as-a-service"},{"field":"Microsoft.Compute/imageOffer","in":["activestate-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackstorm"},{"field":"Microsoft.Compute/imageOffer","in":["stackstorm-2015-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"startekfingerprintmatch"},{"field":"Microsoft.Compute/imageOffer","in":["bioserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"steelhive"},{"field":"Microsoft.Compute/imageOffer","in":["steelhive_carbon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stonefly"},{"field":"Microsoft.Compute/imageOffer","in":["stonefly-cloud-drive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stormshield"},{"field":"Microsoft.Compute/imageOffer","in":["stormshield-network-security-for-cloud","stormshield-network-security-for-cloud-xl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"storreduce"},{"field":"Microsoft.Compute/imageOffer","in":["storreduce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stratumn"},{"field":"Microsoft.Compute/imageOffer","in":["indigo-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"streamsets"},{"field":"Microsoft.Compute/imageOffer","in":["streamsets-data-collector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"striim"},{"field":"Microsoft.Compute/imageOffer","in":["integrationforsqlserveronazure","integrationtoazurestorage","integrationtoeventhub","integrationtohdinsight"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"symantectest1"},{"field":"Microsoft.Compute/imageOffer","in":["cwpsazure-beta-01"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synack-inc"},{"field":"Microsoft.Compute/imageOffer","in":["synack-crowd-security-intelligence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synechron-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blockchain_tradefinance_quorum"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"syte"},{"field":"Microsoft.Compute/imageOffer","in":["syteoffer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tactic"},{"field":"Microsoft.Compute/imageOffer","in":["tactic-workflow-v001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talari-networks"},{"field":"Microsoft.Compute/imageOffer","in":["talari-networks-virtual-appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talena-inc"},{"field":"Microsoft.Compute/imageOffer","in":["talena_inc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tata_communications"},{"field":"Microsoft.Compute/imageOffer","in":["netfoundry_cloud_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tavendo"},{"field":"Microsoft.Compute/imageOffer","in":["crossbar_on_azure_ubuntu1404"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techdivision"},{"field":"Microsoft.Compute/imageOffer","in":["appserver-io-pe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techlatest"},{"field":"Microsoft.Compute/imageOffer","in":["ethereumdevkit","rippledevelopersuit"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"telepat"},{"field":"Microsoft.Compute/imageOffer","in":["free"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tenable"},{"field":"Microsoft.Compute/imageOffer","in":["tenable-nessus-6-byol","tenable-nessus-professional","tenablecorenessus","tenablecorewas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"teradata"},{"field":"Microsoft.Compute/imageOffer","in":["teradata-data-mover","teradata-data-mover-agent","teradata-data-mover-intellisphere","teradata-data-stream-controller","teradata-database-1510","teradata-database-1510-byol","teradata-database-1510-intellisphere","teradata-database-1510-v2","teradata-database-1610-intellisphere","teradata-database-1610-v2","teradata-database-1620","teradata-database-1620-byol","teradata-database-1620-intellisphere","teradata-database-enterprise","teradata-database-v1610","teradata-database-v1610-byol","teradata-ecosystem-manager","teradata-querygrid-manager","teradata-querygrid-manager-intellisphere","teradata-rest-services","teradata-server-management","teradata-viewpoint","teradata-viewpoint-intellisphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thales-vormetric"},{"field":"Microsoft.Compute/imageOffer","in":["ciphertrust-ckm","vormetric-dsm","vormetric-dsm-6-1-0","vormetric-tokenization-server","vts-2_2_0_2604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"things-board"},{"field":"Microsoft.Compute/imageOffer","in":["tb-pe-cassandra"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thoughtspot-inc"},{"field":"Microsoft.Compute/imageOffer","in":["thoughtspotvirtualmachine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tibco-software"},{"field":"Microsoft.Compute/imageOffer","in":["grid-server-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tig"},{"field":"Microsoft.Compute/imageOffer","in":["backup-as-a-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tigergraph"},{"field":"Microsoft.Compute/imageOffer","in":["tigergraph"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tmaxsoft"},{"field":"Microsoft.Compute/imageOffer","in":["tmax-jeusee","tmax-jeusse","tmax-webtobse"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tokyosystemhouse"},{"field":"Microsoft.Compute/imageOffer","in":["osscobol151j-pg961-centos72"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"torusware"},{"field":"Microsoft.Compute/imageOffer","in":["speedus-lite-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"totemo"},{"field":"Microsoft.Compute/imageOffer","in":["totemo-azr-tm6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"townsend-security"},{"field":"Microsoft.Compute/imageOffer","in":["alliance-key-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"trendmicro"},{"field":"Microsoft.Compute/imageOffer","in":["deep-security-vm","deep-security-vm-byol","iot-security-sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"truestack"},{"field":"Microsoft.Compute/imageOffer","in":["tsdc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tsa-public-service"},{"field":"Microsoft.Compute/imageOffer","in":["ckan-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tunnelbiz"},{"field":"Microsoft.Compute/imageOffer","in":["centos70-min","centos7optimizwithwordpress","centos7phpoptimizing","centos7phpoptimizingnginx","centos7phpoptimizwlaravel","centos7phpoptimizwosticket","centos7webserverwithwaf","centos7withaspdotnetcore2apache","centos7withjoomla","debian_web_server","fedora","fusio","linuxwithlimesurvey","networkmonitoringsystem","rimauwaf_cloud","ubuntu_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"twistlock"},{"field":"Microsoft.Compute/imageOffer","in":["twistlock"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"typesafe"},{"field":"Microsoft.Compute/imageOffer","in":["typesafe-reactive-maps-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubeeko"},{"field":"Microsoft.Compute/imageOffer","in":["hfactory-tools-for-hdinsight","hfactory-tools-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubercloud"},{"field":"Microsoft.Compute/imageOffer","in":["ansys-17-2-fluids-structures","ansys_182_test","comsol-multiphysics-v5-2","openfoam-v2dot3-centos-v6","openfoam-v3dot0","star-ccm-v10-04","star-ccm-v10-06-heeds-mdo-v2015","star-ccm-v12-00"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ulex"},{"field":"Microsoft.Compute/imageOffer","in":["voximal"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unifi-software"},{"field":"Microsoft.Compute/imageOffer","in":["unifi-data-catalog","unifi-dataplatform-2-3-3-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unitrends"},{"field":"Microsoft.Compute/imageOffer","in":["unitrends-enterprise-backup-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"usp"},{"field":"Microsoft.Compute/imageOffer","in":["unified-streaming-vod-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"varnish"},{"field":"Microsoft.Compute/imageOffer","in":["varnish-cache_","varnish-custom-statistics","varnish-plus-administration-and-statistics","varnish-plus-caching-engine-4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vaultive-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-security-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vbot"},{"field":"Microsoft.Compute/imageOffer","in":["vbot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"velocloud"},{"field":"Microsoft.Compute/imageOffer","in":["velocloud-virtual-edge","velocloud-virtual-edge-3x"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vidispine"},{"field":"Microsoft.Compute/imageOffer","in":["vidispine-content-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veritas"},{"field":"Microsoft.Compute/imageOffer","in":["cloudpoint-2-0-0","veritas-resiliency-platform-vhd-offer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veeam"},{"field":"Microsoft.Compute/imageOffer","in":["veeamhubimage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vigyanlabs-innovations-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["ipm-plus-energy-saver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"viptela"},{"field":"Microsoft.Compute/imageOffer","in":["viptela-vedge-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vizixiotplatformretail001"},{"field":"Microsoft.Compute/imageOffer","in":["vizix-iot-platform-retail-005"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vmturbo"},{"field":"Microsoft.Compute/imageOffer","in":["turbonomic","vmturbo64-opsmgr-5_3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vte"},{"field":"Microsoft.Compute/imageOffer","in":["slashdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vu-llc"},{"field":"Microsoft.Compute/imageOffer","in":["vu-app-server","vu-facerecogn","vu-fraudanalysis","vu-secureonboarding"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallarm"},{"field":"Microsoft.Compute/imageOffer","in":["wallarm-ng-waf-offer-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallix"},{"field":"Microsoft.Compute/imageOffer","in":["wallix-wabsuite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"watchguard-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["vm-firebox-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"waves"},{"field":"Microsoft.Compute/imageOffer","in":["waves"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"websense-apmailpe"},{"field":"Microsoft.Compute/imageOffer","in":["ap-data-email-gateway","forcepoint-email-security-85beta","triton-ap-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wmspanel"},{"field":"Microsoft.Compute/imageOffer","in":["nimble-streamer-centos","nimble-streamer-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wowza"},{"field":"Microsoft.Compute/imageOffer","in":["wowzastreamingengine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xfinityinc"},{"field":"Microsoft.Compute/imageOffer","in":["d3view-v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xtremedata"},{"field":"Microsoft.Compute/imageOffer","in":["dbx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"yellowfin"},{"field":"Microsoft.Compute/imageOffer","in":["yellowfin-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xyzrd-group-ou"},{"field":"Microsoft.Compute/imageOffer","in":["c73-zultys-mxvirtual"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"your-shop-online"},{"field":"Microsoft.Compute/imageOffer","in":["herefordshire-enterprise-platform-drupal-7","xenofile"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zend"},{"field":"Microsoft.Compute/imageOffer","in":["php-56-zend-server","php-zend-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"z1"},{"field":"Microsoft.Compute/imageOffer","in":["z1-securehub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zerodown_software"},{"field":"Microsoft.Compute/imageOffer","in":["bcaasforazure","stackbcaas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zoomdata"},{"field":"Microsoft.Compute/imageOffer","in":["zoomdata-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zscaler"},{"field":"Microsoft.Compute/imageOffer","in":["zscaler-private-access"]}]}]}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bfa798085e63e6b3","type":"Microsoft.Authorization/policyDefinitions","name":"bfa798085e63e6b3"},{"properties":{"displayName":"azsecpack + nonprod tagging for iaas_1.1","policyType":"Custom","mode":"Indexed","description":"Adds + the AzSecPack tag to a Compute VM resource","metadata":{"category":"azsecpack-msi","createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-22T03:54:05.332867Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"azSecPackTagName":{"type":"String","metadata":{"displayName":"AzSecPack + Tag Name","description":"This policy adds the specified tag"},"defaultValue":"azsecpack"},"azSecPackTagValue":{"type":"String","metadata":{"displayName":"AzSecPack + Tag Value","description":"This policy adds the specified tag value"},"defaultValue":"nonprod"},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPackAutoConfig"},"skipTagName3":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipWindowsAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''azSecPackTagName''), '']'')]","notEquals":"[parameters(''azSecPackTagValue'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName3''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName3''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"operations":[{"operation":"addOrReplace","field":"[concat(''tags['', + parameters(''azSecPackTagName''), '']'')]","value":"[parameters(''azSecPackTagValue'')]"}]}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c09cb226ea763513","type":"Microsoft.Authorization/policyDefinitions","name":"c09cb226ea763513"},{"properties":{"displayName":"audit + ssh auth on existing vms_1.3","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMs use password-only authentication for SSH + on existing resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-25T22:01:38.4305071Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}}},"policyRule":{"if":{"allof":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration","exists":"True"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c2f5d119c894ce34","type":"Microsoft.Authorization/policyDefinitions","name":"c2f5d119c894ce34"},{"properties":{"displayName":"nrms-nsg-rule-107_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:32.278708Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c4184f404efb2fe5","type":"Microsoft.Authorization/policyDefinitions","name":"c4184f404efb2fe5"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack autoupdate policy for iaas_1.2","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-23T19:35:05.015959Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"resourcegrouptagname2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname1'')]]","equals":""},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname2'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"anyOf":[{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]},{"not":{"field":"Microsoft.Compute/virtualMachines/osProfile.windowsConfiguration.provisionVMAgent","equals":"false"}}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachines/extensions","name":"Microsoft.Azure.Geneva.GenevaMonitoring","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachines/extensions/type","equals":"GenevaMonitoring"},{"field":"Microsoft.Compute/virtualMachines/extensions/publisher","equals":"Microsoft.Azure.Geneva"},{"field":"Microsoft.Compute/virtualMachines/extensions/enableAutomaticUpgrade","equals":"true"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmName''), + ''/Microsoft.Azure.Geneva.GenevaMonitoring'')]","type":"Microsoft.Compute/virtualMachines/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{},"protectedSettings":{}}}]},"parameters":{"vmName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c6cc0ff730a1cb3c","type":"Microsoft.Authorization/policyDefinitions","name":"c6cc0ff730a1cb3c"},{"properties":{"displayName":"audit + ssh auth on new vmss_1.3","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMSSs use password-only authentication for + SSH on new resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-25T22:01:43.9041265Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"anyof":[{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication","exists":"False"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"7isolutions"},{"field":"Microsoft.Compute/imageOffer","in":["sapp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"128technology"},{"field":"Microsoft.Compute/imageOffer","in":["128t_networking_platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"4psa"},{"field":"Microsoft.Compute/imageOffer","in":["voipnow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"a10networks"},{"field":"Microsoft.Compute/imageOffer","in":["a10-lightning-adc","a10-vthunder-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accellion"},{"field":"Microsoft.Compute/imageOffer","in":["kiteworks-by-accellion"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"abiquo"},{"field":"Microsoft.Compute/imageOffer","in":["abiquo-hybrid-cloud-34"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accops"},{"field":"Microsoft.Compute/imageOffer","in":["hysecure5050"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian_matrix"},{"field":"Microsoft.Compute/imageOffer","in":["actian_matrix"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actifio"},{"field":"Microsoft.Compute/imageOffer","in":["actifio-sky"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian-corp"},{"field":"Microsoft.Compute/imageOffer","in":["vector-community","vector-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Acronis"},{"field":"Microsoft.Compute/imageOffer","in":["storage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"activeeon"},{"field":"Microsoft.Compute/imageOffer","in":["activeeon-workload-scheduler"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aerospike"},{"field":"Microsoft.Compute/imageOffer","in":["aerospike-database-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"affinio"},{"field":"Microsoft.Compute/imageOffer","in":["platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aiscaler-cache-control-ddos-and-url-rewriting-"},{"field":"Microsoft.Compute/imageOffer","in":["aimobile-site-acceleration","aiprotect-ddos-firewall","aiscaler-traffic-manager-caching","aivideo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"akamai-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["enterprise-application-access"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alces-flight-limited"},{"field":"Microsoft.Compute/imageOffer","in":["alces-flight-compute-solo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alertlogic"},{"field":"Microsoft.Compute/imageOffer","in":["alert-logic-tm","alert-logic-wsm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alienvault"},{"field":"Microsoft.Compute/imageOffer","in":["unified-security-management-anywhere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alldigital-brevity"},{"field":"Microsoft.Compute/imageOffer","in":["alldigital-brevity-uploader"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altair-engineering-inc"},{"field":"Microsoft.Compute/imageOffer","in":["altair_hwulva"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altamira-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["lumify"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"antmedia"},{"field":"Microsoft.Compute/imageOffer","in":["ams_community_edition","ant_media_server_enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"apigee"},{"field":"Microsoft.Compute/imageOffer","in":["apigee-edge"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcara"},{"field":"Microsoft.Compute/imageOffer","in":["app360v43-001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcelerator"},{"field":"Microsoft.Compute/imageOffer","in":["appcelerator-arrow-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appex-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appistry"},{"field":"Microsoft.Compute/imageOffer","in":["genomepilot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appscale-marketplace"},{"field":"Microsoft.Compute/imageOffer","in":["appscale"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arangodb"},{"field":"Microsoft.Compute/imageOffer","in":["arangodb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arista-networks"},{"field":"Microsoft.Compute/imageOffer","in":["veos-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"array_networks"},{"field":"Microsoft.Compute/imageOffer","in":["array-networks-vapv"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"astadia-1148316"},{"field":"Microsoft.Compute/imageOffer","in":["astadia-ui-automation-tee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"atomicorp"},{"field":"Microsoft.Compute/imageOffer","in":["secure-os","secure-ubuntu-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"audiocodes"},{"field":"Microsoft.Compute/imageOffer","in":["mediantsessionbordercontroller"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"auriq-systems"},{"field":"Microsoft.Compute/imageOffer","in":["essentia"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"awingu"},{"field":"Microsoft.Compute/imageOffer","in":["awingu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aviatrix-systems"},{"field":"Microsoft.Compute/imageOffer","in":["aviatrix-cloud-services","aviatrix-companion-gateway","aviatrix-companion-gateway-v2","aviatrix-vpn-gw","aviatrix_multi_cloud_service","aviatrix_openvpn_service","aviatrix_openvpn_service10","aviatrix_openvpn_service25","aviatrix_openvpn_service50"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"avi-networks"},{"field":"Microsoft.Compute/imageOffer","in":["avi-vantage-adc","internal-avi-vantage-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"axway"},{"field":"Microsoft.Compute/imageOffer","in":["axway-mailgate-secure-collaboration-advanced","axway-mailgate-secure-collaboration-premium","axway-mailgate-secure-collaboration-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azul"},{"field":"Microsoft.Compute/imageOffer","in":["azul-zulu-ubuntu-1804"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azurecyclecloud"},{"field":"Microsoft.Compute/imageOffer","in":["azure-cyclecloud-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"AzureDatabricks"},{"field":"Microsoft.Compute/imageOffer","in":["Databricks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baas-techbureau"},{"field":"Microsoft.Compute/imageOffer","in":["b1327623-d29b-4cc1-b833-85067dcc7bce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baffle-io"},{"field":"Microsoft.Compute/imageOffer","in":["baffle-application-data-protection"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"balabit"},{"field":"Microsoft.Compute/imageOffer","in":["balabit-shell-control-box","psm","sps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"barracudanetworks"},{"field":"Microsoft.Compute/imageOffer","in":["barracuda-app-sec-control-center","barracuda-email-security-gateway","barracuda-ng-cc","barracuda-ng-firewall","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"basho"},{"field":"Microsoft.Compute/imageOffer","in":["riak-2-0-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","in":["autodesk-maya-arnold-centos73","rendering-centos73"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bdy"},{"field":"Microsoft.Compute/imageOffer","in":["buddy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Bitnami"},{"field":"Microsoft.Compute/imageOffer","in":["3-4","abantecart","activemq","akeneo","alfrescocommunity","apachesolr","artifactory","canvaslms","cassandra","civicrm","cmsmadesimple","codiad","concrete5","consul","coppermine","couchdb","diaspora","discourse","djangostack","dokuwiki","dolibarr","DreamFactory","drupal","elastic-search","elk","erpnext","espocrm","etcd","eXo-Platform","exoplatform","fatfreecrm","ghost","gitlab","grafana","hadoop","hhvmstack","hordegroupwarewebmail","jasperreports","jenkins","joomla","jrubystack","kafka","kong","kubernetessandbox","lampstack","lappstack","letschat","liferay","limesurvey","livehelperchat","magento","mahara","mantis","mariadb","mattermost","mautic","mean","mediawiki","memcached","modx","mongodb","moodle","multicraft","mybb","mysql","nats","neo4j","neos","nginxstack","noalyss","nodejs","ocportal","odoo","openatrium","opencart","openedx","openfire","openproject","orangehrm","osclass","owncloud","oxid-eshop","parseserver","phabricator","phpbb","phplist","pimcore","piwik","plone","pootle","postgresql","prestashop","processmakerenterprise","processmakeropensourceedition","processwire","publify","rabbitmq","redash","redis","redmine","redmineplusagile","reportserver","reportserverenterprise","resourcespace","reviewboard","reviewboardpowerpack","roundcube","rubystack","seopanel","shopware","silverstripe","simplemachinesforum","sonarqube","spree","subversion","suitecrm","tensorflowserving","testlink","tikiwikicmsgroupware","tinytinyrss","tom-cat","trac","typo3","weblate","webmailpro","wildfly","wordpress","wordpress-multisite","wordpresspro","x2enginesalescrm","xoops","youtrack","zookeeper","zurmo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"black-duck-software"},{"field":"Microsoft.Compute/imageOffer","in":["blackduck_hub_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blk-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blk-io-erc-20-rest-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockapps"},{"field":"Microsoft.Compute/imageOffer","in":["strato-blockchain-base-template-latest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockstack"},{"field":"Microsoft.Compute/imageOffer","in":["blockstack-core-v14"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockchain-foundry"},{"field":"Microsoft.Compute/imageOffer","in":["syscoin-api","syscoin-full-node","syscoin-price-peg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bloombase"},{"field":"Microsoft.Compute/imageOffer","in":["bloombase-storesafe-3_4_7_0_el7_x86_64"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluecat"},{"field":"Microsoft.Compute/imageOffer","in":["bluecat-bam-for-azure","bluecat-dns-for-azure","bluecat-edge-service-point-vm-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluetalon"},{"field":"Microsoft.Compute/imageOffer","in":["bluetalon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"brocade_communications"},{"field":"Microsoft.Compute/imageOffer","in":["brocade-virtual-traffic-manager","brocade-virtual-traffic-manager-with-waf-module","brocade-virtual-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bt-americas-inc"},{"field":"Microsoft.Compute/imageOffer","in":["diamondip-sapphire-ev10","diamondip-sapphire-ev20","diamondip-sapphire-v10","diamondip-sapphire-v20","diamondip-sapphire-v5","diamondip-sapphire-vcaa20"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"buddhalabs"},{"field":"Microsoft.Compute/imageOffer","in":["sles_12_pci"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"carto"},{"field":"Microsoft.Compute/imageOffer","in":["cartobuilder2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cask"},{"field":"Microsoft.Compute/imageOffer","in":["cdap-cloud-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","Ubuntu_Core"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cavirin"},{"field":"Microsoft.Compute/imageOffer","in":["cavirin-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cautelalabs"},{"field":"Microsoft.Compute/imageOffer","in":["log_management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"celum-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["celumdam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cds"},{"field":"Microsoft.Compute/imageOffer","in":["cds-data-migration-solution-for-legacy-to-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-6-v2-0-2-l1","cis-centos-7-v2-1-1-l1","cis-oracle-linux-6-v1-0-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-rhel-6-v2-0-2-l1","cis-rhel-7-v2-2-0-l1","cis-suse-linux-11-v2-0-0-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1404-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"certivox"},{"field":"Microsoft.Compute/imageOffer","in":["sso-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cfd-direct"},{"field":"Microsoft.Compute/imageOffer","in":["cfd-direct-from-the-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chain"},{"field":"Microsoft.Compute/imageOffer","in":["chain-core-developer-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"checkpoint"},{"field":"Microsoft.Compute/imageOffer","in":["check-point-r77-10","check-point-vsec-r80","check-point-vsec-r80-blink","sg2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chef-software"},{"field":"Microsoft.Compute/imageOffer","in":["chef-automate-vm-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"circleci"},{"field":"Microsoft.Compute/imageOffer","in":["circleci-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cires21"},{"field":"Microsoft.Compute/imageOffer","in":["c21l-enc","c21l-mos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cisco"},{"field":"Microsoft.Compute/imageOffer","in":["cisco-asav","cisco-csr-1000v","cisco-ftdv","cisco-meraki-vmx100","cisco-ngfwv-vm-test-unsupported","cisco_cloud_vedge_17_2_4","cos65","cos72","cos72_main_dev","uos14","vwaas-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"citrix"},{"field":"Microsoft.Compute/imageOffer","in":["citrix-sd-wan-opt","netscaler-ma-service-agent-120","netscaler-ma-service-agent-121","netscaler-sd-wan","netscaler-vpx","netscalervpx-120","netscalervpx-121","netscalervpx110-6531","netscalervpx111"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clear-linux-project"},{"field":"Microsoft.Compute/imageOffer","in":["clear-linux-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clouber"},{"field":"Microsoft.Compute/imageOffer","in":["cuber","cws","mcenter"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-cruiser"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-cruiser-16"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees"},{"field":"Microsoft.Compute/imageOffer","in":["jenkins-enterprise","jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees-enterprise-jenkins"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbees-jenkins-enterprise","cloudbees-jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbolt-software"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbolt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudboost"},{"field":"Microsoft.Compute/imageOffer","in":["cloudboost"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudenablers-inc"},{"field":"Microsoft.Compute/imageOffer","in":["corestack"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","in":["squid-proxy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","in":["cloudera-altus-centos-os","cloudera-centos-6","cloudera-centos-os","test-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlanes"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-video-accelerator-nfs","cloudlanes-cloud-backup-accelerator-vtl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlink"},{"field":"Microsoft.Compute/imageOffer","in":["cloudlink-securevm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudplan-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["cloudplan_pcn_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["paladion_ondemand_nextgen_firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsoft"},{"field":"Microsoft.Compute/imageOffer","in":["cloudsoft-amp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clustrix"},{"field":"Microsoft.Compute/imageOffer","in":["clustrixdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codelathe"},{"field":"Microsoft.Compute/imageOffer","in":["codelathe-filecloud-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codenvy"},{"field":"Microsoft.Compute/imageOffer","in":["codenvy-on-prem"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cognosys"},{"field":"Microsoft.Compute/imageOffer","in":["1-click-secured-joomla-on-centos-7-3","1-click-secured-joomla-on-ubuntu-1404-lts","1-click-secured-joomla-on-ubuntu-1604-lts","1-click-secured-joomla-on-ubuntu-1804-lts","centos-6-9","centos-7-3","centos-7-4","centos-7-5","deploy-a-secured-modx-on-ubuntu-14-04-lts","deploy-a-secured-silverstripe-on-ubuntu-14-04-lts","hardened-mysql-5-6-on-centos-7-3","hardened-mysql-5-6-on-ubu-1404-lts","hardened-mysql-5-7-on-centos-7-3","hardened-mysql-5-7-on-ubu-1404-lts","hardened-postgresql-on-ubu-1404-lts","invoice-ninja-2-5-1-1-on-ubuntu-1404","jruby-on-ubuntu-14-04-lts","low-latency-broadcasting-server-for-live-events","owncloud-9-with-lamp-stack-on-ubuntu-1404","piwigogallerys-ubuntu_14-04_lts","sec1011-dokuwiki-on-ubuntu-1404","sec1013-elasticsearch-on-ubuntu-1404","sec1014-opencart-on-ubuntu-1404","sec1015-orangehrm-on-ubuntu-1404","sec1016-nodejs-server-on-ubuntu-1404","sec1018-haproxy-on-ubuntu-1404","sec1019-secured-tomcat-on-ubuntu-1404","sec1020-phpbb-on-hardened-ubuntu-1404","sec1021-mybb-on-hardened-ubuntu-1404","sec1022-sugarcrm-on-ubuntu-1404","sec1023-moodle-on-ubuntu-1404","sec1024_magento-on-ubuntu-1404","sec1025-secured-drupal-on-ubuntu-1404","sec1027-secured-wordpress-on-ubuntu-1404","sec1028-secured-lamp-sever-on-ubuntu-1404","sec1029-secured-mediawiki-on-ubuntu-1404","sec1030-secured-subversion-on-ubuntu-1404","sec1031-secured-passenger-nginx-on-ubuntu-1404","sec1033-secured-piwik-on-ubuntu-1404","sec1034-secured-pligg-on-ubuntu-1404","sec1035-secured-jenkins-on-ubuntu-1404","sec1036-secured-postgresql-on-ubuntu-1404","secure-cloud-lamp-ubuntu-1404","secured-abantecart-on-centos","secured-abantecart-on-ubuntu-14-04-lts","secured-acquia-drupal-on-centos","secured-acquiadurpal-on-ubuntu-14-04-lts","secured-apachesolr-on-centos","secured-apachesolr-on-ubuntu-14-04-lts","secured-arartifactory-on-centos","secured-artifactory-on-ubuntu-14-04-lts","secured-cakephp-on-centos","secured-cakephp-on-ubuntu-14-04-lts","secured-cms-made-simple-on-centos","secured-cms-made-simple-on-ubuntu-14-04-lts","secured-codiad-on-centos","secured-codiad-on-ubuntu-14-04-lts","secured-cogdam-on-centos","secured-cogdam-on-ubuntu-14-04-lts","secured-concrete5-on-centos","secured-concrete5-on-ubuntu-14-04-lts","secured-coppermine-on-centos","secured-coppermine-on-ubuntu-14-04-lts","secured-crushftp-on-centos","secured-crushftp-on-ubuntu-14-04-lts","secured-django-on-centos","secured-django-on-ubuntu-14-04-lts","secured-dokuwiki-on-centos","secured-dolibarr-on-centos","secured-dolivbarr-on-ubuntu-14-04-lts","secured-drupal-on-centos","secured-elasticsearch-on-centos","secured-enterprise-nginx-varnish-haproxy-php","secured-espocrm-on-centos","secured-espocrm-on-ubuntu-14-04-lts","secured-exoplatform-on-centos","secured-exoplatform-on-ubuntu-14-04-lts","secured-ghost-on-centos","secured-ghost-on-ubuntu-14-04-lts","secured-gradle-on-centos","secured-gradle-on-ubuntu-14-04-lts","secured-haproxy-on-centos","secured-invoice-ninja-on-centos","secured-jboss-as-on-centos","secured-jbossas-on-ubuntu-14-04-lts","secured-jenkins-on-centos","secured-jruby-on-cento","secured-lamp-on-centos","secured-lamp-on-centos-m10","secured-lapp-on-centos","secured-lapp-on-ubuntu-14-04-lts","secured-lemp-sever-on-ubuntu-1404","secured-lime-survey-on-centos","secured-limesurvey-on-ubuntu-1404","secured-live-helper-chat-on-centos","secured-livehelperchat-on-ubuntu-14-04-lts","secured-magento-on-centos","secured-mahara-on-centos","secured-mahara-on-ubuntu-14-04-lts","secured-mantis-on-centos","secured-mantis-on-ubuntu-14-04-lts","secured-mariadb-on-ubuntu-16-04","secured-mautic-on-centos","secured-mautic-on-ubuntu-14-04-lts","secured-media-wiki-on-centos","secured-modx-on-centos","secured-moodle-on-centos","secured-ngnix-on-centos-7-3","secured-ngnix-on-ubuntu-14-04-lts","secured-ngnix-on-ubuntu-16-04-lts","secured-noalyss-on-centos","secured-noalyss-on-ubuntu-14-04-lts","secured-nodejs-on-centos","secured-occlass-on-ubuntu-14-04-lts","secured-ocportal-on-ubuntu-14-04-lts","secured-open-cart-on-centos","secured-orangehrm-on-centos","secured-osclass-on-centos","secured-owncloud-on-centos","secured-oxid-eshop-on-centos","secured-oxideshop-on-ubuntu-14-04-lts","secured-passenger-nginx-on-centos","secured-piwigo-gallery-on-centos","secured-plone-on-centos","secured-plone-on-ubuntu-14-04-lts","secured-prestashop-on-centos","secured-prestashop-on-ubuntu-14-04-lts","secured-railo-on-ubuntu-14-04-lts","secured-redis-on-centos","secured-redis-on-ubuntu-1404","secured-redmine-on-centos","secured-redmine-on-ubuntu-14-04-lts","secured-redmineagile-on-ubuntu-14-04-lts","secured-report-server-on-centos","secured-reportserverent-on-ubuntu-14-04-lts","secured-resource-space-on-centos","secured-resourcespace-on-ubuntu-14-04-lts","secured-round-cube-on-centos","secured-roundcube-on-ubuntu-14-04-lts","secured-ruby-on-centos","secured-ruby-on-ubuntu-14-04-lts","secured-seopanel-on-centos","secured-seopanel-on-ubuntu-14-04-lts","secured-silverstripe-on-centos","secured-simple-invoice-on-centos","secured-simple-machines-on-centos","secured-simple-machines-on-ubuntu-14-04-lts","secured-simpleinvoice-on-ubuntu-14-04-lts","secured-subversion-on-centos","secured-suitecrm-on-centos","secured-suitecrm-on-ubuntu-14-04-lts","secured-test-link-on-centos","secured-testlink-on-ubuntu-14-04-lts","secured-thinkup-on-centos","secured-thinkup-on-ubuntu-14-04-lts","secured-tikiwikicms-on-centos","secured-tikiwikicms-on-ubuntu-14-04-lts","secured-tiny-tiny-rss-on-centos","secured-tinytinyrss-on-ubuntu-14-04-lts","secured-tomcat-on-centos","secured-trac-on-centos","secured-trac-on-ubuntu-14-04-lts","secured-typo3-on-centos","secured-typo3-on-ubuntu-14-04-lts","secured-varnish-on-centos","secured-varnish-on-ubuntu-1404","secured-wildfly-on-centos","secured-wildfly-on-ubuntu-14-04-lts","secured-wordpress-on-centos-7-3","secured-wordpress-on-ubuntu-16-04-lts","secured-x-cart-on-ubuntu-14-04-lts","secured-xoops-on-centos","secured-xoops-on-ubuntu-14-04-lts","secured-zurmo-on-centos","secured-zurmo-on-ubuntu-14-04-lts","suse15","ubuntu-14-04-lts","ubuntu-16-04-lts","ubuntu-17-04-high-performance-hardened-tcp-bbr","ubuntu-18-04","ubuntu-18-04-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesity"},{"field":"Microsoft.Compute/imageOffer","in":["cohesity-cloudtd-tool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesive"},{"field":"Microsoft.Compute/imageOffer","in":["vns3_4x_network_security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"confluentinc"},{"field":"Microsoft.Compute/imageOffer","in":["confluentplatform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"consensys"},{"field":"Microsoft.Compute/imageOffer","in":["truffle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"convertigo"},{"field":"Microsoft.Compute/imageOffer","in":["convertigo-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"corda"},{"field":"Microsoft.Compute/imageOffer","in":["corda"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"CoreOS"},{"field":"Microsoft.Compute/imageOffer","in":["CoreOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"couchbase"},{"field":"Microsoft.Compute/imageOffer","in":["couchbase-server-enterprise","couchbase-sync-gateway-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cryptzone"},{"field":"Microsoft.Compute/imageOffer","in":["appgate-appliance-3_2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cybernetica-as"},{"field":"Microsoft.Compute/imageOffer","in":["uxp-securityserver-connector","uxp-securityserver_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cyxtera"},{"field":"Microsoft.Compute/imageOffer","in":["appgatesdp-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataart"},{"field":"Microsoft.Compute/imageOffer","in":["devicehive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"databricks"},{"field":"Microsoft.Compute/imageOffer","in":["spfqogzeculbhdh"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datalayer"},{"field":"Microsoft.Compute/imageOffer","in":["datalayer-notebook"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datastax"},{"field":"Microsoft.Compute/imageOffer","in":["datastax-enterprise","datastax-enterprise-non-production-use-only"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datasunrise"},{"field":"Microsoft.Compute/imageOffer","in":["datasunrise-database-security-suite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataiku"},{"field":"Microsoft.Compute/imageOffer","in":["dataiku-data-science-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datometry"},{"field":"Microsoft.Compute/imageOffer","in":["hyper-q"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dellemc"},{"field":"Microsoft.Compute/imageOffer","in":["dell-emc-avamar-virtual-edition","dell-emc-datadomain-management-center","dell-emc-datadomain-virtual-edition","dell-emc-datadomain-virtual-edition-v4","dell-emc-networker-virtual-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"delphix"},{"field":"Microsoft.Compute/imageOffer","in":["delphix_dynamic_data_platform","omniosce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denodo"},{"field":"Microsoft.Compute/imageOffer","in":["denodo-platform","denodo-platform-7_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denyall"},{"field":"Microsoft.Compute/imageOffer","in":["denyall-rweb","denyall-vulnerability-manager","denyall-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dgsecure"},{"field":"Microsoft.Compute/imageOffer","in":["dgsecure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"diladele"},{"field":"Microsoft.Compute/imageOffer","in":["websafety"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dimensionalmechanics-inc"},{"field":"Microsoft.Compute/imageOffer","in":["neopulse-ai-studio","neopulse-query-runtime"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"docker"},{"field":"Microsoft.Compute/imageOffer","in":["docker-ce","docker-ce-edge","docker-datacenter-custom","docker-ee","docker-ee-basic","docker4azure","docker4azure-cs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dome9"},{"field":"Microsoft.Compute/imageOffer","in":["dome9ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drizti"},{"field":"Microsoft.Compute/imageOffer","in":["hpcbox-ansys-19-cluster-master","hpcbox-cluster-compute-node","hpcbox-cluster-cuda-node","hpcbox-cluster-gpu-node","hpcbox-docker-cluster-master","hpcbox-openfoam-cluster-master","hpcbox-su2-cluster-master"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drone"},{"field":"Microsoft.Compute/imageOffer","in":["drone"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dyadic_security"},{"field":"Microsoft.Compute/imageOffer","in":["dyadic_sec","ukc_image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dynatrace"},{"field":"Microsoft.Compute/imageOffer","in":["ruxit-managed-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"eastwind-networks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["eastwind-ixia-sensor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"egnyte"},{"field":"Microsoft.Compute/imageOffer","in":["egnyte-connect"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elasticbox"},{"field":"Microsoft.Compute/imageOffer","in":["elasticbox-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"electric-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["electricflowce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elfiqnetworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"emercoin"},{"field":"Microsoft.Compute/imageOffer","in":["emercoin"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprise-ethereum-alliance"},{"field":"Microsoft.Compute/imageOffer","in":["quorum-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprisedb-corp"},{"field":"Microsoft.Compute/imageOffer","in":["edb-postgres-ark"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"equalum"},{"field":"Microsoft.Compute/imageOffer","in":["equalum-vm-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"esdenera"},{"field":"Microsoft.Compute/imageOffer","in":["esdenera-firewall-3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ethereum"},{"field":"Microsoft.Compute/imageOffer","in":["ethereum-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"evostream-inc"},{"field":"Microsoft.Compute/imageOffer","in":["ems-for-template","ems-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"exasol"},{"field":"Microsoft.Compute/imageOffer","in":["exasol-analytics-database-byol","exasolution-analytic-database"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"falconstorsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["fss-v9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"f5-networks"},{"field":"Microsoft.Compute/imageOffer","in":["f5-big-ip-adc","f5-big-ip-advanced-waf","f5-big-ip-best","f5-big-ip-better","f5-big-ip-byol","f5-big-ip-good","f5-big-ip-per-app-ve","f5-big-iq","f5-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"filecatalyst"},{"field":"Microsoft.Compute/imageOffer","in":["filecatalyst-direct-per-hr-billing","filecatalyst-direct-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"firehost"},{"field":"Microsoft.Compute/imageOffer","in":["firehost_armor","firehost_armor_ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flexify-io"},{"field":"Microsoft.Compute/imageOffer","in":["single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flashgrid-inc"},{"field":"Microsoft.Compute/imageOffer","in":["flashgrid-racnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"foghorn-systems"},{"field":"Microsoft.Compute/imageOffer","in":["foghorn-edge-device-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forcepoint-llc"},{"field":"Microsoft.Compute/imageOffer","in":["forcepoint-ngfw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forscene"},{"field":"Microsoft.Compute/imageOffer","in":["forscene-edgeserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortycloud"},{"field":"Microsoft.Compute/imageOffer","in":["fortycloud-gw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortinet"},{"field":"Microsoft.Compute/imageOffer","in":["fortinet-fortianalyzer","fortinet-fortimanager","fortinet_fortigate-vm_v5","fortinet_fortimail","fortinet_fortivoice","fortinet_fortiweb-vm_v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fujitsu_fast"},{"field":"Microsoft.Compute/imageOffer","in":["fep10-rh7-test","feptest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gemalto-safenet"},{"field":"Microsoft.Compute/imageOffer","in":["safenet-keysecure-k170v","safenet-protectv","safenet-protectv-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gigamon-inc"},{"field":"Microsoft.Compute/imageOffer","in":["gigamon-fm-5_3_01","gigamon-fm-5_3_01_hourly","gigamon-fm-5_4_00","gigamon-fm-5_4_00_hourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gitlab"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-ce","gitlab-ee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"GitHub"},{"field":"Microsoft.Compute/imageOffer","in":["GitHub-Enterprise","githubenterprise-test-publishing"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"great-software-laboratory-private-limited"},{"field":"Microsoft.Compute/imageOffer","in":["xid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"greensql"},{"field":"Microsoft.Compute/imageOffer","in":["greensql-database-security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gridgain"},{"field":"Microsoft.Compute/imageOffer","in":["gridgain-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"guardicore"},{"field":"Microsoft.Compute/imageOffer","in":["guardicorecentra","infection_monkey"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haivision"},{"field":"Microsoft.Compute/imageOffer","in":["haivision-media-gateway-1-2","haivision-media-gateway-1-5","haivision-media-gateway-1-6-2","media-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"h2o-ai"},{"field":"Microsoft.Compute/imageOffer","in":["h2o-driverles-ai","h2o-driverless-ai","h2o-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haproxy-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hapee-rhel","hapee-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"harpaitalia"},{"field":"Microsoft.Compute/imageOffer","in":["mcuboenergy","yg","yougreen_trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hcl-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hcl17cp1104"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"heimdall-data"},{"field":"Microsoft.Compute/imageOffer","in":["heimdall-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"help-systems"},{"field":"Microsoft.Compute/imageOffer","in":["goanywheremftubuntulinux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hewlett-packard"},{"field":"Microsoft.Compute/imageOffer","in":["hpe-helion-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hillstone-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudedge-virtual-ngfw-advanced-edition","cloudedge-virtual-ngfw-standard-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hortonworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbreak-for-hortonworks-data-platform","hortonworks-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hitachi-solutions"},{"field":"Microsoft.Compute/imageOffer","in":["credeon-sfs-and-kms-for-sharepoint-online","credeonsecurefull-textsearch1_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hpe"},{"field":"Microsoft.Compute/imageOffer","in":["storeoncevsa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"huawei"},{"field":"Microsoft.Compute/imageOffer","in":["euleros-v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hyperglance"},{"field":"Microsoft.Compute/imageOffer","in":["hyperglance-dynamic-topology"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hypergrid"},{"field":"Microsoft.Compute/imageOffer","in":["hyperform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hytrust"},{"field":"Microsoft.Compute/imageOffer","in":["hytrust-keycontrol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ibm"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-security-guardium-multi-cloud","qradar_security_analytics"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iaansys"},{"field":"Microsoft.Compute/imageOffer","in":["iaansys-magento"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iboss"},{"field":"Microsoft.Compute/imageOffer","in":["iboss-14600-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imaginecommunications"},{"field":"Microsoft.Compute/imageOffer","in":["cloudxtream-cdvr","cloudxtream-dai-vms","telurio-aim"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imperva"},{"field":"Microsoft.Compute/imageOffer","in":["imperva-dam-v13","securesphere-waf","securesphere-waf-for-azr","securesphere-waf-v12","securesphere-waf-v13"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"infoblox"},{"field":"Microsoft.Compute/imageOffer","in":["infoblox-vnios-te-v1420"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informatica"},{"field":"Microsoft.Compute/imageOffer","in":["bdm10-1-1-u2","big-data-management-10-2","big-data-management-10-2-1","data_accelerator_for_azure_byol","data_quality_10_1_1_rhel_7_3_byol","eic","ics-byol","ics-payg-ubuntu","platform_10_1_1_multi_node_domain_rhel-7-3_byol","platform_10_2_hf1_domain_rhel-7-3_byol","powercenter-v10-domain-image-ubuntu14-04-3","powercenter-v10-update1-domain-image-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informationbuilders"},{"field":"Microsoft.Compute/imageOffer","in":["iway-big-data-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ingrammicro"},{"field":"Microsoft.Compute/imageOffer","in":["ingrammicroensimcentostrial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel"},{"field":"Microsoft.Compute/imageOffer","in":["lustre-cloud-edition-gs-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-bigdl"},{"field":"Microsoft.Compute/imageOffer","in":["bigdl-0815","bigdl__vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-fpga"},{"field":"Microsoft.Compute/imageOffer","in":["quartus_pro_opencl_sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intellicus-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["intellicus_bi_server_100_user_linux","intellicus_bi_server_10_user_linux","intellicus_bi_server_25_user_linux","intellicus_bi_server_50_user_linux","intellicus_bi_server_5_user_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intersystems"},{"field":"Microsoft.Compute/imageOffer","in":["intersystems-iris-single-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intigua"},{"field":"Microsoft.Compute/imageOffer","in":["intigua-agent-manager-3_7_0-trial","intigua-agent-manager-trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iquest"},{"field":"Microsoft.Compute/imageOffer","in":["keyhub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ishlangu-load-balancer-adc"},{"field":"Microsoft.Compute/imageOffer","in":["ishlangu-load-balancer-byol","ishlangu-load-balancer-is10","ishlangu-load-balancer-is100","ishlangu-load-balancer-is1000","ishlangu-load-balancer-is200","ishlangu-load-balancer-is5000","ishlangu-load-balancer-isbfg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"issp-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["ispocr"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"itelios"},{"field":"Microsoft.Compute/imageOffer","in":["magento2-on-zendserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jamcracker"},{"field":"Microsoft.Compute/imageOffer","in":["4632d5b4-feb0-4332-8452-f2e66133672f","jamcracker-cloudanalytics","jamcracker-cloudanalytics-version4","jamcracker-cloudanalytics-version5","jamcracker-csb-service-provider","jamcracker-csb-serviceprovider","jamcracker-csb-standard","jamcracker-csb-standard-v3","jamcracker-csb-standard-version4","jamcracker-hybrid-cloud-management-version4","jamcracker_cloud_control_appliance_version4","jsdnapp_csb_serviceprovider-version4","jsdnapp_hybrid","jsdnapp_hybrid_v3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jedox"},{"field":"Microsoft.Compute/imageOffer","in":["jedox-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jelastic"},{"field":"Microsoft.Compute/imageOffer","in":["jelastic-hybrid-paas-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetnexus"},{"field":"Microsoft.Compute/imageOffer","in":["dvwa","jetnexus-application-load-balancer","jetnexus-global-load-balancer","jetnexus-waf","zap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetware-srl"},{"field":"Microsoft.Compute/imageOffer","in":["caffe2","caffe_python_cpu","caffe_python_gpu","cockroachdb","lamp_optimized","lemp7_optimized","memcached","mongodb","mxnet_python","mysql","nodejs_nginx","percona_mongodb","percona_mysql","postgresql","pytorch","pytorch_cuda_notebook","pytorch_cuda_production","redis","redmine","tensorflow_cpu_notebook","tensorflow_cpu_production","tensorflow_cuda_notebook","tensorflow_cuda_production","tensorflow_python","theano_python","wordpress4_lemp7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jitterbit_integration"},{"field":"Microsoft.Compute/imageOffer","in":["jitterbit-harmony-agent"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jm-technology-inc"},{"field":"Microsoft.Compute/imageOffer","in":["smart-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"juniper-networks"},{"field":"Microsoft.Compute/imageOffer","in":["vmx-services-gateway-byol","vmx-services-gateway-byol-soltemp","vmx-virtual-router","vsrx-next-generation-firewall","vsrx-next-generation-firewall-payg","vsrx-next-generation-firewall-solution-templ-payg","vsrx-next-generation-firewall-solution-template"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaazing"},{"field":"Microsoft.Compute/imageOffer","in":["kaazing-kwic","kaazing-vpa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kali-linux"},{"field":"Microsoft.Compute/imageOffer","in":["kali-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kemptech"},{"field":"Microsoft.Compute/imageOffer","in":["kemp360central-byol","vlm-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kinetica"},{"field":"Microsoft.Compute/imageOffer","in":["kineticadbbyol","kineticadbpayasyougo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaspersky_lab"},{"field":"Microsoft.Compute/imageOffer","in":["kaspersky_secure_mail_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"knime"},{"field":"Microsoft.Compute/imageOffer","in":["knime-server-5-user_4-4-0","knime-server-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"krypc-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["krypccore"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leap-orbit"},{"field":"Microsoft.Compute/imageOffer","in":["leaporbitstoragebackedsftp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leostream-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["connection-broker"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquid-files"},{"field":"Microsoft.Compute/imageOffer","in":["liquidfiles"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquidware"},{"field":"Microsoft.Compute/imageOffer","in":["stratusphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"literatu"},{"field":"Microsoft.Compute/imageOffer","in":["literatu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"loadbalancer"},{"field":"Microsoft.Compute/imageOffer","in":["loadbalancer-org-load-balancer-for-azure","loadbalancer-org-load-balancer-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logsign"},{"field":"Microsoft.Compute/imageOffer","in":["logsignfocus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logtrust"},{"field":"Microsoft.Compute/imageOffer","in":["logtrust-log-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"looker"},{"field":"Microsoft.Compute/imageOffer","in":["looker-analytics-platform","looker-analytics-platform-326","looker-analytics-platform-5_6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"lti-lt-infotech"},{"field":"Microsoft.Compute/imageOffer","in":["trade-finance-blockchain"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"luminate-security"},{"field":"Microsoft.Compute/imageOffer","in":["luminate-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mapr-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["mapr52-base-dev","mapr60-base","mapr60-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mariadb"},{"field":"Microsoft.Compute/imageOffer","in":["mariadb-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"marklogic"},{"field":"Microsoft.Compute/imageOffer","in":["marklogic-9-byol","marklogic-developer-9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"massiveanalytic-"},{"field":"Microsoft.Compute/imageOffer","in":["oscarap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mathworks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["matlab-ref-arch-18a-v1-linux-disk","mps-ref-arch-18a-v1-linux-disk2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"matillion"},{"field":"Microsoft.Compute/imageOffer","in":["matillion-etl-snowflake"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mavinglobal"},{"field":"Microsoft.Compute/imageOffer","in":["mavin-business-trial","mavin-enterprise-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"meanio"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-enterprise-ready","linnovate-open-source-sla-pro","mean-machine-20","openideal3","redash"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"media3-technologies-llc"},{"field":"Microsoft.Compute/imageOffer","in":["cpan1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"memsql"},{"field":"Microsoft.Compute/imageOffer","in":["memsql-community-single-vm","memsql-enterprise-single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mendix"},{"field":"Microsoft.Compute/imageOffer","in":["mendix-docker","mendix-pro"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mfe_azure"},{"field":"Microsoft.Compute/imageOffer","in":["atd-mcafee","mcafee_vnsp_controller_for_azure","mcafee_vnsp_for_azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"micro-focus"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-avere"},{"field":"Microsoft.Compute/imageOffer","in":["vfxt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-batch"},{"field":"Microsoft.Compute/imageOffer","in":["centos-container","centos-container-rdma","ubuntu-server-container","ubuntu-server-container-rdma"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-compute"},{"field":"Microsoft.Compute/imageOffer","in":["azureconfidentialcompute"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["azureml","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftAzureSiteRecovery"},{"field":"Microsoft.Compute/imageOffer","in":["ASR-Hydration-VMs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftOSTC"},{"field":"Microsoft.Compute/imageOffer","in":["FreeBSD"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","in":["MLServer-CentOS","MLServer-RedHat","MLServer-Ubuntu","RServer-CentOS","RServer-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midfin"},{"field":"Microsoft.Compute/imageOffer","in":["mf_neon_cgw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midvision"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-datapower-virtual-edition-75","ibm-datapower-virtual-edition-76","ibm-datapower-virtual-edition-77","ibm-http-server","ibm-websphere-portal-server-85","ibm-websphere-portal-server-90","websphere-application-server-be","websphere-application-server-be-80","websphere-application-server-be-85","websphere-application-server-be-90","websphere-application-server-be-and-mq","websphere-application-server-lp","websphere-application-server-lp-16","websphere-application-server-lp-17","websphere-application-server-lp-18","websphere-application-server-nde","websphere-application-server-nde-80","websphere-application-server-nde-85","websphere-application-server-nde-90","websphere-mq","websphere-mq-75","websphere-mq-90","websphere-mq-91"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miraclelinux"},{"field":"Microsoft.Compute/imageOffer","in":["asianux-server-4-sp5","asianux-server-4-sp6","asianux-server-4-sp7","asianux-server-7-sp1","asianux-server-7-sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miri-infotech-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mobilab"},{"field":"Microsoft.Compute/imageOffer","in":["magento-wirecard-checkout"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moogsoft"},{"field":"Microsoft.Compute/imageOffer","in":["moogsoft-aiops"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moviemasher"},{"field":"Microsoft.Compute/imageOffer","in":["moviemasher"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","in":["SQL2017-RHEL7","SQL2017-RHEL73","SQL2017-SLES12SP2","SQL2017-Ubuntu1604","SQL2019-RHEL7","SQL2019-Ubuntu1604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mtnfog"},{"field":"Microsoft.Compute/imageOffer","in":["idyl-e3-entity-extraction-engine","prose-sentence-extraction-engine","renku-language-detection-engine","sonnet-tokenization-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mxhero"},{"field":"Microsoft.Compute/imageOffer","in":["mail2cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"my-com"},{"field":"Microsoft.Compute/imageOffer","in":["tarantool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"narrativescience"},{"field":"Microsoft.Compute/imageOffer","in":["narratives-for-power-bi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nasuni"},{"field":"Microsoft.Compute/imageOffer","in":["nasuni-nmc","nasuni_edge_appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ncbi"},{"field":"Microsoft.Compute/imageOffer","in":["ncbi-blast-2-3-0","ncbi-free-2-2-31"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nebbiolo-technologies-inc"},{"field":"Microsoft.Compute/imageOffer","in":["fog-system-manager","fogsm_basic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neo4j"},{"field":"Microsoft.Compute/imageOffer","in":["neo4j-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netapp"},{"field":"Microsoft.Compute/imageOffer","in":["netapp-altavault-cloud-integrated-storage-solution","netapp-oncommand-cloud-manager","netapp-ontap-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netgate"},{"field":"Microsoft.Compute/imageOffer","in":["netgate-pfsense-azure-fw-vpn-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netiq"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netscout"},{"field":"Microsoft.Compute/imageOffer","in":["netscout_virtual_ngeniusone_with_vscout","netscout_vstream"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netmail"},{"field":"Microsoft.Compute/imageOffer","in":["netmail-search"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netsweeper"},{"field":"Microsoft.Compute/imageOffer","in":["netsweeper6-0-6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netx"},{"field":"Microsoft.Compute/imageOffer","in":["simplehelp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neusoft-neteye"},{"field":"Microsoft.Compute/imageOffer","in":["neusoft-nisg-va-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nginxinc"},{"field":"Microsoft.Compute/imageOffer","in":["nginx-plus-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nicepeopleatwork"},{"field":"Microsoft.Compute/imageOffer","in":["youzana"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nodejsapi"},{"field":"Microsoft.Compute/imageOffer","in":["node-js-api"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"noobaa"},{"field":"Microsoft.Compute/imageOffer","in":["noobaa-hybrid-s3-archive-05","noobaa-multi-cloud-deduplication"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"northbridge-secure"},{"field":"Microsoft.Compute/imageOffer","in":["netconnect1","netconnectx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nubeva-inc"},{"field":"Microsoft.Compute/imageOffer","in":["controller","test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuco-networks"},{"field":"Microsoft.Compute/imageOffer","in":["aionnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuxeo"},{"field":"Microsoft.Compute/imageOffer","in":["nuxeo-6-lts","nuxeo-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nvidia"},{"field":"Microsoft.Compute/imageOffer","in":["ngc_azure_17_11"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"o2mc-real-time-data-platform"},{"field":"Microsoft.Compute/imageOffer","in":["o2mc-platform-app"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"oceanblue-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["obc-sdwan-solutions"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"omega-software"},{"field":"Microsoft.Compute/imageOffer","in":["ods_datastage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onyx-point-inc"},{"field":"Microsoft.Compute/imageOffer","in":["op-bnf-v1","op-bnf1_6-v1","op-bpnifi-v1","op-bpnifi16-v1","op-scc-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onapsis"},{"field":"Microsoft.Compute/imageOffer","in":["osp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"op5"},{"field":"Microsoft.Compute/imageOffer","in":["op5-monitor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"opencell"},{"field":"Microsoft.Compute/imageOffer","in":["meveo","meveo403sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"openvpn"},{"field":"Microsoft.Compute/imageOffer","in":["openvpnas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-WebLogic-Server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"orientdb"},{"field":"Microsoft.Compute/imageOffer","in":["orientdb-community-edition","orientdb-community-edition-2_2","orientdb-enterprise-edition-2_2","orientdb-enterprise-edition-2_2_17"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osirium-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["osirium-pxm-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osnexus"},{"field":"Microsoft.Compute/imageOffer","in":["quantastorvsav4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"paloaltonetworks"},{"field":"Microsoft.Compute/imageOffer","in":["panorama","vmseries1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"panzura-file-system"},{"field":"Microsoft.Compute/imageOffer","in":["azura-freedom-filer-v7110","panzura-cloud-filer","panzura-freedom-filer-7140-13222","panzura-freedom-filer-716-13549","panzura-freedom-filer-v7020"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"parasoft"},{"field":"Microsoft.Compute/imageOffer","in":["parasoft-service-virtualization"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"passlogy"},{"field":"Microsoft.Compute/imageOffer","in":["passlogic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"penta-security-systems-inc"},{"field":"Microsoft.Compute/imageOffer","in":["wapples"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"percona"},{"field":"Microsoft.Compute/imageOffer","in":["percona-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"postgres-pro"},{"field":"Microsoft.Compute/imageOffer","in":["postgres-pro-enterprise","postgres-pro-enterprise-10","postgres-pro-standard","postgres-pro-standard-10"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"plesk"},{"field":"Microsoft.Compute/imageOffer","in":["plesk-onyx-linux","solution-server-business","solution-server-wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prestashop"},{"field":"Microsoft.Compute/imageOffer","in":["prestashop16-lamp","ubuntu-base-for-prestashop"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prime-strategy"},{"field":"Microsoft.Compute/imageOffer","in":["kusanagi-77"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","in":["pivotal-gpdb-vm","pivotal-greenplum-images","pivotal-ops-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"process-one"},{"field":"Microsoft.Compute/imageOffer","in":["ejabberd-community-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"profecia"},{"field":"Microsoft.Compute/imageOffer","in":["full_disk_encryption_vm","project_tools_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"progelspa"},{"field":"Microsoft.Compute/imageOffer","in":["libra-esva-antispam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ptsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["ptaf-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pulse-secure"},{"field":"Microsoft.Compute/imageOffer","in":["pulse-connect-secure-vm","pulse-virtual-traffic-manager","pulse-virtual-traffic-manager-with-waf","pulse-virtual-traffic-manager-with-waf2","pulse-virtual-traffic-manager2","pulse-virtual-web-application-firewall","pulse-virtual-web-application-firewall2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"PuppetLabs"},{"field":"Microsoft.Compute/imageOffer","in":["PuppetEnterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"puppet"},{"field":"Microsoft.Compute/imageOffer","in":["puppet-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pydio"},{"field":"Microsoft.Compute/imageOffer","in":["pydio-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qore-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["qorus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qualysguard"},{"field":"Microsoft.Compute/imageOffer","in":["qualys-virtual-firewall-appliance","qualys-virtual-scanner-v23b","qualys-virtual-scanner-v24"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quasardb"},{"field":"Microsoft.Compute/imageOffer","in":["quasardb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qubole-inc"},{"field":"Microsoft.Compute/imageOffer","in":["qubole-data-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quest"},{"field":"Microsoft.Compute/imageOffer","in":["fve"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"racknap"},{"field":"Microsoft.Compute/imageOffer","in":["racknap-server","racknap-server-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radware"},{"field":"Microsoft.Compute/imageOffer","in":["radware-alteon-va"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radiant-logic"},{"field":"Microsoft.Compute/imageOffer","in":["radiantone-vms"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rancher"},{"field":"Microsoft.Compute/imageOffer","in":["rancheros"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapid7"},{"field":"Microsoft.Compute/imageOffer","in":["nexpose-scan-engine","rapid7-vm-console"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapidminer"},{"field":"Microsoft.Compute/imageOffer","in":["rapidminer_server_75","rapidminer_server_76","rapidminer_server_80","rapidminer_server_81"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"realm"},{"field":"Microsoft.Compute/imageOffer","in":["realm-mobile-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"reblaze"},{"field":"Microsoft.Compute/imageOffer","in":["rbzr-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HANA"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"relevance-lab"},{"field":"Microsoft.Compute/imageOffer","in":["rlcatalyst"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"remotelearner"},{"field":"Microsoft.Compute/imageOffer","in":["fully-supported-moodle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"revolution-analytics"},{"field":"Microsoft.Compute/imageOffer","in":["revolution-r-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RightScaleLinux"},{"field":"Microsoft.Compute/imageOffer","in":["RightImage-CentOS","RightImage-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RiverbedTechnology"},{"field":"Microsoft.Compute/imageOffer","in":["steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"riverbed"},{"field":"Microsoft.Compute/imageOffer","in":["riverbed-sccm-5-5-1","riverbed-steelcentral-appinternals","riverbed-steelhead-9-2","riverbed-steelhead-9-5-0","riverbed-steelhead-9-6-0","riverbed_steelconnect_gw","riverbed_steelconnect_sh","steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rocketsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["rocket-discover"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsa-security-llc"},{"field":"Microsoft.Compute/imageOffer","in":["rsa-nw-azure-arch","rsa-nw-azure-broker","rsa-nw-azure-con","rsa-nw-azure-esa","rsa-nw-azure-ldec","rsa-nw-azure-vlc","rsa-nw-suite-11","rsa-nw-suite-11-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsk-labs"},{"field":"Microsoft.Compute/imageOffer","in":["rsk-bamboo-beta-node","rsk-node-orchid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saama"},{"field":"Microsoft.Compute/imageOffer","in":["fluidanalyticsengine","insurancefraudanalytics","realworldevidence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saltstack"},{"field":"Microsoft.Compute/imageOffer","in":["centos65saltstackenterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalearc"},{"field":"Microsoft.Compute/imageOffer","in":["scalearc-for-mysql-paygo","scalearc-for-sql-server-pay-go","scalearc_mysql-server","scalearc_sql_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalegrid"},{"field":"Microsoft.Compute/imageOffer","in":["centos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sap"},{"field":"Microsoft.Compute/imageOffer","in":["hanaexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scality"},{"field":"Microsoft.Compute/imageOffer","in":["scalityconnecthourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"secureworks"},{"field":"Microsoft.Compute/imageOffer","in":["scwx-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"shadow-soft"},{"field":"Microsoft.Compute/imageOffer","in":["icinga","icinga2-5","icinga2-7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"signal-sciences"},{"field":"Microsoft.Compute/imageOffer","in":["signalscienceswpp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sightapps"},{"field":"Microsoft.Compute/imageOffer","in":["sightapps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"silver-peak-systems"},{"field":"Microsoft.Compute/imageOffer","in":["silver_peak_edgeconnect","silver_peak_vx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"simmachinesinc"},{"field":"Microsoft.Compute/imageOffer","in":["simmachines_vm_v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sinefa"},{"field":"Microsoft.Compute/imageOffer","in":["sinefa-probe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"skyarc"},{"field":"Microsoft.Compute/imageOffer","in":["mt6","mta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"smartmessage-autoflow"},{"field":"Microsoft.Compute/imageOffer","in":["martmessage-autoflow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"snapt-adc"},{"field":"Microsoft.Compute/imageOffer","in":["snaptadc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soasta"},{"field":"Microsoft.Compute/imageOffer","in":["cloudtest-lite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"softnas"},{"field":"Microsoft.Compute/imageOffer","in":["cloud_dev","mp_ce","mp_ent","mp_nas_byol","mp_nas_ep","mp_nas_gp","mp_nas_hp","mp_plat","private_offerings","softnas-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solanolabs"},{"field":"Microsoft.Compute/imageOffer","in":["solano-ci-private-beta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soha"},{"field":"Microsoft.Compute/imageOffer","in":["soha-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solar-security"},{"field":"Microsoft.Compute/imageOffer","in":["solar-incode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sonicwall-inc"},{"field":"Microsoft.Compute/imageOffer","in":["sonicwall-nsz-azure","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sophos"},{"field":"Microsoft.Compute/imageOffer","in":["sophos-xg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spagobi"},{"field":"Microsoft.Compute/imageOffer","in":["spagobi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spacecurve"},{"field":"Microsoft.Compute/imageOffer","in":["spacecurve-quickstart"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"splunk"},{"field":"Microsoft.Compute/imageOffer","in":["splunk-enterprise-base-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"src-solution"},{"field":"Microsoft.Compute/imageOffer","in":["pilot-things-onem2m-smart-network"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sqlstream"},{"field":"Microsoft.Compute/imageOffer","in":["com"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sphere3d"},{"field":"Microsoft.Compute/imageOffer","in":["snapcloud-byol","snapcloud-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackato-platform-as-a-service"},{"field":"Microsoft.Compute/imageOffer","in":["activestate-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackstorm"},{"field":"Microsoft.Compute/imageOffer","in":["stackstorm-2015-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"startekfingerprintmatch"},{"field":"Microsoft.Compute/imageOffer","in":["bioserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"steelhive"},{"field":"Microsoft.Compute/imageOffer","in":["steelhive_carbon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stonefly"},{"field":"Microsoft.Compute/imageOffer","in":["stonefly-cloud-drive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stormshield"},{"field":"Microsoft.Compute/imageOffer","in":["stormshield-network-security-for-cloud","stormshield-network-security-for-cloud-xl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"storreduce"},{"field":"Microsoft.Compute/imageOffer","in":["storreduce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stratumn"},{"field":"Microsoft.Compute/imageOffer","in":["indigo-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"streamsets"},{"field":"Microsoft.Compute/imageOffer","in":["streamsets-data-collector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"striim"},{"field":"Microsoft.Compute/imageOffer","in":["integrationforsqlserveronazure","integrationtoazurestorage","integrationtoeventhub","integrationtohdinsight"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"symantectest1"},{"field":"Microsoft.Compute/imageOffer","in":["cwpsazure-beta-01"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synack-inc"},{"field":"Microsoft.Compute/imageOffer","in":["synack-crowd-security-intelligence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synechron-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blockchain_tradefinance_quorum"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"syte"},{"field":"Microsoft.Compute/imageOffer","in":["syteoffer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tactic"},{"field":"Microsoft.Compute/imageOffer","in":["tactic-workflow-v001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talari-networks"},{"field":"Microsoft.Compute/imageOffer","in":["talari-networks-virtual-appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talena-inc"},{"field":"Microsoft.Compute/imageOffer","in":["talena_inc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tata_communications"},{"field":"Microsoft.Compute/imageOffer","in":["netfoundry_cloud_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tavendo"},{"field":"Microsoft.Compute/imageOffer","in":["crossbar_on_azure_ubuntu1404"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techdivision"},{"field":"Microsoft.Compute/imageOffer","in":["appserver-io-pe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techlatest"},{"field":"Microsoft.Compute/imageOffer","in":["ethereumdevkit","rippledevelopersuit"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"telepat"},{"field":"Microsoft.Compute/imageOffer","in":["free"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tenable"},{"field":"Microsoft.Compute/imageOffer","in":["tenable-nessus-6-byol","tenable-nessus-professional","tenablecorenessus","tenablecorewas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"teradata"},{"field":"Microsoft.Compute/imageOffer","in":["teradata-data-mover","teradata-data-mover-agent","teradata-data-mover-intellisphere","teradata-data-stream-controller","teradata-database-1510","teradata-database-1510-byol","teradata-database-1510-intellisphere","teradata-database-1510-v2","teradata-database-1610-intellisphere","teradata-database-1610-v2","teradata-database-1620","teradata-database-1620-byol","teradata-database-1620-intellisphere","teradata-database-enterprise","teradata-database-v1610","teradata-database-v1610-byol","teradata-ecosystem-manager","teradata-querygrid-manager","teradata-querygrid-manager-intellisphere","teradata-rest-services","teradata-server-management","teradata-viewpoint","teradata-viewpoint-intellisphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thales-vormetric"},{"field":"Microsoft.Compute/imageOffer","in":["ciphertrust-ckm","vormetric-dsm","vormetric-dsm-6-1-0","vormetric-tokenization-server","vts-2_2_0_2604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"things-board"},{"field":"Microsoft.Compute/imageOffer","in":["tb-pe-cassandra"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thoughtspot-inc"},{"field":"Microsoft.Compute/imageOffer","in":["thoughtspotvirtualmachine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tibco-software"},{"field":"Microsoft.Compute/imageOffer","in":["grid-server-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tig"},{"field":"Microsoft.Compute/imageOffer","in":["backup-as-a-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tigergraph"},{"field":"Microsoft.Compute/imageOffer","in":["tigergraph"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tmaxsoft"},{"field":"Microsoft.Compute/imageOffer","in":["tmax-jeusee","tmax-jeusse","tmax-webtobse"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tokyosystemhouse"},{"field":"Microsoft.Compute/imageOffer","in":["osscobol151j-pg961-centos72"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"torusware"},{"field":"Microsoft.Compute/imageOffer","in":["speedus-lite-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"totemo"},{"field":"Microsoft.Compute/imageOffer","in":["totemo-azr-tm6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"townsend-security"},{"field":"Microsoft.Compute/imageOffer","in":["alliance-key-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"trendmicro"},{"field":"Microsoft.Compute/imageOffer","in":["deep-security-vm","deep-security-vm-byol","iot-security-sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"truestack"},{"field":"Microsoft.Compute/imageOffer","in":["tsdc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tsa-public-service"},{"field":"Microsoft.Compute/imageOffer","in":["ckan-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tunnelbiz"},{"field":"Microsoft.Compute/imageOffer","in":["centos70-min","centos7optimizwithwordpress","centos7phpoptimizing","centos7phpoptimizingnginx","centos7phpoptimizwlaravel","centos7phpoptimizwosticket","centos7webserverwithwaf","centos7withaspdotnetcore2apache","centos7withjoomla","debian_web_server","fedora","fusio","linuxwithlimesurvey","networkmonitoringsystem","rimauwaf_cloud","ubuntu_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"twistlock"},{"field":"Microsoft.Compute/imageOffer","in":["twistlock"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"typesafe"},{"field":"Microsoft.Compute/imageOffer","in":["typesafe-reactive-maps-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubeeko"},{"field":"Microsoft.Compute/imageOffer","in":["hfactory-tools-for-hdinsight","hfactory-tools-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubercloud"},{"field":"Microsoft.Compute/imageOffer","in":["ansys-17-2-fluids-structures","ansys_182_test","comsol-multiphysics-v5-2","openfoam-v2dot3-centos-v6","openfoam-v3dot0","star-ccm-v10-04","star-ccm-v10-06-heeds-mdo-v2015","star-ccm-v12-00"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ulex"},{"field":"Microsoft.Compute/imageOffer","in":["voximal"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unifi-software"},{"field":"Microsoft.Compute/imageOffer","in":["unifi-data-catalog","unifi-dataplatform-2-3-3-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unitrends"},{"field":"Microsoft.Compute/imageOffer","in":["unitrends-enterprise-backup-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"usp"},{"field":"Microsoft.Compute/imageOffer","in":["unified-streaming-vod-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"varnish"},{"field":"Microsoft.Compute/imageOffer","in":["varnish-cache_","varnish-custom-statistics","varnish-plus-administration-and-statistics","varnish-plus-caching-engine-4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vaultive-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-security-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vbot"},{"field":"Microsoft.Compute/imageOffer","in":["vbot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"velocloud"},{"field":"Microsoft.Compute/imageOffer","in":["velocloud-virtual-edge","velocloud-virtual-edge-3x"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vidispine"},{"field":"Microsoft.Compute/imageOffer","in":["vidispine-content-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veritas"},{"field":"Microsoft.Compute/imageOffer","in":["cloudpoint-2-0-0","veritas-resiliency-platform-vhd-offer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veeam"},{"field":"Microsoft.Compute/imageOffer","in":["veeamhubimage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vigyanlabs-innovations-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["ipm-plus-energy-saver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"viptela"},{"field":"Microsoft.Compute/imageOffer","in":["viptela-vedge-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vizixiotplatformretail001"},{"field":"Microsoft.Compute/imageOffer","in":["vizix-iot-platform-retail-005"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vmturbo"},{"field":"Microsoft.Compute/imageOffer","in":["turbonomic","vmturbo64-opsmgr-5_3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vte"},{"field":"Microsoft.Compute/imageOffer","in":["slashdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vu-llc"},{"field":"Microsoft.Compute/imageOffer","in":["vu-app-server","vu-facerecogn","vu-fraudanalysis","vu-secureonboarding"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallarm"},{"field":"Microsoft.Compute/imageOffer","in":["wallarm-ng-waf-offer-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallix"},{"field":"Microsoft.Compute/imageOffer","in":["wallix-wabsuite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"watchguard-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["vm-firebox-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"waves"},{"field":"Microsoft.Compute/imageOffer","in":["waves"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"websense-apmailpe"},{"field":"Microsoft.Compute/imageOffer","in":["ap-data-email-gateway","forcepoint-email-security-85beta","triton-ap-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wmspanel"},{"field":"Microsoft.Compute/imageOffer","in":["nimble-streamer-centos","nimble-streamer-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wowza"},{"field":"Microsoft.Compute/imageOffer","in":["wowzastreamingengine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xfinityinc"},{"field":"Microsoft.Compute/imageOffer","in":["d3view-v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xtremedata"},{"field":"Microsoft.Compute/imageOffer","in":["dbx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"yellowfin"},{"field":"Microsoft.Compute/imageOffer","in":["yellowfin-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xyzrd-group-ou"},{"field":"Microsoft.Compute/imageOffer","in":["c73-zultys-mxvirtual"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"your-shop-online"},{"field":"Microsoft.Compute/imageOffer","in":["herefordshire-enterprise-platform-drupal-7","xenofile"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zend"},{"field":"Microsoft.Compute/imageOffer","in":["php-56-zend-server","php-zend-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"z1"},{"field":"Microsoft.Compute/imageOffer","in":["z1-securehub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zerodown_software"},{"field":"Microsoft.Compute/imageOffer","in":["bcaasforazure","stackbcaas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zoomdata"},{"field":"Microsoft.Compute/imageOffer","in":["zoomdata-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zscaler"},{"field":"Microsoft.Compute/imageOffer","in":["zscaler-private-access"]}]}]}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c901e756f9e2e56e","type":"Microsoft.Authorization/policyDefinitions","name":"c901e756f9e2e56e"},{"properties":{"displayName":"vmvmssfirstpartyidentificationtag_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-20T00:19:29.4243668Z","updatedBy":null,"updatedOn":null},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"tagName","description":"Opted + in for PKI"},"defaultValue":"platformsettings.host_environment.service.platform_optedin_for_rootcerts"},"tagValue":{"type":"String","metadata":{"displayName":"tagValue","description":"is + this the first party VM?"},"defaultValue":"true"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""}]},"then":{"effect":"append","details":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/c953c5a58a9ab221","type":"Microsoft.Authorization/policyDefinitions","name":"c953c5a58a9ab221"},{"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:00.4442389Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"tags[''NRMSVNetIntException'']","exists":"false"},{"value":"[resourceGroup().tags[''NRMSVNetIntException'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"not":{"field":"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin","notIn":["null",""]}}]},{"allOf":[{"field":"type","equals":"Microsoft.ContainerService/managedClusters"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"not":{"field":"Microsoft.ContainerService/managedClusters/networkProfile.networkPlugin","equals":"azure"}}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323","type":"Microsoft.Authorization/policyDefinitions","name":"cb9c916fd4b6c323"},{"properties":{"displayName":"nrms-batch-require-user-subscription-mode_2.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-08-08T22:25:06.8419431Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Batch/batchAccounts/pools"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"anyOf":[{"field":"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId","exists":"false"},{"field":"Microsoft.Batch/batchAccounts/pools/networkConfiguration.subnetId","in":["null",""]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cdd4d274005fb67b","type":"Microsoft.Authorization/policyDefinitions","name":"cdd4d274005fb67b"},{"properties":{"displayName":"nrms-nsg-rule-108_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:25.3178329Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"}},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","equals":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Any"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ce4b13eba037b5cc","type":"Microsoft.Authorization/policyDefinitions","name":"ce4b13eba037b5cc"},{"properties":{"displayName":"azuresecuritylinuxagent + extension autoupdate policy for vmss_1.3","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-09T20:11:42.4836235Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"not":{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent","equals":"false"}},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal","0001-com-ubuntu-server-eoan","0001-com-ubuntu-server-focal-daily","0001-com-ubuntu-pro-bionic","0001-com-ubuntu-pro-focal","0003-com-ubuntu-server-trusted-vm"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"20_04-lts*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"8"},{"field":"Microsoft.Compute/imageSKU","equals":"9"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Debian"},{"field":"Microsoft.Compute/imageOffer","in":["Debian-10"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-HA","RHEL-HA","RHEL-SAP-APPS","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-Linux-7","Oracle-WebLogic-Server"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SLES-12-SP5","SLES-15-SP2","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"gen*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1804-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1804-*"}]}]}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"AzureSecurityLinuxAgent"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Security.Monitoring"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmssName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmssName''), + ''/Microsoft.Azure.Security.Monitoring.AzureSecurityLinuxAgent'')]","type":"Microsoft.Compute/virtualMachineScaleSets/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Security.Monitoring","type":"AzureSecurityLinuxAgent","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":false,"settings":{"enableGenevaUpload":true},"protectedSettings":{}}}]},"parameters":{"vmssName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/d3d7dd009867a719","type":"Microsoft.Authorization/policyDefinitions","name":"d3d7dd009867a719"},{"properties":{"displayName":"audit + ssh auth on existing vmss_1.3","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMSSs use password-only authentication for + SSH on existing resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-25T22:01:41.6737137Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}}},"policyRule":{"if":{"allof":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration","exists":"True"},{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/d950db6f06d4cd0c","type":"Microsoft.Authorization/policyDefinitions","name":"d950db6f06d4cd0c"},{"properties":{"displayName":"audit + ssh auth on new resources_1.1","policyType":"Custom","mode":"All","description":"This + policy audits whether any Linux VMs use password-only authentication for SSH + on new resources.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-12-06T21:04:41.4948364Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","notEquals":""},{"field":"Microsoft.Compute/virtualMachines/osProfile.adminPassword","exists":"True"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"7isolutions"},{"field":"Microsoft.Compute/imageOffer","in":["sapp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"128technology"},{"field":"Microsoft.Compute/imageOffer","in":["128t_networking_platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"4psa"},{"field":"Microsoft.Compute/imageOffer","in":["voipnow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"a10networks"},{"field":"Microsoft.Compute/imageOffer","in":["a10-lightning-adc","a10-vthunder-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accellion"},{"field":"Microsoft.Compute/imageOffer","in":["kiteworks-by-accellion"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"abiquo"},{"field":"Microsoft.Compute/imageOffer","in":["abiquo-hybrid-cloud-34"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accops"},{"field":"Microsoft.Compute/imageOffer","in":["hysecure5050"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian_matrix"},{"field":"Microsoft.Compute/imageOffer","in":["actian_matrix"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actifio"},{"field":"Microsoft.Compute/imageOffer","in":["actifio-sky"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian-corp"},{"field":"Microsoft.Compute/imageOffer","in":["vector-community","vector-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Acronis"},{"field":"Microsoft.Compute/imageOffer","in":["storage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"activeeon"},{"field":"Microsoft.Compute/imageOffer","in":["activeeon-workload-scheduler"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aerospike"},{"field":"Microsoft.Compute/imageOffer","in":["aerospike-database-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"affinio"},{"field":"Microsoft.Compute/imageOffer","in":["platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aiscaler-cache-control-ddos-and-url-rewriting-"},{"field":"Microsoft.Compute/imageOffer","in":["aimobile-site-acceleration","aiprotect-ddos-firewall","aiscaler-traffic-manager-caching","aivideo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"akamai-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["enterprise-application-access"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alces-flight-limited"},{"field":"Microsoft.Compute/imageOffer","in":["alces-flight-compute-solo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alertlogic"},{"field":"Microsoft.Compute/imageOffer","in":["alert-logic-tm","alert-logic-wsm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alienvault"},{"field":"Microsoft.Compute/imageOffer","in":["unified-security-management-anywhere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alldigital-brevity"},{"field":"Microsoft.Compute/imageOffer","in":["alldigital-brevity-uploader"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altair-engineering-inc"},{"field":"Microsoft.Compute/imageOffer","in":["altair_hwulva"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altamira-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["lumify"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"antmedia"},{"field":"Microsoft.Compute/imageOffer","in":["ams_community_edition","ant_media_server_enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"apigee"},{"field":"Microsoft.Compute/imageOffer","in":["apigee-edge"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcara"},{"field":"Microsoft.Compute/imageOffer","in":["app360v43-001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcelerator"},{"field":"Microsoft.Compute/imageOffer","in":["appcelerator-arrow-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appex-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appistry"},{"field":"Microsoft.Compute/imageOffer","in":["genomepilot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appscale-marketplace"},{"field":"Microsoft.Compute/imageOffer","in":["appscale"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arangodb"},{"field":"Microsoft.Compute/imageOffer","in":["arangodb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arista-networks"},{"field":"Microsoft.Compute/imageOffer","in":["veos-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"array_networks"},{"field":"Microsoft.Compute/imageOffer","in":["array-networks-vapv"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"astadia-1148316"},{"field":"Microsoft.Compute/imageOffer","in":["astadia-ui-automation-tee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"atomicorp"},{"field":"Microsoft.Compute/imageOffer","in":["secure-os","secure-ubuntu-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"audiocodes"},{"field":"Microsoft.Compute/imageOffer","in":["mediantsessionbordercontroller"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"auriq-systems"},{"field":"Microsoft.Compute/imageOffer","in":["essentia"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"awingu"},{"field":"Microsoft.Compute/imageOffer","in":["awingu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aviatrix-systems"},{"field":"Microsoft.Compute/imageOffer","in":["aviatrix-cloud-services","aviatrix-companion-gateway","aviatrix-companion-gateway-v2","aviatrix-vpn-gw","aviatrix_multi_cloud_service","aviatrix_openvpn_service","aviatrix_openvpn_service10","aviatrix_openvpn_service25","aviatrix_openvpn_service50"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"avi-networks"},{"field":"Microsoft.Compute/imageOffer","in":["avi-vantage-adc","internal-avi-vantage-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"axway"},{"field":"Microsoft.Compute/imageOffer","in":["axway-mailgate-secure-collaboration-advanced","axway-mailgate-secure-collaboration-premium","axway-mailgate-secure-collaboration-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azul"},{"field":"Microsoft.Compute/imageOffer","in":["azul-zulu-ubuntu-1804"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azurecyclecloud"},{"field":"Microsoft.Compute/imageOffer","in":["azure-cyclecloud-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"AzureDatabricks"},{"field":"Microsoft.Compute/imageOffer","in":["Databricks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baas-techbureau"},{"field":"Microsoft.Compute/imageOffer","in":["b1327623-d29b-4cc1-b833-85067dcc7bce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baffle-io"},{"field":"Microsoft.Compute/imageOffer","in":["baffle-application-data-protection"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"balabit"},{"field":"Microsoft.Compute/imageOffer","in":["balabit-shell-control-box","psm","sps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"barracudanetworks"},{"field":"Microsoft.Compute/imageOffer","in":["barracuda-app-sec-control-center","barracuda-email-security-gateway","barracuda-ng-cc","barracuda-ng-firewall","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"basho"},{"field":"Microsoft.Compute/imageOffer","in":["riak-2-0-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","in":["autodesk-maya-arnold-centos73","rendering-centos73"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bdy"},{"field":"Microsoft.Compute/imageOffer","in":["buddy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Bitnami"},{"field":"Microsoft.Compute/imageOffer","in":["3-4","abantecart","activemq","akeneo","alfrescocommunity","apachesolr","artifactory","canvaslms","cassandra","civicrm","cmsmadesimple","codiad","concrete5","consul","coppermine","couchdb","diaspora","discourse","djangostack","dokuwiki","dolibarr","DreamFactory","drupal","elastic-search","elk","erpnext","espocrm","etcd","eXo-Platform","exoplatform","fatfreecrm","ghost","gitlab","grafana","hadoop","hhvmstack","hordegroupwarewebmail","jasperreports","jenkins","joomla","jrubystack","kafka","kong","kubernetessandbox","lampstack","lappstack","letschat","liferay","limesurvey","livehelperchat","magento","mahara","mantis","mariadb","mattermost","mautic","mean","mediawiki","memcached","modx","mongodb","moodle","multicraft","mybb","mysql","nats","neo4j","neos","nginxstack","noalyss","nodejs","ocportal","odoo","openatrium","opencart","openedx","openfire","openproject","orangehrm","osclass","owncloud","oxid-eshop","parseserver","phabricator","phpbb","phplist","pimcore","piwik","plone","pootle","postgresql","prestashop","processmakerenterprise","processmakeropensourceedition","processwire","publify","rabbitmq","redash","redis","redmine","redmineplusagile","reportserver","reportserverenterprise","resourcespace","reviewboard","reviewboardpowerpack","roundcube","rubystack","seopanel","shopware","silverstripe","simplemachinesforum","sonarqube","spree","subversion","suitecrm","tensorflowserving","testlink","tikiwikicmsgroupware","tinytinyrss","tom-cat","trac","typo3","weblate","webmailpro","wildfly","wordpress","wordpress-multisite","wordpresspro","x2enginesalescrm","xoops","youtrack","zookeeper","zurmo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"black-duck-software"},{"field":"Microsoft.Compute/imageOffer","in":["blackduck_hub_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blk-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blk-io-erc-20-rest-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockapps"},{"field":"Microsoft.Compute/imageOffer","in":["strato-blockchain-base-template-latest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockstack"},{"field":"Microsoft.Compute/imageOffer","in":["blockstack-core-v14"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockchain-foundry"},{"field":"Microsoft.Compute/imageOffer","in":["syscoin-api","syscoin-full-node","syscoin-price-peg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bloombase"},{"field":"Microsoft.Compute/imageOffer","in":["bloombase-storesafe-3_4_7_0_el7_x86_64"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluecat"},{"field":"Microsoft.Compute/imageOffer","in":["bluecat-bam-for-azure","bluecat-dns-for-azure","bluecat-edge-service-point-vm-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluetalon"},{"field":"Microsoft.Compute/imageOffer","in":["bluetalon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"brocade_communications"},{"field":"Microsoft.Compute/imageOffer","in":["brocade-virtual-traffic-manager","brocade-virtual-traffic-manager-with-waf-module","brocade-virtual-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bt-americas-inc"},{"field":"Microsoft.Compute/imageOffer","in":["diamondip-sapphire-ev10","diamondip-sapphire-ev20","diamondip-sapphire-v10","diamondip-sapphire-v20","diamondip-sapphire-v5","diamondip-sapphire-vcaa20"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"buddhalabs"},{"field":"Microsoft.Compute/imageOffer","in":["sles_12_pci"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"carto"},{"field":"Microsoft.Compute/imageOffer","in":["cartobuilder2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cask"},{"field":"Microsoft.Compute/imageOffer","in":["cdap-cloud-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","Ubuntu_Core"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cavirin"},{"field":"Microsoft.Compute/imageOffer","in":["cavirin-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cautelalabs"},{"field":"Microsoft.Compute/imageOffer","in":["log_management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"celum-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["celumdam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cds"},{"field":"Microsoft.Compute/imageOffer","in":["cds-data-migration-solution-for-legacy-to-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-6-v2-0-2-l1","cis-centos-7-v2-1-1-l1","cis-oracle-linux-6-v1-0-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-rhel-6-v2-0-2-l1","cis-rhel-7-v2-2-0-l1","cis-suse-linux-11-v2-0-0-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1404-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"certivox"},{"field":"Microsoft.Compute/imageOffer","in":["sso-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cfd-direct"},{"field":"Microsoft.Compute/imageOffer","in":["cfd-direct-from-the-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chain"},{"field":"Microsoft.Compute/imageOffer","in":["chain-core-developer-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"checkpoint"},{"field":"Microsoft.Compute/imageOffer","in":["check-point-r77-10","check-point-vsec-r80","check-point-vsec-r80-blink","sg2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chef-software"},{"field":"Microsoft.Compute/imageOffer","in":["chef-automate-vm-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"circleci"},{"field":"Microsoft.Compute/imageOffer","in":["circleci-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cires21"},{"field":"Microsoft.Compute/imageOffer","in":["c21l-enc","c21l-mos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cisco"},{"field":"Microsoft.Compute/imageOffer","in":["cisco-asav","cisco-csr-1000v","cisco-ftdv","cisco-meraki-vmx100","cisco-ngfwv-vm-test-unsupported","cisco_cloud_vedge_17_2_4","cos65","cos72","cos72_main_dev","uos14","vwaas-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"citrix"},{"field":"Microsoft.Compute/imageOffer","in":["citrix-sd-wan-opt","netscaler-ma-service-agent-120","netscaler-ma-service-agent-121","netscaler-sd-wan","netscaler-vpx","netscalervpx-120","netscalervpx-121","netscalervpx110-6531","netscalervpx111"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clear-linux-project"},{"field":"Microsoft.Compute/imageOffer","in":["clear-linux-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clouber"},{"field":"Microsoft.Compute/imageOffer","in":["cuber","cws","mcenter"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-cruiser"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-cruiser-16"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees"},{"field":"Microsoft.Compute/imageOffer","in":["jenkins-enterprise","jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees-enterprise-jenkins"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbees-jenkins-enterprise","cloudbees-jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbolt-software"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbolt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudboost"},{"field":"Microsoft.Compute/imageOffer","in":["cloudboost"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudenablers-inc"},{"field":"Microsoft.Compute/imageOffer","in":["corestack"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","in":["squid-proxy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","in":["cloudera-altus-centos-os","cloudera-centos-6","cloudera-centos-os","test-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlanes"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-video-accelerator-nfs","cloudlanes-cloud-backup-accelerator-vtl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlink"},{"field":"Microsoft.Compute/imageOffer","in":["cloudlink-securevm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudplan-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["cloudplan_pcn_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["paladion_ondemand_nextgen_firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsoft"},{"field":"Microsoft.Compute/imageOffer","in":["cloudsoft-amp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clustrix"},{"field":"Microsoft.Compute/imageOffer","in":["clustrixdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codelathe"},{"field":"Microsoft.Compute/imageOffer","in":["codelathe-filecloud-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codenvy"},{"field":"Microsoft.Compute/imageOffer","in":["codenvy-on-prem"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cognosys"},{"field":"Microsoft.Compute/imageOffer","in":["1-click-secured-joomla-on-centos-7-3","1-click-secured-joomla-on-ubuntu-1404-lts","1-click-secured-joomla-on-ubuntu-1604-lts","1-click-secured-joomla-on-ubuntu-1804-lts","centos-6-9","centos-7-3","centos-7-4","centos-7-5","deploy-a-secured-modx-on-ubuntu-14-04-lts","deploy-a-secured-silverstripe-on-ubuntu-14-04-lts","hardened-mysql-5-6-on-centos-7-3","hardened-mysql-5-6-on-ubu-1404-lts","hardened-mysql-5-7-on-centos-7-3","hardened-mysql-5-7-on-ubu-1404-lts","hardened-postgresql-on-ubu-1404-lts","invoice-ninja-2-5-1-1-on-ubuntu-1404","jruby-on-ubuntu-14-04-lts","low-latency-broadcasting-server-for-live-events","owncloud-9-with-lamp-stack-on-ubuntu-1404","piwigogallerys-ubuntu_14-04_lts","sec1011-dokuwiki-on-ubuntu-1404","sec1013-elasticsearch-on-ubuntu-1404","sec1014-opencart-on-ubuntu-1404","sec1015-orangehrm-on-ubuntu-1404","sec1016-nodejs-server-on-ubuntu-1404","sec1018-haproxy-on-ubuntu-1404","sec1019-secured-tomcat-on-ubuntu-1404","sec1020-phpbb-on-hardened-ubuntu-1404","sec1021-mybb-on-hardened-ubuntu-1404","sec1022-sugarcrm-on-ubuntu-1404","sec1023-moodle-on-ubuntu-1404","sec1024_magento-on-ubuntu-1404","sec1025-secured-drupal-on-ubuntu-1404","sec1027-secured-wordpress-on-ubuntu-1404","sec1028-secured-lamp-sever-on-ubuntu-1404","sec1029-secured-mediawiki-on-ubuntu-1404","sec1030-secured-subversion-on-ubuntu-1404","sec1031-secured-passenger-nginx-on-ubuntu-1404","sec1033-secured-piwik-on-ubuntu-1404","sec1034-secured-pligg-on-ubuntu-1404","sec1035-secured-jenkins-on-ubuntu-1404","sec1036-secured-postgresql-on-ubuntu-1404","secure-cloud-lamp-ubuntu-1404","secured-abantecart-on-centos","secured-abantecart-on-ubuntu-14-04-lts","secured-acquia-drupal-on-centos","secured-acquiadurpal-on-ubuntu-14-04-lts","secured-apachesolr-on-centos","secured-apachesolr-on-ubuntu-14-04-lts","secured-arartifactory-on-centos","secured-artifactory-on-ubuntu-14-04-lts","secured-cakephp-on-centos","secured-cakephp-on-ubuntu-14-04-lts","secured-cms-made-simple-on-centos","secured-cms-made-simple-on-ubuntu-14-04-lts","secured-codiad-on-centos","secured-codiad-on-ubuntu-14-04-lts","secured-cogdam-on-centos","secured-cogdam-on-ubuntu-14-04-lts","secured-concrete5-on-centos","secured-concrete5-on-ubuntu-14-04-lts","secured-coppermine-on-centos","secured-coppermine-on-ubuntu-14-04-lts","secured-crushftp-on-centos","secured-crushftp-on-ubuntu-14-04-lts","secured-django-on-centos","secured-django-on-ubuntu-14-04-lts","secured-dokuwiki-on-centos","secured-dolibarr-on-centos","secured-dolivbarr-on-ubuntu-14-04-lts","secured-drupal-on-centos","secured-elasticsearch-on-centos","secured-enterprise-nginx-varnish-haproxy-php","secured-espocrm-on-centos","secured-espocrm-on-ubuntu-14-04-lts","secured-exoplatform-on-centos","secured-exoplatform-on-ubuntu-14-04-lts","secured-ghost-on-centos","secured-ghost-on-ubuntu-14-04-lts","secured-gradle-on-centos","secured-gradle-on-ubuntu-14-04-lts","secured-haproxy-on-centos","secured-invoice-ninja-on-centos","secured-jboss-as-on-centos","secured-jbossas-on-ubuntu-14-04-lts","secured-jenkins-on-centos","secured-jruby-on-cento","secured-lamp-on-centos","secured-lamp-on-centos-m10","secured-lapp-on-centos","secured-lapp-on-ubuntu-14-04-lts","secured-lemp-sever-on-ubuntu-1404","secured-lime-survey-on-centos","secured-limesurvey-on-ubuntu-1404","secured-live-helper-chat-on-centos","secured-livehelperchat-on-ubuntu-14-04-lts","secured-magento-on-centos","secured-mahara-on-centos","secured-mahara-on-ubuntu-14-04-lts","secured-mantis-on-centos","secured-mantis-on-ubuntu-14-04-lts","secured-mariadb-on-ubuntu-16-04","secured-mautic-on-centos","secured-mautic-on-ubuntu-14-04-lts","secured-media-wiki-on-centos","secured-modx-on-centos","secured-moodle-on-centos","secured-ngnix-on-centos-7-3","secured-ngnix-on-ubuntu-14-04-lts","secured-ngnix-on-ubuntu-16-04-lts","secured-noalyss-on-centos","secured-noalyss-on-ubuntu-14-04-lts","secured-nodejs-on-centos","secured-occlass-on-ubuntu-14-04-lts","secured-ocportal-on-ubuntu-14-04-lts","secured-open-cart-on-centos","secured-orangehrm-on-centos","secured-osclass-on-centos","secured-owncloud-on-centos","secured-oxid-eshop-on-centos","secured-oxideshop-on-ubuntu-14-04-lts","secured-passenger-nginx-on-centos","secured-piwigo-gallery-on-centos","secured-plone-on-centos","secured-plone-on-ubuntu-14-04-lts","secured-prestashop-on-centos","secured-prestashop-on-ubuntu-14-04-lts","secured-railo-on-ubuntu-14-04-lts","secured-redis-on-centos","secured-redis-on-ubuntu-1404","secured-redmine-on-centos","secured-redmine-on-ubuntu-14-04-lts","secured-redmineagile-on-ubuntu-14-04-lts","secured-report-server-on-centos","secured-reportserverent-on-ubuntu-14-04-lts","secured-resource-space-on-centos","secured-resourcespace-on-ubuntu-14-04-lts","secured-round-cube-on-centos","secured-roundcube-on-ubuntu-14-04-lts","secured-ruby-on-centos","secured-ruby-on-ubuntu-14-04-lts","secured-seopanel-on-centos","secured-seopanel-on-ubuntu-14-04-lts","secured-silverstripe-on-centos","secured-simple-invoice-on-centos","secured-simple-machines-on-centos","secured-simple-machines-on-ubuntu-14-04-lts","secured-simpleinvoice-on-ubuntu-14-04-lts","secured-subversion-on-centos","secured-suitecrm-on-centos","secured-suitecrm-on-ubuntu-14-04-lts","secured-test-link-on-centos","secured-testlink-on-ubuntu-14-04-lts","secured-thinkup-on-centos","secured-thinkup-on-ubuntu-14-04-lts","secured-tikiwikicms-on-centos","secured-tikiwikicms-on-ubuntu-14-04-lts","secured-tiny-tiny-rss-on-centos","secured-tinytinyrss-on-ubuntu-14-04-lts","secured-tomcat-on-centos","secured-trac-on-centos","secured-trac-on-ubuntu-14-04-lts","secured-typo3-on-centos","secured-typo3-on-ubuntu-14-04-lts","secured-varnish-on-centos","secured-varnish-on-ubuntu-1404","secured-wildfly-on-centos","secured-wildfly-on-ubuntu-14-04-lts","secured-wordpress-on-centos-7-3","secured-wordpress-on-ubuntu-16-04-lts","secured-x-cart-on-ubuntu-14-04-lts","secured-xoops-on-centos","secured-xoops-on-ubuntu-14-04-lts","secured-zurmo-on-centos","secured-zurmo-on-ubuntu-14-04-lts","suse15","ubuntu-14-04-lts","ubuntu-16-04-lts","ubuntu-17-04-high-performance-hardened-tcp-bbr","ubuntu-18-04","ubuntu-18-04-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesity"},{"field":"Microsoft.Compute/imageOffer","in":["cohesity-cloudtd-tool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesive"},{"field":"Microsoft.Compute/imageOffer","in":["vns3_4x_network_security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"confluentinc"},{"field":"Microsoft.Compute/imageOffer","in":["confluentplatform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"consensys"},{"field":"Microsoft.Compute/imageOffer","in":["truffle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"convertigo"},{"field":"Microsoft.Compute/imageOffer","in":["convertigo-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"corda"},{"field":"Microsoft.Compute/imageOffer","in":["corda"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"CoreOS"},{"field":"Microsoft.Compute/imageOffer","in":["CoreOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"couchbase"},{"field":"Microsoft.Compute/imageOffer","in":["couchbase-server-enterprise","couchbase-sync-gateway-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cryptzone"},{"field":"Microsoft.Compute/imageOffer","in":["appgate-appliance-3_2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cybernetica-as"},{"field":"Microsoft.Compute/imageOffer","in":["uxp-securityserver-connector","uxp-securityserver_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cyxtera"},{"field":"Microsoft.Compute/imageOffer","in":["appgatesdp-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataart"},{"field":"Microsoft.Compute/imageOffer","in":["devicehive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"databricks"},{"field":"Microsoft.Compute/imageOffer","in":["spfqogzeculbhdh"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datalayer"},{"field":"Microsoft.Compute/imageOffer","in":["datalayer-notebook"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datastax"},{"field":"Microsoft.Compute/imageOffer","in":["datastax-enterprise","datastax-enterprise-non-production-use-only"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datasunrise"},{"field":"Microsoft.Compute/imageOffer","in":["datasunrise-database-security-suite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataiku"},{"field":"Microsoft.Compute/imageOffer","in":["dataiku-data-science-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datometry"},{"field":"Microsoft.Compute/imageOffer","in":["hyper-q"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dellemc"},{"field":"Microsoft.Compute/imageOffer","in":["dell-emc-avamar-virtual-edition","dell-emc-datadomain-management-center","dell-emc-datadomain-virtual-edition","dell-emc-datadomain-virtual-edition-v4","dell-emc-networker-virtual-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"delphix"},{"field":"Microsoft.Compute/imageOffer","in":["delphix_dynamic_data_platform","omniosce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denodo"},{"field":"Microsoft.Compute/imageOffer","in":["denodo-platform","denodo-platform-7_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denyall"},{"field":"Microsoft.Compute/imageOffer","in":["denyall-rweb","denyall-vulnerability-manager","denyall-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dgsecure"},{"field":"Microsoft.Compute/imageOffer","in":["dgsecure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"diladele"},{"field":"Microsoft.Compute/imageOffer","in":["websafety"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dimensionalmechanics-inc"},{"field":"Microsoft.Compute/imageOffer","in":["neopulse-ai-studio","neopulse-query-runtime"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"docker"},{"field":"Microsoft.Compute/imageOffer","in":["docker-ce","docker-ce-edge","docker-datacenter-custom","docker-ee","docker-ee-basic","docker4azure","docker4azure-cs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dome9"},{"field":"Microsoft.Compute/imageOffer","in":["dome9ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drizti"},{"field":"Microsoft.Compute/imageOffer","in":["hpcbox-ansys-19-cluster-master","hpcbox-cluster-compute-node","hpcbox-cluster-cuda-node","hpcbox-cluster-gpu-node","hpcbox-docker-cluster-master","hpcbox-openfoam-cluster-master","hpcbox-su2-cluster-master"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drone"},{"field":"Microsoft.Compute/imageOffer","in":["drone"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dyadic_security"},{"field":"Microsoft.Compute/imageOffer","in":["dyadic_sec","ukc_image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dynatrace"},{"field":"Microsoft.Compute/imageOffer","in":["ruxit-managed-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"eastwind-networks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["eastwind-ixia-sensor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"egnyte"},{"field":"Microsoft.Compute/imageOffer","in":["egnyte-connect"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elasticbox"},{"field":"Microsoft.Compute/imageOffer","in":["elasticbox-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"electric-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["electricflowce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elfiqnetworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"emercoin"},{"field":"Microsoft.Compute/imageOffer","in":["emercoin"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprise-ethereum-alliance"},{"field":"Microsoft.Compute/imageOffer","in":["quorum-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprisedb-corp"},{"field":"Microsoft.Compute/imageOffer","in":["edb-postgres-ark"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"equalum"},{"field":"Microsoft.Compute/imageOffer","in":["equalum-vm-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"esdenera"},{"field":"Microsoft.Compute/imageOffer","in":["esdenera-firewall-3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ethereum"},{"field":"Microsoft.Compute/imageOffer","in":["ethereum-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"evostream-inc"},{"field":"Microsoft.Compute/imageOffer","in":["ems-for-template","ems-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"exasol"},{"field":"Microsoft.Compute/imageOffer","in":["exasol-analytics-database-byol","exasolution-analytic-database"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"falconstorsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["fss-v9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"f5-networks"},{"field":"Microsoft.Compute/imageOffer","in":["f5-big-ip-adc","f5-big-ip-advanced-waf","f5-big-ip-best","f5-big-ip-better","f5-big-ip-byol","f5-big-ip-good","f5-big-ip-per-app-ve","f5-big-iq","f5-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"filecatalyst"},{"field":"Microsoft.Compute/imageOffer","in":["filecatalyst-direct-per-hr-billing","filecatalyst-direct-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"firehost"},{"field":"Microsoft.Compute/imageOffer","in":["firehost_armor","firehost_armor_ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flexify-io"},{"field":"Microsoft.Compute/imageOffer","in":["single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flashgrid-inc"},{"field":"Microsoft.Compute/imageOffer","in":["flashgrid-racnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"foghorn-systems"},{"field":"Microsoft.Compute/imageOffer","in":["foghorn-edge-device-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forcepoint-llc"},{"field":"Microsoft.Compute/imageOffer","in":["forcepoint-ngfw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forscene"},{"field":"Microsoft.Compute/imageOffer","in":["forscene-edgeserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortycloud"},{"field":"Microsoft.Compute/imageOffer","in":["fortycloud-gw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortinet"},{"field":"Microsoft.Compute/imageOffer","in":["fortinet-fortianalyzer","fortinet-fortimanager","fortinet_fortigate-vm_v5","fortinet_fortimail","fortinet_fortivoice","fortinet_fortiweb-vm_v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fujitsu_fast"},{"field":"Microsoft.Compute/imageOffer","in":["fep10-rh7-test","feptest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gemalto-safenet"},{"field":"Microsoft.Compute/imageOffer","in":["safenet-keysecure-k170v","safenet-protectv","safenet-protectv-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gigamon-inc"},{"field":"Microsoft.Compute/imageOffer","in":["gigamon-fm-5_3_01","gigamon-fm-5_3_01_hourly","gigamon-fm-5_4_00","gigamon-fm-5_4_00_hourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gitlab"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-ce","gitlab-ee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"GitHub"},{"field":"Microsoft.Compute/imageOffer","in":["GitHub-Enterprise","githubenterprise-test-publishing"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"great-software-laboratory-private-limited"},{"field":"Microsoft.Compute/imageOffer","in":["xid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"greensql"},{"field":"Microsoft.Compute/imageOffer","in":["greensql-database-security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gridgain"},{"field":"Microsoft.Compute/imageOffer","in":["gridgain-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"guardicore"},{"field":"Microsoft.Compute/imageOffer","in":["guardicorecentra","infection_monkey"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haivision"},{"field":"Microsoft.Compute/imageOffer","in":["haivision-media-gateway-1-2","haivision-media-gateway-1-5","haivision-media-gateway-1-6-2","media-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"h2o-ai"},{"field":"Microsoft.Compute/imageOffer","in":["h2o-driverles-ai","h2o-driverless-ai","h2o-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haproxy-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hapee-rhel","hapee-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"harpaitalia"},{"field":"Microsoft.Compute/imageOffer","in":["mcuboenergy","yg","yougreen_trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hcl-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hcl17cp1104"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"heimdall-data"},{"field":"Microsoft.Compute/imageOffer","in":["heimdall-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"help-systems"},{"field":"Microsoft.Compute/imageOffer","in":["goanywheremftubuntulinux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hewlett-packard"},{"field":"Microsoft.Compute/imageOffer","in":["hpe-helion-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hillstone-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudedge-virtual-ngfw-advanced-edition","cloudedge-virtual-ngfw-standard-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hortonworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbreak-for-hortonworks-data-platform","hortonworks-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hitachi-solutions"},{"field":"Microsoft.Compute/imageOffer","in":["credeon-sfs-and-kms-for-sharepoint-online","credeonsecurefull-textsearch1_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hpe"},{"field":"Microsoft.Compute/imageOffer","in":["storeoncevsa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"huawei"},{"field":"Microsoft.Compute/imageOffer","in":["euleros-v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hyperglance"},{"field":"Microsoft.Compute/imageOffer","in":["hyperglance-dynamic-topology"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hypergrid"},{"field":"Microsoft.Compute/imageOffer","in":["hyperform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hytrust"},{"field":"Microsoft.Compute/imageOffer","in":["hytrust-keycontrol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ibm"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-security-guardium-multi-cloud","qradar_security_analytics"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iaansys"},{"field":"Microsoft.Compute/imageOffer","in":["iaansys-magento"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iboss"},{"field":"Microsoft.Compute/imageOffer","in":["iboss-14600-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imaginecommunications"},{"field":"Microsoft.Compute/imageOffer","in":["cloudxtream-cdvr","cloudxtream-dai-vms","telurio-aim"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imperva"},{"field":"Microsoft.Compute/imageOffer","in":["imperva-dam-v13","securesphere-waf","securesphere-waf-for-azr","securesphere-waf-v12","securesphere-waf-v13"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"infoblox"},{"field":"Microsoft.Compute/imageOffer","in":["infoblox-vnios-te-v1420"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informatica"},{"field":"Microsoft.Compute/imageOffer","in":["bdm10-1-1-u2","big-data-management-10-2","big-data-management-10-2-1","data_accelerator_for_azure_byol","data_quality_10_1_1_rhel_7_3_byol","eic","ics-byol","ics-payg-ubuntu","platform_10_1_1_multi_node_domain_rhel-7-3_byol","platform_10_2_hf1_domain_rhel-7-3_byol","powercenter-v10-domain-image-ubuntu14-04-3","powercenter-v10-update1-domain-image-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informationbuilders"},{"field":"Microsoft.Compute/imageOffer","in":["iway-big-data-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ingrammicro"},{"field":"Microsoft.Compute/imageOffer","in":["ingrammicroensimcentostrial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel"},{"field":"Microsoft.Compute/imageOffer","in":["lustre-cloud-edition-gs-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-bigdl"},{"field":"Microsoft.Compute/imageOffer","in":["bigdl-0815","bigdl__vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-fpga"},{"field":"Microsoft.Compute/imageOffer","in":["quartus_pro_opencl_sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intellicus-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["intellicus_bi_server_100_user_linux","intellicus_bi_server_10_user_linux","intellicus_bi_server_25_user_linux","intellicus_bi_server_50_user_linux","intellicus_bi_server_5_user_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intersystems"},{"field":"Microsoft.Compute/imageOffer","in":["intersystems-iris-single-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intigua"},{"field":"Microsoft.Compute/imageOffer","in":["intigua-agent-manager-3_7_0-trial","intigua-agent-manager-trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iquest"},{"field":"Microsoft.Compute/imageOffer","in":["keyhub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ishlangu-load-balancer-adc"},{"field":"Microsoft.Compute/imageOffer","in":["ishlangu-load-balancer-byol","ishlangu-load-balancer-is10","ishlangu-load-balancer-is100","ishlangu-load-balancer-is1000","ishlangu-load-balancer-is200","ishlangu-load-balancer-is5000","ishlangu-load-balancer-isbfg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"issp-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["ispocr"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"itelios"},{"field":"Microsoft.Compute/imageOffer","in":["magento2-on-zendserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jamcracker"},{"field":"Microsoft.Compute/imageOffer","in":["4632d5b4-feb0-4332-8452-f2e66133672f","jamcracker-cloudanalytics","jamcracker-cloudanalytics-version4","jamcracker-cloudanalytics-version5","jamcracker-csb-service-provider","jamcracker-csb-serviceprovider","jamcracker-csb-standard","jamcracker-csb-standard-v3","jamcracker-csb-standard-version4","jamcracker-hybrid-cloud-management-version4","jamcracker_cloud_control_appliance_version4","jsdnapp_csb_serviceprovider-version4","jsdnapp_hybrid","jsdnapp_hybrid_v3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jedox"},{"field":"Microsoft.Compute/imageOffer","in":["jedox-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jelastic"},{"field":"Microsoft.Compute/imageOffer","in":["jelastic-hybrid-paas-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetnexus"},{"field":"Microsoft.Compute/imageOffer","in":["dvwa","jetnexus-application-load-balancer","jetnexus-global-load-balancer","jetnexus-waf","zap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetware-srl"},{"field":"Microsoft.Compute/imageOffer","in":["caffe2","caffe_python_cpu","caffe_python_gpu","cockroachdb","lamp_optimized","lemp7_optimized","memcached","mongodb","mxnet_python","mysql","nodejs_nginx","percona_mongodb","percona_mysql","postgresql","pytorch","pytorch_cuda_notebook","pytorch_cuda_production","redis","redmine","tensorflow_cpu_notebook","tensorflow_cpu_production","tensorflow_cuda_notebook","tensorflow_cuda_production","tensorflow_python","theano_python","wordpress4_lemp7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jitterbit_integration"},{"field":"Microsoft.Compute/imageOffer","in":["jitterbit-harmony-agent"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jm-technology-inc"},{"field":"Microsoft.Compute/imageOffer","in":["smart-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"juniper-networks"},{"field":"Microsoft.Compute/imageOffer","in":["vmx-services-gateway-byol","vmx-services-gateway-byol-soltemp","vmx-virtual-router","vsrx-next-generation-firewall","vsrx-next-generation-firewall-payg","vsrx-next-generation-firewall-solution-templ-payg","vsrx-next-generation-firewall-solution-template"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaazing"},{"field":"Microsoft.Compute/imageOffer","in":["kaazing-kwic","kaazing-vpa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kali-linux"},{"field":"Microsoft.Compute/imageOffer","in":["kali-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kemptech"},{"field":"Microsoft.Compute/imageOffer","in":["kemp360central-byol","vlm-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kinetica"},{"field":"Microsoft.Compute/imageOffer","in":["kineticadbbyol","kineticadbpayasyougo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaspersky_lab"},{"field":"Microsoft.Compute/imageOffer","in":["kaspersky_secure_mail_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"knime"},{"field":"Microsoft.Compute/imageOffer","in":["knime-server-5-user_4-4-0","knime-server-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"krypc-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["krypccore"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leap-orbit"},{"field":"Microsoft.Compute/imageOffer","in":["leaporbitstoragebackedsftp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leostream-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["connection-broker"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquid-files"},{"field":"Microsoft.Compute/imageOffer","in":["liquidfiles"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquidware"},{"field":"Microsoft.Compute/imageOffer","in":["stratusphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"literatu"},{"field":"Microsoft.Compute/imageOffer","in":["literatu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"loadbalancer"},{"field":"Microsoft.Compute/imageOffer","in":["loadbalancer-org-load-balancer-for-azure","loadbalancer-org-load-balancer-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logsign"},{"field":"Microsoft.Compute/imageOffer","in":["logsignfocus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logtrust"},{"field":"Microsoft.Compute/imageOffer","in":["logtrust-log-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"looker"},{"field":"Microsoft.Compute/imageOffer","in":["looker-analytics-platform","looker-analytics-platform-326","looker-analytics-platform-5_6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"lti-lt-infotech"},{"field":"Microsoft.Compute/imageOffer","in":["trade-finance-blockchain"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"luminate-security"},{"field":"Microsoft.Compute/imageOffer","in":["luminate-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mapr-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["mapr52-base-dev","mapr60-base","mapr60-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mariadb"},{"field":"Microsoft.Compute/imageOffer","in":["mariadb-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"marklogic"},{"field":"Microsoft.Compute/imageOffer","in":["marklogic-9-byol","marklogic-developer-9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"massiveanalytic-"},{"field":"Microsoft.Compute/imageOffer","in":["oscarap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mathworks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["matlab-ref-arch-18a-v1-linux-disk","mps-ref-arch-18a-v1-linux-disk2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"matillion"},{"field":"Microsoft.Compute/imageOffer","in":["matillion-etl-snowflake"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mavinglobal"},{"field":"Microsoft.Compute/imageOffer","in":["mavin-business-trial","mavin-enterprise-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"meanio"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-enterprise-ready","linnovate-open-source-sla-pro","mean-machine-20","openideal3","redash"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"media3-technologies-llc"},{"field":"Microsoft.Compute/imageOffer","in":["cpan1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"memsql"},{"field":"Microsoft.Compute/imageOffer","in":["memsql-community-single-vm","memsql-enterprise-single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mendix"},{"field":"Microsoft.Compute/imageOffer","in":["mendix-docker","mendix-pro"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mfe_azure"},{"field":"Microsoft.Compute/imageOffer","in":["atd-mcafee","mcafee_vnsp_controller_for_azure","mcafee_vnsp_for_azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"micro-focus"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-avere"},{"field":"Microsoft.Compute/imageOffer","in":["vfxt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-batch"},{"field":"Microsoft.Compute/imageOffer","in":["centos-container","centos-container-rdma","ubuntu-server-container","ubuntu-server-container-rdma"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-compute"},{"field":"Microsoft.Compute/imageOffer","in":["azureconfidentialcompute"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["azureml","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftAzureSiteRecovery"},{"field":"Microsoft.Compute/imageOffer","in":["ASR-Hydration-VMs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftOSTC"},{"field":"Microsoft.Compute/imageOffer","in":["FreeBSD"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","in":["MLServer-CentOS","MLServer-RedHat","MLServer-Ubuntu","RServer-CentOS","RServer-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midfin"},{"field":"Microsoft.Compute/imageOffer","in":["mf_neon_cgw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midvision"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-datapower-virtual-edition-75","ibm-datapower-virtual-edition-76","ibm-datapower-virtual-edition-77","ibm-http-server","ibm-websphere-portal-server-85","ibm-websphere-portal-server-90","websphere-application-server-be","websphere-application-server-be-80","websphere-application-server-be-85","websphere-application-server-be-90","websphere-application-server-be-and-mq","websphere-application-server-lp","websphere-application-server-lp-16","websphere-application-server-lp-17","websphere-application-server-lp-18","websphere-application-server-nde","websphere-application-server-nde-80","websphere-application-server-nde-85","websphere-application-server-nde-90","websphere-mq","websphere-mq-75","websphere-mq-90","websphere-mq-91"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miraclelinux"},{"field":"Microsoft.Compute/imageOffer","in":["asianux-server-4-sp5","asianux-server-4-sp6","asianux-server-4-sp7","asianux-server-7-sp1","asianux-server-7-sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miri-infotech-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mobilab"},{"field":"Microsoft.Compute/imageOffer","in":["magento-wirecard-checkout"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moogsoft"},{"field":"Microsoft.Compute/imageOffer","in":["moogsoft-aiops"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moviemasher"},{"field":"Microsoft.Compute/imageOffer","in":["moviemasher"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","in":["SQL2017-RHEL7","SQL2017-RHEL73","SQL2017-SLES12SP2","SQL2017-Ubuntu1604","SQL2019-RHEL7","SQL2019-Ubuntu1604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mtnfog"},{"field":"Microsoft.Compute/imageOffer","in":["idyl-e3-entity-extraction-engine","prose-sentence-extraction-engine","renku-language-detection-engine","sonnet-tokenization-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mxhero"},{"field":"Microsoft.Compute/imageOffer","in":["mail2cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"my-com"},{"field":"Microsoft.Compute/imageOffer","in":["tarantool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"narrativescience"},{"field":"Microsoft.Compute/imageOffer","in":["narratives-for-power-bi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nasuni"},{"field":"Microsoft.Compute/imageOffer","in":["nasuni-nmc","nasuni_edge_appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ncbi"},{"field":"Microsoft.Compute/imageOffer","in":["ncbi-blast-2-3-0","ncbi-free-2-2-31"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nebbiolo-technologies-inc"},{"field":"Microsoft.Compute/imageOffer","in":["fog-system-manager","fogsm_basic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neo4j"},{"field":"Microsoft.Compute/imageOffer","in":["neo4j-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netapp"},{"field":"Microsoft.Compute/imageOffer","in":["netapp-altavault-cloud-integrated-storage-solution","netapp-oncommand-cloud-manager","netapp-ontap-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netgate"},{"field":"Microsoft.Compute/imageOffer","in":["netgate-pfsense-azure-fw-vpn-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netiq"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netscout"},{"field":"Microsoft.Compute/imageOffer","in":["netscout_virtual_ngeniusone_with_vscout","netscout_vstream"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netmail"},{"field":"Microsoft.Compute/imageOffer","in":["netmail-search"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netsweeper"},{"field":"Microsoft.Compute/imageOffer","in":["netsweeper6-0-6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netx"},{"field":"Microsoft.Compute/imageOffer","in":["simplehelp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neusoft-neteye"},{"field":"Microsoft.Compute/imageOffer","in":["neusoft-nisg-va-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nginxinc"},{"field":"Microsoft.Compute/imageOffer","in":["nginx-plus-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nicepeopleatwork"},{"field":"Microsoft.Compute/imageOffer","in":["youzana"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nodejsapi"},{"field":"Microsoft.Compute/imageOffer","in":["node-js-api"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"noobaa"},{"field":"Microsoft.Compute/imageOffer","in":["noobaa-hybrid-s3-archive-05","noobaa-multi-cloud-deduplication"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"northbridge-secure"},{"field":"Microsoft.Compute/imageOffer","in":["netconnect1","netconnectx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nubeva-inc"},{"field":"Microsoft.Compute/imageOffer","in":["controller","test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuco-networks"},{"field":"Microsoft.Compute/imageOffer","in":["aionnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuxeo"},{"field":"Microsoft.Compute/imageOffer","in":["nuxeo-6-lts","nuxeo-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nvidia"},{"field":"Microsoft.Compute/imageOffer","in":["ngc_azure_17_11"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"o2mc-real-time-data-platform"},{"field":"Microsoft.Compute/imageOffer","in":["o2mc-platform-app"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"oceanblue-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["obc-sdwan-solutions"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"omega-software"},{"field":"Microsoft.Compute/imageOffer","in":["ods_datastage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onyx-point-inc"},{"field":"Microsoft.Compute/imageOffer","in":["op-bnf-v1","op-bnf1_6-v1","op-bpnifi-v1","op-bpnifi16-v1","op-scc-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onapsis"},{"field":"Microsoft.Compute/imageOffer","in":["osp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"op5"},{"field":"Microsoft.Compute/imageOffer","in":["op5-monitor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"opencell"},{"field":"Microsoft.Compute/imageOffer","in":["meveo","meveo403sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"openvpn"},{"field":"Microsoft.Compute/imageOffer","in":["openvpnas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-WebLogic-Server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"orientdb"},{"field":"Microsoft.Compute/imageOffer","in":["orientdb-community-edition","orientdb-community-edition-2_2","orientdb-enterprise-edition-2_2","orientdb-enterprise-edition-2_2_17"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osirium-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["osirium-pxm-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osnexus"},{"field":"Microsoft.Compute/imageOffer","in":["quantastorvsav4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"paloaltonetworks"},{"field":"Microsoft.Compute/imageOffer","in":["panorama","vmseries1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"panzura-file-system"},{"field":"Microsoft.Compute/imageOffer","in":["azura-freedom-filer-v7110","panzura-cloud-filer","panzura-freedom-filer-7140-13222","panzura-freedom-filer-716-13549","panzura-freedom-filer-v7020"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"parasoft"},{"field":"Microsoft.Compute/imageOffer","in":["parasoft-service-virtualization"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"passlogy"},{"field":"Microsoft.Compute/imageOffer","in":["passlogic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"penta-security-systems-inc"},{"field":"Microsoft.Compute/imageOffer","in":["wapples"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"percona"},{"field":"Microsoft.Compute/imageOffer","in":["percona-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"postgres-pro"},{"field":"Microsoft.Compute/imageOffer","in":["postgres-pro-enterprise","postgres-pro-enterprise-10","postgres-pro-standard","postgres-pro-standard-10"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"plesk"},{"field":"Microsoft.Compute/imageOffer","in":["plesk-onyx-linux","solution-server-business","solution-server-wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prestashop"},{"field":"Microsoft.Compute/imageOffer","in":["prestashop16-lamp","ubuntu-base-for-prestashop"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prime-strategy"},{"field":"Microsoft.Compute/imageOffer","in":["kusanagi-77"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","in":["pivotal-gpdb-vm","pivotal-greenplum-images","pivotal-ops-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"process-one"},{"field":"Microsoft.Compute/imageOffer","in":["ejabberd-community-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"profecia"},{"field":"Microsoft.Compute/imageOffer","in":["full_disk_encryption_vm","project_tools_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"progelspa"},{"field":"Microsoft.Compute/imageOffer","in":["libra-esva-antispam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ptsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["ptaf-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pulse-secure"},{"field":"Microsoft.Compute/imageOffer","in":["pulse-connect-secure-vm","pulse-virtual-traffic-manager","pulse-virtual-traffic-manager-with-waf","pulse-virtual-traffic-manager-with-waf2","pulse-virtual-traffic-manager2","pulse-virtual-web-application-firewall","pulse-virtual-web-application-firewall2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"PuppetLabs"},{"field":"Microsoft.Compute/imageOffer","in":["PuppetEnterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"puppet"},{"field":"Microsoft.Compute/imageOffer","in":["puppet-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pydio"},{"field":"Microsoft.Compute/imageOffer","in":["pydio-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qore-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["qorus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qualysguard"},{"field":"Microsoft.Compute/imageOffer","in":["qualys-virtual-firewall-appliance","qualys-virtual-scanner-v23b","qualys-virtual-scanner-v24"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quasardb"},{"field":"Microsoft.Compute/imageOffer","in":["quasardb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qubole-inc"},{"field":"Microsoft.Compute/imageOffer","in":["qubole-data-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quest"},{"field":"Microsoft.Compute/imageOffer","in":["fve"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"racknap"},{"field":"Microsoft.Compute/imageOffer","in":["racknap-server","racknap-server-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radware"},{"field":"Microsoft.Compute/imageOffer","in":["radware-alteon-va"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radiant-logic"},{"field":"Microsoft.Compute/imageOffer","in":["radiantone-vms"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rancher"},{"field":"Microsoft.Compute/imageOffer","in":["rancheros"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapid7"},{"field":"Microsoft.Compute/imageOffer","in":["nexpose-scan-engine","rapid7-vm-console"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapidminer"},{"field":"Microsoft.Compute/imageOffer","in":["rapidminer_server_75","rapidminer_server_76","rapidminer_server_80","rapidminer_server_81"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"realm"},{"field":"Microsoft.Compute/imageOffer","in":["realm-mobile-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"reblaze"},{"field":"Microsoft.Compute/imageOffer","in":["rbzr-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HANA"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"relevance-lab"},{"field":"Microsoft.Compute/imageOffer","in":["rlcatalyst"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"remotelearner"},{"field":"Microsoft.Compute/imageOffer","in":["fully-supported-moodle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"revolution-analytics"},{"field":"Microsoft.Compute/imageOffer","in":["revolution-r-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RightScaleLinux"},{"field":"Microsoft.Compute/imageOffer","in":["RightImage-CentOS","RightImage-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RiverbedTechnology"},{"field":"Microsoft.Compute/imageOffer","in":["steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"riverbed"},{"field":"Microsoft.Compute/imageOffer","in":["riverbed-sccm-5-5-1","riverbed-steelcentral-appinternals","riverbed-steelhead-9-2","riverbed-steelhead-9-5-0","riverbed-steelhead-9-6-0","riverbed_steelconnect_gw","riverbed_steelconnect_sh","steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rocketsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["rocket-discover"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsa-security-llc"},{"field":"Microsoft.Compute/imageOffer","in":["rsa-nw-azure-arch","rsa-nw-azure-broker","rsa-nw-azure-con","rsa-nw-azure-esa","rsa-nw-azure-ldec","rsa-nw-azure-vlc","rsa-nw-suite-11","rsa-nw-suite-11-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsk-labs"},{"field":"Microsoft.Compute/imageOffer","in":["rsk-bamboo-beta-node","rsk-node-orchid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saama"},{"field":"Microsoft.Compute/imageOffer","in":["fluidanalyticsengine","insurancefraudanalytics","realworldevidence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saltstack"},{"field":"Microsoft.Compute/imageOffer","in":["centos65saltstackenterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalearc"},{"field":"Microsoft.Compute/imageOffer","in":["scalearc-for-mysql-paygo","scalearc-for-sql-server-pay-go","scalearc_mysql-server","scalearc_sql_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalegrid"},{"field":"Microsoft.Compute/imageOffer","in":["centos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sap"},{"field":"Microsoft.Compute/imageOffer","in":["hanaexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scality"},{"field":"Microsoft.Compute/imageOffer","in":["scalityconnecthourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"secureworks"},{"field":"Microsoft.Compute/imageOffer","in":["scwx-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"shadow-soft"},{"field":"Microsoft.Compute/imageOffer","in":["icinga","icinga2-5","icinga2-7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"signal-sciences"},{"field":"Microsoft.Compute/imageOffer","in":["signalscienceswpp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sightapps"},{"field":"Microsoft.Compute/imageOffer","in":["sightapps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"silver-peak-systems"},{"field":"Microsoft.Compute/imageOffer","in":["silver_peak_edgeconnect","silver_peak_vx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"simmachinesinc"},{"field":"Microsoft.Compute/imageOffer","in":["simmachines_vm_v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sinefa"},{"field":"Microsoft.Compute/imageOffer","in":["sinefa-probe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"skyarc"},{"field":"Microsoft.Compute/imageOffer","in":["mt6","mta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"smartmessage-autoflow"},{"field":"Microsoft.Compute/imageOffer","in":["martmessage-autoflow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"snapt-adc"},{"field":"Microsoft.Compute/imageOffer","in":["snaptadc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soasta"},{"field":"Microsoft.Compute/imageOffer","in":["cloudtest-lite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"softnas"},{"field":"Microsoft.Compute/imageOffer","in":["cloud_dev","mp_ce","mp_ent","mp_nas_byol","mp_nas_ep","mp_nas_gp","mp_nas_hp","mp_plat","private_offerings","softnas-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solanolabs"},{"field":"Microsoft.Compute/imageOffer","in":["solano-ci-private-beta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soha"},{"field":"Microsoft.Compute/imageOffer","in":["soha-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solar-security"},{"field":"Microsoft.Compute/imageOffer","in":["solar-incode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sonicwall-inc"},{"field":"Microsoft.Compute/imageOffer","in":["sonicwall-nsz-azure","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sophos"},{"field":"Microsoft.Compute/imageOffer","in":["sophos-xg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spagobi"},{"field":"Microsoft.Compute/imageOffer","in":["spagobi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spacecurve"},{"field":"Microsoft.Compute/imageOffer","in":["spacecurve-quickstart"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"splunk"},{"field":"Microsoft.Compute/imageOffer","in":["splunk-enterprise-base-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"src-solution"},{"field":"Microsoft.Compute/imageOffer","in":["pilot-things-onem2m-smart-network"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sqlstream"},{"field":"Microsoft.Compute/imageOffer","in":["com"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sphere3d"},{"field":"Microsoft.Compute/imageOffer","in":["snapcloud-byol","snapcloud-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackato-platform-as-a-service"},{"field":"Microsoft.Compute/imageOffer","in":["activestate-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackstorm"},{"field":"Microsoft.Compute/imageOffer","in":["stackstorm-2015-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"startekfingerprintmatch"},{"field":"Microsoft.Compute/imageOffer","in":["bioserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"steelhive"},{"field":"Microsoft.Compute/imageOffer","in":["steelhive_carbon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stonefly"},{"field":"Microsoft.Compute/imageOffer","in":["stonefly-cloud-drive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stormshield"},{"field":"Microsoft.Compute/imageOffer","in":["stormshield-network-security-for-cloud","stormshield-network-security-for-cloud-xl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"storreduce"},{"field":"Microsoft.Compute/imageOffer","in":["storreduce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stratumn"},{"field":"Microsoft.Compute/imageOffer","in":["indigo-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"streamsets"},{"field":"Microsoft.Compute/imageOffer","in":["streamsets-data-collector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"striim"},{"field":"Microsoft.Compute/imageOffer","in":["integrationforsqlserveronazure","integrationtoazurestorage","integrationtoeventhub","integrationtohdinsight"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"symantectest1"},{"field":"Microsoft.Compute/imageOffer","in":["cwpsazure-beta-01"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synack-inc"},{"field":"Microsoft.Compute/imageOffer","in":["synack-crowd-security-intelligence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synechron-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blockchain_tradefinance_quorum"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"syte"},{"field":"Microsoft.Compute/imageOffer","in":["syteoffer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tactic"},{"field":"Microsoft.Compute/imageOffer","in":["tactic-workflow-v001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talari-networks"},{"field":"Microsoft.Compute/imageOffer","in":["talari-networks-virtual-appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talena-inc"},{"field":"Microsoft.Compute/imageOffer","in":["talena_inc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tata_communications"},{"field":"Microsoft.Compute/imageOffer","in":["netfoundry_cloud_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tavendo"},{"field":"Microsoft.Compute/imageOffer","in":["crossbar_on_azure_ubuntu1404"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techdivision"},{"field":"Microsoft.Compute/imageOffer","in":["appserver-io-pe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techlatest"},{"field":"Microsoft.Compute/imageOffer","in":["ethereumdevkit","rippledevelopersuit"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"telepat"},{"field":"Microsoft.Compute/imageOffer","in":["free"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tenable"},{"field":"Microsoft.Compute/imageOffer","in":["tenable-nessus-6-byol","tenable-nessus-professional","tenablecorenessus","tenablecorewas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"teradata"},{"field":"Microsoft.Compute/imageOffer","in":["teradata-data-mover","teradata-data-mover-agent","teradata-data-mover-intellisphere","teradata-data-stream-controller","teradata-database-1510","teradata-database-1510-byol","teradata-database-1510-intellisphere","teradata-database-1510-v2","teradata-database-1610-intellisphere","teradata-database-1610-v2","teradata-database-1620","teradata-database-1620-byol","teradata-database-1620-intellisphere","teradata-database-enterprise","teradata-database-v1610","teradata-database-v1610-byol","teradata-ecosystem-manager","teradata-querygrid-manager","teradata-querygrid-manager-intellisphere","teradata-rest-services","teradata-server-management","teradata-viewpoint","teradata-viewpoint-intellisphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thales-vormetric"},{"field":"Microsoft.Compute/imageOffer","in":["ciphertrust-ckm","vormetric-dsm","vormetric-dsm-6-1-0","vormetric-tokenization-server","vts-2_2_0_2604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"things-board"},{"field":"Microsoft.Compute/imageOffer","in":["tb-pe-cassandra"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thoughtspot-inc"},{"field":"Microsoft.Compute/imageOffer","in":["thoughtspotvirtualmachine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tibco-software"},{"field":"Microsoft.Compute/imageOffer","in":["grid-server-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tig"},{"field":"Microsoft.Compute/imageOffer","in":["backup-as-a-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tigergraph"},{"field":"Microsoft.Compute/imageOffer","in":["tigergraph"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tmaxsoft"},{"field":"Microsoft.Compute/imageOffer","in":["tmax-jeusee","tmax-jeusse","tmax-webtobse"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tokyosystemhouse"},{"field":"Microsoft.Compute/imageOffer","in":["osscobol151j-pg961-centos72"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"torusware"},{"field":"Microsoft.Compute/imageOffer","in":["speedus-lite-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"totemo"},{"field":"Microsoft.Compute/imageOffer","in":["totemo-azr-tm6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"townsend-security"},{"field":"Microsoft.Compute/imageOffer","in":["alliance-key-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"trendmicro"},{"field":"Microsoft.Compute/imageOffer","in":["deep-security-vm","deep-security-vm-byol","iot-security-sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"truestack"},{"field":"Microsoft.Compute/imageOffer","in":["tsdc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tsa-public-service"},{"field":"Microsoft.Compute/imageOffer","in":["ckan-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tunnelbiz"},{"field":"Microsoft.Compute/imageOffer","in":["centos70-min","centos7optimizwithwordpress","centos7phpoptimizing","centos7phpoptimizingnginx","centos7phpoptimizwlaravel","centos7phpoptimizwosticket","centos7webserverwithwaf","centos7withaspdotnetcore2apache","centos7withjoomla","debian_web_server","fedora","fusio","linuxwithlimesurvey","networkmonitoringsystem","rimauwaf_cloud","ubuntu_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"twistlock"},{"field":"Microsoft.Compute/imageOffer","in":["twistlock"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"typesafe"},{"field":"Microsoft.Compute/imageOffer","in":["typesafe-reactive-maps-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubeeko"},{"field":"Microsoft.Compute/imageOffer","in":["hfactory-tools-for-hdinsight","hfactory-tools-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubercloud"},{"field":"Microsoft.Compute/imageOffer","in":["ansys-17-2-fluids-structures","ansys_182_test","comsol-multiphysics-v5-2","openfoam-v2dot3-centos-v6","openfoam-v3dot0","star-ccm-v10-04","star-ccm-v10-06-heeds-mdo-v2015","star-ccm-v12-00"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ulex"},{"field":"Microsoft.Compute/imageOffer","in":["voximal"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unifi-software"},{"field":"Microsoft.Compute/imageOffer","in":["unifi-data-catalog","unifi-dataplatform-2-3-3-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unitrends"},{"field":"Microsoft.Compute/imageOffer","in":["unitrends-enterprise-backup-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"usp"},{"field":"Microsoft.Compute/imageOffer","in":["unified-streaming-vod-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"varnish"},{"field":"Microsoft.Compute/imageOffer","in":["varnish-cache_","varnish-custom-statistics","varnish-plus-administration-and-statistics","varnish-plus-caching-engine-4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vaultive-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-security-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vbot"},{"field":"Microsoft.Compute/imageOffer","in":["vbot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"velocloud"},{"field":"Microsoft.Compute/imageOffer","in":["velocloud-virtual-edge","velocloud-virtual-edge-3x"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vidispine"},{"field":"Microsoft.Compute/imageOffer","in":["vidispine-content-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veritas"},{"field":"Microsoft.Compute/imageOffer","in":["cloudpoint-2-0-0","veritas-resiliency-platform-vhd-offer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veeam"},{"field":"Microsoft.Compute/imageOffer","in":["veeamhubimage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vigyanlabs-innovations-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["ipm-plus-energy-saver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"viptela"},{"field":"Microsoft.Compute/imageOffer","in":["viptela-vedge-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vizixiotplatformretail001"},{"field":"Microsoft.Compute/imageOffer","in":["vizix-iot-platform-retail-005"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vmturbo"},{"field":"Microsoft.Compute/imageOffer","in":["turbonomic","vmturbo64-opsmgr-5_3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vte"},{"field":"Microsoft.Compute/imageOffer","in":["slashdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vu-llc"},{"field":"Microsoft.Compute/imageOffer","in":["vu-app-server","vu-facerecogn","vu-fraudanalysis","vu-secureonboarding"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallarm"},{"field":"Microsoft.Compute/imageOffer","in":["wallarm-ng-waf-offer-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallix"},{"field":"Microsoft.Compute/imageOffer","in":["wallix-wabsuite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"watchguard-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["vm-firebox-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"waves"},{"field":"Microsoft.Compute/imageOffer","in":["waves"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"websense-apmailpe"},{"field":"Microsoft.Compute/imageOffer","in":["ap-data-email-gateway","forcepoint-email-security-85beta","triton-ap-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wmspanel"},{"field":"Microsoft.Compute/imageOffer","in":["nimble-streamer-centos","nimble-streamer-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wowza"},{"field":"Microsoft.Compute/imageOffer","in":["wowzastreamingengine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xfinityinc"},{"field":"Microsoft.Compute/imageOffer","in":["d3view-v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xtremedata"},{"field":"Microsoft.Compute/imageOffer","in":["dbx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"yellowfin"},{"field":"Microsoft.Compute/imageOffer","in":["yellowfin-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xyzrd-group-ou"},{"field":"Microsoft.Compute/imageOffer","in":["c73-zultys-mxvirtual"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"your-shop-online"},{"field":"Microsoft.Compute/imageOffer","in":["herefordshire-enterprise-platform-drupal-7","xenofile"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zend"},{"field":"Microsoft.Compute/imageOffer","in":["php-56-zend-server","php-zend-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"z1"},{"field":"Microsoft.Compute/imageOffer","in":["z1-securehub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zerodown_software"},{"field":"Microsoft.Compute/imageOffer","in":["bcaasforazure","stackbcaas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zoomdata"},{"field":"Microsoft.Compute/imageOffer","in":["zoomdata-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zscaler"},{"field":"Microsoft.Compute/imageOffer","in":["zscaler-private-access"]}]}]}]},"then":{"effect":"audit"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/d974fab8daefe230","type":"Microsoft.Authorization/policyDefinitions","name":"d974fab8daefe230"},{"properties":{"displayName":"geneva + monitoring extension and azsecpack autoupdate policy for vmss_2.0","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-12T00:29:56.9604539Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"anyOf":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/osProfile.windowsConfiguration","exists":"true"},{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftWindowsServer"}]}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Compute/virtualMachineScaleSets/extensions","name":"Microsoft.Azure.Geneva.GenevaMonitoring","existenceCondition":{"allOf":[{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/type","equals":"GenevaMonitoring"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/publisher","equals":"Microsoft.Azure.Geneva"},{"field":"Microsoft.Compute/virtualMachineScaleSets/extensions/enableAutomaticUpgrade","equals":"true"}]},"roleDefinitionIds":["/providers/microsoft.authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"vmssName":{"type":"string"},"location":{"type":"string"}},"resources":[{"apiVersion":"2018-10-01","name":"[concat(parameters(''vmssName''), + ''/Microsoft.Azure.Geneva.GenevaMonitoring'')]","type":"Microsoft.Compute/virtualMachineScaleSets/extensions","location":"[parameters(''location'')]","properties":{"publisher":"Microsoft.Azure.Geneva","type":"GenevaMonitoring","typeHandlerVersion":"2.0","autoUpgradeMinorVersion":true,"enableAutomaticUpgrade":true,"settings":{}}}]},"parameters":{"vmssName":{"value":"[field(''name'')]"},"location":{"value":"[field(''location'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/dac4e4f8ad529fe5","type":"Microsoft.Authorization/policyDefinitions","name":"dac4e4f8ad529fe5"},{"properties":{"displayName":"azuremonitorlinuxagent + append policy for vmss_1.3","policyType":"Custom","mode":"Indexed","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-09T20:11:41.4235763Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"skipTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipASMAzSecPack"},"skipTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the resource, + resource group level, or subscription level"},"defaultValue":"SkipLinuxAzSecPack"},"skipResourceGroupTagName1":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotcluster"},"skipResourceGroupTagName2":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"},"defaultValue":"autopilotenvironment"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Compute/virtualMachineScaleSets"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''skipTagName1''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName1''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName1''))]","equals":"false"},{"field":"[concat(''tags['', + parameters(''skipTagName2''), '']'')]","exists":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(subscription().tags, + parameters(''skipTagName2''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName1''))]","equals":"false"},{"value":"[contains(resourceGroup().tags, + parameters(''skipResourceGroupTagName2''))]","equals":"false"},{"field":"Microsoft.Compute/VirtualMachineScaleSets/virtualMachineProfile","exists":"true"},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","0001-com-ubuntu-server-focal","0001-com-ubuntu-server-eoan","0001-com-ubuntu-server-focal-daily","0001-com-ubuntu-pro-bionic","0001-com-ubuntu-pro-focal","0003-com-ubuntu-server-trusted-vm"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"16.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"18.04*LTS"},{"field":"Microsoft.Compute/imageSKU","like":"20_04-lts*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"8"},{"field":"Microsoft.Compute/imageSKU","equals":"9"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Debian"},{"field":"Microsoft.Compute/imageOffer","in":["Debian-10"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","equals":"10"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-HA","RHEL-HA","RHEL-SAP-APPS","RHEL-SAP-HANA"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-Linux-7","Oracle-WebLogic-Server"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"7.*"},{"field":"Microsoft.Compute/imageSKU","like":"7*"},{"field":"Microsoft.Compute/imageSKU","like":"8*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SLES-12-SP5","SLES-15-SP2","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"12*"},{"field":"Microsoft.Compute/imageSKU","like":"gen*"}]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]},{"anyOf":[{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-ubuntu-1804-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1604-*"},{"field":"Microsoft.Compute/imageSKU","like":"aks-engine-ubuntu-1804-*"}]}]}]},{"field":"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*].type","notEquals":"AzureMonitorLinuxAgent"},{"not":{"field":"Microsoft.Compute/virtualMachineScaleSets/virtualMachineProfile.osProfile.linuxConfiguration.provisionVMAgent","equals":"false"}}]},"then":{"effect":"append","details":[{"field":"Microsoft.Compute/VirtualMachineScaleSets/extensionProfile.extensions[*]","value":{"name":"Microsoft.Azure.Monitor.AzureMonitorLinuxAgent","properties":{"publisher":"Microsoft.Azure.Monitor","type":"AzureMonitorLinuxAgent","typeHandlerVersion":"1.0","autoUpgradeMinorVersion":true,"settings":{}}}}]}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/db5e87f8595e3529","type":"Microsoft.Authorization/policyDefinitions","name":"db5e87f8595e3529"},{"properties":{"displayName":"vmvmssfirstpartyidentificationtag_1.4","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-25T21:13:08.9110481Z","updatedBy":null,"updatedOn":null},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"tagName","description":"Opted + in for PKI"},"defaultValue":"platformsettings.host_environment.service.platform_optedin_for_rootcerts"},"tagValue":{"type":"String","metadata":{"displayName":"tagValue","description":"is + this the first party VM?"},"defaultValue":"true"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""}]},"then":{"effect":"append","details":[{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/dc188748309e5653","type":"Microsoft.Authorization/policyDefinitions","name":"dc188748309e5653"},{"properties":{"displayName":"nrms-nsg-rule-109_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:52.5486159Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff","type":"Microsoft.Authorization/policyDefinitions","name":"e0bc08af3bd773ff"},{"properties":{"displayName":"nrms-nsg-rule-103_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:24.0068177Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e24b2791c9576d86","type":"Microsoft.Authorization/policyDefinitions","name":"e24b2791c9576d86"},{"properties":{"displayName":"sqlads-auditifnotexists-advanced + data security should be enabled on your sql servers_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:35.0244464Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"tagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the SQL + Server"}},"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["AuditIfNotExists","Disabled"],"defaultValue":"AuditIfNotExists"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Sql/servers"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''tagname'')]]","equals":""}]},"then":{"effect":"[parameters(''effect'')]","details":{"type":"Microsoft.Sql/servers/securityAlertPolicies","name":"Default","existenceCondition":{"field":"Microsoft.Sql/servers/securityAlertPolicies/state","equals":"Enabled"}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e3cff6e23ce4018a","type":"Microsoft.Authorization/policyDefinitions","name":"e3cff6e23ce4018a"},{"properties":{"displayName":"require + ssh key for authentication on linux vms_1.7","policyType":"Custom","mode":"All","description":"This + policy denies the creation of Linux VMs which use password-only authentication + for SSH. Use of SSH key is more secure than passwords. To unblock, do not + use password for SSH authentication.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-07T02:55:12.0260825Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Policy + exclusion Tag Name at the resource level","description":"Rule is not deployed + if this tag exists on the Virtual Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Policy + exclusion Tag Name at the resource group level","description":"Rule is not + deployed if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Policy + exclusion Tag Name at the subscription level","description":"Rule is not deployed + if this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"field":"type","equals":"Microsoft.Compute/virtualMachines"},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"anyof":[{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","exists":"False"},{"field":"Microsoft.Compute/virtualMachines/osProfile.linuxConfiguration.disablePasswordAuthentication","equals":"false"}]},{"anyOf":[{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"7isolutions"},{"field":"Microsoft.Compute/imageOffer","in":["sapp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"128technology"},{"field":"Microsoft.Compute/imageOffer","in":["128t_networking_platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"4psa"},{"field":"Microsoft.Compute/imageOffer","in":["voipnow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"a10networks"},{"field":"Microsoft.Compute/imageOffer","in":["a10-lightning-adc","a10-vthunder-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accellion"},{"field":"Microsoft.Compute/imageOffer","in":["kiteworks-by-accellion"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"abiquo"},{"field":"Microsoft.Compute/imageOffer","in":["abiquo-hybrid-cloud-34"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"accops"},{"field":"Microsoft.Compute/imageOffer","in":["hysecure5050"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian_matrix"},{"field":"Microsoft.Compute/imageOffer","in":["actian_matrix"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actifio"},{"field":"Microsoft.Compute/imageOffer","in":["actifio-sky"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"actian-corp"},{"field":"Microsoft.Compute/imageOffer","in":["vector-community","vector-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Acronis"},{"field":"Microsoft.Compute/imageOffer","in":["storage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"activeeon"},{"field":"Microsoft.Compute/imageOffer","in":["activeeon-workload-scheduler"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aerospike"},{"field":"Microsoft.Compute/imageOffer","in":["aerospike-database-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"affinio"},{"field":"Microsoft.Compute/imageOffer","in":["platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aiscaler-cache-control-ddos-and-url-rewriting-"},{"field":"Microsoft.Compute/imageOffer","in":["aimobile-site-acceleration","aiprotect-ddos-firewall","aiscaler-traffic-manager-caching","aivideo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"akamai-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["enterprise-application-access"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alces-flight-limited"},{"field":"Microsoft.Compute/imageOffer","in":["alces-flight-compute-solo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alertlogic"},{"field":"Microsoft.Compute/imageOffer","in":["alert-logic-tm","alert-logic-wsm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alienvault"},{"field":"Microsoft.Compute/imageOffer","in":["unified-security-management-anywhere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"alldigital-brevity"},{"field":"Microsoft.Compute/imageOffer","in":["alldigital-brevity-uploader"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altair-engineering-inc"},{"field":"Microsoft.Compute/imageOffer","in":["altair_hwulva"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"altamira-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["lumify"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"antmedia"},{"field":"Microsoft.Compute/imageOffer","in":["ams_community_edition","ant_media_server_enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"apigee"},{"field":"Microsoft.Compute/imageOffer","in":["apigee-edge"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcara"},{"field":"Microsoft.Compute/imageOffer","in":["app360v43-001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appcelerator"},{"field":"Microsoft.Compute/imageOffer","in":["appcelerator-arrow-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appex-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appistry"},{"field":"Microsoft.Compute/imageOffer","in":["genomepilot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"appscale-marketplace"},{"field":"Microsoft.Compute/imageOffer","in":["appscale"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arangodb"},{"field":"Microsoft.Compute/imageOffer","in":["arangodb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"arista-networks"},{"field":"Microsoft.Compute/imageOffer","in":["veos-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"array_networks"},{"field":"Microsoft.Compute/imageOffer","in":["array-networks-vapv"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"astadia-1148316"},{"field":"Microsoft.Compute/imageOffer","in":["astadia-ui-automation-tee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"atomicorp"},{"field":"Microsoft.Compute/imageOffer","in":["secure-os","secure-ubuntu-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"audiocodes"},{"field":"Microsoft.Compute/imageOffer","in":["mediantsessionbordercontroller"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"auriq-systems"},{"field":"Microsoft.Compute/imageOffer","in":["essentia"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"awingu"},{"field":"Microsoft.Compute/imageOffer","in":["awingu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"aviatrix-systems"},{"field":"Microsoft.Compute/imageOffer","in":["aviatrix-cloud-services","aviatrix-companion-gateway","aviatrix-companion-gateway-v2","aviatrix-vpn-gw","aviatrix_multi_cloud_service","aviatrix_openvpn_service","aviatrix_openvpn_service10","aviatrix_openvpn_service25","aviatrix_openvpn_service50"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"avi-networks"},{"field":"Microsoft.Compute/imageOffer","in":["avi-vantage-adc","internal-avi-vantage-adc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"axway"},{"field":"Microsoft.Compute/imageOffer","in":["axway-mailgate-secure-collaboration-advanced","axway-mailgate-secure-collaboration-premium","axway-mailgate-secure-collaboration-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azul"},{"field":"Microsoft.Compute/imageOffer","in":["azul-zulu-ubuntu-1804"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"azurecyclecloud"},{"field":"Microsoft.Compute/imageOffer","in":["azure-cyclecloud-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"AzureDatabricks"},{"field":"Microsoft.Compute/imageOffer","in":["Databricks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baas-techbureau"},{"field":"Microsoft.Compute/imageOffer","in":["b1327623-d29b-4cc1-b833-85067dcc7bce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"baffle-io"},{"field":"Microsoft.Compute/imageOffer","in":["baffle-application-data-protection"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"balabit"},{"field":"Microsoft.Compute/imageOffer","in":["balabit-shell-control-box","psm","sps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"barracudanetworks"},{"field":"Microsoft.Compute/imageOffer","in":["barracuda-app-sec-control-center","barracuda-email-security-gateway","barracuda-ng-cc","barracuda-ng-firewall","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"basho"},{"field":"Microsoft.Compute/imageOffer","in":["riak-2-0-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"batch"},{"field":"Microsoft.Compute/imageOffer","in":["autodesk-maya-arnold-centos73","rendering-centos73"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bdy"},{"field":"Microsoft.Compute/imageOffer","in":["buddy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Bitnami"},{"field":"Microsoft.Compute/imageOffer","in":["3-4","abantecart","activemq","akeneo","alfrescocommunity","apachesolr","artifactory","canvaslms","cassandra","civicrm","cmsmadesimple","codiad","concrete5","consul","coppermine","couchdb","diaspora","discourse","djangostack","dokuwiki","dolibarr","DreamFactory","drupal","elastic-search","elk","erpnext","espocrm","etcd","eXo-Platform","exoplatform","fatfreecrm","ghost","gitlab","grafana","hadoop","hhvmstack","hordegroupwarewebmail","jasperreports","jenkins","joomla","jrubystack","kafka","kong","kubernetessandbox","lampstack","lappstack","letschat","liferay","limesurvey","livehelperchat","magento","mahara","mantis","mariadb","mattermost","mautic","mean","mediawiki","memcached","modx","mongodb","moodle","multicraft","mybb","mysql","nats","neo4j","neos","nginxstack","noalyss","nodejs","ocportal","odoo","openatrium","opencart","openedx","openfire","openproject","orangehrm","osclass","owncloud","oxid-eshop","parseserver","phabricator","phpbb","phplist","pimcore","piwik","plone","pootle","postgresql","prestashop","processmakerenterprise","processmakeropensourceedition","processwire","publify","rabbitmq","redash","redis","redmine","redmineplusagile","reportserver","reportserverenterprise","resourcespace","reviewboard","reviewboardpowerpack","roundcube","rubystack","seopanel","shopware","silverstripe","simplemachinesforum","sonarqube","spree","subversion","suitecrm","tensorflowserving","testlink","tikiwikicmsgroupware","tinytinyrss","tom-cat","trac","typo3","weblate","webmailpro","wildfly","wordpress","wordpress-multisite","wordpresspro","x2enginesalescrm","xoops","youtrack","zookeeper","zurmo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"black-duck-software"},{"field":"Microsoft.Compute/imageOffer","in":["blackduck_hub_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blk-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blk-io-erc-20-rest-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockapps"},{"field":"Microsoft.Compute/imageOffer","in":["strato-blockchain-base-template-latest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockstack"},{"field":"Microsoft.Compute/imageOffer","in":["blockstack-core-v14"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"blockchain-foundry"},{"field":"Microsoft.Compute/imageOffer","in":["syscoin-api","syscoin-full-node","syscoin-price-peg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bloombase"},{"field":"Microsoft.Compute/imageOffer","in":["bloombase-storesafe-3_4_7_0_el7_x86_64"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluecat"},{"field":"Microsoft.Compute/imageOffer","in":["bluecat-bam-for-azure","bluecat-dns-for-azure","bluecat-edge-service-point-vm-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bluetalon"},{"field":"Microsoft.Compute/imageOffer","in":["bluetalon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"brocade_communications"},{"field":"Microsoft.Compute/imageOffer","in":["brocade-virtual-traffic-manager","brocade-virtual-traffic-manager-with-waf-module","brocade-virtual-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"bt-americas-inc"},{"field":"Microsoft.Compute/imageOffer","in":["diamondip-sapphire-ev10","diamondip-sapphire-ev20","diamondip-sapphire-v10","diamondip-sapphire-v20","diamondip-sapphire-v5","diamondip-sapphire-vcaa20"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"buddhalabs"},{"field":"Microsoft.Compute/imageOffer","in":["sles_12_pci"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"carto"},{"field":"Microsoft.Compute/imageOffer","in":["cartobuilder2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cask"},{"field":"Microsoft.Compute/imageOffer","in":["cdap-cloud-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Canonical"},{"field":"Microsoft.Compute/imageOffer","in":["UbuntuServer","Ubuntu_Core"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cavirin"},{"field":"Microsoft.Compute/imageOffer","in":["cavirin-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cautelalabs"},{"field":"Microsoft.Compute/imageOffer","in":["log_management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"celum-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["celumdam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cds"},{"field":"Microsoft.Compute/imageOffer","in":["cds-data-migration-solution-for-legacy-to-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"center-for-internet-security-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cis-centos-6-v2-0-2-l1","cis-centos-7-v2-1-1-l1","cis-oracle-linux-6-v1-0-0-l1","cis-oracle-linux-7-v2-0-0-l1","cis-rhel-6-v2-0-2-l1","cis-rhel-7-v2-2-0-l1","cis-suse-linux-11-v2-0-0-l1","cis-suse-linux-12-v2-0-0-l1","cis-ubuntu-linux-1404-v2-0-0-l1","cis-ubuntu-linux-1604-v1-0-0-l1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"certivox"},{"field":"Microsoft.Compute/imageOffer","in":["sso-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cfd-direct"},{"field":"Microsoft.Compute/imageOffer","in":["cfd-direct-from-the-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chain"},{"field":"Microsoft.Compute/imageOffer","in":["chain-core-developer-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"checkpoint"},{"field":"Microsoft.Compute/imageOffer","in":["check-point-r77-10","check-point-vsec-r80","check-point-vsec-r80-blink","sg2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"chef-software"},{"field":"Microsoft.Compute/imageOffer","in":["chef-automate-vm-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"circleci"},{"field":"Microsoft.Compute/imageOffer","in":["circleci-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cires21"},{"field":"Microsoft.Compute/imageOffer","in":["c21l-enc","c21l-mos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cisco"},{"field":"Microsoft.Compute/imageOffer","in":["cisco-asav","cisco-csr-1000v","cisco-ftdv","cisco-meraki-vmx100","cisco-ngfwv-vm-test-unsupported","cisco_cloud_vedge_17_2_4","cos65","cos72","cos72_main_dev","uos14","vwaas-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"citrix"},{"field":"Microsoft.Compute/imageOffer","in":["citrix-sd-wan-opt","netscaler-ma-service-agent-120","netscaler-ma-service-agent-121","netscaler-sd-wan","netscaler-vpx","netscalervpx-120","netscalervpx-121","netscalervpx110-6531","netscalervpx111"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clear-linux-project"},{"field":"Microsoft.Compute/imageOffer","in":["clear-linux-os"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clouber"},{"field":"Microsoft.Compute/imageOffer","in":["cuber","cws","mcenter"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-cruiser"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-cruiser-16"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees"},{"field":"Microsoft.Compute/imageOffer","in":["jenkins-enterprise","jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbees-enterprise-jenkins"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbees-jenkins-enterprise","cloudbees-jenkins-operations-center"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudbolt-software"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbolt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudboost"},{"field":"Microsoft.Compute/imageOffer","in":["cloudboost"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudenablers-inc"},{"field":"Microsoft.Compute/imageOffer","in":["corestack"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloud-infrastructure-services"},{"field":"Microsoft.Compute/imageOffer","in":["squid-proxy"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudera"},{"field":"Microsoft.Compute/imageOffer","in":["cloudera-altus-centos-os","cloudera-centos-6","cloudera-centos-os","test-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlanes"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-video-accelerator-nfs","cloudlanes-cloud-backup-accelerator-vtl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudlink"},{"field":"Microsoft.Compute/imageOffer","in":["cloudlink-securevm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudplan-gmbh"},{"field":"Microsoft.Compute/imageOffer","in":["cloudplan_pcn_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["paladion_ondemand_nextgen_firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cloudsoft"},{"field":"Microsoft.Compute/imageOffer","in":["cloudsoft-amp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"clustrix"},{"field":"Microsoft.Compute/imageOffer","in":["clustrixdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codelathe"},{"field":"Microsoft.Compute/imageOffer","in":["codelathe-filecloud-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"codenvy"},{"field":"Microsoft.Compute/imageOffer","in":["codenvy-on-prem"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cognosys"},{"field":"Microsoft.Compute/imageOffer","in":["1-click-secured-joomla-on-centos-7-3","1-click-secured-joomla-on-ubuntu-1404-lts","1-click-secured-joomla-on-ubuntu-1604-lts","1-click-secured-joomla-on-ubuntu-1804-lts","centos-6-9","centos-7-3","centos-7-4","centos-7-5","deploy-a-secured-modx-on-ubuntu-14-04-lts","deploy-a-secured-silverstripe-on-ubuntu-14-04-lts","hardened-mysql-5-6-on-centos-7-3","hardened-mysql-5-6-on-ubu-1404-lts","hardened-mysql-5-7-on-centos-7-3","hardened-mysql-5-7-on-ubu-1404-lts","hardened-postgresql-on-ubu-1404-lts","invoice-ninja-2-5-1-1-on-ubuntu-1404","jruby-on-ubuntu-14-04-lts","low-latency-broadcasting-server-for-live-events","owncloud-9-with-lamp-stack-on-ubuntu-1404","piwigogallerys-ubuntu_14-04_lts","sec1011-dokuwiki-on-ubuntu-1404","sec1013-elasticsearch-on-ubuntu-1404","sec1014-opencart-on-ubuntu-1404","sec1015-orangehrm-on-ubuntu-1404","sec1016-nodejs-server-on-ubuntu-1404","sec1018-haproxy-on-ubuntu-1404","sec1019-secured-tomcat-on-ubuntu-1404","sec1020-phpbb-on-hardened-ubuntu-1404","sec1021-mybb-on-hardened-ubuntu-1404","sec1022-sugarcrm-on-ubuntu-1404","sec1023-moodle-on-ubuntu-1404","sec1024_magento-on-ubuntu-1404","sec1025-secured-drupal-on-ubuntu-1404","sec1027-secured-wordpress-on-ubuntu-1404","sec1028-secured-lamp-sever-on-ubuntu-1404","sec1029-secured-mediawiki-on-ubuntu-1404","sec1030-secured-subversion-on-ubuntu-1404","sec1031-secured-passenger-nginx-on-ubuntu-1404","sec1033-secured-piwik-on-ubuntu-1404","sec1034-secured-pligg-on-ubuntu-1404","sec1035-secured-jenkins-on-ubuntu-1404","sec1036-secured-postgresql-on-ubuntu-1404","secure-cloud-lamp-ubuntu-1404","secured-abantecart-on-centos","secured-abantecart-on-ubuntu-14-04-lts","secured-acquia-drupal-on-centos","secured-acquiadurpal-on-ubuntu-14-04-lts","secured-apachesolr-on-centos","secured-apachesolr-on-ubuntu-14-04-lts","secured-arartifactory-on-centos","secured-artifactory-on-ubuntu-14-04-lts","secured-cakephp-on-centos","secured-cakephp-on-ubuntu-14-04-lts","secured-cms-made-simple-on-centos","secured-cms-made-simple-on-ubuntu-14-04-lts","secured-codiad-on-centos","secured-codiad-on-ubuntu-14-04-lts","secured-cogdam-on-centos","secured-cogdam-on-ubuntu-14-04-lts","secured-concrete5-on-centos","secured-concrete5-on-ubuntu-14-04-lts","secured-coppermine-on-centos","secured-coppermine-on-ubuntu-14-04-lts","secured-crushftp-on-centos","secured-crushftp-on-ubuntu-14-04-lts","secured-django-on-centos","secured-django-on-ubuntu-14-04-lts","secured-dokuwiki-on-centos","secured-dolibarr-on-centos","secured-dolivbarr-on-ubuntu-14-04-lts","secured-drupal-on-centos","secured-elasticsearch-on-centos","secured-enterprise-nginx-varnish-haproxy-php","secured-espocrm-on-centos","secured-espocrm-on-ubuntu-14-04-lts","secured-exoplatform-on-centos","secured-exoplatform-on-ubuntu-14-04-lts","secured-ghost-on-centos","secured-ghost-on-ubuntu-14-04-lts","secured-gradle-on-centos","secured-gradle-on-ubuntu-14-04-lts","secured-haproxy-on-centos","secured-invoice-ninja-on-centos","secured-jboss-as-on-centos","secured-jbossas-on-ubuntu-14-04-lts","secured-jenkins-on-centos","secured-jruby-on-cento","secured-lamp-on-centos","secured-lamp-on-centos-m10","secured-lapp-on-centos","secured-lapp-on-ubuntu-14-04-lts","secured-lemp-sever-on-ubuntu-1404","secured-lime-survey-on-centos","secured-limesurvey-on-ubuntu-1404","secured-live-helper-chat-on-centos","secured-livehelperchat-on-ubuntu-14-04-lts","secured-magento-on-centos","secured-mahara-on-centos","secured-mahara-on-ubuntu-14-04-lts","secured-mantis-on-centos","secured-mantis-on-ubuntu-14-04-lts","secured-mariadb-on-ubuntu-16-04","secured-mautic-on-centos","secured-mautic-on-ubuntu-14-04-lts","secured-media-wiki-on-centos","secured-modx-on-centos","secured-moodle-on-centos","secured-ngnix-on-centos-7-3","secured-ngnix-on-ubuntu-14-04-lts","secured-ngnix-on-ubuntu-16-04-lts","secured-noalyss-on-centos","secured-noalyss-on-ubuntu-14-04-lts","secured-nodejs-on-centos","secured-occlass-on-ubuntu-14-04-lts","secured-ocportal-on-ubuntu-14-04-lts","secured-open-cart-on-centos","secured-orangehrm-on-centos","secured-osclass-on-centos","secured-owncloud-on-centos","secured-oxid-eshop-on-centos","secured-oxideshop-on-ubuntu-14-04-lts","secured-passenger-nginx-on-centos","secured-piwigo-gallery-on-centos","secured-plone-on-centos","secured-plone-on-ubuntu-14-04-lts","secured-prestashop-on-centos","secured-prestashop-on-ubuntu-14-04-lts","secured-railo-on-ubuntu-14-04-lts","secured-redis-on-centos","secured-redis-on-ubuntu-1404","secured-redmine-on-centos","secured-redmine-on-ubuntu-14-04-lts","secured-redmineagile-on-ubuntu-14-04-lts","secured-report-server-on-centos","secured-reportserverent-on-ubuntu-14-04-lts","secured-resource-space-on-centos","secured-resourcespace-on-ubuntu-14-04-lts","secured-round-cube-on-centos","secured-roundcube-on-ubuntu-14-04-lts","secured-ruby-on-centos","secured-ruby-on-ubuntu-14-04-lts","secured-seopanel-on-centos","secured-seopanel-on-ubuntu-14-04-lts","secured-silverstripe-on-centos","secured-simple-invoice-on-centos","secured-simple-machines-on-centos","secured-simple-machines-on-ubuntu-14-04-lts","secured-simpleinvoice-on-ubuntu-14-04-lts","secured-subversion-on-centos","secured-suitecrm-on-centos","secured-suitecrm-on-ubuntu-14-04-lts","secured-test-link-on-centos","secured-testlink-on-ubuntu-14-04-lts","secured-thinkup-on-centos","secured-thinkup-on-ubuntu-14-04-lts","secured-tikiwikicms-on-centos","secured-tikiwikicms-on-ubuntu-14-04-lts","secured-tiny-tiny-rss-on-centos","secured-tinytinyrss-on-ubuntu-14-04-lts","secured-tomcat-on-centos","secured-trac-on-centos","secured-trac-on-ubuntu-14-04-lts","secured-typo3-on-centos","secured-typo3-on-ubuntu-14-04-lts","secured-varnish-on-centos","secured-varnish-on-ubuntu-1404","secured-wildfly-on-centos","secured-wildfly-on-ubuntu-14-04-lts","secured-wordpress-on-centos-7-3","secured-wordpress-on-ubuntu-16-04-lts","secured-x-cart-on-ubuntu-14-04-lts","secured-xoops-on-centos","secured-xoops-on-ubuntu-14-04-lts","secured-zurmo-on-centos","secured-zurmo-on-ubuntu-14-04-lts","suse15","ubuntu-14-04-lts","ubuntu-16-04-lts","ubuntu-17-04-high-performance-hardened-tcp-bbr","ubuntu-18-04","ubuntu-18-04-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesity"},{"field":"Microsoft.Compute/imageOffer","in":["cohesity-cloudtd-tool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cohesive"},{"field":"Microsoft.Compute/imageOffer","in":["vns3_4x_network_security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"confluentinc"},{"field":"Microsoft.Compute/imageOffer","in":["confluentplatform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"consensys"},{"field":"Microsoft.Compute/imageOffer","in":["truffle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"convertigo"},{"field":"Microsoft.Compute/imageOffer","in":["convertigo-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"corda"},{"field":"Microsoft.Compute/imageOffer","in":["corda"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"CoreOS"},{"field":"Microsoft.Compute/imageOffer","in":["CoreOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"couchbase"},{"field":"Microsoft.Compute/imageOffer","in":["couchbase-server-enterprise","couchbase-sync-gateway-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"credativ"},{"field":"Microsoft.Compute/imageOffer","in":["Debian"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cryptzone"},{"field":"Microsoft.Compute/imageOffer","in":["appgate-appliance-3_2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cybernetica-as"},{"field":"Microsoft.Compute/imageOffer","in":["uxp-securityserver-connector","uxp-securityserver_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"cyxtera"},{"field":"Microsoft.Compute/imageOffer","in":["appgatesdp-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataart"},{"field":"Microsoft.Compute/imageOffer","in":["devicehive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"databricks"},{"field":"Microsoft.Compute/imageOffer","in":["spfqogzeculbhdh"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datalayer"},{"field":"Microsoft.Compute/imageOffer","in":["datalayer-notebook"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datastax"},{"field":"Microsoft.Compute/imageOffer","in":["datastax-enterprise","datastax-enterprise-non-production-use-only"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datasunrise"},{"field":"Microsoft.Compute/imageOffer","in":["datasunrise-database-security-suite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dataiku"},{"field":"Microsoft.Compute/imageOffer","in":["dataiku-data-science-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"datometry"},{"field":"Microsoft.Compute/imageOffer","in":["hyper-q"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dellemc"},{"field":"Microsoft.Compute/imageOffer","in":["dell-emc-avamar-virtual-edition","dell-emc-datadomain-management-center","dell-emc-datadomain-virtual-edition","dell-emc-datadomain-virtual-edition-v4","dell-emc-networker-virtual-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"delphix"},{"field":"Microsoft.Compute/imageOffer","in":["delphix_dynamic_data_platform","omniosce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denodo"},{"field":"Microsoft.Compute/imageOffer","in":["denodo-platform","denodo-platform-7_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"denyall"},{"field":"Microsoft.Compute/imageOffer","in":["denyall-rweb","denyall-vulnerability-manager","denyall-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dgsecure"},{"field":"Microsoft.Compute/imageOffer","in":["dgsecure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"diladele"},{"field":"Microsoft.Compute/imageOffer","in":["websafety"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dimensionalmechanics-inc"},{"field":"Microsoft.Compute/imageOffer","in":["neopulse-ai-studio","neopulse-query-runtime"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"docker"},{"field":"Microsoft.Compute/imageOffer","in":["docker-ce","docker-ce-edge","docker-datacenter-custom","docker-ee","docker-ee-basic","docker4azure","docker4azure-cs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dome9"},{"field":"Microsoft.Compute/imageOffer","in":["dome9ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drizti"},{"field":"Microsoft.Compute/imageOffer","in":["hpcbox-ansys-19-cluster-master","hpcbox-cluster-compute-node","hpcbox-cluster-cuda-node","hpcbox-cluster-gpu-node","hpcbox-docker-cluster-master","hpcbox-openfoam-cluster-master","hpcbox-su2-cluster-master"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"drone"},{"field":"Microsoft.Compute/imageOffer","in":["drone"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dyadic_security"},{"field":"Microsoft.Compute/imageOffer","in":["dyadic_sec","ukc_image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"dynatrace"},{"field":"Microsoft.Compute/imageOffer","in":["ruxit-managed-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"eastwind-networks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["eastwind-ixia-sensor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"egnyte"},{"field":"Microsoft.Compute/imageOffer","in":["egnyte-connect"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elasticbox"},{"field":"Microsoft.Compute/imageOffer","in":["elasticbox-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"electric-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["electricflowce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"elfiqnetworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"emercoin"},{"field":"Microsoft.Compute/imageOffer","in":["emercoin"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprise-ethereum-alliance"},{"field":"Microsoft.Compute/imageOffer","in":["quorum-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"enterprisedb-corp"},{"field":"Microsoft.Compute/imageOffer","in":["edb-postgres-ark"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"equalum"},{"field":"Microsoft.Compute/imageOffer","in":["equalum-vm-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"esdenera"},{"field":"Microsoft.Compute/imageOffer","in":["esdenera-firewall-3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ethereum"},{"field":"Microsoft.Compute/imageOffer","in":["ethereum-studio"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"evostream-inc"},{"field":"Microsoft.Compute/imageOffer","in":["ems-for-template","ems-test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"exasol"},{"field":"Microsoft.Compute/imageOffer","in":["exasol-analytics-database-byol","exasolution-analytic-database"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"falconstorsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["fss-v9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"f5-networks"},{"field":"Microsoft.Compute/imageOffer","in":["f5-big-ip-adc","f5-big-ip-advanced-waf","f5-big-ip-best","f5-big-ip-better","f5-big-ip-byol","f5-big-ip-good","f5-big-ip-per-app-ve","f5-big-iq","f5-web-application-firewall"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"filecatalyst"},{"field":"Microsoft.Compute/imageOffer","in":["filecatalyst-direct-per-hr-billing","filecatalyst-direct-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"firehost"},{"field":"Microsoft.Compute/imageOffer","in":["firehost_armor","firehost_armor_ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flexify-io"},{"field":"Microsoft.Compute/imageOffer","in":["single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"flashgrid-inc"},{"field":"Microsoft.Compute/imageOffer","in":["flashgrid-racnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"foghorn-systems"},{"field":"Microsoft.Compute/imageOffer","in":["foghorn-edge-device-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forcepoint-llc"},{"field":"Microsoft.Compute/imageOffer","in":["forcepoint-ngfw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"forscene"},{"field":"Microsoft.Compute/imageOffer","in":["forscene-edgeserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortycloud"},{"field":"Microsoft.Compute/imageOffer","in":["fortycloud-gw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fortinet"},{"field":"Microsoft.Compute/imageOffer","in":["fortinet-fortianalyzer","fortinet-fortimanager","fortinet_fortigate-vm_v5","fortinet_fortimail","fortinet_fortivoice","fortinet_fortiweb-vm_v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"fujitsu_fast"},{"field":"Microsoft.Compute/imageOffer","in":["fep10-rh7-test","feptest"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gemalto-safenet"},{"field":"Microsoft.Compute/imageOffer","in":["safenet-keysecure-k170v","safenet-protectv","safenet-protectv-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gigamon-inc"},{"field":"Microsoft.Compute/imageOffer","in":["gigamon-fm-5_3_01","gigamon-fm-5_3_01_hourly","gigamon-fm-5_4_00","gigamon-fm-5_4_00_hourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gitlab"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-ce","gitlab-ee"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"GitHub"},{"field":"Microsoft.Compute/imageOffer","in":["GitHub-Enterprise","githubenterprise-test-publishing"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"great-software-laboratory-private-limited"},{"field":"Microsoft.Compute/imageOffer","in":["xid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"greensql"},{"field":"Microsoft.Compute/imageOffer","in":["greensql-database-security"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"gridgain"},{"field":"Microsoft.Compute/imageOffer","in":["gridgain-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"guardicore"},{"field":"Microsoft.Compute/imageOffer","in":["guardicorecentra","infection_monkey"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haivision"},{"field":"Microsoft.Compute/imageOffer","in":["haivision-media-gateway-1-2","haivision-media-gateway-1-5","haivision-media-gateway-1-6-2","media-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"h2o-ai"},{"field":"Microsoft.Compute/imageOffer","in":["h2o-driverles-ai","h2o-driverless-ai","h2o-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"haproxy-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hapee-rhel","hapee-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"harpaitalia"},{"field":"Microsoft.Compute/imageOffer","in":["mcuboenergy","yg","yougreen_trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hcl-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["hcl17cp1104"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"heimdall-data"},{"field":"Microsoft.Compute/imageOffer","in":["heimdall-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"help-systems"},{"field":"Microsoft.Compute/imageOffer","in":["goanywheremftubuntulinux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hewlett-packard"},{"field":"Microsoft.Compute/imageOffer","in":["hpe-helion-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hillstone-networks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudedge-virtual-ngfw-advanced-edition","cloudedge-virtual-ngfw-standard-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hortonworks"},{"field":"Microsoft.Compute/imageOffer","in":["cloudbreak-for-hortonworks-data-platform","hortonworks-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hitachi-solutions"},{"field":"Microsoft.Compute/imageOffer","in":["credeon-sfs-and-kms-for-sharepoint-online","credeonsecurefull-textsearch1_0"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hpe"},{"field":"Microsoft.Compute/imageOffer","in":["storeoncevsa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"huawei"},{"field":"Microsoft.Compute/imageOffer","in":["euleros-v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hyperglance"},{"field":"Microsoft.Compute/imageOffer","in":["hyperglance-dynamic-topology"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hypergrid"},{"field":"Microsoft.Compute/imageOffer","in":["hyperform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"hytrust"},{"field":"Microsoft.Compute/imageOffer","in":["hytrust-keycontrol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ibm"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-security-guardium-multi-cloud","qradar_security_analytics"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iaansys"},{"field":"Microsoft.Compute/imageOffer","in":["iaansys-magento"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iboss"},{"field":"Microsoft.Compute/imageOffer","in":["iboss-14600-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imaginecommunications"},{"field":"Microsoft.Compute/imageOffer","in":["cloudxtream-cdvr","cloudxtream-dai-vms","telurio-aim"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"imperva"},{"field":"Microsoft.Compute/imageOffer","in":["imperva-dam-v13","securesphere-waf","securesphere-waf-for-azr","securesphere-waf-v12","securesphere-waf-v13"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"infoblox"},{"field":"Microsoft.Compute/imageOffer","in":["infoblox-vnios-te-v1420"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informatica"},{"field":"Microsoft.Compute/imageOffer","in":["bdm10-1-1-u2","big-data-management-10-2","big-data-management-10-2-1","data_accelerator_for_azure_byol","data_quality_10_1_1_rhel_7_3_byol","eic","ics-byol","ics-payg-ubuntu","platform_10_1_1_multi_node_domain_rhel-7-3_byol","platform_10_2_hf1_domain_rhel-7-3_byol","powercenter-v10-domain-image-ubuntu14-04-3","powercenter-v10-update1-domain-image-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"informationbuilders"},{"field":"Microsoft.Compute/imageOffer","in":["iway-big-data-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ingrammicro"},{"field":"Microsoft.Compute/imageOffer","in":["ingrammicroensimcentostrial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel"},{"field":"Microsoft.Compute/imageOffer","in":["lustre-cloud-edition-gs-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-bigdl"},{"field":"Microsoft.Compute/imageOffer","in":["bigdl-0815","bigdl__vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intel-fpga"},{"field":"Microsoft.Compute/imageOffer","in":["quartus_pro_opencl_sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intellicus-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["intellicus_bi_server_100_user_linux","intellicus_bi_server_10_user_linux","intellicus_bi_server_25_user_linux","intellicus_bi_server_50_user_linux","intellicus_bi_server_5_user_linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intersystems"},{"field":"Microsoft.Compute/imageOffer","in":["intersystems-iris-single-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"intigua"},{"field":"Microsoft.Compute/imageOffer","in":["intigua-agent-manager-3_7_0-trial","intigua-agent-manager-trial"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"iquest"},{"field":"Microsoft.Compute/imageOffer","in":["keyhub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ishlangu-load-balancer-adc"},{"field":"Microsoft.Compute/imageOffer","in":["ishlangu-load-balancer-byol","ishlangu-load-balancer-is10","ishlangu-load-balancer-is100","ishlangu-load-balancer-is1000","ishlangu-load-balancer-is200","ishlangu-load-balancer-is5000","ishlangu-load-balancer-isbfg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"issp-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["ispocr"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"itelios"},{"field":"Microsoft.Compute/imageOffer","in":["magento2-on-zendserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jamcracker"},{"field":"Microsoft.Compute/imageOffer","in":["4632d5b4-feb0-4332-8452-f2e66133672f","jamcracker-cloudanalytics","jamcracker-cloudanalytics-version4","jamcracker-cloudanalytics-version5","jamcracker-csb-service-provider","jamcracker-csb-serviceprovider","jamcracker-csb-standard","jamcracker-csb-standard-v3","jamcracker-csb-standard-version4","jamcracker-hybrid-cloud-management-version4","jamcracker_cloud_control_appliance_version4","jsdnapp_csb_serviceprovider-version4","jsdnapp_hybrid","jsdnapp_hybrid_v3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jedox"},{"field":"Microsoft.Compute/imageOffer","in":["jedox-for-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jelastic"},{"field":"Microsoft.Compute/imageOffer","in":["jelastic-hybrid-paas-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetnexus"},{"field":"Microsoft.Compute/imageOffer","in":["dvwa","jetnexus-application-load-balancer","jetnexus-global-load-balancer","jetnexus-waf","zap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jetware-srl"},{"field":"Microsoft.Compute/imageOffer","in":["caffe2","caffe_python_cpu","caffe_python_gpu","cockroachdb","lamp_optimized","lemp7_optimized","memcached","mongodb","mxnet_python","mysql","nodejs_nginx","percona_mongodb","percona_mysql","postgresql","pytorch","pytorch_cuda_notebook","pytorch_cuda_production","redis","redmine","tensorflow_cpu_notebook","tensorflow_cpu_production","tensorflow_cuda_notebook","tensorflow_cuda_production","tensorflow_python","theano_python","wordpress4_lemp7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jitterbit_integration"},{"field":"Microsoft.Compute/imageOffer","in":["jitterbit-harmony-agent"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"jm-technology-inc"},{"field":"Microsoft.Compute/imageOffer","in":["smart-gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"juniper-networks"},{"field":"Microsoft.Compute/imageOffer","in":["vmx-services-gateway-byol","vmx-services-gateway-byol-soltemp","vmx-virtual-router","vsrx-next-generation-firewall","vsrx-next-generation-firewall-payg","vsrx-next-generation-firewall-solution-templ-payg","vsrx-next-generation-firewall-solution-template"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaazing"},{"field":"Microsoft.Compute/imageOffer","in":["kaazing-kwic","kaazing-vpa"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kali-linux"},{"field":"Microsoft.Compute/imageOffer","in":["kali-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kemptech"},{"field":"Microsoft.Compute/imageOffer","in":["kemp360central-byol","vlm-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kinetica"},{"field":"Microsoft.Compute/imageOffer","in":["kineticadbbyol","kineticadbpayasyougo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"kaspersky_lab"},{"field":"Microsoft.Compute/imageOffer","in":["kaspersky_secure_mail_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"knime"},{"field":"Microsoft.Compute/imageOffer","in":["knime-server-5-user_4-4-0","knime-server-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"krypc-technologies-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["krypccore"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leap-orbit"},{"field":"Microsoft.Compute/imageOffer","in":["leaporbitstoragebackedsftp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"leostream-corporation"},{"field":"Microsoft.Compute/imageOffer","in":["connection-broker"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquid-files"},{"field":"Microsoft.Compute/imageOffer","in":["liquidfiles"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"liquidware"},{"field":"Microsoft.Compute/imageOffer","in":["stratusphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"literatu"},{"field":"Microsoft.Compute/imageOffer","in":["literatu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"loadbalancer"},{"field":"Microsoft.Compute/imageOffer","in":["loadbalancer-org-load-balancer-for-azure","loadbalancer-org-load-balancer-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logsign"},{"field":"Microsoft.Compute/imageOffer","in":["logsignfocus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"logtrust"},{"field":"Microsoft.Compute/imageOffer","in":["logtrust-log-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"looker"},{"field":"Microsoft.Compute/imageOffer","in":["looker-analytics-platform","looker-analytics-platform-326","looker-analytics-platform-5_6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"lti-lt-infotech"},{"field":"Microsoft.Compute/imageOffer","in":["trade-finance-blockchain"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"luminate-security"},{"field":"Microsoft.Compute/imageOffer","in":["luminate-connector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mapr-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["mapr52-base-dev","mapr60-base","mapr60-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mariadb"},{"field":"Microsoft.Compute/imageOffer","in":["mariadb-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"marklogic"},{"field":"Microsoft.Compute/imageOffer","in":["marklogic-9-byol","marklogic-developer-9"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"massiveanalytic-"},{"field":"Microsoft.Compute/imageOffer","in":["oscarap"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mathworks-inc"},{"field":"Microsoft.Compute/imageOffer","in":["matlab-ref-arch-18a-v1-linux-disk","mps-ref-arch-18a-v1-linux-disk2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"matillion"},{"field":"Microsoft.Compute/imageOffer","in":["matillion-etl-snowflake"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mavinglobal"},{"field":"Microsoft.Compute/imageOffer","in":["mavin-business-trial","mavin-enterprise-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"meanio"},{"field":"Microsoft.Compute/imageOffer","in":["gitlab-enterprise-ready","linnovate-open-source-sla-pro","mean-machine-20","openideal3","redash"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"media3-technologies-llc"},{"field":"Microsoft.Compute/imageOffer","in":["cpan1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"memsql"},{"field":"Microsoft.Compute/imageOffer","in":["memsql-community-single-vm","memsql-enterprise-single-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mendix"},{"field":"Microsoft.Compute/imageOffer","in":["mendix-docker","mendix-pro"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mfe_azure"},{"field":"Microsoft.Compute/imageOffer","in":["atd-mcafee","mcafee_vnsp_controller_for_azure","mcafee_vnsp_for_azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-ads"},{"field":"Microsoft.Compute/imageOffer","in":["linux-data-science-vm","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-aks"},{"field":"Microsoft.Compute/imageOffer","in":["aks"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"micro-focus"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-avere"},{"field":"Microsoft.Compute/imageOffer","in":["vfxt"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-batch"},{"field":"Microsoft.Compute/imageOffer","in":["centos-container","centos-container-rdma","ubuntu-server-container","ubuntu-server-container-rdma"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-azure-compute"},{"field":"Microsoft.Compute/imageOffer","in":["azureconfidentialcompute"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"microsoft-dsvm"},{"field":"Microsoft.Compute/imageOffer","in":["azureml","linux-data-science-vm-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftAzureSiteRecovery"},{"field":"Microsoft.Compute/imageOffer","in":["ASR-Hydration-VMs"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftOSTC"},{"field":"Microsoft.Compute/imageOffer","in":["FreeBSD"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftRServer"},{"field":"Microsoft.Compute/imageOffer","in":["MLServer-CentOS","MLServer-RedHat","MLServer-Ubuntu","RServer-CentOS","RServer-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midfin"},{"field":"Microsoft.Compute/imageOffer","in":["mf_neon_cgw"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"midvision"},{"field":"Microsoft.Compute/imageOffer","in":["ibm-datapower-virtual-edition-75","ibm-datapower-virtual-edition-76","ibm-datapower-virtual-edition-77","ibm-http-server","ibm-websphere-portal-server-85","ibm-websphere-portal-server-90","websphere-application-server-be","websphere-application-server-be-80","websphere-application-server-be-85","websphere-application-server-be-90","websphere-application-server-be-and-mq","websphere-application-server-lp","websphere-application-server-lp-16","websphere-application-server-lp-17","websphere-application-server-lp-18","websphere-application-server-nde","websphere-application-server-nde-80","websphere-application-server-nde-85","websphere-application-server-nde-90","websphere-mq","websphere-mq-75","websphere-mq-90","websphere-mq-91"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miraclelinux"},{"field":"Microsoft.Compute/imageOffer","in":["asianux-server-4-sp5","asianux-server-4-sp6","asianux-server-4-sp7","asianux-server-7-sp1","asianux-server-7-sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"miri-infotech-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mobilab"},{"field":"Microsoft.Compute/imageOffer","in":["magento-wirecard-checkout"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moogsoft"},{"field":"Microsoft.Compute/imageOffer","in":["moogsoft-aiops"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"moviemasher"},{"field":"Microsoft.Compute/imageOffer","in":["moviemasher"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"MicrosoftSQLServer"},{"field":"Microsoft.Compute/imageOffer","in":["SQL2017-RHEL7","SQL2017-RHEL73","SQL2017-SLES12SP2","SQL2017-Ubuntu1604","SQL2019-RHEL7","SQL2019-Ubuntu1604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mtnfog"},{"field":"Microsoft.Compute/imageOffer","in":["idyl-e3-entity-extraction-engine","prose-sentence-extraction-engine","renku-language-detection-engine","sonnet-tokenization-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"mxhero"},{"field":"Microsoft.Compute/imageOffer","in":["mail2cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"my-com"},{"field":"Microsoft.Compute/imageOffer","in":["tarantool"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"narrativescience"},{"field":"Microsoft.Compute/imageOffer","in":["narratives-for-power-bi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nasuni"},{"field":"Microsoft.Compute/imageOffer","in":["nasuni-nmc","nasuni_edge_appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ncbi"},{"field":"Microsoft.Compute/imageOffer","in":["ncbi-blast-2-3-0","ncbi-free-2-2-31"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nebbiolo-technologies-inc"},{"field":"Microsoft.Compute/imageOffer","in":["fog-system-manager","fogsm_basic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neo4j"},{"field":"Microsoft.Compute/imageOffer","in":["neo4j-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netapp"},{"field":"Microsoft.Compute/imageOffer","in":["netapp-altavault-cloud-integrated-storage-solution","netapp-oncommand-cloud-manager","netapp-ontap-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netgate"},{"field":"Microsoft.Compute/imageOffer","in":["netgate-pfsense-azure-fw-vpn-router"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netiq"},{"field":"Microsoft.Compute/imageOffer","in":["replication_environment"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netscout"},{"field":"Microsoft.Compute/imageOffer","in":["netscout_virtual_ngeniusone_with_vscout","netscout_vstream"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netmail"},{"field":"Microsoft.Compute/imageOffer","in":["netmail-search"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netsweeper"},{"field":"Microsoft.Compute/imageOffer","in":["netsweeper6-0-6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"netx"},{"field":"Microsoft.Compute/imageOffer","in":["simplehelp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"neusoft-neteye"},{"field":"Microsoft.Compute/imageOffer","in":["neusoft-nisg-va-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nginxinc"},{"field":"Microsoft.Compute/imageOffer","in":["nginx-plus-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nicepeopleatwork"},{"field":"Microsoft.Compute/imageOffer","in":["youzana"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nodejsapi"},{"field":"Microsoft.Compute/imageOffer","in":["node-js-api"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"noobaa"},{"field":"Microsoft.Compute/imageOffer","in":["noobaa-hybrid-s3-archive-05","noobaa-multi-cloud-deduplication"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"northbridge-secure"},{"field":"Microsoft.Compute/imageOffer","in":["netconnect1","netconnectx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nubeva-inc"},{"field":"Microsoft.Compute/imageOffer","in":["controller","test"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuco-networks"},{"field":"Microsoft.Compute/imageOffer","in":["aionnode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nuxeo"},{"field":"Microsoft.Compute/imageOffer","in":["nuxeo-6-lts","nuxeo-lts"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"nvidia"},{"field":"Microsoft.Compute/imageOffer","in":["ngc_azure_17_11"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"o2mc-real-time-data-platform"},{"field":"Microsoft.Compute/imageOffer","in":["o2mc-platform-app"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"oceanblue-cloud"},{"field":"Microsoft.Compute/imageOffer","in":["obc-sdwan-solutions"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"omega-software"},{"field":"Microsoft.Compute/imageOffer","in":["ods_datastage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onyx-point-inc"},{"field":"Microsoft.Compute/imageOffer","in":["op-bnf-v1","op-bnf1_6-v1","op-bpnifi-v1","op-bpnifi16-v1","op-scc-v1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"onapsis"},{"field":"Microsoft.Compute/imageOffer","in":["osp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"op5"},{"field":"Microsoft.Compute/imageOffer","in":["op5-monitor"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"opencell"},{"field":"Microsoft.Compute/imageOffer","in":["meveo","meveo403sp2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"OpenLogic"},{"field":"Microsoft.Compute/imageOffer","in":["CentOS","CentOS-CI","CentOS-HPC","CentOS-LVM","CentOS-SRIOV"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"openvpn"},{"field":"Microsoft.Compute/imageOffer","in":["openvpnas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"Oracle"},{"field":"Microsoft.Compute/imageOffer","in":["Oracle-Database-Ee","Oracle-Database-Se","Oracle-Linux","Oracle-WebLogic-Server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"orientdb"},{"field":"Microsoft.Compute/imageOffer","in":["orientdb-community-edition","orientdb-community-edition-2_2","orientdb-enterprise-edition-2_2","orientdb-enterprise-edition-2_2_17"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osirium-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["osirium-pxm-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"osnexus"},{"field":"Microsoft.Compute/imageOffer","in":["quantastorvsav4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"paloaltonetworks"},{"field":"Microsoft.Compute/imageOffer","in":["panorama","vmseries1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"panzura-file-system"},{"field":"Microsoft.Compute/imageOffer","in":["azura-freedom-filer-v7110","panzura-cloud-filer","panzura-freedom-filer-7140-13222","panzura-freedom-filer-716-13549","panzura-freedom-filer-v7020"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"parasoft"},{"field":"Microsoft.Compute/imageOffer","in":["parasoft-service-virtualization"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"passlogy"},{"field":"Microsoft.Compute/imageOffer","in":["passlogic"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"penta-security-systems-inc"},{"field":"Microsoft.Compute/imageOffer","in":["wapples"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"percona"},{"field":"Microsoft.Compute/imageOffer","in":["percona-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"postgres-pro"},{"field":"Microsoft.Compute/imageOffer","in":["postgres-pro-enterprise","postgres-pro-enterprise-10","postgres-pro-standard","postgres-pro-standard-10"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"plesk"},{"field":"Microsoft.Compute/imageOffer","in":["plesk-onyx-linux","solution-server-business","solution-server-wordpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prestashop"},{"field":"Microsoft.Compute/imageOffer","in":["prestashop16-lamp","ubuntu-base-for-prestashop"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"prime-strategy"},{"field":"Microsoft.Compute/imageOffer","in":["kusanagi-77"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pivotal"},{"field":"Microsoft.Compute/imageOffer","in":["pivotal-gpdb-vm","pivotal-greenplum-images","pivotal-ops-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"process-one"},{"field":"Microsoft.Compute/imageOffer","in":["ejabberd-community-edition"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"profecia"},{"field":"Microsoft.Compute/imageOffer","in":["full_disk_encryption_vm","project_tools_vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"progelspa"},{"field":"Microsoft.Compute/imageOffer","in":["libra-esva-antispam"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ptsecurity"},{"field":"Microsoft.Compute/imageOffer","in":["ptaf-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pulse-secure"},{"field":"Microsoft.Compute/imageOffer","in":["pulse-connect-secure-vm","pulse-virtual-traffic-manager","pulse-virtual-traffic-manager-with-waf","pulse-virtual-traffic-manager-with-waf2","pulse-virtual-traffic-manager2","pulse-virtual-web-application-firewall","pulse-virtual-web-application-firewall2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"PuppetLabs"},{"field":"Microsoft.Compute/imageOffer","in":["PuppetEnterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"puppet"},{"field":"Microsoft.Compute/imageOffer","in":["puppet-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"pydio"},{"field":"Microsoft.Compute/imageOffer","in":["pydio-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qore-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["qorus"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qualysguard"},{"field":"Microsoft.Compute/imageOffer","in":["qualys-virtual-firewall-appliance","qualys-virtual-scanner-v23b","qualys-virtual-scanner-v24"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quasardb"},{"field":"Microsoft.Compute/imageOffer","in":["quasardb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"qubole-inc"},{"field":"Microsoft.Compute/imageOffer","in":["qubole-data-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"quest"},{"field":"Microsoft.Compute/imageOffer","in":["fve"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"racknap"},{"field":"Microsoft.Compute/imageOffer","in":["racknap-server","racknap-server-linux"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radware"},{"field":"Microsoft.Compute/imageOffer","in":["radware-alteon-va"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"radiant-logic"},{"field":"Microsoft.Compute/imageOffer","in":["radiantone-vms"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rancher"},{"field":"Microsoft.Compute/imageOffer","in":["rancheros"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapid7"},{"field":"Microsoft.Compute/imageOffer","in":["nexpose-scan-engine","rapid7-vm-console"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rapidminer"},{"field":"Microsoft.Compute/imageOffer","in":["rapidminer_server_75","rapidminer_server_76","rapidminer_server_80","rapidminer_server_81"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"realm"},{"field":"Microsoft.Compute/imageOffer","in":["realm-mobile-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"reblaze"},{"field":"Microsoft.Compute/imageOffer","in":["rbzr-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RedHat"},{"field":"Microsoft.Compute/imageOffer","in":["osa","RHEL","rhel-byos","rhel-ocp-marketplace","RHEL-SAP","RHEL-SAP-APPS","RHEL-SAP-HANA"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"relevance-lab"},{"field":"Microsoft.Compute/imageOffer","in":["rlcatalyst"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"remotelearner"},{"field":"Microsoft.Compute/imageOffer","in":["fully-supported-moodle"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"revolution-analytics"},{"field":"Microsoft.Compute/imageOffer","in":["revolution-r-enterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RightScaleLinux"},{"field":"Microsoft.Compute/imageOffer","in":["RightImage-CentOS","RightImage-Ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"RiverbedTechnology"},{"field":"Microsoft.Compute/imageOffer","in":["steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"riverbed"},{"field":"Microsoft.Compute/imageOffer","in":["riverbed-sccm-5-5-1","riverbed-steelcentral-appinternals","riverbed-steelhead-9-2","riverbed-steelhead-9-5-0","riverbed-steelhead-9-6-0","riverbed_steelconnect_gw","riverbed_steelconnect_sh","steelapp_traffic_manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rocketsoftware"},{"field":"Microsoft.Compute/imageOffer","in":["rocket-discover"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsa-security-llc"},{"field":"Microsoft.Compute/imageOffer","in":["rsa-nw-azure-arch","rsa-nw-azure-broker","rsa-nw-azure-con","rsa-nw-azure-esa","rsa-nw-azure-ldec","rsa-nw-azure-vlc","rsa-nw-suite-11","rsa-nw-suite-11-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"rsk-labs"},{"field":"Microsoft.Compute/imageOffer","in":["rsk-bamboo-beta-node","rsk-node-orchid"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saama"},{"field":"Microsoft.Compute/imageOffer","in":["fluidanalyticsengine","insurancefraudanalytics","realworldevidence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"saltstack"},{"field":"Microsoft.Compute/imageOffer","in":["centos65saltstackenterprise"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalearc"},{"field":"Microsoft.Compute/imageOffer","in":["scalearc-for-mysql-paygo","scalearc-for-sql-server-pay-go","scalearc_mysql-server","scalearc_sql_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scalegrid"},{"field":"Microsoft.Compute/imageOffer","in":["centos"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sap"},{"field":"Microsoft.Compute/imageOffer","in":["hanaexpress"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"scality"},{"field":"Microsoft.Compute/imageOffer","in":["scalityconnecthourly"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"secureworks"},{"field":"Microsoft.Compute/imageOffer","in":["scwx-azure-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"shadow-soft"},{"field":"Microsoft.Compute/imageOffer","in":["icinga","icinga2-5","icinga2-7"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"signal-sciences"},{"field":"Microsoft.Compute/imageOffer","in":["signalscienceswpp"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sightapps"},{"field":"Microsoft.Compute/imageOffer","in":["sightapps"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"silver-peak-systems"},{"field":"Microsoft.Compute/imageOffer","in":["silver_peak_edgeconnect","silver_peak_vx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"simmachinesinc"},{"field":"Microsoft.Compute/imageOffer","in":["simmachines_vm_v2"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sinefa"},{"field":"Microsoft.Compute/imageOffer","in":["sinefa-probe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"skyarc"},{"field":"Microsoft.Compute/imageOffer","in":["mt6","mta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"smartmessage-autoflow"},{"field":"Microsoft.Compute/imageOffer","in":["martmessage-autoflow"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"snapt-adc"},{"field":"Microsoft.Compute/imageOffer","in":["snaptadc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soasta"},{"field":"Microsoft.Compute/imageOffer","in":["cloudtest-lite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"softnas"},{"field":"Microsoft.Compute/imageOffer","in":["cloud_dev","mp_ce","mp_ent","mp_nas_byol","mp_nas_ep","mp_nas_gp","mp_nas_hp","mp_plat","private_offerings","softnas-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solanolabs"},{"field":"Microsoft.Compute/imageOffer","in":["solano-ci-private-beta"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"soha"},{"field":"Microsoft.Compute/imageOffer","in":["soha-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"solar-security"},{"field":"Microsoft.Compute/imageOffer","in":["solar-incode"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sonicwall-inc"},{"field":"Microsoft.Compute/imageOffer","in":["sonicwall-nsz-azure","waf"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sophos"},{"field":"Microsoft.Compute/imageOffer","in":["sophos-xg"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spagobi"},{"field":"Microsoft.Compute/imageOffer","in":["spagobi"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"spacecurve"},{"field":"Microsoft.Compute/imageOffer","in":["spacecurve-quickstart"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"splunk"},{"field":"Microsoft.Compute/imageOffer","in":["splunk-enterprise-base-image"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"src-solution"},{"field":"Microsoft.Compute/imageOffer","in":["pilot-things-onem2m-smart-network"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sqlstream"},{"field":"Microsoft.Compute/imageOffer","in":["com"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"sphere3d"},{"field":"Microsoft.Compute/imageOffer","in":["snapcloud-byol","snapcloud-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackato-platform-as-a-service"},{"field":"Microsoft.Compute/imageOffer","in":["activestate-stackato"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stackstorm"},{"field":"Microsoft.Compute/imageOffer","in":["stackstorm-2015-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"startekfingerprintmatch"},{"field":"Microsoft.Compute/imageOffer","in":["bioserver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"steelhive"},{"field":"Microsoft.Compute/imageOffer","in":["steelhive_carbon"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stonefly"},{"field":"Microsoft.Compute/imageOffer","in":["stonefly-cloud-drive"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stormshield"},{"field":"Microsoft.Compute/imageOffer","in":["stormshield-network-security-for-cloud","stormshield-network-security-for-cloud-xl"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"storreduce"},{"field":"Microsoft.Compute/imageOffer","in":["storreduce"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"stratumn"},{"field":"Microsoft.Compute/imageOffer","in":["indigo-node"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"streamsets"},{"field":"Microsoft.Compute/imageOffer","in":["streamsets-data-collector"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"striim"},{"field":"Microsoft.Compute/imageOffer","in":["integrationforsqlserveronazure","integrationtoazurestorage","integrationtoeventhub","integrationtohdinsight"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"SUSE"},{"field":"Microsoft.Compute/imageOffer","in":["openSUSE-Leap","SLES","SLES-BYOS","SLES-HPC","SLES-HPC-Priority","SLES-Priority","SLES-SAP","SLES-SAP-BYOS","SLES-SAPCAL","SLES-Standard","SUSE-CaaSP-Admin-BYOS","SUSE-CaaSP-Cluster-BYOS","SUSE-Manager-Proxy-BYOS","SUSE-Manager-Server-BYOS"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"symantectest1"},{"field":"Microsoft.Compute/imageOffer","in":["cwpsazure-beta-01"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synack-inc"},{"field":"Microsoft.Compute/imageOffer","in":["synack-crowd-security-intelligence"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"synechron-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["blockchain_tradefinance_quorum"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"syte"},{"field":"Microsoft.Compute/imageOffer","in":["syteoffer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tactic"},{"field":"Microsoft.Compute/imageOffer","in":["tactic-workflow-v001"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talari-networks"},{"field":"Microsoft.Compute/imageOffer","in":["talari-networks-virtual-appliance"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"talena-inc"},{"field":"Microsoft.Compute/imageOffer","in":["talena_inc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tata_communications"},{"field":"Microsoft.Compute/imageOffer","in":["netfoundry_cloud_gateway"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tavendo"},{"field":"Microsoft.Compute/imageOffer","in":["crossbar_on_azure_ubuntu1404"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techdivision"},{"field":"Microsoft.Compute/imageOffer","in":["appserver-io-pe"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"techlatest"},{"field":"Microsoft.Compute/imageOffer","in":["ethereumdevkit","rippledevelopersuit"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"telepat"},{"field":"Microsoft.Compute/imageOffer","in":["free"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tenable"},{"field":"Microsoft.Compute/imageOffer","in":["tenable-nessus-6-byol","tenable-nessus-professional","tenablecorenessus","tenablecorewas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"teradata"},{"field":"Microsoft.Compute/imageOffer","in":["teradata-data-mover","teradata-data-mover-agent","teradata-data-mover-intellisphere","teradata-data-stream-controller","teradata-database-1510","teradata-database-1510-byol","teradata-database-1510-intellisphere","teradata-database-1510-v2","teradata-database-1610-intellisphere","teradata-database-1610-v2","teradata-database-1620","teradata-database-1620-byol","teradata-database-1620-intellisphere","teradata-database-enterprise","teradata-database-v1610","teradata-database-v1610-byol","teradata-ecosystem-manager","teradata-querygrid-manager","teradata-querygrid-manager-intellisphere","teradata-rest-services","teradata-server-management","teradata-viewpoint","teradata-viewpoint-intellisphere"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thales-vormetric"},{"field":"Microsoft.Compute/imageOffer","in":["ciphertrust-ckm","vormetric-dsm","vormetric-dsm-6-1-0","vormetric-tokenization-server","vts-2_2_0_2604"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"things-board"},{"field":"Microsoft.Compute/imageOffer","in":["tb-pe-cassandra"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"thoughtspot-inc"},{"field":"Microsoft.Compute/imageOffer","in":["thoughtspotvirtualmachine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tibco-software"},{"field":"Microsoft.Compute/imageOffer","in":["grid-server-engine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tig"},{"field":"Microsoft.Compute/imageOffer","in":["backup-as-a-service"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tigergraph"},{"field":"Microsoft.Compute/imageOffer","in":["tigergraph"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tmaxsoft"},{"field":"Microsoft.Compute/imageOffer","in":["tmax-jeusee","tmax-jeusse","tmax-webtobse"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tokyosystemhouse"},{"field":"Microsoft.Compute/imageOffer","in":["osscobol151j-pg961-centos72"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"torusware"},{"field":"Microsoft.Compute/imageOffer","in":["speedus-lite-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"totemo"},{"field":"Microsoft.Compute/imageOffer","in":["totemo-azr-tm6"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"townsend-security"},{"field":"Microsoft.Compute/imageOffer","in":["alliance-key-manager"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"trendmicro"},{"field":"Microsoft.Compute/imageOffer","in":["deep-security-vm","deep-security-vm-byol","iot-security-sdk"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"truestack"},{"field":"Microsoft.Compute/imageOffer","in":["tsdc"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tsa-public-service"},{"field":"Microsoft.Compute/imageOffer","in":["ckan-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"tunnelbiz"},{"field":"Microsoft.Compute/imageOffer","in":["centos70-min","centos7optimizwithwordpress","centos7phpoptimizing","centos7phpoptimizingnginx","centos7phpoptimizwlaravel","centos7phpoptimizwosticket","centos7webserverwithwaf","centos7withaspdotnetcore2apache","centos7withjoomla","debian_web_server","fedora","fusio","linuxwithlimesurvey","networkmonitoringsystem","rimauwaf_cloud","ubuntu_server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"twistlock"},{"field":"Microsoft.Compute/imageOffer","in":["twistlock"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"typesafe"},{"field":"Microsoft.Compute/imageOffer","in":["typesafe-reactive-maps-demo"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubeeko"},{"field":"Microsoft.Compute/imageOffer","in":["hfactory-tools-for-hdinsight","hfactory-tools-sandbox"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ubercloud"},{"field":"Microsoft.Compute/imageOffer","in":["ansys-17-2-fluids-structures","ansys_182_test","comsol-multiphysics-v5-2","openfoam-v2dot3-centos-v6","openfoam-v3dot0","star-ccm-v10-04","star-ccm-v10-06-heeds-mdo-v2015","star-ccm-v12-00"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"ulex"},{"field":"Microsoft.Compute/imageOffer","in":["voximal"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unifi-software"},{"field":"Microsoft.Compute/imageOffer","in":["unifi-data-catalog","unifi-dataplatform-2-3-3-vm"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"unitrends"},{"field":"Microsoft.Compute/imageOffer","in":["unitrends-enterprise-backup-azure"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"usp"},{"field":"Microsoft.Compute/imageOffer","in":["unified-streaming-vod-standard"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"varnish"},{"field":"Microsoft.Compute/imageOffer","in":["varnish-cache_","varnish-custom-statistics","varnish-plus-administration-and-statistics","varnish-plus-caching-engine-4"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vaultive-inc"},{"field":"Microsoft.Compute/imageOffer","in":["cloud-security-platform"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vbot"},{"field":"Microsoft.Compute/imageOffer","in":["vbot"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"velocloud"},{"field":"Microsoft.Compute/imageOffer","in":["velocloud-virtual-edge","velocloud-virtual-edge-3x"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vidispine"},{"field":"Microsoft.Compute/imageOffer","in":["vidispine-content-management"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veritas"},{"field":"Microsoft.Compute/imageOffer","in":["cloudpoint-2-0-0","veritas-resiliency-platform-vhd-offer"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"veeam"},{"field":"Microsoft.Compute/imageOffer","in":["veeamhubimage"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vigyanlabs-innovations-pvt-ltd"},{"field":"Microsoft.Compute/imageOffer","in":["ipm-plus-energy-saver"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"viptela"},{"field":"Microsoft.Compute/imageOffer","in":["viptela-vedge-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vizixiotplatformretail001"},{"field":"Microsoft.Compute/imageOffer","in":["vizix-iot-platform-retail-005"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vmturbo"},{"field":"Microsoft.Compute/imageOffer","in":["turbonomic","vmturbo64-opsmgr-5_3"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vte"},{"field":"Microsoft.Compute/imageOffer","in":["slashdb"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"vu-llc"},{"field":"Microsoft.Compute/imageOffer","in":["vu-app-server","vu-facerecogn","vu-fraudanalysis","vu-secureonboarding"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallarm"},{"field":"Microsoft.Compute/imageOffer","in":["wallarm-ng-waf-offer-1"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wallix"},{"field":"Microsoft.Compute/imageOffer","in":["wallix-wabsuite"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"watchguard-technologies"},{"field":"Microsoft.Compute/imageOffer","in":["vm-firebox-cloud"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"waves"},{"field":"Microsoft.Compute/imageOffer","in":["waves"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"websense-apmailpe"},{"field":"Microsoft.Compute/imageOffer","in":["ap-data-email-gateway","forcepoint-email-security-85beta","triton-ap-data"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wmspanel"},{"field":"Microsoft.Compute/imageOffer","in":["nimble-streamer-centos","nimble-streamer-ubuntu"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"wowza"},{"field":"Microsoft.Compute/imageOffer","in":["wowzastreamingengine"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xfinityinc"},{"field":"Microsoft.Compute/imageOffer","in":["d3view-v5"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xtremedata"},{"field":"Microsoft.Compute/imageOffer","in":["dbx"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"yellowfin"},{"field":"Microsoft.Compute/imageOffer","in":["yellowfin-for-azure-byol"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"xyzrd-group-ou"},{"field":"Microsoft.Compute/imageOffer","in":["c73-zultys-mxvirtual"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"your-shop-online"},{"field":"Microsoft.Compute/imageOffer","in":["herefordshire-enterprise-platform-drupal-7","xenofile"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zend"},{"field":"Microsoft.Compute/imageOffer","in":["php-56-zend-server","php-zend-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"z1"},{"field":"Microsoft.Compute/imageOffer","in":["z1-securehub"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zerodown_software"},{"field":"Microsoft.Compute/imageOffer","in":["bcaasforazure","stackbcaas"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zoomdata"},{"field":"Microsoft.Compute/imageOffer","in":["zoomdata-server"]}]},{"allOf":[{"field":"Microsoft.Compute/imagePublisher","equals":"zscaler"},{"field":"Microsoft.Compute/imageOffer","in":["zscaler-private-access"]}]}]}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e6063e2e57f123c2","type":"Microsoft.Authorization/policyDefinitions","name":"e6063e2e57f123c2"},{"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:58.9310187Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"priorities":{"type":"Array","metadata":{"displayName":"Rule + Priority","description":"List of Rule Priority Numbers reserved for Security"}},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups/securityRules"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","In":"[parameters(''priorities'')]"},{"field":"location","In":"[parameters(''allowedLocations'')]"},{"allOf":[{"not":{"field":"name","contains":"Cleanuptool"}},{"not":{"field":"name","contains":"NRMS-Rule-"}}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d","type":"Microsoft.Authorization/policyDefinitions","name":"e695de0794b757d"},{"properties":{"displayName":"nrms-nsg-rule-102_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:16.2005161Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"}},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","equals":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Any"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e788a85b5ac6ce0f","type":"Microsoft.Authorization/policyDefinitions","name":"e788a85b5ac6ce0f"},{"properties":{"displayName":"nrms-nsg-rule-109_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:36.1193587Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/eb9b3ba85853f934","type":"Microsoft.Authorization/policyDefinitions","name":"eb9b3ba85853f934"},{"properties":{"displayName":"nrms-nsg-rule-104_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:24.2401173Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/eed6a81371f5e28b","type":"Microsoft.Authorization/policyDefinitions","name":"eed6a81371f5e28b"},{"properties":{"displayName":"nrms-nsg-rule-107_1.1","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-08T19:20:24.6068273Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"}},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"}},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","equals":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"Any"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/f0e3de3e84e21226","type":"Microsoft.Authorization/policyDefinitions","name":"f0e3de3e84e21226"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-06-26T21:23:26.5935651Z","updatedBy":null,"updatedOn":null},"parameters":{"effect":{"type":"String","metadata":{"displayName":"Effect","description":"Enable + or disable the execution of the policy"},"allowedValues":["Audit","Deny","Disabled"],"defaultValue":"Audit"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}}},"policyRule":{"if":{"allOf":[{"field":"location","in":"[parameters(''allowedLocations'')]"},{"anyOf":[{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"not":{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","notIn":["null",""]}}]},{"allOf":[{"field":"type","equals":"Microsoft.Network/virtualNetworks/subnets"},{"field":"Microsoft.Network/virtualNetworks/subnets/networkSecurityGroup.id","exists":"false"}]}]}]},"then":{"effect":"[parameters(''effect'')]"}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/f828e370e4aad7e8","type":"Microsoft.Authorization/policyDefinitions","name":"f828e370e4aad7e8"},{"properties":{"displayName":"vmvmssfirstpartyidentificationtag_1.5","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-05T18:34:13.0016573Z","updatedBy":null,"updatedOn":null},"parameters":{"tagName":{"type":"String","metadata":{"displayName":"tagName","description":"Opted + in for PKI"},"defaultValue":"platformsettings.host_environment.service.platform_optedin_for_rootcerts"},"tagValue":{"type":"String","metadata":{"displayName":"tagValue","description":"is + this the first party VM?"},"defaultValue":"true"},"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"resourcetagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name","description":"Rule is not deployed if this tag exists on the Virtual + Machine"}},"resourcegrouptagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the resource group level","description":"Rule is not deployed + if this tag exists on the Resource Group"}},"subscriptiontagname":{"type":"String","metadata":{"displayName":"Exclusion + Tag Name at the subscription level","description":"Rule is not deployed if + this tag exists on the Subscription"}}},"policyRule":{"if":{"allOf":[{"field":"type","in":["Microsoft.Compute/virtualMachines","Microsoft.Compute/virtualMachineScaleSets"]},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''resourcetagname''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''resourcegrouptagname'')]]","equals":""},{"value":"[subscription().tags[parameters(''subscriptiontagname'')]]","equals":""},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"}]},"then":{"effect":"modify","details":{"roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/9980e02c-c2be-4d73-94e8-173b1dc7cf3c"],"operations":[{"operation":"add","field":"[concat(''tags['', + parameters(''tagName''), '']'')]","value":"[parameters(''tagValue'')]"}]}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb643d414982627","type":"Microsoft.Authorization/policyDefinitions","name":"fb643d414982627"},{"properties":{"displayName":"nrms-nsg-rule-107_1.3","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:08.0100184Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"value":"[resourceGroup().tags[parameters(''tagname'')]]","equals":""},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[resourceGroup().tags[''SkipNRMSAll'']]","equals":""},{"field":"tags[''autopilotcluster'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotcluster'']]","equals":""},{"field":"tags[''autopilotenvironment'']","exists":"false"},{"value":"[resourceGroup().tags[''autopilotenvironment'']]","equals":""},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1","type":"Microsoft.Authorization/policyDefinitions","name":"fb6de85c9e746cf1"},{"properties":{"displayName":"nrms-nsg-rule-108_1.2","policyType":"Custom","mode":"All","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-07-09T18:15:32.8982907Z","updatedBy":null,"updatedOn":null},"parameters":{"allowedLocations":{"type":"Array","metadata":{"displayName":"Allowed + locations","description":"The list of locations that can be specified when + deploying resources.","strongType":"location"}},"ruleNo":{"type":"String","metadata":{"displayName":"Priority","description":"The + priority slot for the new rule"},"allowedValues":["100","101","102","103","104","105","106","107","108","109"]},"info":{"type":"String","metadata":{"displayName":"Description","description":"A + description"},"defaultValue":""},"destinationPortRanges":{"type":"Array","metadata":{"displayName":"Port + Number","description":"Security rule port numbers must match these numbers"}},"subscriptionExclusions":{"type":"Array","metadata":{"displayName":"Subscriptions + Excluded","description":"Subscriptions excluded from policy due to security + exceptions"},"defaultValue":[]},"protocol":{"type":"String","metadata":{"displayName":"protocol","description":"Protocol + for the rule"},"allowedValues":["*","Tcp","Udp"]},"sourceType":{"type":"String","metadata":{"displayName":"sourceType","description":null},"allowedValues":["IP + Addresses","Service Tag","App Security Group"]},"sourceValue":{"type":"String","metadata":{"displayName":"sourceValue","description":null}},"actionValue":{"type":"String","metadata":{"displayName":"actionValue","description":null},"allowedValues":["Allow","Deny"]},"direction":{"type":"String","metadata":{"displayName":"direction","description":null},"allowedValues":["Inbound","Outbound"]},"tagname":{"type":"String","metadata":{"displayName":"Tag + Name","description":"Rule is not deployed if this tag exists on the NSG"},"allowedValues":["NA","NRMSException","SkipNRMSCorp","nrmsskipcorpnetsaw","SkipNRMSSAW","SkipNRMSDatabricks","SkipNRMSRDPSSH","SkipNRMSMgmt","SkipNRMSHigh","SkipNRMSVNet","SkipNRMSLoadBal","SkipNRMSDB","SkipNRMSMedium"],"defaultValue":"NA"}},"policyRule":{"if":{"allOf":[{"field":"type","equals":"Microsoft.Network/networkSecurityGroups"},{"field":"location","in":"[parameters(''allowedLocations'')]"},{"field":"[concat(''tags['', + parameters(''tagName''), '']'')]","exists":"false"},{"field":"tags[''SkipNRMSAll'']","exists":"false"},{"value":"[subscription().subscriptionId]","notIn":"[parameters(''subscriptionExclusions'')]"}]},"then":{"effect":"deployIfNotExists","details":{"type":"Microsoft.Network/networkSecurityGroups/securityRules","roleDefinitionIds":["/providers/Microsoft.Authorization/roleDefinitions/4d97b98b-1d4f-4787-a291-c67834d212e7"],"existenceCondition":{"anyOf":[{"allOf":[{"field":"fullName","equals":"[concat(field(''name''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"[parameters(''ruleno'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","equals":"[parameters(''sourceValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"[parameters(''actionValue'')]"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"[parameters(''direction'')]"}]},{"allOf":[{"field":"fullName","contains":"Cleanuptool-Deny-103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/priority","equals":"103"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/sourceAddressPrefix","in":["Any","*"]},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/access","equals":"Deny"},{"field":"Microsoft.Network/networkSecurityGroups/securityRules/direction","equals":"Inbound"}]}]},"deployment":{"properties":{"mode":"incremental","template":{"$schema":"https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#","contentVersion":"1.0.0.0","parameters":{"fullName":{"type":"string"},"ruleNo":{"type":"String"},"destinationPortRanges":{"type":"Array"},"protocol":{"type":"String"},"sourceType":{"type":"String"},"sourceValue":{"type":"String"},"actionValue":{"type":"String"},"direction":{"type":"String"},"info":{"type":"String"}},"variables":{"SourceArr":"[split(parameters(''sourceValue''),'','')]","appSecGroups":{"copy":[{"name":"values","count":"[length(variables(''SourceArr''))]","input":{"id":"[if(equals(parameters(''sourceType''),''App + Security Group''),if(contains(variables(''SourceArr'')[copyindex(''values'')],''subscriptions''), + variables(''SourceArr'')[copyindex(''values'')],resourceId(''Microsoft.Network/applicationSecurityGroups'', + variables(''SourceArr'')[copyindex(''values'')])), '''')]"}}]}},"resources":[{"type":"Microsoft.Network/networkSecurityGroups/securityRules","name":"[concat(parameters(''fullName''),''/'',''NRMS-Rule-'', + parameters(''ruleNo''))]","apiVersion":"2017-10-01","scale":null,"properties":{"protocol":"[parameters(''protocol'')]","description":"[parameters(''info'')]","sourcePortRange":"*","sourceAddressPrefix":"[if(equals(parameters(''sourceType''),''Service + Tag''),parameters(''sourceValue''),json(''null''))]","sourceAddressPrefixes":"[if(equals(parameters(''sourceType''),''IP + Addresses''),variables(''SourceArr''),json(''null''))]","sourceApplicationSecurityGroups":"[if(equals(parameters(''sourceType''),''App + Security Group''),variables(''appSecGroups'').values,json(''null''))]","destinationPortRanges":"[if + (equals(1,length(parameters(''destinationPortRanges''))), json(''null''), + parameters(''destinationPortRanges''))]","destinationPortRange":"[if (equals(1,length(parameters(''destinationPortRanges''))), + parameters(''destinationPortRanges'')[0], json(''null''))]","destinationAddressPrefix":"*","destinationApplicationSecurityGroups":[],"access":"[parameters(''actionValue'')]","priority":"[parameters(''ruleNo'')]","direction":"[parameters(''direction'')]"}}]},"parameters":{"fullName":{"value":"[field(''fullName'')]"},"ruleNo":{"value":"[parameters(''ruleNo'')]"},"destinationPortRanges":{"value":"[parameters(''destinationPortRanges'')]"},"protocol":{"value":"[parameters(''protocol'')]"},"sourceType":{"value":"[parameters(''sourceType'')]"},"sourceValue":{"value":"[parameters(''sourceValue'')]"},"actionValue":{"value":"[parameters(''actionValue'')]"},"direction":{"value":"[parameters(''direction'')]"},"info":{"value":"[parameters(''info'')]"}}}}}}}},"id":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fc84f507da5fe442","type":"Microsoft.Authorization/policyDefinitions","name":"fc84f507da5fe442"},{"properties":{"displayName":"Deny + WVD resource creation","policyType":"Custom","mode":"All","description":"IAMAADENG@microsoft.com","metadata":{"createdBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","createdOn":"2020-11-17T19:39:30.6756461Z","updatedBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","updatedOn":"2020-11-20T18:58:37.8969657Z"},"policyRule":{"if":{"allOf":[{"field":"type","like":"Microsoft.DesktopVirtualization/*"},{"value":"[field(''type'')]","like":"Microsoft.DesktopVirtualization/*"}]},"then":{"effect":"deny"}}},"id":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/Deny + WVD creation","type":"Microsoft.Authorization/policyDefinitions","name":"Deny + WVD creation"},{"properties":{"policyType":"Custom","mode":"Indexed","description":"Don''t + create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-10-27T07:24:34.317512Z","updatedBy":"123743cc-88ef-49ee-920e-13958fe5697d","updatedOn":"2020-10-27T08:22:55.7453346Z"},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/policyxyz","type":"Microsoft.Authorization/policyDefinitions","name":"policyxyz"},{"properties":{"policyType":"Custom","mode":"Indexed","description":"Don''t + create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:15.3292265Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}]}' headers: cache-control: - no-cache content-length: - - '3225879' + - '671322' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:56 GMT + - Fri, 26 Feb 2021 07:40:17 GMT expires: - '-1' pragma: @@ -41527,7 +25821,7 @@ interactions: code: 200 message: OK - request: - body: 'b''{"properties": {"policyDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0"}}''' + body: '{"properties": {"policyDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0"}}' headers: Accept: - application/json @@ -41540,21 +25834,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:58.2723724Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:19.0050823Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:57 GMT + - Fri, 26 Feb 2021 07:40:18 GMT expires: - '-1' pragma: @@ -41564,15 +25858,15 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1192' + - '1197' status: code: 201 message: Created - request: - body: 'b''{"properties": {"displayName": "Cost Management", "description": "Policies + body: '{"properties": {"displayName": "Cost Management", "description": "Policies to enforce low cost storage SKUs", "metadata": {"category": "Cost Management"}, "policyDefinitions": [{"policyDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0", - "parameters": {}}]}}''' + "parameters": {}}]}}' headers: Accept: - application/json @@ -41585,13 +25879,13 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"displayName":"Cost Management","policyType":"Custom","description":"Policies - to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:59.5562933Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' + to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:20.5642023Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -41600,7 +25894,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:59 GMT + - Fri, 26 Feb 2021 07:40:20 GMT expires: - '-1' pragma: @@ -41610,7 +25904,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1191' + - '1196' status: code: 201 message: Created @@ -41624,21 +25918,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:58.2723724Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:19.0050823Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:59 GMT + - Fri, 26 Feb 2021 07:40:20 GMT expires: - '-1' pragma: @@ -41664,114 +25958,136 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments?api-version=2020-09-01 response: body: - string: '{"value":[{"sku":{"name":"A1","tier":"Standard"},"properties":{"displayName":"ASC - Default (subscription: 00000000-0000-0000-0000-000000000000)","policyDefinitionId":"/providers/Microsoft.Authorization/policySetDefinitions/1f3afdf9-d0c9-4c3d-847f-89da613e70a8","scope":"/subscriptions/00000000-0000-0000-0000-000000000000","parameters":{"diagnosticsLogsInServiceFabricMonitoringEffect":{"value":"AuditIfNotExists"},"systemUpdatesMonitoringEffect":{"value":"AuditIfNotExists"},"systemConfigurationsMonitoringEffect":{"value":"AuditIfNotExists"},"endpointProtectionMonitoringEffect":{"value":"AuditIfNotExists"},"diskEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"networkSecurityGroupsMonitoringEffect":{"value":"AuditIfNotExists"},"webApplicationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"sqlAuditingMonitoringEffect":{"value":"AuditIfNotExists"},"sqlEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"nextGenerationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"vulnerabilityAssesmentMonitoringEffect":{"value":"AuditIfNotExists"},"storageEncryptionMonitoringEffect":{"value":"Audit"},"jitNetworkAccessMonitoringEffect":{"value":"AuditIfNotExists"},"adaptiveApplicationControlsMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateLessThanOwnersMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateMoreThanOneOwnerMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"}},"description":"This + string: '{"value":[{"properties":{"displayName":"ASC Default (subscription: + 00000000-0000-0000-0000-000000000000)","policyDefinitionId":"/providers/Microsoft.Authorization/policySetDefinitions/1f3afdf9-d0c9-4c3d-847f-89da613e70a8","scope":"/subscriptions/00000000-0000-0000-0000-000000000000","parameters":{"diagnosticsLogsInServiceFabricMonitoringEffect":{"value":"AuditIfNotExists"},"systemUpdatesMonitoringEffect":{"value":"AuditIfNotExists"},"systemConfigurationsMonitoringEffect":{"value":"AuditIfNotExists"},"endpointProtectionMonitoringEffect":{"value":"AuditIfNotExists"},"diskEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"networkSecurityGroupsMonitoringEffect":{"value":"AuditIfNotExists"},"webApplicationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"sqlAuditingMonitoringEffect":{"value":"AuditIfNotExists"},"sqlEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"nextGenerationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"vulnerabilityAssesmentMonitoringEffect":{"value":"AuditIfNotExists"},"storageEncryptionMonitoringEffect":{"value":"Audit"},"jitNetworkAccessMonitoringEffect":{"value":"AuditIfNotExists"},"adaptiveApplicationControlsMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateLessThanOwnersMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateMoreThanOneOwnerMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"}},"description":"This policy assignment was automatically created by Azure Security Center","metadata":{"assignedBy":"Security - Center"},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/SecurityCenterBuiltIn","type":"Microsoft.Authorization/policyAssignments","name":"SecurityCenterBuiltIn"},{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:58.2723724Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"audit - ssh auth_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3be0ea1bef3d71ca","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","global","brazilsoutheast"]}},"description":"This + Center"},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/SecurityCenterBuiltIn","type":"Microsoft.Authorization/policyAssignments","name":"SecurityCenterBuiltIn"},{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:19.0050823Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"},{"properties":{"displayName":"audit + ssh auth_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3be0ea1bef3d71ca","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["uknorth","uksouth2"]}},"description":"This initiative audits whether any Linux VMs or VMSS use password-only authentication - for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:48:29.541787Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-17T15:34:05.0362645Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/1fc2c9de5f6971ca","type":"Microsoft.Authorization/policyAssignments","name":"1fc2c9de5f6971ca"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-batch-require-user-subscription-mode_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Batch + for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:48:29.541787Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-28T00:29:36.4436324Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/1fc2c9de5f6971ca","type":"Microsoft.Authorization/policyAssignments","name":"1fc2c9de5f6971ca"},{"properties":{"displayName":"nrms-batch-require-user-subscription-mode_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"Batch Accounts must use a Pool Allocation Mode of User subscription on the Advanced tab to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the Batch Account. See https://aka.ms/netiso/vnetinjection - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.9760562Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:40.3716797Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6bff79d27acb9c88","type":"Microsoft.Authorization/policyAssignments","name":"6bff79d27acb9c88"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-auditing + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.9760562Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:48.0566559Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6bff79d27acb9c88","type":"Microsoft.Authorization/policyAssignments","name":"6bff79d27acb9c88"},{"properties":{"displayName":"sqlads-auditifnotexists-auditing should be enabled on advanced data security settings on sql server_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fce770def99399","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"},"setting":{"value":"enabled"}},"description":"Audits - SQL server level auditing coverage in the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.4717502Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:25.8570726Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6c0b4582049bbf99","type":"Microsoft.Authorization/policyAssignments","name":"6c0b4582049bbf99"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-vulnerability + SQL server level auditing coverage in the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.4717502Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:25.8570726Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6c0b4582049bbf99","type":"Microsoft.Authorization/policyAssignments","name":"6c0b4582049bbf99"},{"properties":{"displayName":"sqlads-auditifnotexists-vulnerability assessment should be enabled on your sql servers_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/410c2966a1e1856e","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - SQL Vulnerability Assessment coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.5097966Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:30.2774737Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/80a3851a4561856e","type":"Microsoft.Authorization/policyAssignments","name":"80a3851a4561856e"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-atp + SQL Vulnerability Assessment coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.5097966Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:30.2774737Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/80a3851a4561856e","type":"Microsoft.Authorization/policyAssignments","name":"80a3851a4561856e"},{"properties":{"displayName":"sqlads-auditifnotexists-atp types should be set to ''all'' in sql server advanced data security settings_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ac3fc8ad361a9985","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - active SQL ATP detection types across the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:41.0071959Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:28.8367577Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/8eb4c5f8edb95985","type":"Microsoft.Authorization/policyAssignments","name":"8eb4c5f8edb95985"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"deny - ssh password auth_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/cd305803df135c1b","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"This - initiative denies the creations of Linux VMs or VMSS which use password-only - authentication for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-07-14T00:05:26.0127492Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/91de26bf144b5c1b","type":"Microsoft.Authorization/policyAssignments","name":"91de26bf144b5c1b"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All + active SQL ATP detection types across the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:41.0071959Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:28.8367577Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/8eb4c5f8edb95985","type":"Microsoft.Authorization/policyAssignments","name":"8eb4c5f8edb95985"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.682075Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:35.5430963Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/aca4d19ab4e30392","type":"Microsoft.Authorization/policyAssignments","name":"aca4d19ab4e30392"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.682075Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:35.5430963Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/aca4d19ab4e30392","type":"Microsoft.Authorization/policyAssignments","name":"aca4d19ab4e30392"},{"properties":{"displayName":"audit + ssh auth_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/71cf5bbb7fef0368","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative audits whether any Linux VMs or VMSS use password-only authentication + for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-20T01:19:35.5785163Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-27T00:28:44.8040626Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/adb29f78ffa9a68","type":"Microsoft.Authorization/policyAssignments","name":"adb29f78ffa9a68"},{"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.5549343Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:08.0237953Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/b65cf29bbd4b57d","type":"Microsoft.Authorization/policyAssignments","name":"b65cf29bbd4b57d"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.5549343Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:08.0237953Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/b65cf29bbd4b57d","type":"Microsoft.Authorization/policyAssignments","name":"b65cf29bbd4b57d"},{"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets must use the Advanced Networking option to configure the Kubernetes cluster to use a Virtual Network that is on the subscription of the user. This enables the use of NSGs to secure the network traffic for the Kubernetes container. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:58.085345Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:42.6798866Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bce5fcf8b40531aa","type":"Microsoft.Authorization/policyAssignments","name":"bce5fcf8b40531aa"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-advanced + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:58.085345Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:42.6798866Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bce5fcf8b40531aa","type":"Microsoft.Authorization/policyAssignments","name":"bce5fcf8b40531aa"},{"properties":{"displayName":"require + ssh key for authentication_1.7","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9925b5f9b7103ed9","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","notScopes":["/providers/Microsoft.Management/managementGroups/09beb1ce-2126-fa82-35c8-3dc74a7b1853"],"parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative denies the creation of Linux VMs or VMSS which use password-only + authentication for SSH. Use of SSH key is more secure than passwords. To unblock, + do not use password for SSH authentication. See https://aka.ms/gt/AzurePolicy + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-07T02:55:19.2429066Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-14T01:06:26.051533Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bebc74b8871a3ed9","type":"Microsoft.Authorization/policyAssignments","name":"bebc74b8871a3ed9"},{"properties":{"displayName":"sqlads-auditifnotexists-advanced data security should be enabled on your sql servers_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e3cff6e23ce4018a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - SQL ADS coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:35.5090528Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:26.7963478Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/ef59abada7fba18a","type":"Microsoft.Authorization/policyAssignments","name":"ef59abada7fba18a"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-hdinsight-require-subnet_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"HDInsight + SQL ADS coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:35.5090528Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:26.7963478Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/ef59abada7fba18a","type":"Microsoft.Authorization/policyAssignments","name":"ef59abada7fba18a"},{"properties":{"displayName":"nrms-hdinsight-require-subnet_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"HDInsight Clusters must use the Custom configuration option to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the HDInsight cluster. See https://aka.ms/netiso/vnetinjection for more - details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.3537501Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:47.7820687Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/fcbba78ebf3e874f","type":"Microsoft.Authorization/policyAssignments","name":"fcbba78ebf3e874f"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"audit + details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.3537501Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:51.0239915Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/fcbba78ebf3e874f","type":"Microsoft.Authorization/policyAssignments","name":"fcbba78ebf3e874f"},{"properties":{"displayName":"audit soft delete enabled on key vault_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5353f06bfd8b6546","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","global"]},"effect":{"value":"audit"}},"description":"Soft - Delete must be enabled on all key vaults","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-09-01T00:04:04.3938416Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-09-08T00:04:25.5301187Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/Key-Vault-Soft-Delete-v1","type":"Microsoft.Authorization/policyAssignments","name":"Key-Vault-Soft-Delete-v1"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-batch-require-user-subscription-mode_2.1","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Batch + Delete must be enabled on all key vaults","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-09-01T00:04:04.3938416Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-09-08T00:04:25.5301187Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/Key-Vault-Soft-Delete-v1","type":"Microsoft.Authorization/policyAssignments","name":"Key-Vault-Soft-Delete-v1"},{"properties":{"displayName":"nrms-batch-require-user-subscription-mode_2.1","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"Batch Pools must be configured to use a VNet in the users subscription. This enables the use of NSGs to secure the network traffic for the Batch Account. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:59.165052Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:33.0369273Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-BTCH-AUDT-VINJ-v021","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-BTCH-AUDT-VINJ-v021"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-hdinsight-require-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"HDInsight + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:59.165052Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:46.6761239Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-BTCH-AUDT-VINJ-v021","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-BTCH-AUDT-VINJ-v021"},{"properties":{"displayName":"nrms-hdinsight-require-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"HDInsight Clusters must use the Custom configuration option to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the HDInsight cluster. See https://aka.ms/netiso/vnetinjection for more - details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:58.0927784Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:11.7643493Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-HDIN-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-HDIN-AUDT-VINJ-v012"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets + details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:58.0927784Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:59.7496297Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-HDIN-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-HDIN-AUDT-VINJ-v012"},{"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets must use the Advanced Networking option to configure the Kubernetes cluster to use a Virtual Network that is on the subscription of the user. This enables the use of NSGs to secure the network traffic for the Kubernetes container. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:02.4581818Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:41.1573353Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-KBNT-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-KBNT-AUDT-VINJ-v012"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-101_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"101"},"info":{"value":"Created + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:02.4581818Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:41.1573353Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-KBNT-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-KBNT-AUDT-VINJ-v012"},{"properties":{"displayName":"nrms-nsg-rule-101_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"101"},"info":{"value":"Created by Azure Core Security managed policy, placeholder you can delete, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["443"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"VirtualNetwork"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSDatabricks"},"subscriptionExclusions":{"value":[]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:06.5946651Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:50.9652509Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7a49237-f5b0-473f-a4ff-6830d23af17d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR101-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR101-v013","location":"uaenorth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-102_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"102"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:06.5946651Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:50.9652509Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7a49237-f5b0-473f-a4ff-6830d23af17d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR101-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR101-v013","location":"uaenorth"},{"properties":{"displayName":"nrms-nsg-rule-102_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"102"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"IP Addresses"},"sourceValue":{"value":"194.69.126.224/27,194.69.126.128/27,194.69.127.0/27,194.69.127.96/27,194.69.127.144/29,194.69.104.0/25,20.184.57.184/32,52.139.245.61/32,52.139.245.172/32,52.137.88.174/32,20.42.25.133/32,104.44.112.128/25,104.44.111.128/26,52.191.237.247/32,52.191.220.88/32,52.188.221.200/32,52.151.243.229/32,52.148.118.116/32,52.224.187.226/32,40.91.115.44/32,40.91.114.244/32,40.91.95.146/32,40.91.93.196/32,40.91.94.53/32,40.91.77.216/32,40.119.207.69/32,66.119.150.192/26,191.234.97.0/26,131.107.132.16/28,131.107.132.32/28,131.107.174.0/24,131.107.160.0/24,131.107.159.0/24,131.107.147.0/24,167.220.237.128/27,167.220.226.0/23,167.220.232.0/23,167.220.238.64/27,167.220.238.192/27,167.220.238.128/27,167.220.238.0/27,167.220.248.32/27,167.220.248.96/27,167.220.253.128/29,167.220.255.0/25,167.220.196.0/23,167.220.148.0/23,167.220.128.0/23,167.220.242.64/27,167.220.242.192/27,167.220.242.128/27,167.220.242.0/27,167.220.64.0/19,167.220.70.64/26,167.220.76.192/26,167.220.80.192/26,167.220.77.64/26,167.220.81.128/26,167.220.65.0/27,167.220.81.192/26,167.220.64.0/32,167.220.2.0/24,167.220.0.0/23,167.220.26.0/24,167.220.24.0/24,157.58.31.128/25,157.58.30.128/25,157.58.220.0/22,157.58.218.0/23,157.58.217.0/24,157.58.216.128/25,157.58.216.0/26,157.58.208.0/21,157.58.214.128/26,157.58.213.64/26,157.58.214.192/26,157.58.213.192/26,157.58.212.64/26,157.58.212.128/26,157.58.215.128/25,157.58.192.0/20,157.58.196.64/27,157.58.198.15/32,65.55.188.128/25,65.55.188.132/32,65.55.188.131/32,65.55.188.129/32,65.54.12.64/26,94.245.87.0/24,207.46.217.128/25,207.46.216.128/25,207.46.216.226/32,207.46.216.225/32,70.42.230.0/23"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSCorp"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:34.1091048Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:36.4135634Z"},"enforcementMode":"Default"},"identity":{"principalId":"985bb80e-8113-4542-8d68-418589e6ff34","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR102-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR102-v013","location":"southafricanorth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-103_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"103"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:34.1091048Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:36.4135634Z"},"enforcementMode":"Default"},"identity":{"principalId":"985bb80e-8113-4542-8d68-418589e6ff34","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR102-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR102-v013","location":"southafricanorth"},{"properties":{"displayName":"nrms-nsg-rule-103_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"103"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"CorpNetPublic"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSCorp"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:27:59.4953193Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:23.3383233Z"},"enforcementMode":"Default"},"identity":{"principalId":"2ac3f52f-f3ad-40a4-9b2d-aa24e4c7bbba","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR103-v014","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR103-v014","location":"eastus2"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-104_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"104"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:27:59.4953193Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:23.3383233Z"},"enforcementMode":"Default"},"identity":{"principalId":"2ac3f52f-f3ad-40a4-9b2d-aa24e4c7bbba","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR103-v014","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR103-v014","location":"eastus2"},{"properties":{"displayName":"nrms-nsg-rule-104_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"104"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"CorpNetSaw"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSSAW"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:25.1822092Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:55.9717659Z"},"enforcementMode":"Default"},"identity":{"principalId":"f2e939bc-742a-42f9-a27a-f0982c6e3f64","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR104-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR104-v013","location":"japanwest"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-105_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"105"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:25.1822092Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:55.9717659Z"},"enforcementMode":"Default"},"identity":{"principalId":"f2e939bc-742a-42f9-a27a-f0982c6e3f64","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR104-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR104-v013","location":"japanwest"},{"properties":{"displayName":"nrms-nsg-rule-105_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"105"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["1433","1434","3306","4333","5432","6379","7000","7001","7199","9042","9160","9300","16379","26379","27017"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSDB"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943","6f5dcae0-a801-4d61-869d-7cf26ac8b3c3"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:47.192623Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:38:02.2961864Z"},"enforcementMode":"Default"},"identity":{"principalId":"4a113caa-961f-4535-ac9b-79bfba8b9ed2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR105-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR105-v013","location":"australiasoutheast"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-106_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"106"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:47.192623Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:38:02.2961864Z"},"enforcementMode":"Default"},"identity":{"principalId":"4a113caa-961f-4535-ac9b-79bfba8b9ed2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR105-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR105-v013","location":"australiasoutheast"},{"properties":{"displayName":"nrms-nsg-rule-106_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"ruleNo":{"value":"106"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["22","3389"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSRDPSSH"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:53.5540872Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:24.5779103Z"},"enforcementMode":"Default"},"identity":{"principalId":"6179a082-c057-4fe3-8118-916b816a42e3","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR106-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR106-v013","location":"japanwest"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-107_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"107"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:53.5540872Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:43.2893268Z"},"enforcementMode":"Default"},"identity":{"principalId":"6179a082-c057-4fe3-8118-916b816a42e3","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR106-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR106-v013","location":"japanwest"},{"properties":{"displayName":"nrms-nsg-rule-107_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"107"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["23","135","445","5985","5986"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSMgmt"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:11.2279015Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:22.5704574Z"},"enforcementMode":"Default"},"identity":{"principalId":"7c2d0d59-528c-434a-8c6c-03330539cad2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR107-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR107-v013","location":"uksouth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-108_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"108"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:11.2279015Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:22.5704574Z"},"enforcementMode":"Default"},"identity":{"principalId":"7c2d0d59-528c-434a-8c6c-03330539cad2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR107-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR107-v013","location":"uksouth"},{"properties":{"displayName":"nrms-nsg-rule-108_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"ruleNo":{"value":"108"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["13","17","19","53","69","111","123","512","514","593","873","1900","5353","11211"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSHigh"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:02.4628867Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:01.428405Z"},"enforcementMode":"Default"},"identity":{"principalId":"7d7aed0a-228e-420b-a6a2-82a49dacb8cb","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR108-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR108-v013","location":"germanywestcentral"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-109_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"109"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:02.4628867Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:56.7239102Z"},"enforcementMode":"Default"},"identity":{"principalId":"7d7aed0a-228e-420b-a6a2-82a49dacb8cb","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR108-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR108-v013","location":"germanywestcentral"},{"properties":{"displayName":"nrms-nsg-rule-109_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"109"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["119","137","138","139","161","162","389","636","2049","2301","2381","3268","5800","5900"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSMedium"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:57.9727253Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:50.054199Z"},"enforcementMode":"Default"},"identity":{"principalId":"56d08bc2-cc29-4d23-9d23-fd396b807b02","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR109-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR109-v013","location":"southeastasia"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:57.9727253Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:50.054199Z"},"enforcementMode":"Default"},"identity":{"principalId":"56d08bc2-cc29-4d23-9d23-fd396b807b02","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR109-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR109-v013","location":"southeastasia"},{"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:59.4565556Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:28.1981569Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSGS-AUDT-RULS-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSGS-AUDT-RULS-v013"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-subnet-require-nsg_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:59.4565556Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:28.1981569Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSGS-AUDT-RULS-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSGS-AUDT-RULS-v013"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:34:02.1062104Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:27.2901901Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-AUDT-NSG-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-AUDT-NSG-v013"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:34:02.1062104Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:27.2901901Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-AUDT-NSG-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-AUDT-NSG-v013"},{"properties":{"displayName":"nrms-nsg-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:32:33.7856438Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:17.0959962Z"},"enforcementMode":"Default"},"identity":{"principalId":"6fe923a8-2e4d-4c1f-b7d6-a7c5984f0129","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-DINE-NSG-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-DINE-NSG-v012","location":"southindia"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"azuresecuritypackautoupdate_3.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9c46cf6e83dedb18","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]}},"description":"Combinations - of multiple policies to enable auto update of security pack and geneva agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-23T19:35:15.9907469Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-07-01T19:36:03.1679769Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7b8bd19-f827-425f-9be1-fd8a86b21904","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AzSecPack-v032","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AzSecPack-v032","location":"australiacentral"}]}' + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:32:33.7856438Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:17.0959962Z"},"enforcementMode":"Default"},"identity":{"principalId":"6fe923a8-2e4d-4c1f-b7d6-a7c5984f0129","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-DINE-NSG-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-DINE-NSG-v012","location":"southindia"},{"properties":{"displayName":"antimalwaresignatureautoupdate_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/42ce40d2aa7d488c","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","global"]}},"description":"Combinations + of multiple policies to enable auto update of antimalware signature extension","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-11-09T17:52:54.3586884Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-11-17T01:04:01.7112876Z"},"enforcementMode":"Default"},"identity":{"principalId":"944ac5b9-0504-45a1-bd94-a7f6a32f2b78","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AmSigUpd-v012","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AmSigUpd-v012","location":"francecentral"},{"properties":{"displayName":"linuxazuresecuritypackautodeployiaas_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/39a3148b77c63de","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":[]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on IaaS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-10T05:16:02.7297386Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-23T21:20:00.6512074Z"},"enforcementMode":"Default"},"identity":{"principalId":"f3ec068d-c01c-4221-856c-2ec3ce8e4985","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VM-Central-v15","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VM-Central-v15","location":"eastasia"},{"properties":{"displayName":"linuxazuresecuritypackautodeployiaas_1.6","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/732406cc80ca0778","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on IaaS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:03.1821044Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"ebdfc7cf-4fad-4d3e-8da8-9ec3457a541d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VM-Central-v16","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VM-Central-v16","location":"uksouth"},{"properties":{"displayName":"linuxazuresecuritypackautodeployvmss_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/134109bb7d72e8a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":[]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-10T05:16:05.3531754Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-23T21:20:06.7029288Z"},"enforcementMode":"Default"},"identity":{"principalId":"fab9cec9-3881-4d1d-be89-9585f4c48120","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VMSS-Central-v15","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VMSS-Central-v15","location":"centralindia"},{"properties":{"displayName":"linuxazuresecuritypackautodeployvmss_1.6","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/20e1853705896d6b","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:10.0659204Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"dd9f1754-4394-41c9-afb3-846fc72afcfe","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VMSS-Central-v16","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VMSS-Central-v16","location":"eastasia"},{"properties":{"displayName":"azsecpackautodeployuamsi_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/51dd9327c4c2bc9a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable AzSecPack AutoConfig on VM and VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:03.1205715Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"dc0a7a3d-0c4b-475d-be5f-143b7e4ee0f6","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASM-UA-MSI-v10","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASM-UA-MSI-v10","location":"eastus2"},{"properties":{"displayName":"azuresecuritypackautodeploy_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/c07a73127ee784cb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of security pack and Geneva Agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-22T03:54:10.2185722Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"76ae450f-630f-4af4-92cf-e7153ba839f0","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASP-AutoDeploy-v12","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASP-AutoDeploy-v12","location":"westus"},{"properties":{"displayName":"azuresecuritypackautoupdate_3.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9c46cf6e83dedb18","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]}},"description":"Combinations + of multiple policies to enable auto update of security pack and geneva agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-23T19:35:15.9907469Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-07-01T19:36:03.1679769Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7b8bd19-f827-425f-9be1-fd8a86b21904","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AzSecPack-v032","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AzSecPack-v032","location":"australiacentral"},{"properties":{"displayName":"vmvmssfirstpartytaginitiative_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3e9b6c243abfa9e3","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative consists of Append and Modify policy that will update all 1st party + VM, VMSS with an identification tag","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-05T18:44:17.0051974Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-12T16:51:02.8220402Z"},"enforcementMode":"Default"},"identity":{"principalId":"fd3aca68-eb29-4ad8-be21-662836d3f454","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/VMVMSSFirstParty-v015","type":"Microsoft.Authorization/policyAssignments","name":"VMVMSSFirstParty-v015","location":"southafricawest"},{"properties":{"displayName":"CSEO + Block WVD resource creation","policyDefinitionId":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/Deny + WVD creation","scope":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000","notScopes":["/providers/Microsoft.Management/managementGroups/MSFT-DSRE-ISO-IAM","/providers/Microsoft.Management/managementGroups/9ce3369a-545b-cfba-c329-3631400b552f","/providers/Microsoft.Management/managementGroups/WVDSelfhost","/subscriptions/3ae2e9a4-54bd-459f-8211-6f920ecd52c4","/providers/Microsoft.Management/managementGroups/595d008b-0e4c-41f8-af09-254420fd7571","/providers/Microsoft.Management/managementGroups/CloudPCMSFTSubscriptions"],"description":"IAMAADENG@microsoft.com","metadata":{"createdBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","createdOn":"2020-11-17T19:41:36.3082667Z","updatedBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","updatedOn":"2020-12-08T00:12:36.8374178Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/Block + WVD creation","type":"Microsoft.Authorization/policyAssignments","name":"Block + WVD creation"}]}' headers: cache-control: - no-cache content-length: - - '141624' + - '154455' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:59 GMT + - Fri, 26 Feb 2021 07:40:20 GMT expires: - '-1' pragma: @@ -41797,114 +26113,135 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments?api-version=2020-09-01 response: body: - string: '{"value":[{"sku":{"name":"A1","tier":"Standard"},"properties":{"displayName":"ASC - Default (subscription: 00000000-0000-0000-0000-000000000000)","policyDefinitionId":"/providers/Microsoft.Authorization/policySetDefinitions/1f3afdf9-d0c9-4c3d-847f-89da613e70a8","scope":"/subscriptions/00000000-0000-0000-0000-000000000000","parameters":{"diagnosticsLogsInServiceFabricMonitoringEffect":{"value":"AuditIfNotExists"},"systemUpdatesMonitoringEffect":{"value":"AuditIfNotExists"},"systemConfigurationsMonitoringEffect":{"value":"AuditIfNotExists"},"endpointProtectionMonitoringEffect":{"value":"AuditIfNotExists"},"diskEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"networkSecurityGroupsMonitoringEffect":{"value":"AuditIfNotExists"},"webApplicationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"sqlAuditingMonitoringEffect":{"value":"AuditIfNotExists"},"sqlEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"nextGenerationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"vulnerabilityAssesmentMonitoringEffect":{"value":"AuditIfNotExists"},"storageEncryptionMonitoringEffect":{"value":"Audit"},"jitNetworkAccessMonitoringEffect":{"value":"AuditIfNotExists"},"adaptiveApplicationControlsMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateLessThanOwnersMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateMoreThanOneOwnerMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"}},"description":"This - policy assignment was automatically created by Azure Security Center","metadata":{"assignedBy":"Security - Center"},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/SecurityCenterBuiltIn","type":"Microsoft.Authorization/policyAssignments","name":"SecurityCenterBuiltIn"},{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:58.2723724Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"audit - ssh auth_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3be0ea1bef3d71ca","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","global","brazilsoutheast"]}},"description":"This + string: '{"value":[{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:19.0050823Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"},{"properties":{"displayName":"audit + ssh auth_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3be0ea1bef3d71ca","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["uknorth","uksouth2"]}},"description":"This initiative audits whether any Linux VMs or VMSS use password-only authentication - for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:48:29.541787Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-17T15:34:05.0362645Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/1fc2c9de5f6971ca","type":"Microsoft.Authorization/policyAssignments","name":"1fc2c9de5f6971ca"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-batch-require-user-subscription-mode_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Batch + for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-05-12T23:48:29.541787Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-28T00:29:36.4436324Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/1fc2c9de5f6971ca","type":"Microsoft.Authorization/policyAssignments","name":"1fc2c9de5f6971ca"},{"properties":{"displayName":"nrms-batch-require-user-subscription-mode_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/74c98b59a6341488","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"Batch Accounts must use a Pool Allocation Mode of User subscription on the Advanced tab to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the Batch Account. See https://aka.ms/netiso/vnetinjection - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.9760562Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:40.3716797Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6bff79d27acb9c88","type":"Microsoft.Authorization/policyAssignments","name":"6bff79d27acb9c88"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-auditing + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.9760562Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:48.0566559Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6bff79d27acb9c88","type":"Microsoft.Authorization/policyAssignments","name":"6bff79d27acb9c88"},{"properties":{"displayName":"sqlads-auditifnotexists-auditing should be enabled on advanced data security settings on sql server_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/8fce770def99399","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"},"setting":{"value":"enabled"}},"description":"Audits - SQL server level auditing coverage in the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.4717502Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:25.8570726Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6c0b4582049bbf99","type":"Microsoft.Authorization/policyAssignments","name":"6c0b4582049bbf99"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-vulnerability + SQL server level auditing coverage in the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.4717502Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:25.8570726Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/6c0b4582049bbf99","type":"Microsoft.Authorization/policyAssignments","name":"6c0b4582049bbf99"},{"properties":{"displayName":"sqlads-auditifnotexists-vulnerability assessment should be enabled on your sql servers_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/410c2966a1e1856e","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - SQL Vulnerability Assessment coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.5097966Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:30.2774737Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/80a3851a4561856e","type":"Microsoft.Authorization/policyAssignments","name":"80a3851a4561856e"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-atp + SQL Vulnerability Assessment coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:37.5097966Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:30.2774737Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/80a3851a4561856e","type":"Microsoft.Authorization/policyAssignments","name":"80a3851a4561856e"},{"properties":{"displayName":"sqlads-auditifnotexists-atp types should be set to ''all'' in sql server advanced data security settings_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/ac3fc8ad361a9985","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - active SQL ATP detection types across the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:41.0071959Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:28.8367577Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/8eb4c5f8edb95985","type":"Microsoft.Authorization/policyAssignments","name":"8eb4c5f8edb95985"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"deny - ssh password auth_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/cd305803df135c1b","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"This - initiative denies the creations of Linux VMs or VMSS which use password-only - authentication for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-07-14T00:05:26.0127492Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/91de26bf144b5c1b","type":"Microsoft.Authorization/policyAssignments","name":"91de26bf144b5c1b"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All + active SQL ATP detection types across the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:41.0071959Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:28.8367577Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/8eb4c5f8edb95985","type":"Microsoft.Authorization/policyAssignments","name":"8eb4c5f8edb95985"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/b8f1faa61cb41f92","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.682075Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:35.5430963Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/aca4d19ab4e30392","type":"Microsoft.Authorization/policyAssignments","name":"aca4d19ab4e30392"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.682075Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:35.5430963Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/aca4d19ab4e30392","type":"Microsoft.Authorization/policyAssignments","name":"aca4d19ab4e30392"},{"properties":{"displayName":"audit + ssh auth_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/71cf5bbb7fef0368","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative audits whether any Linux VMs or VMSS use password-only authentication + for SSH. See https://aka.ms/gt/AzurePolicy for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-20T01:19:35.5785163Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-27T00:28:44.8040626Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/adb29f78ffa9a68","type":"Microsoft.Authorization/policyAssignments","name":"adb29f78ffa9a68"},{"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e695de0794b757d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.5549343Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:08.0237953Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/b65cf29bbd4b57d","type":"Microsoft.Authorization/policyAssignments","name":"b65cf29bbd4b57d"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:59.5549343Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:08.0237953Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/b65cf29bbd4b57d","type":"Microsoft.Authorization/policyAssignments","name":"b65cf29bbd4b57d"},{"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/26db8d27b6fa91aa","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets must use the Advanced Networking option to configure the Kubernetes cluster to use a Virtual Network that is on the subscription of the user. This enables the use of NSGs to secure the network traffic for the Kubernetes container. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:58.085345Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:42.6798866Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bce5fcf8b40531aa","type":"Microsoft.Authorization/policyAssignments","name":"bce5fcf8b40531aa"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"sqlads-auditifnotexists-advanced + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:23:58.085345Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:42.6798866Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bce5fcf8b40531aa","type":"Microsoft.Authorization/policyAssignments","name":"bce5fcf8b40531aa"},{"properties":{"displayName":"require + ssh key for authentication_1.7","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9925b5f9b7103ed9","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","notScopes":["/providers/Microsoft.Management/managementGroups/09beb1ce-2126-fa82-35c8-3dc74a7b1853"],"parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative denies the creation of Linux VMs or VMSS which use password-only + authentication for SSH. Use of SSH key is more secure than passwords. To unblock, + do not use password for SSH authentication. See https://aka.ms/gt/AzurePolicy + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-07T02:55:19.2429066Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-01-14T01:06:26.051533Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/bebc74b8871a3ed9","type":"Microsoft.Authorization/policyAssignments","name":"bebc74b8871a3ed9"},{"properties":{"displayName":"sqlads-auditifnotexists-advanced data security should be enabled on your sql servers_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e3cff6e23ce4018a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]},"effect":{"value":"AuditIfNotExists"},"tagname":{"value":"SQLADSExcluded"}},"description":"Audits - SQL ADS coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:35.5090528Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:26.7963478Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/ef59abada7fba18a","type":"Microsoft.Authorization/policyAssignments","name":"ef59abada7fba18a"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-hdinsight-require-subnet_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"HDInsight + SQL ADS coverage the MS Corp tenant.","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-10T02:12:35.5090528Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-24T02:13:26.7963478Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/ef59abada7fba18a","type":"Microsoft.Authorization/policyAssignments","name":"ef59abada7fba18a"},{"properties":{"displayName":"nrms-hdinsight-require-subnet_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/11094169db59074f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","uksouth2","centralus","eastus","westus2","francecentral","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","uknorth","eastus2","southcentralus","brazilsouth","westindia","francesouth","global","brazilus","indiasouth","indiawest","indiacentral","uaecentral","uaenorth","southafricanorth","southafricawest","switzerlandnorth","switzerlandwest","germanynorth","germanywestcentral","norwayeast","norwaywest","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"HDInsight Clusters must use the Custom configuration option to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the HDInsight cluster. See https://aka.ms/netiso/vnetinjection for more - details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.3537501Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:47.7820687Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/fcbba78ebf3e874f","type":"Microsoft.Authorization/policyAssignments","name":"fcbba78ebf3e874f"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"audit + details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2019-04-01T22:24:01.3537501Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:51.0239915Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/fcbba78ebf3e874f","type":"Microsoft.Authorization/policyAssignments","name":"fcbba78ebf3e874f"},{"properties":{"displayName":"audit soft delete enabled on key vault_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5353f06bfd8b6546","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","global"]},"effect":{"value":"audit"}},"description":"Soft - Delete must be enabled on all key vaults","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-09-01T00:04:04.3938416Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-09-08T00:04:25.5301187Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/Key-Vault-Soft-Delete-v1","type":"Microsoft.Authorization/policyAssignments","name":"Key-Vault-Soft-Delete-v1"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-batch-require-user-subscription-mode_2.1","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Batch + Delete must be enabled on all key vaults","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-09-01T00:04:04.3938416Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-09-08T00:04:25.5301187Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/Key-Vault-Soft-Delete-v1","type":"Microsoft.Authorization/policyAssignments","name":"Key-Vault-Soft-Delete-v1"},{"properties":{"displayName":"nrms-batch-require-user-subscription-mode_2.1","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/5aac1290d24c772d","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"Batch Pools must be configured to use a VNet in the users subscription. This enables the use of NSGs to secure the network traffic for the Batch Account. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:59.165052Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:33.0369273Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-BTCH-AUDT-VINJ-v021","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-BTCH-AUDT-VINJ-v021"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-hdinsight-require-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"HDInsight + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:59.165052Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:46.6761239Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-BTCH-AUDT-VINJ-v021","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-BTCH-AUDT-VINJ-v021"},{"properties":{"displayName":"nrms-hdinsight-require-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/1b0f9cd579f5f04a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"effect":{"value":"Audit"}},"description":"HDInsight Clusters must use the Custom configuration option to configure a VNet in the subscriptiong. This enables the use of NSGs to secure the network traffic for the HDInsight cluster. See https://aka.ms/netiso/vnetinjection for more - details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:58.0927784Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:11.7643493Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-HDIN-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-HDIN-AUDT-VINJ-v012"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets + details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:32:58.0927784Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:59.7496297Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-HDIN-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-HDIN-AUDT-VINJ-v012"},{"properties":{"displayName":"nrms-kubernet-require-azure-networkplugin_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/cb9c916fd4b6c323","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"Kubernets must use the Advanced Networking option to configure the Kubernetes cluster to use a Virtual Network that is on the subscription of the user. This enables the use of NSGs to secure the network traffic for the Kubernetes container. See - https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:02.4581818Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:41.1573353Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-KBNT-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-KBNT-AUDT-VINJ-v012"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-101_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"101"},"info":{"value":"Created + https://aka.ms/netiso/vnetinjection for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:02.4581818Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:41.1573353Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-KBNT-AUDT-VINJ-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-KBNT-AUDT-VINJ-v012"},{"properties":{"displayName":"nrms-nsg-rule-101_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9d78e6174e6e69be","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"101"},"info":{"value":"Created by Azure Core Security managed policy, placeholder you can delete, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["443"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"VirtualNetwork"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSDatabricks"},"subscriptionExclusions":{"value":[]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:06.5946651Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:50.9652509Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7a49237-f5b0-473f-a4ff-6830d23af17d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR101-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR101-v013","location":"uaenorth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-102_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"102"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:06.5946651Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:50.9652509Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7a49237-f5b0-473f-a4ff-6830d23af17d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR101-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR101-v013","location":"uaenorth"},{"properties":{"displayName":"nrms-nsg-rule-102_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/7c066e9166289efb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"102"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"IP Addresses"},"sourceValue":{"value":"194.69.126.224/27,194.69.126.128/27,194.69.127.0/27,194.69.127.96/27,194.69.127.144/29,194.69.104.0/25,20.184.57.184/32,52.139.245.61/32,52.139.245.172/32,52.137.88.174/32,20.42.25.133/32,104.44.112.128/25,104.44.111.128/26,52.191.237.247/32,52.191.220.88/32,52.188.221.200/32,52.151.243.229/32,52.148.118.116/32,52.224.187.226/32,40.91.115.44/32,40.91.114.244/32,40.91.95.146/32,40.91.93.196/32,40.91.94.53/32,40.91.77.216/32,40.119.207.69/32,66.119.150.192/26,191.234.97.0/26,131.107.132.16/28,131.107.132.32/28,131.107.174.0/24,131.107.160.0/24,131.107.159.0/24,131.107.147.0/24,167.220.237.128/27,167.220.226.0/23,167.220.232.0/23,167.220.238.64/27,167.220.238.192/27,167.220.238.128/27,167.220.238.0/27,167.220.248.32/27,167.220.248.96/27,167.220.253.128/29,167.220.255.0/25,167.220.196.0/23,167.220.148.0/23,167.220.128.0/23,167.220.242.64/27,167.220.242.192/27,167.220.242.128/27,167.220.242.0/27,167.220.64.0/19,167.220.70.64/26,167.220.76.192/26,167.220.80.192/26,167.220.77.64/26,167.220.81.128/26,167.220.65.0/27,167.220.81.192/26,167.220.64.0/32,167.220.2.0/24,167.220.0.0/23,167.220.26.0/24,167.220.24.0/24,157.58.31.128/25,157.58.30.128/25,157.58.220.0/22,157.58.218.0/23,157.58.217.0/24,157.58.216.128/25,157.58.216.0/26,157.58.208.0/21,157.58.214.128/26,157.58.213.64/26,157.58.214.192/26,157.58.213.192/26,157.58.212.64/26,157.58.212.128/26,157.58.215.128/25,157.58.192.0/20,157.58.196.64/27,157.58.198.15/32,65.55.188.128/25,65.55.188.132/32,65.55.188.131/32,65.55.188.129/32,65.54.12.64/26,94.245.87.0/24,207.46.217.128/25,207.46.216.128/25,207.46.216.226/32,207.46.216.225/32,70.42.230.0/23"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSCorp"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:34.1091048Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:36.4135634Z"},"enforcementMode":"Default"},"identity":{"principalId":"985bb80e-8113-4542-8d68-418589e6ff34","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR102-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR102-v013","location":"southafricanorth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-103_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"103"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:34.1091048Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:36.4135634Z"},"enforcementMode":"Default"},"identity":{"principalId":"985bb80e-8113-4542-8d68-418589e6ff34","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR102-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR102-v013","location":"southafricanorth"},{"properties":{"displayName":"nrms-nsg-rule-103_1.4","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/3c07197392ad62f","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"103"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"CorpNetPublic"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSCorp"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:27:59.4953193Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:23.3383233Z"},"enforcementMode":"Default"},"identity":{"principalId":"2ac3f52f-f3ad-40a4-9b2d-aa24e4c7bbba","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR103-v014","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR103-v014","location":"eastus2"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-104_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"104"},"info":{"value":"Created + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:27:59.4953193Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:23.3383233Z"},"enforcementMode":"Default"},"identity":{"principalId":"2ac3f52f-f3ad-40a4-9b2d-aa24e4c7bbba","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR103-v014","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR103-v014","location":"eastus2"},{"properties":{"displayName":"nrms-nsg-rule-104_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/bac0fb65020410a4","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"104"},"info":{"value":"Created by Azure Core Security managed policy, rule can be deleted but do not change source ips, please see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["*"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"CorpNetSaw"},"actionValue":{"value":"Allow"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSSAW"},"subscriptionExclusions":{"value":["e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:25.1822092Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:55.9717659Z"},"enforcementMode":"Default"},"identity":{"principalId":"f2e939bc-742a-42f9-a27a-f0982c6e3f64","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR104-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR104-v013","location":"japanwest"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-105_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"105"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:25.1822092Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:55.9717659Z"},"enforcementMode":"Default"},"identity":{"principalId":"f2e939bc-742a-42f9-a27a-f0982c6e3f64","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR104-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR104-v013","location":"japanwest"},{"properties":{"displayName":"nrms-nsg-rule-105_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/91f42c0ca66ff7dd","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"105"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["1433","1434","3306","4333","5432","6379","7000","7001","7199","9042","9160","9300","16379","26379","27017"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSDB"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943","6f5dcae0-a801-4d61-869d-7cf26ac8b3c3"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:47.192623Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:38:02.2961864Z"},"enforcementMode":"Default"},"identity":{"principalId":"4a113caa-961f-4535-ac9b-79bfba8b9ed2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR105-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR105-v013","location":"australiasoutheast"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-106_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"106"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:47.192623Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:38:02.2961864Z"},"enforcementMode":"Default"},"identity":{"principalId":"4a113caa-961f-4535-ac9b-79bfba8b9ed2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR105-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR105-v013","location":"australiasoutheast"},{"properties":{"displayName":"nrms-nsg-rule-106_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/9b8d76c443040b08","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"ruleNo":{"value":"106"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["22","3389"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSRDPSSH"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:53.5540872Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:35:24.5779103Z"},"enforcementMode":"Default"},"identity":{"principalId":"6179a082-c057-4fe3-8118-916b816a42e3","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR106-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR106-v013","location":"japanwest"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-107_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"107"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:53.5540872Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:43.2893268Z"},"enforcementMode":"Default"},"identity":{"principalId":"6179a082-c057-4fe3-8118-916b816a42e3","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR106-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR106-v013","location":"japanwest"},{"properties":{"displayName":"nrms-nsg-rule-107_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/fb6de85c9e746cf1","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"107"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["23","135","445","5985","5986"]},"protocol":{"value":"Tcp"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSMgmt"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:11.2279015Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:22.5704574Z"},"enforcementMode":"Default"},"identity":{"principalId":"7c2d0d59-528c-434a-8c6c-03330539cad2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR107-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR107-v013","location":"uksouth"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-108_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"108"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:11.2279015Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:22.5704574Z"},"enforcementMode":"Default"},"identity":{"principalId":"7c2d0d59-528c-434a-8c6c-03330539cad2","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR107-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR107-v013","location":"uksouth"},{"properties":{"displayName":"nrms-nsg-rule-108_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/532396f35af78946","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","westus3","eastusslv"]},"ruleNo":{"value":"108"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["13","17","19","53","69","111","123","512","514","593","873","1900","5353","11211"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSHigh"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:02.4628867Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:01.428405Z"},"enforcementMode":"Default"},"identity":{"principalId":"7d7aed0a-228e-420b-a6a2-82a49dacb8cb","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR108-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR108-v013","location":"germanywestcentral"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-rule-109_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"109"},"info":{"value":"DO + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:29:02.4628867Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-12-15T03:08:56.7239102Z"},"enforcementMode":"Default"},"identity":{"principalId":"7d7aed0a-228e-420b-a6a2-82a49dacb8cb","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR108-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR108-v013","location":"germanywestcentral"},{"properties":{"displayName":"nrms-nsg-rule-109_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/e0bc08af3bd773ff","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"ruleNo":{"value":"109"},"info":{"value":"DO NOT DELETE - Will result in ICM Sev 2 - Azure Core Security, see aka.ms/cainsgpolicy"},"destinationPortRanges":{"value":["119","137","138","139","161","162","389","636","2049","2301","2381","3268","5800","5900"]},"protocol":{"value":"*"},"sourceType":{"value":"Service Tag"},"sourceValue":{"value":"Internet"},"actionValue":{"value":"Deny"},"direction":{"value":"Inbound"},"tagname":{"value":"SkipNRMSMedium"},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:57.9727253Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:50.054199Z"},"enforcementMode":"Default"},"identity":{"principalId":"56d08bc2-cc29-4d23-9d23-fd396b807b02","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR109-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR109-v013","location":"southeastasia"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:28:57.9727253Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:50.054199Z"},"enforcementMode":"Default"},"identity":{"principalId":"56d08bc2-cc29-4d23-9d23-fd396b807b02","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSG-DINE-SR109-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSG-DINE-SR109-v013","location":"southeastasia"},{"properties":{"displayName":"nrms-warning-non-c+ai-security-rules_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/686f7311dc548f32","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"},"priorities":{"value":["100","101","102","103","104","105","106","107","108","109","110","111","112","113","114","115","116","117","118","119"]}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:59.4565556Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:28.1981569Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSGS-AUDT-RULS-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSGS-AUDT-RULS-v013"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-subnet-require-nsg_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:33:59.4565556Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:36:28.1981569Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-NSGS-AUDT-RULS-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-NSGS-AUDT-RULS-v013"},{"properties":{"displayName":"nrms-subnet-require-nsg_1.3","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/789cfec91f9e1858","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"effect":{"value":"Audit"}},"description":"All C+AI Subscriptions must have a NSG on all VNets in the subscription. See - https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:34:02.1062104Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:27.2901901Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-AUDT-NSG-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-AUDT-NSG-v013"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"nrms-nsg-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All + https://aka.ms/netiso/nsgs for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T19:34:02.1062104Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:27.2901901Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-AUDT-NSG-v013","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-AUDT-NSG-v013"},{"properties":{"displayName":"nrms-nsg-subnet_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyDefinitions/852aeb0ee2c0a3a5","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"allowedLocations":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","global","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast"]},"subscriptionExclusions":{"value":["61868ab8-16d4-44ec-a9ff-f35d05922847","41c39ac7-6cde-4be7-87c3-d57a168b7b92","235d341f-7fb9-435c-9bdc-034b7306c9b4","239b3f1a-daab-4125-918c-f028b0edb054","12f44720-8952-422c-bb7d-28831c2de639","c36fd9e7-e5b1-4d3e-bb85-2e538040258b","243b67d4-60ca-4dfd-a556-216ee06f77a1","24ae0a2f-2cb0-4a1a-9929-bed71bad0d59","b4582baf-35d9-47b9-b03d-1bd126876221","65f79f71-cb42-45b1-82b7-4635fd05fc26","9532a63e-f2eb-4649-bb23-5ed01077ce80","1533031f-9510-4d8d-8f83-af94df45d43c","73d25f92-e703-4c91-8aed-2fb23c8e151f","86d6f8d7-564b-4005-912c-b1a3a9a286ce","97a3d790-8d62-4f20-b579-39ee6b06cb45","179be307-0377-46c0-a8bb-17437582d266","6c516c14-f378-4780-bc52-dd1d098a9c0b","cc5e1d36-a80d-4878-add9-5204a7efda20","0bf83929-3a19-4a96-87da-b23c3aca7fd7","ad7af743-6a66-480e-98cd-e022f833d0ce","0cfe98e1-3cf6-41ca-9f54-435d1ddaf0de","ce6570fa-18fb-4503-80d9-4a225591a428","2f8446c7-7c1e-42f0-a6b7-d68df1255cc4","ff78024c-d5a1-48ae-88eb-d61f0f60f8ff","bdd789f3-d9d1-4bea-ac14-30a39ed66d33","6fe0c04c-acb9-4f74-8153-56a6cb666ca8","7fa88f8d-252c-4b22-a73e-cd77f85cca66","bafb24c9-f4bb-46a0-9891-4b3e12dab22e","aab411af-ed4d-4f02-bb87-5de8b00d880d","7e7b7a6f-0b34-4db9-958d-ece4c89b419f","964c10bb-8a6c-43bc-83d3-6b318c6c7305","7b29bb4e-8391-4d57-8045-b34a092e5108","3f706ca0-34d7-4ede-a432-3c1a37ddd5c6","7856cb6f-e1a8-48f2-b2a5-bfaa7f8c34a1","49e3ed89-bbdb-4545-844f-e3502d6ce44f","8cad7ef7-ae41-4adf-86b8-ffcb11fae200","8e9ec0f8-bfe6-43a5-acd2-b6c4666ef9f6","b8fc6ee8-6802-4605-b4a5-1d131084c62f","45493131-fef6-4cb1-80e9-f0dadaa0255a","9c8295ef-4bf7-49db-90aa-5f0837dc60b7","ed0b2672-8412-463f-a0c1-1867730d7e27","7f31cba8-b597-4129-b158-8f21a7395bd0","3b658bfc-dbb0-4f7a-9e6c-a7659ade3514","825d553e-1fdf-4961-8f6b-bab24c6b07a7","477d55b5-bef1-4c35-b8bd-42df6ef99d25","0cd887ff-5af0-405b-8d48-b2b0495af57b","4259a25b-fc62-41d0-a101-60bfaab38086","3ae1ab9b-5849-4409-b744-58ba98878274","8d8d3365-2fab-415f-862e-712d989871b2","1ef6f67e-7981-498c-8349-b67109d0fd0f","e9b95386-37fe-4820-9dc6-30a44fbeafba","f9e81224-18f1-4474-80b5-bd6b832f0b73","f0b97671-152e-45cc-a831-73fd5caa8740","d4c1893d-adf1-4111-aaa3-93d55a4059b9","2d3ea1e9-269c-4fd1-8878-21e84bf9d214","1267b3e1-8812-4435-82ff-9e57f390c194","38c49794-e385-48e6-b6ee-c42b9f2075be","2843db96-7d25-4cf5-8e67-71baed52dfb7","a531aaa4-20f4-40e6-ba1a-858a0359f602","b835f458-560c-49c2-8781-4b13d892ddd9","e4d287eb-a38c-4387-832a-e3c61ea576bd","af878dc5-7fe2-4698-b7fb-2ed4b2ffe4db","26d6d535-5164-443d-82f6-4c695caf7688","d862948f-6520-451f-af67-123309e4e4ce","ff96a11f-784d-4c26-94c7-34346d4d660e","38b241a5-8658-4b50-bfba-1800ee2d4d09","28f78ae5-97b2-487e-b097-270de10ce6b8","6c048bcd-2cc6-47fe-a558-ca54083d537e","62fc3d9a-b8ab-47e7-8df1-be09f78bb25a","48aae13c-e8a8-4057-a5d5-f77eaa56f1fd","b30d9dbd-c0f7-405f-902c-3eabd080eb00","aa858381-0720-4837-b0f8-60468c0b2763","7e6898e7-868d-490f-8f91-0cffa67c48a0","816e6e0f-a719-487e-a651-813f40cc95c5","aeaa528b-2620-42a7-bbe8-17b698d42530","9c870d54-05fd-46bb-9bb5-63a5756320a0","36e4aeae-caae-4cd6-8d6b-7015355c6229","d53f365b-64c6-45fa-9253-99fc92dfae5d","6b7b20bf-f54b-4a3d-9961-c85fbe894b67","875bd0a7-0adc-4391-8b42-85e866e87e5d","97454014-0118-4294-9648-938eb8f52327","de1883af-a411-450a-8c9f-55b07d48cd60","991af618-96d9-4bc0-879d-0e13ac6020c1","21eedfa4-4dc5-4056-bdba-dcfaf3b1a222","0e57ff86-19ec-4f88-8403-879bd0d64af8","31c8019a-6c01-4c1d-9a04-6bbd091e8ccd","52ce96d0-a12d-4e17-9644-50e0059a7730","f5f248fd-943d-477b-a9d2-de3db83d7712","c4ae973f-3a15-4409-a6cc-9cc91147f42e","ed10ec26-e9a9-40ba-85df-2d7e2dec7765","a083c30e-d4e5-4dc1-b310-02aaf36b316a","c1fd1678-d0fe-4253-a15f-a03eee323432","a013b98a-6c2a-4f92-a6a7-82266ac6f437","ef7a7954-0173-4574-86a1-486e015ab617","ded8fcaf-289f-40bd-b124-572d3d4f58ed","178b7546-3fed-4e8a-b001-9c71b1051ce9","f2b7f785-c33d-471f-bb13-57d62e83af62","a226aace-1c2d-4a53-96a3-de0ea8f3e4ad","b909342e-42c0-423e-8815-ea07509e27f9","9d124ad5-c7de-4c56-8ffe-0f3f6566d3b3","ddc736d4-2fe4-44ad-8b82-080913c64b79","ea406f31-bf7a-4139-a444-1f23847f1350","66affadd-ce7e-4ac3-a16c-d85dc2d07544","d0e65693-60a1-438c-be56-2225cf43d568","902dc4d6-9ae1-4141-ac1b-ca5b3071cd63","cac63bb3-1459-4b23-a864-f2ea6c6456e9","2fa553a5-a443-4f09-bd4c-dbc9ded93a1c","9d7c4ce2-5443-4499-a07a-695894000463","3814aaea-6bb6-4e31-b3c4-45e761c8d6d1","9d0fe465-cebe-41a0-afc4-e49fe70dee55","2edae715-e43e-471a-9b6d-a6bc52a395c0","c7d2e450-636b-443d-b737-5e2708629ea1","4bb073a1-ad47-4f14-bfa6-9ffd55ea8f81","0fbc3fc8-1bcd-433d-a6f0-b96ca76c60dc","f3d00ca5-7ce1-4562-8160-2a856dd6d1f3","1c91c686-b0d1-4f51-8784-9eee52c07b7e","c1089427-83d3-4286-9f35-5af546a6eb67","ec716296-0c8d-410a-8666-1eff05989831","c31ad117-e07c-4388-9148-387a2ba72135","c9802e4f-0860-43a1-b3ed-37d3ae8cdf92","708474aa-31a7-4dbd-a106-84de1043185d","f6470ed6-05de-421c-bae8-184d8d28be10","17cfecb9-1a5f-4b8b-a32f-119de8c44f5a","70d2f261-7253-4b1a-a52a-406e7a328c33","2fda68f7-567f-4c8f-b0b7-f4b6a5988e84","86b0b59c-8538-4aa6-90f6-ce8329258bb2","8ecadfc9-d1a3-4ea4-b844-0d9f87e4d7c8","433e1858-1953-42b2-a9dd-d7601c25d347","bb1216b4-4400-422b-8a67-8a80a9c88d5e","cf5e3b9b-595a-499d-8669-00b88b449213","e01c1ddb-8025-491a-986d-c249fa9a69a0","9d71e31b-7356-4d2d-a6e9-d588fc7692c2","c6e602bd-0d12-4265-bebc-cb208dd5030f","e929be23-7420-44f3-bd80-810a56d06e1e","46b59458-3f32-4f06-b6a2-bd27dda4305c","14cff334-91a5-4d9d-bf42-39c6d630d37c","80c8978c-c1c6-4f9e-94cd-874798b05935","f9da0435-3452-483a-a5f4-743988dc6b1d","0f1325ea-bcfe-4b02-a303-baaefb80a9f9","70407fa2-4234-4266-812c-d70754ed228c","41e806f1-99ee-4c48-9ce8-379068350924","7b6fdce7-2d25-4c7f-b8c1-004a375626cb","4a725092-b458-4dc2-9ae9-f8f0e7d415dc","178b2260-bd62-4372-ab30-7cf02b6a3108","d9964125-396a-4343-8d4e-b16c0281ae58","4df9862d-6ce3-486d-a4e1-8b246cb08f79","db205d1d-a8b1-49e1-8d5a-4f5b5ae39169","363499fe-248b-4624-ba5b-5f477bb924f4","9eefe291-18db-46f1-b308-4d7851fa270d","e4e0b3b0-1587-400f-95f9-1bb605a252c2","139c34d4-91bf-42c9-8dc5-b6c37f9ac517","8ab2ca47-1f5f-4936-8f37-c5780ff265d0","511013e8-8a72-4ddf-a9b4-1a9bb3a5fa6a","0a5044a6-a614-40e1-97e0-20af784237ea","a3fcf642-fa77-4d3c-886e-527258f00e72","4f6cdb57-2658-40b9-8adc-1b2ddf7dd7a2","df39322a-6ecd-418b-828d-09fd796dc10a","e1cb07f7-a3ac-4110-9d24-218d93bfa6f9","91280670-dbb5-4fcd-8dc3-dc9d53d94805","90b505b3-1abf-455b-af4d-f08d1135cf33","850d8476-e5fc-4059-9aed-9aeee349c384","ae2dd76f-0dd4-4484-b957-6700179f183f","9fb58da5-7347-4dbf-a892-7c933e5d7776","fc4ea3c9-1d30-4f18-b33b-7404e7da0123","693ffe34-785e-44cd-8fb7-81da25f4d3bd","3e272a96-8781-45f2-8378-6ffaa1596bcc","f2124ee6-885b-4aa6-885d-793c8626b87c","47ff8d6e-e419-464f-8940-dfa750f2115d","18f0638d-ad9b-460a-bd8b-61f12d998d0c","48021fc6-c9c8-4568-8c29-953aad4d1e0a","df41dfd5-a3a6-4c35-a58e-9b6ac732236e","1da3ace1-2326-4842-ba52-0e3a8dce989e","68f6be96-60c4-40f5-a14e-2a04dcacc1a6","5833e0eb-b53c-4156-b478-2eac8f04aec6","34530d5b-398d-496e-88d0-07a6e3de107e","4f698849-a196-4c80-be45-52d507ffb2d4","43350253-f84c-4fb3-a988-cc63366cc570","d466671a-79ad-4ca5-878f-599df8bcd17e","5ea9ae04-3601-468a-ba84-cb7e82ae1e48","31614129-0f24-4a4c-9731-53ceecc3017d","990d87fa-2d5a-48cc-bdff-0d3c6b9dd32d","5a2d898e-7f0b-43fd-8e0e-2b517b736499","16fc4a98-74ad-4970-9857-74d0f39a6c64","47380de2-eddf-42b2-b853-434cde2b5fa0","947d47b4-7883-4bb9-9d85-c5e8e2f572ce","8ca10d88-d6ce-458e-b707-a00f3b6183fd","76fb3144-bc19-4baf-ab79-432d526559b7","da07f543-88e8-4349-b9e1-2d135eb818c2","360cdc41-af67-426b-9249-b46077592db4","13973b32-e60a-4396-bf7a-85f0670d658d","b50578f7-df0d-4152-892d-ad77b284e233","0e584a02-5f47-4317-b102-9665aa08fc7d","83db2801-3fb7-4fda-9c88-227effca791f","ef378126-746c-42ef-87ea-83624095a7cc","6e793a99-19b9-4ac5-8f6a-709fd4da0b49","7bfee1d3-395f-414a-b76a-203385a535b8","100919d5-c4a2-4894-a3d7-83a8534dee66","00a794e2-f9ed-41f6-b2a3-444ec0b61131","3dfa5f20-e79c-437f-add7-0a2ade4379aa","359833f5-8592-40b6-8175-edc664e2196a","fddd10df-2a17-496f-8f2c-40845adac181","301ad868-469e-494a-948f-5212604443f0","9afb6667-24a4-456b-8720-48d5b530a003","05b724b7-9613-42c0-a5d1-45f2a0b40efd","5bb8c800-7777-43d0-a2ad-e8fae03ed3b7","b614deb1-8c61-4b74-9e54-f2c4ba8658af","6fd29849-b584-40ea-82c1-c908b83efd3f","921c46aa-ffa6-4d3b-9be2-b0affd7142d7","62ba464b-5e1c-468d-9a1f-9ddcd1053d68","5c0d4798-3eef-449f-9bfd-58d59fe6ff28","c90dc44b-a834-4a18-b728-b0631c14afa9","6a13868b-c532-4562-9131-5c866bddacf9","c33d86ef-305d-408c-87a2-b014fbcf2e16","7fe76de7-a6e6-491a-b482-449cec7c91fd","673fd28e-faab-4725-9bf4-a59b317f8f93","62f44dee-82b5-4a2f-896e-c2d132a4e415","8643025a-c059-4a48-85d0-d76f51d63a74","26fe00f8-9173-4872-9134-bb1d2e00343a","af599e54-878e-494d-8a8f-b8f8d8896f1a","c4c3550e-a965-4993-a50c-628fd38cd3e1","ab699598-7d66-4003-a0aa-86a0f827bbbf","6cedb63e-a5a2-4d1b-bf27-71f3688871ee","f3b504bb-826e-46c7-a1b7-674a5a0ae43a","9f9df1fb-cf10-42f4-b684-3913a492cc6d","be3bb907-a9fa-4b85-a21b-3154efeb0196","460397b3-c4d8-441c-9d4a-9374b15850d3","7b8aa759-d584-418d-b7e7-99e07cb45bc0","97f95e63-ac5d-4ad4-96ba-a5be9131f52b","86fe5e45-3696-4c0e-b88a-cf350e31ee68","bf0d72cc-0680-4042-bd37-2ff5d224c8d3","566c16c0-5a70-4062-80eb-42c00c823556","5bbcca67-469c-4af6-aa1f-f12014aa4747","e88da25c-3aa8-47a6-86d7-c9b2230171d8","4279e979-0fe8-4bba-8a79-e0012d33d2f7","7d3f20f0-ba46-4205-8bfa-508d47dec375","effdf562-0b65-48b3-bc44-bd406ceeb4c0","0af6e6ec-18c4-4cd6-97de-655d15eda26d","fc71d843-9b8c-4c31-a691-e34f2bf61a58","5d264b2d-d8de-4dce-8e0f-57a40c037732","facdd972-8587-42d9-94db-fea86c95f74b","04a198f4-df84-4ecf-8114-648150edc5f6","c707a0ae-7ee9-4d7a-9262-8cc87c7444ef","0944cf9e-9f5a-4cc8-a6bb-982a82145e32","0dea505e-f72c-4939-91fb-c5d318d31cbd","16018ead-6f73-447d-a422-e5895ea2f1e8","4110a755-2084-451d-a03f-2267f377e37a","c44b3809-aa60-4e78-ad0c-fc02ae6b0fb9","9f657a3d-7377-48a8-b6a3-b5a871d58953","02c0fdb9-19a4-4156-9d06-b8aa940e792a","fd78894d-5436-4f66-907a-9ef485a20d7f","11199e7d-90dd-47b0-9da2-1fc58ed7e9b7","51deb6a1-950b-4cd2-8c66-4a0b5a37291b","5eed6188-c6d6-4966-9543-28b3c88ee4e1","e51231c2-1e1d-4b36-9499-4761c759c21d","599ba755-215c-4d72-a152-5e902c03e753","9d21bfc7-b04f-4615-93d5-eb79e9e217e2","1fa05968-fc4e-4728-bf0e-c48de37a2ae1","73c521c0-1787-493e-845e-89b957b58b8b","c570afbe-46af-4d76-b23b-6e16d8d57df4","85d99e6d-f6d6-408f-a9f1-b7a97237d5c4","227e9423-1792-43b0-82e6-ac94397ed789","bc018f2c-f33c-4f25-bffb-34f3da74d2db","cfd6dc82-faa9-4f51-8534-964917ca7666","5ea8beca-77b8-44cb-8871-93620f04a6e7","7cbc7e85-a998-4d7c-bc89-78fbd0df6e8c","f35ee5d5-f4eb-42c4-a2bb-0f3c706afee7","5f94ce71-7492-4d10-ae80-3482646ca6cd","5299e6b7-b23b-46c8-8277-dc1147807117","c0f60687-8f09-4186-801b-9dd11d82d2e1","1400552c-6fe7-4bbd-a3ca-59ffea564316","ef686670-a2cc-4aec-89bf-8a67c4033507","ced133bc-30d4-48de-b239-78e9fe91c8c0","ba9770c6-6fb6-480b-9fcd-ee2ca1d7b0d6","3778be8b-3cde-493e-8ebc-a6c3f9be6129","5ce1ccad-10d3-4d04-a455-4ab42ee64a61","70d2b6ec-b846-43dc-b4f7-1a84ff24a176","0302f714-23e2-4c23-bd45-d1c97c1c1000","8c4b4f4e-6bf7-4da8-a51a-d341baf3ce44","eba5c6e7-188e-488f-a40d-0f14e1edf190","664a82c2-8810-4432-b9c4-bc5be3f7a0a6","1ef94f5a-a930-4996-9ddb-1dca7c74d040","12df5617-a0af-48ca-bf2c-4bcca863fd84","c80801f3-5848-4f8f-9c7a-dc0052a3655d","fb3429ab-83d0-4bed-95e9-1a8e9455252c","e05dbbce-79c2-45a2-a7ef-f1058856feb3","4bb527f3-5718-477f-93ae-96a00a4944fe","cafc4bb9-6584-480c-b992-c6643801be41","ba4c5917-5ba3-495b-857c-af2642a5b115","e4b5cac5-c0f5-4618-aa98-3c01e18c5fde","e6fd4e44-694e-4e30-b72a-7da4ef662a29","6b82129a-13ef-4554-93a5-17cda6672746","5f14ad42-7fae-4258-b7bf-ab24eb46988d","548801a8-a653-452a-b883-db65b6d06fac","0afea355-fcdc-47a0-a82c-f5436b883790","184ca802-aa58-44e3-96a1-5905c23d9364","50dc548d-0c1f-41c5-bf52-cb6957d9d052","82be74c1-6520-4ab5-b10e-fc17162b8c86","b69ac3e7-4dd7-45e8-ad79-2bf1d780f221","d2da8762-d5bc-4197-94d0-8c298fc6e5ed","c1b0ff3b-5ef1-4cf6-b723-64c216558172","08ea33e0-01df-4486-88f0-e1f35de8ca0b","cabab48d-da29-4857-88f0-789518f35342","a3ea6660-0f26-4ca7-8772-09c454995588","406307ea-f1c6-4592-b338-fdf958e300e6","3b98cb2d-64df-4532-a36a-b835b0494744","076cf91a-5eb9-4ee2-9bbf-647e8d818ddb","3742010c-b092-4f45-9448-d0ba8d14c7b8","148e2723-a8b5-4bac-ba2a-02ee22afe3dc","c8cf041f-6c65-4e3a-b304-e0b7cfe5a7a8","4aafbb38-45c3-4510-a4fb-79ddee4609e1","9295f662-1576-4cd9-ae2c-e5b98e004013","caa10cde-996e-4f8d-adfb-d7e3d8046726","73992542-7eea-446a-a813-be9be977a1e9","800d0ed9-5ab9-43c2-b9bf-65bb3d740822","75cbd5cd-883c-4b21-a7f7-cd7f4862c796","4f15c6a9-03c7-4290-a534-d8125d5cf9c0","e1f7972d-096f-4309-8ff3-e95fc6e290be","b88ac08b-1838-4987-8510-5d098e4e029b","bbeb12ae-8826-49e2-b9c1-efb3c49c336e","7c2068ba-d812-424b-bb7f-59445cac4081","ce7feb1b-c0e1-4a8e-a841-3711b1bee26d","07fd3b0d-1350-46c2-91be-bf586c46e878","e76d4f0e-1cbc-4afb-85f9-eea31e83f8e0","3985e331-9778-4909-aa73-79e23575ccc5","7cf78357-6f6e-49bc-9d7c-2a53a51a7de2","45fae77e-3723-4cd9-a1c4-bb7f1dae5943"]}},"description":"All C+AI Subscriptions must have pre-defined C+AI NSG rules. See https://aka.ms/netiso/nsgs - for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:32:33.7856438Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:17.0959962Z"},"enforcementMode":"Default"},"identity":{"principalId":"6fe923a8-2e4d-4c1f-b7d6-a7c5984f0129","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-DINE-NSG-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-DINE-NSG-v012","location":"southindia"},{"sku":{"name":"A0","tier":"Free"},"properties":{"displayName":"azuresecuritypackautoupdate_3.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9c46cf6e83dedb18","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]}},"description":"Combinations - of multiple policies to enable auto update of security pack and geneva agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-23T19:35:15.9907469Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-07-01T19:36:03.1679769Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7b8bd19-f827-425f-9be1-fd8a86b21904","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AzSecPack-v032","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AzSecPack-v032","location":"australiacentral"}]}' + for more details","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-02-24T21:32:33.7856438Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-06-09T16:37:17.0959962Z"},"enforcementMode":"Default"},"identity":{"principalId":"6fe923a8-2e4d-4c1f-b7d6-a7c5984f0129","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/NRMS-SBNT-DINE-NSG-v012","type":"Microsoft.Authorization/policyAssignments","name":"NRMS-SBNT-DINE-NSG-v012","location":"southindia"},{"properties":{"displayName":"antimalwaresignatureautoupdate_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/42ce40d2aa7d488c","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","global"]}},"description":"Combinations + of multiple policies to enable auto update of antimalware signature extension","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-11-09T17:52:54.3586884Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-11-17T01:04:01.7112876Z"},"enforcementMode":"Default"},"identity":{"principalId":"944ac5b9-0504-45a1-bd94-a7f6a32f2b78","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AmSigUpd-v012","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AmSigUpd-v012","location":"francecentral"},{"properties":{"displayName":"linuxazuresecuritypackautodeployiaas_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/39a3148b77c63de","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":[]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on IaaS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-10T05:16:02.7297386Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-23T21:20:00.6512074Z"},"enforcementMode":"Default"},"identity":{"principalId":"f3ec068d-c01c-4221-856c-2ec3ce8e4985","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VM-Central-v15","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VM-Central-v15","location":"eastasia"},{"properties":{"displayName":"linuxazuresecuritypackautodeployiaas_1.6","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/732406cc80ca0778","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on IaaS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:03.1821044Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"ebdfc7cf-4fad-4d3e-8da8-9ec3457a541d","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VM-Central-v16","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VM-Central-v16","location":"uksouth"},{"properties":{"displayName":"linuxazuresecuritypackautodeployvmss_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/134109bb7d72e8a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":[]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-10T05:16:05.3531754Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-23T21:20:06.7029288Z"},"enforcementMode":"Default"},"identity":{"principalId":"fab9cec9-3881-4d1d-be89-9585f4c48120","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VMSS-Central-v15","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VMSS-Central-v15","location":"centralindia"},{"properties":{"displayName":"linuxazuresecuritypackautodeployvmss_1.6","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/20e1853705896d6b","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of AzureMonitorLinuxAgent and AzureSecurityLinuxAgent + on VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:10.0659204Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"dd9f1754-4394-41c9-afb3-846fc72afcfe","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASA-VMSS-Central-v16","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASA-VMSS-Central-v16","location":"eastasia"},{"properties":{"displayName":"azsecpackautodeployuamsi_1.0","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/51dd9327c4c2bc9a","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable AzSecPack AutoConfig on VM and VMSS resources","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-23T21:20:03.1205715Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"dc0a7a3d-0c4b-475d-be5f-143b7e4ee0f6","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASM-UA-MSI-v10","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASM-UA-MSI-v10","location":"eastus2"},{"properties":{"displayName":"azuresecuritypackautodeploy_1.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/c07a73127ee784cb","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap"]}},"description":"Policies + to enable auto deploy of security pack and Geneva Agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-01-22T03:54:10.2185722Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"identity":{"principalId":"76ae450f-630f-4af4-92cf-e7153ba839f0","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-ASP-AutoDeploy-v12","type":"Microsoft.Authorization/policyAssignments","name":"SEC-ASP-AutoDeploy-v12","location":"westus"},{"properties":{"displayName":"azuresecuritypackautoupdate_3.2","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/9c46cf6e83dedb18","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","uknorth","uksouth2","brazilsoutheast","global"]}},"description":"Combinations + of multiple policies to enable auto update of security pack and geneva agent","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2020-06-23T19:35:15.9907469Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2020-07-01T19:36:03.1679769Z"},"enforcementMode":"Default"},"identity":{"principalId":"b7b8bd19-f827-425f-9be1-fd8a86b21904","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/SEC-AzSecPack-v032","type":"Microsoft.Authorization/policyAssignments","name":"SEC-AzSecPack-v032","location":"australiacentral"},{"properties":{"displayName":"vmvmssfirstpartytaginitiative_1.5","policyDefinitionId":"/providers/Microsoft.Management/managementgroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policySetDefinitions/3e9b6c243abfa9e3","scope":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792","parameters":{"AllowedLocations1":{"value":["centraluseuap","eastus2euap","westcentralus","northcentralus","westus","eastasia","australiacentral","australiaeast","canadacentral","northeurope","centralindia","japaneast","koreacentral","uksouth","centralus","eastus","westus2","francecentral","southafricanorth","germanynorth","norwayeast","switzerlandnorth","uaenorth","southeastasia","australiacentral2","australiasoutheast","canadaeast","westeurope","southindia","japanwest","koreasouth","ukwest","eastus2","southcentralus","brazilsouth","westindia","francesouth","southafricawest","germanywestcentral","norwaywest","uaecentral","switzerlandwest","brazilus","indiasouth","indiawest","indiacentral","brazilsoutheast","westus3","eastusslv","global"]}},"description":"This + initiative consists of Append and Modify policy that will update all 1st party + VM, VMSS with an identification tag","metadata":{"createdBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","createdOn":"2021-02-05T18:44:17.0051974Z","updatedBy":"1f75b9dd-4f1d-4e80-9521-321a8b1f5764","updatedOn":"2021-02-12T16:51:02.8220402Z"},"enforcementMode":"Default"},"identity":{"principalId":"fd3aca68-eb29-4ad8-be21-662836d3f454","tenantId":"00000000-0000-0000-0000-000000000000","type":"SystemAssigned"},"id":"/providers/Microsoft.Management/managementGroups/48fed3a1-0814-4847-88ce-b766155f2792/providers/Microsoft.Authorization/policyAssignments/VMVMSSFirstParty-v015","type":"Microsoft.Authorization/policyAssignments","name":"VMVMSSFirstParty-v015","location":"southafricawest"},{"properties":{"displayName":"CSEO + Block WVD resource creation","policyDefinitionId":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/Deny + WVD creation","scope":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000","notScopes":["/providers/Microsoft.Management/managementGroups/MSFT-DSRE-ISO-IAM","/providers/Microsoft.Management/managementGroups/9ce3369a-545b-cfba-c329-3631400b552f","/providers/Microsoft.Management/managementGroups/WVDSelfhost","/subscriptions/3ae2e9a4-54bd-459f-8211-6f920ecd52c4","/providers/Microsoft.Management/managementGroups/595d008b-0e4c-41f8-af09-254420fd7571","/providers/Microsoft.Management/managementGroups/CloudPCMSFTSubscriptions"],"description":"IAMAADENG@microsoft.com","metadata":{"createdBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","createdOn":"2020-11-17T19:41:36.3082667Z","updatedBy":"7f1579a6-c648-43a1-ac1e-0c3020dd9b8e","updatedOn":"2020-12-08T00:12:36.8374178Z"},"enforcementMode":"Default"},"id":"/providers/Microsoft.Management/managementGroups/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/Block + WVD creation","type":"Microsoft.Authorization/policyAssignments","name":"Block + WVD creation"},{"properties":{"displayName":"ASC Default (subscription: 00000000-0000-0000-0000-000000000000)","policyDefinitionId":"/providers/Microsoft.Authorization/policySetDefinitions/1f3afdf9-d0c9-4c3d-847f-89da613e70a8","scope":"/subscriptions/00000000-0000-0000-0000-000000000000","parameters":{"diagnosticsLogsInServiceFabricMonitoringEffect":{"value":"AuditIfNotExists"},"systemUpdatesMonitoringEffect":{"value":"AuditIfNotExists"},"systemConfigurationsMonitoringEffect":{"value":"AuditIfNotExists"},"endpointProtectionMonitoringEffect":{"value":"AuditIfNotExists"},"diskEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"networkSecurityGroupsMonitoringEffect":{"value":"AuditIfNotExists"},"webApplicationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"sqlAuditingMonitoringEffect":{"value":"AuditIfNotExists"},"sqlEncryptionMonitoringEffect":{"value":"AuditIfNotExists"},"nextGenerationFirewallMonitoringEffect":{"value":"AuditIfNotExists"},"vulnerabilityAssesmentMonitoringEffect":{"value":"AuditIfNotExists"},"storageEncryptionMonitoringEffect":{"value":"Audit"},"jitNetworkAccessMonitoringEffect":{"value":"AuditIfNotExists"},"adaptiveApplicationControlsMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateLessThanOwnersMonitoringEffect":{"value":"AuditIfNotExists"},"identityDesignateMoreThanOneOwnerMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityEnableMFAForReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveDeprecatedAccountMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithOwnerPermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithWritePermissionsMonitoringEffect":{"value":"AuditIfNotExists"},"identityRemoveExternalAccountWithReadPermissionsMonitoringEffect":{"value":"AuditIfNotExists"}},"description":"This + policy assignment was automatically created by Azure Security Center","metadata":{"assignedBy":"Security + Center"},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyAssignments/SecurityCenterBuiltIn","type":"Microsoft.Authorization/policyAssignments","name":"SecurityCenterBuiltIn"}]}' headers: cache-control: - no-cache content-length: - - '141624' + - '154455' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:59 GMT + - Fri, 26 Feb 2021 07:40:21 GMT expires: - '-1' pragma: @@ -41932,21 +26269,21 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:58.2723724Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:19.0050823Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:02:59 GMT + - Fri, 26 Feb 2021 07:40:21 GMT expires: - '-1' pragma: @@ -41960,12 +26297,12 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14997' + - '14999' status: code: 200 message: OK - request: - body: 'b''{"properties": {"policyDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0"}}''' + body: '{"properties": {"policyDefinitionId": "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0"}}' headers: Accept: - application/json @@ -41978,21 +26315,21 @@ interactions: Content-Type: - application/json User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: PUT - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:03:00.5855978Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:22.2987206Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:00 GMT + - Fri, 26 Feb 2021 07:40:21 GMT expires: - '-1' pragma: @@ -42002,7 +26339,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-writes: - - '1190' + - '1195' status: code: 201 message: Created @@ -42016,13 +26353,13 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"displayName":"Cost Management","policyType":"Custom","description":"Policies - to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:59.5562933Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' + to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:20.5642023Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -42031,7 +26368,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:00 GMT + - Fri, 26 Feb 2021 07:40:21 GMT expires: - '-1' pragma: @@ -42057,21 +26394,21 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:03:00.5855978Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:22.2987206Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:00 GMT + - Fri, 26 Feb 2021 07:40:21 GMT expires: - '-1' pragma: @@ -42099,21 +26436,21 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0?api-version=2020-09-01 response: body: - string: '{"sku":{"name":"A0","tier":"Free"},"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:03:00.5855978Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' + string: '{"properties":{"policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","scope":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:22.2987206Z","updatedBy":null,"updatedOn":null},"enforcementMode":"Default"},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rgname/providers/Microsoft.Authorization/policyAssignments/pypolicyassignmentea4a13f0","type":"Microsoft.Authorization/policyAssignments","name":"pypolicyassignmentea4a13f0"}' headers: cache-control: - no-cache content-length: - - '832' + - '798' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:00 GMT + - Fri, 26 Feb 2021 07:40:22 GMT expires: - '-1' pragma: @@ -42127,7 +26464,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14996' + - '14998' status: code: 200 message: OK @@ -42143,13 +26480,13 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"displayName":"Cost Management","policyType":"Custom","description":"Policies - to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:59.5562933Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' + to enforce low cost storage SKUs","metadata":{"category":"Cost Management","createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:20.5642023Z","updatedBy":null,"updatedOn":null},"policyDefinitions":[{"policyDefinitionReferenceId":"11590709240127142599","policyDefinitionId":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","parameters":{}}]},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policySetDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policySetDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -42158,7 +26495,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:00 GMT + - Fri, 26 Feb 2021 07:40:22 GMT expires: - '-1' pragma: @@ -42172,7 +26509,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14995' + - '14997' status: code: 200 message: OK @@ -42188,13 +26525,13 @@ interactions: Content-Length: - '0' User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: DELETE - uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2019-09-01 + uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0?api-version=2020-09-01 response: body: string: '{"properties":{"policyType":"Custom","mode":"Indexed","description":"Don''t - create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2020-09-17T09:02:55.7481401Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' + create a VM anywhere","metadata":{"createdBy":"123743cc-88ef-49ee-920e-13958fe5697d","createdOn":"2021-02-26T07:40:15.3292265Z","updatedBy":null,"updatedOn":null},"policyRule":{"if":{"allOf":[{"source":"action","equals":"Microsoft.Compute/virtualMachines/read"},{"field":"location","in":["eastus","eastus2","centralus"]}]},"then":{"effect":"deny"}}},"id":"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/pypolicyea4a13f0","type":"Microsoft.Authorization/policyDefinitions","name":"pypolicyea4a13f0"}' headers: cache-control: - no-cache @@ -42203,7 +26540,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:03:01 GMT + - Fri, 26 Feb 2021 07:40:22 GMT expires: - '-1' pragma: @@ -42217,7 +26554,7 @@ interactions: x-content-type-options: - nosniff x-ms-ratelimit-remaining-subscription-deletes: - - '14994' + - '14996' status: code: 200 message: OK diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition_at_management_group.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition_at_management_group.yaml deleted file mode 100644 index c181e3f031ee..000000000000 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_policy.test_policy_definition_at_management_group.yaml +++ /dev/null @@ -1,55 +0,0 @@ -interactions: -- request: - body: '{"name": "20000000-0001-0000-0000-000000000123"}' - headers: - Accept: - - application/json - Accept-Encoding: - - gzip, deflate - Cache-Control: - - no-cache - Connection: - - keep-alive - Content-Length: - - '48' - Content-Type: - - application/json; charset=utf-8 - User-Agent: - - python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) msrest/0.6.10 - msrest_azure/0.6.2 azure-mgmt-managementgroups/0.2.0 Azure-SDK-For-Python - accept-language: - - en-US - method: PUT - uri: https://management.azure.com/providers/Microsoft.Management/managementGroups/20000000-0001-0000-0000-000000000123?api-version=2018-03-01-preview - response: - body: - string: '{"error":{"code":"InvalidAuthenticationToken","message":"The access - token is invalid."}}' - headers: - cache-control: - - no-cache - connection: - - close - content-length: - - '88' - content-type: - - application/json; charset=utf-8 - date: - - Thu, 17 Sep 2020 09:03:15 GMT - expires: - - '-1' - pragma: - - no-cache - strict-transport-security: - - max-age=31536000; includeSubDomains - www-authenticate: - - Bearer authorization_uri="https://login.windows.net/", error="invalid_token", - error_description="The access token is invalid." - x-content-type-options: - - nosniff - x-ms-failure-cause: - - gateway - status: - code: 401 - message: Unauthorized -version: 1 diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_subscriptions.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_subscriptions.yaml index a95283530808..61a7506bc583 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_subscriptions.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_subscriptions.yaml @@ -9,7 +9,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions?api-version=2019-11-01 response: @@ -24,7 +24,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:04:47 GMT + - Fri, 26 Feb 2021 07:40:58 GMT expires: - '-1' pragma: @@ -48,7 +48,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000/locations?api-version=2019-11-01 response: @@ -106,7 +106,8 @@ interactions: Pacific"}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/centraluseuap","name":"centraluseuap","displayName":"Central US EUAP","regionalDisplayName":"(US) Central US EUAP","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"US","longitude":"-93.6208","latitude":"41.5908","pairedRegion":[{"name":"eastus2euap","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/eastus2euap"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/eastus2euap","name":"eastus2euap","displayName":"East US 2 EUAP","regionalDisplayName":"(US) East US 2 EUAP","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"US","longitude":"-78.3889","latitude":"36.6681","pairedRegion":[{"name":"centraluseuap","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/centraluseuap"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/westcentralus","name":"westcentralus","displayName":"West - Central US","regionalDisplayName":"(US) West Central US","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"US","longitude":"-110.234","latitude":"40.890","physicalLocation":"Wyoming","pairedRegion":[{"name":"westus2","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/westus2"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/southafricawest","name":"southafricawest","displayName":"South + Central US","regionalDisplayName":"(US) West Central US","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"US","longitude":"-110.234","latitude":"40.890","physicalLocation":"Wyoming","pairedRegion":[{"name":"westus2","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/westus2"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/westus3","name":"westus3","displayName":"West + US 3","regionalDisplayName":"(US) West US 3","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"US","longitude":"-112.074036","latitude":"33.448376","physicalLocation":"Phoenix","pairedRegion":[{"name":"eastus","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/eastus"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/southafricawest","name":"southafricawest","displayName":"South Africa West","regionalDisplayName":"(Africa) South Africa West","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"Africa","longitude":"18.843266","latitude":"-34.075691","physicalLocation":"Cape Town","pairedRegion":[{"name":"southafricanorth","id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/southafricanorth"}]}},{"id":"/subscriptions/00000000-0000-0000-0000-000000000000/locations/australiacentral","name":"australiacentral","displayName":"Australia Central","regionalDisplayName":"(Asia Pacific) Australia Central","metadata":{"regionType":"Physical","regionCategory":"Other","geographyGroup":"Asia @@ -138,11 +139,11 @@ interactions: cache-control: - no-cache content-length: - - '25098' + - '25532' content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:04:48 GMT + - Fri, 26 Feb 2021 07:40:59 GMT expires: - '-1' pragma: @@ -166,7 +167,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/subscriptions/00000000-0000-0000-0000-000000000000?api-version=2019-11-01 response: @@ -181,7 +182,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:04:48 GMT + - Fri, 26 Feb 2021 07:40:59 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_tenants.yaml b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_tenants.yaml index a115a51ae50c..8097726b094b 100644 --- a/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_tenants.yaml +++ b/sdk/resources/azure-mgmt-resource/tests/recordings/test_mgmt_resource_subscriptions.test_tenants.yaml @@ -9,7 +9,7 @@ interactions: Connection: - keep-alive User-Agent: - - azsdk-python-azure-mgmt-resource/0.1.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) + - azsdk-python-azure-mgmt-resource/16.0.0 Python/3.6.9 (Linux-4.9.184-linuxkit-x86_64-with-Ubuntu-18.04-bionic) method: GET uri: https://management.azure.com/tenants?api-version=2019-11-01 response: @@ -23,7 +23,7 @@ interactions: content-type: - application/json; charset=utf-8 date: - - Thu, 17 Sep 2020 09:04:48 GMT + - Fri, 26 Feb 2021 07:41:01 GMT expires: - '-1' pragma: diff --git a/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_deployment_scripts.py b/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_deployment_scripts.py index 4abc959dfbaf..7a24ff966098 100644 --- a/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_deployment_scripts.py +++ b/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_deployment_scripts.py @@ -65,8 +65,8 @@ def test_deployment_scripts(self, resource_group, location): # "https://uri1.to.supporting.script", # "https://uri2.to.supporting.script" # ], - "retentionInterval": "P7D", - "timeout": "PT1H", + "retentionInterval": "PT26H", + "timeout": "PT30M", "cleanupPreference": "Always" } ) diff --git a/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_managed_application.py b/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_managed_application.py index 75c958f548c4..2bfb1998a6de 100644 --- a/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_managed_application.py +++ b/sdk/resources/azure-mgmt-resource/tests/test_mgmt_resource_managed_application.py @@ -18,6 +18,7 @@ from azure.core.exceptions import HttpResponseError from devtools_testutils import AzureMgmtTestCase, RandomNameResourceGroupPreparer +@unittest.skip("Hard to test, skip them") class MgmtResourceLinksTest(AzureMgmtTestCase): def setUp(self): @@ -110,7 +111,7 @@ def test_application_by_id(self, resource_group, location): application_id, BODY ) - # result = result.result() + result = result.result() # Get application by id self.mgmt_client.applications.get_by_id( @@ -203,11 +204,12 @@ def test_application(self, resource_group, location): "location": "East US", "kind": "ServiceCatalog" } - self.mgmt_client.applications.begin_create_or_update( + result = self.mgmt_client.applications.begin_create_or_update( resource_group.name, application_name, BODY ) + result.wait() # Get application self.mgmt_client.applications.get( @@ -250,6 +252,7 @@ def test_application(self, resource_group, location): resource_group.name, app_def_name ) + result.wait(0) # Delete result_delete = self.resource_client.resource_groups.begin_delete(group_name) From 591ccd5266e227874a3cc342deeb6e9893a4430d Mon Sep 17 00:00:00 2001 From: "Adam Ling (MSFT)" Date: Mon, 1 Mar 2021 02:35:48 -0800 Subject: [PATCH 24/30] [ServiceBus] Improve AMQP Error handling (#16427) * improve error handling * Update sdk/servicebus/azure-servicebus/CHANGELOG.md --- sdk/servicebus/azure-servicebus/CHANGELOG.md | 4 +++ .../azure/servicebus/exceptions.py | 3 ++ .../tests/livetest/test_errors.py | 33 +++++++++++++++++++ 3 files changed, 40 insertions(+) create mode 100644 sdk/servicebus/azure-servicebus/tests/livetest/test_errors.py diff --git a/sdk/servicebus/azure-servicebus/CHANGELOG.md b/sdk/servicebus/azure-servicebus/CHANGELOG.md index e85ed6c56cd8..86d892779eed 100644 --- a/sdk/servicebus/azure-servicebus/CHANGELOG.md +++ b/sdk/servicebus/azure-servicebus/CHANGELOG.md @@ -2,6 +2,10 @@ ## 7.0.2 (Unreleased) +**BugFixes** + +* Operations failing due to `uamqp.errors.LinkForceDetach` caused by no activity on the connection for 10 minutes will now be retried internally except for the session receiver case. +* `uamqp.errors.AMQPConnectionError` errors with condition code `amqp:unknown-error` are now categorized into `ServiceBusConnectionError` instead of the general `ServiceBusError`. ## 7.0.1 (2021-01-12) diff --git a/sdk/servicebus/azure-servicebus/azure/servicebus/exceptions.py b/sdk/servicebus/azure-servicebus/azure/servicebus/exceptions.py index d2a2c781d965..29afc9b4c829 100644 --- a/sdk/servicebus/azure-servicebus/azure/servicebus/exceptions.py +++ b/sdk/servicebus/azure-servicebus/azure/servicebus/exceptions.py @@ -101,6 +101,8 @@ def _handle_amqp_exception_with_condition( elif condition == AMQPErrorCodes.ClientError and "timed out" in str(exception): # handle send timeout error_cls = OperationTimeoutError + elif condition == AMQPErrorCodes.UnknownError and isinstance(exception, AMQPErrors.AMQPConnectionError): + error_cls = ServiceBusConnectionError else: # handle other error codes error_cls = _ERROR_CODE_TO_ERROR_MAPPING.get(condition, ServiceBusError) @@ -491,6 +493,7 @@ class AutoLockRenewTimeout(ServiceBusError): AMQPErrorCodes.UnauthorizedAccess: ServiceBusAuthorizationError, AMQPErrorCodes.NotImplemented: ServiceBusError, AMQPErrorCodes.NotAllowed: ServiceBusError, + AMQPErrorCodes.LinkDetachForced: ServiceBusConnectionError, ERROR_CODE_MESSAGE_LOCK_LOST: MessageLockLostError, ERROR_CODE_MESSAGE_NOT_FOUND: MessageNotFoundError, ERROR_CODE_AUTH_FAILED: ServiceBusAuthorizationError, diff --git a/sdk/servicebus/azure-servicebus/tests/livetest/test_errors.py b/sdk/servicebus/azure-servicebus/tests/livetest/test_errors.py new file mode 100644 index 000000000000..9eeda3d10396 --- /dev/null +++ b/sdk/servicebus/azure-servicebus/tests/livetest/test_errors.py @@ -0,0 +1,33 @@ +import logging + +from uamqp import errors as AMQPErrors, constants as AMQPConstants +from azure.servicebus.exceptions import ( + _create_servicebus_exception, + ServiceBusConnectionError, + ServiceBusError +) + + +def test_link_idle_timeout(): + logger = logging.getLogger("testlogger") + amqp_error = AMQPErrors.LinkDetach(AMQPConstants.ErrorCodes.LinkDetachForced, description="Details: AmqpMessageConsumer.IdleTimerExpired: Idle timeout: 00:10:00.") + sb_error = _create_servicebus_exception(logger, amqp_error) + assert isinstance(sb_error, ServiceBusConnectionError) + assert sb_error._retryable + assert sb_error._shutdown_handler + + +def test_unknown_connection_error(): + logger = logging.getLogger("testlogger") + amqp_error = AMQPErrors.AMQPConnectionError(AMQPConstants.ErrorCodes.UnknownError) + sb_error = _create_servicebus_exception(logger, amqp_error) + assert isinstance(sb_error,ServiceBusConnectionError) + assert sb_error._retryable + assert sb_error._shutdown_handler + + amqp_error = AMQPErrors.AMQPError(AMQPConstants.ErrorCodes.UnknownError) + sb_error = _create_servicebus_exception(logger, amqp_error) + assert not isinstance(sb_error,ServiceBusConnectionError) + assert isinstance(sb_error,ServiceBusError) + assert not sb_error._retryable + assert sb_error._shutdown_handler From f54eefb79a450fed830063bb11121d90ca3df9ae Mon Sep 17 00:00:00 2001 From: Sean Kane <68240067+seankane-msft@users.noreply.github.com> Date: Mon, 1 Mar 2021 08:03:30 -0500 Subject: [PATCH 25/30] adds support for milliseconds on datetime objects (#16847) --- sdk/tables/azure-data-tables/CHANGELOG.md | 1 + .../azure/data/tables/_common_conversion.py | 5 +- .../azure/data/tables/_deserialize.py | 31 ++- .../azure/data/tables/_error.py | 5 - ...ble_entity.test_datetime_milliseconds.yaml | 192 ++++++++++++++++ ...tity.test_query_user_filter_datetimes.yaml | 75 +++---- ...tity_async.test_datetime_milliseconds.yaml | 147 +++++++++++++ ...sync.test_query_user_filter_datetimes.yaml | 77 +++---- ...ity_cosmos.test_datetime_milliseconds.yaml | 206 ++++++++++++++++++ ...smos.test_query_user_filter_datetimes.yaml | 85 ++++---- ...smos_async.test_datetime_milliseconds.yaml | 136 ++++++++++++ ...sync.test_query_user_filter_datetimes.yaml | 79 +++---- .../tests/test_table_entity.py | 22 ++ .../tests/test_table_entity_async.py | 22 ++ .../tests/test_table_entity_cosmos.py | 23 ++ .../tests/test_table_entity_cosmos_async.py | 23 ++ 16 files changed, 962 insertions(+), 167 deletions(-) create mode 100644 sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_datetime_milliseconds.yaml create mode 100644 sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_datetime_milliseconds.yaml create mode 100644 sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_datetime_milliseconds.yaml create mode 100644 sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_datetime_milliseconds.yaml diff --git a/sdk/tables/azure-data-tables/CHANGELOG.md b/sdk/tables/azure-data-tables/CHANGELOG.md index 77a8bfee94e1..217ae52c87a6 100644 --- a/sdk/tables/azure-data-tables/CHANGELOG.md +++ b/sdk/tables/azure-data-tables/CHANGELOG.md @@ -3,6 +3,7 @@ ## 12.0.0b5 (Unreleased) * Bumped minimum requirement of msrest from `0.6.10` to `0.6.19`. +* Added support for datetime entities with milliseconds ## 12.0.0b4 (2020-01-12) * Fixes an [issue](https://github.com/Azure/azure-sdk-for-python/issues/15554) where `query_entities` kwarg `parameters` would not work with multiple parameters or with non-string parameters. This now works with multiple parameters and numeric, string, boolean, UUID, and datetime objects. diff --git a/sdk/tables/azure-data-tables/azure/data/tables/_common_conversion.py b/sdk/tables/azure-data-tables/azure/data/tables/_common_conversion.py index 964c8822b217..d9c1116bc126 100644 --- a/sdk/tables/azure-data-tables/azure/data/tables/_common_conversion.py +++ b/sdk/tables/azure-data-tables/azure/data/tables/_common_conversion.py @@ -28,7 +28,10 @@ def _to_str(value): def _to_utc_datetime(value): - return value.strftime("%Y-%m-%dT%H:%M:%SZ") + try: + return value.strftime("%Y-%m-%dT%H:%M:%S.%fZ") + except ValueError: + return value.strftime("%Y-%m-%dT%H:%M:%SZ") def _encode_base64(data): diff --git a/sdk/tables/azure-data-tables/azure/data/tables/_deserialize.py b/sdk/tables/azure-data-tables/azure/data/tables/_deserialize.py index 86f4df027911..ad0c107d7a39 100644 --- a/sdk/tables/azure-data-tables/azure/data/tables/_deserialize.py +++ b/sdk/tables/azure-data-tables/azure/data/tables/_deserialize.py @@ -96,11 +96,32 @@ def tzname(self, dt): def _from_entity_datetime(value): # Cosmos returns this with a decimal point that throws an error on deserialization - if value[-9:] == ".0000000Z": - value = value[:-9] + "Z" - return datetime.datetime.strptime(value, "%Y-%m-%dT%H:%M:%SZ").replace( - tzinfo=Timezone() - ) + value = clean_up_dotnet_timestamps(value) + + try: + return datetime.datetime.strptime(value, "%Y-%m-%dT%H:%M:%S.%fZ").replace( + tzinfo=Timezone() + ) + except ValueError: + return datetime.datetime.strptime(value, "%Y-%m-%dT%H:%M:%SZ").replace( + tzinfo=Timezone() + ) + + +def clean_up_dotnet_timestamps(value): + # .NET has more decimal places than Python supports in datetime objects, this truncates + # values after 6 decimal places. + value = value.split(".") + ms = "" + if len(value) == 2: + ms = value[-1].replace("Z", "") + if len(ms) > 6: + ms = ms[:6] + ms = ms + "Z" + return ".".join([value[0], ms]) + + return value[0] + def _from_entity_guid(value): diff --git a/sdk/tables/azure-data-tables/azure/data/tables/_error.py b/sdk/tables/azure-data-tables/azure/data/tables/_error.py index 3850d2ca52e6..506f328c32b6 100644 --- a/sdk/tables/azure-data-tables/azure/data/tables/_error.py +++ b/sdk/tables/azure-data-tables/azure/data/tables/_error.py @@ -24,15 +24,10 @@ def _str(value): return value.encode("utf-8") return str(value) - - else: _str = str -def _to_utc_datetime(value): - return value.strftime("%Y-%m-%dT%H:%M:%SZ") - def _to_str(value): return _str(value) if value is not None else None diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_datetime_milliseconds.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_datetime_milliseconds.yaml new file mode 100644 index 000000000000..0c2a1d297cd8 --- /dev/null +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_datetime_milliseconds.yaml @@ -0,0 +1,192 @@ +interactions: +- request: + body: '{"TableName": "uttable97bd1223"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '32' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:35 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:35 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_table_account.table.core.windows.net/Tables + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#Tables/@Element","TableName":"uttable97bd1223"}' + headers: + cache-control: + - no-cache + content-type: + - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: + - Mon, 22 Feb 2021 14:24:35 GMT + location: + - https://fake_table_account.table.core.windows.net/Tables('uttable97bd1223') + server: + - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + x-content-type-options: + - nosniff + x-ms-version: + - '2019-02-02' + status: + code: 201 + message: Created +- request: + body: '{"PartitionKey": "pk97bd1223", "PartitionKey@odata.type": "Edm.String", + "RowKey": "rk97bd1223", "RowKey@odata.type": "Edm.String", "age": 39, "sex": + "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid", "milliseconds": "2011-11-04T00:05:23.283000Z", + "milliseconds@odata.type": "Edm.DateTime"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '681' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:35 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:35 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_table_account.table.core.windows.net/uttable97bd1223 + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable97bd1223/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A36.5672082Z''\"","PartitionKey":"pk97bd1223","RowKey":"rk97bd1223","Timestamp":"2021-02-22T14:24:36.5672082Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.283Z"}' + headers: + cache-control: + - no-cache + content-type: + - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: + - Mon, 22 Feb 2021 14:24:36 GMT + etag: + - W/"datetime'2021-02-22T14%3A24%3A36.5672082Z'" + location: + - https://fake_table_account.table.core.windows.net/uttable97bd1223(PartitionKey='pk97bd1223',RowKey='rk97bd1223') + server: + - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + x-content-type-options: + - nosniff + x-ms-version: + - '2019-02-02' + status: + code: 201 + message: Created +- request: + body: null + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:36 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:36 GMT + x-ms-version: + - '2019-02-02' + method: GET + uri: https://fake_table_account.table.core.windows.net/uttable97bd1223(PartitionKey='pk97bd1223',RowKey='rk97bd1223') + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable97bd1223/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A36.5672082Z''\"","PartitionKey":"pk97bd1223","RowKey":"rk97bd1223","Timestamp":"2021-02-22T14:24:36.5672082Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.283Z"}' + headers: + cache-control: + - no-cache + content-type: + - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: + - Mon, 22 Feb 2021 14:24:36 GMT + etag: + - W/"datetime'2021-02-22T14%3A24%3A36.5672082Z'" + server: + - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + x-content-type-options: + - nosniff + x-ms-version: + - '2019-02-02' + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '0' + Date: + - Mon, 22 Feb 2021 14:24:36 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:36 GMT + x-ms-version: + - '2019-02-02' + method: DELETE + uri: https://fake_table_account.table.core.windows.net/Tables('uttable97bd1223') + response: + body: + string: '' + headers: + cache-control: + - no-cache + content-length: + - '0' + date: + - Mon, 22 Feb 2021 14:24:36 GMT + server: + - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + x-content-type-options: + - nosniff + x-ms-version: + - '2019-02-02' + status: + code: 204 + message: No Content +version: 1 diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_query_user_filter_datetimes.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_query_user_filter_datetimes.yaml index 04a341c49cb0..0ffd80e12ac5 100644 --- a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_query_user_filter_datetimes.yaml +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity.test_query_user_filter_datetimes.yaml @@ -15,11 +15,11 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:11:33 GMT + - Mon, 22 Feb 2021 13:53:14 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:11:33 GMT + - Mon, 22 Feb 2021 13:53:14 GMT x-ms-version: - '2019-02-02' method: POST @@ -33,7 +33,7 @@ interactions: content-type: - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 date: - - Wed, 06 Jan 2021 19:11:32 GMT + - Mon, 22 Feb 2021 13:53:15 GMT location: - https://fake_table_account.table.core.windows.net/Tables('uttable114d14c9') server: @@ -51,10 +51,11 @@ interactions: body: '{"PartitionKey": "pk114d14c9", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk114d14c9", "RowKey@odata.type": "Edm.String", "age": 39, "sex": "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, - "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": "Edm.Binary", "other": - 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", "clsid@odata.type": "Edm.Guid"}' + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata @@ -63,33 +64,33 @@ interactions: Connection: - keep-alive Content-Length: - - '577' + - '591' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_table_account.table.core.windows.net/uttable114d14c9 response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A11%3A32.6136547Z''\"","PartitionKey":"pk114d14c9","RowKey":"rk114d14c9","Timestamp":"2021-01-06T19:11:32.6136547Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A15.9013159Z''\"","PartitionKey":"pk114d14c9","RowKey":"rk114d14c9","Timestamp":"2021-02-22T13:53:15.9013159Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}' headers: cache-control: - no-cache content-type: - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 date: - - Wed, 06 Jan 2021 19:11:32 GMT + - Mon, 22 Feb 2021 13:53:15 GMT etag: - - W/"datetime'2021-01-06T19%3A11%3A32.6136547Z'" + - W/"datetime'2021-02-22T13%3A53%3A15.9013159Z'" location: - https://fake_table_account.table.core.windows.net/uttable114d14c9(PartitionKey='pk114d14c9',RowKey='rk114d14c9') server: @@ -107,11 +108,11 @@ interactions: body: '{"PartitionKey": "pk114d14c91", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk114d14c91", "RowKey@odata.type": "Edm.String", "age": 49, "sex": "female", "sex@odata.type": "Edm.String", "married": false, "deceased": true, - "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": "Edm.Binary", - "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", "clsid@odata.type": - "Edm.Guid"}' + "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": + "Edm.Binary", "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata @@ -120,33 +121,33 @@ interactions: Connection: - keep-alive Content-Length: - - '592' + - '606' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_table_account.table.core.windows.net/uttable114d14c9 response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A11%3A32.7377442Z''\"","PartitionKey":"pk114d14c91","RowKey":"rk114d14c91","Timestamp":"2021-01-06T19:11:32.7377442Z","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833"}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A16.0314087Z''\"","PartitionKey":"pk114d14c91","RowKey":"rk114d14c91","Timestamp":"2021-02-22T13:53:16.0314087Z","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833"}' headers: cache-control: - no-cache content-type: - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 date: - - Wed, 06 Jan 2021 19:11:32 GMT + - Mon, 22 Feb 2021 13:53:15 GMT etag: - - W/"datetime'2021-01-06T19%3A11%3A32.7377442Z'" + - W/"datetime'2021-02-22T13%3A53%3A16.0314087Z'" location: - https://fake_table_account.table.core.windows.net/uttable114d14c9(PartitionKey='pk114d14c91',RowKey='rk114d14c91') server: @@ -172,25 +173,25 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT x-ms-version: - '2019-02-02' method: GET - uri: https://fake_table_account.table.core.windows.net/uttable114d14c9()?$filter=birthday%20eq%20datetime%271970-10-04T00%3A00%3A00Z%27 + uri: https://fake_table_account.table.core.windows.net/uttable114d14c9()?$filter=birthday%20eq%20datetime%271970-10-04T00%3A00%3A00.000000Z%27 response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9","value":[{"odata.etag":"W/\"datetime''2021-01-06T19%3A11%3A32.6136547Z''\"","PartitionKey":"pk114d14c9","RowKey":"rk114d14c9","Timestamp":"2021-01-06T19:11:32.6136547Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}]}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable114d14c9","value":[{"odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A15.9013159Z''\"","PartitionKey":"pk114d14c9","RowKey":"rk114d14c9","Timestamp":"2021-02-22T13:53:15.9013159Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}]}' headers: cache-control: - no-cache content-type: - application/json;odata=minimalmetadata;streaming=true;charset=utf-8 date: - - Wed, 06 Jan 2021 19:11:32 GMT + - Mon, 22 Feb 2021 13:53:16 GMT server: - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 transfer-encoding: @@ -214,11 +215,11 @@ interactions: Content-Length: - '0' Date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:11:34 GMT + - Mon, 22 Feb 2021 13:53:15 GMT x-ms-version: - '2019-02-02' method: DELETE @@ -232,7 +233,7 @@ interactions: content-length: - '0' date: - - Wed, 06 Jan 2021 19:11:32 GMT + - Mon, 22 Feb 2021 13:53:16 GMT server: - Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 x-content-type-options: diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_datetime_milliseconds.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_datetime_milliseconds.yaml new file mode 100644 index 000000000000..15a2d96a796f --- /dev/null +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_datetime_milliseconds.yaml @@ -0,0 +1,147 @@ +interactions: +- request: + body: '{"TableName": "uttablee6814a0"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Content-Length: + - '31' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:36 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:36 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_table_account.table.core.windows.net/Tables + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#Tables/@Element","TableName":"uttablee6814a0"}' + headers: + cache-control: no-cache + content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: Mon, 22 Feb 2021 14:24:36 GMT + location: https://fake_table_account.table.core.windows.net/Tables('uttablee6814a0') + server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + x-content-type-options: nosniff + x-ms-version: '2019-02-02' + status: + code: 201 + message: Created + url: https://seankaneprim.table.core.windows.net/Tables +- request: + body: '{"PartitionKey": "pke6814a0", "PartitionKey@odata.type": "Edm.String", + "RowKey": "rke6814a0", "RowKey@odata.type": "Edm.String", "age": 39, "sex": + "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid", "milliseconds": "2011-11-04T00:05:23.283000Z", + "milliseconds@odata.type": "Edm.DateTime"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Content-Length: + - '679' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:37 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:37 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_table_account.table.core.windows.net/uttablee6814a0 + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttablee6814a0/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A37.7329395Z''\"","PartitionKey":"pke6814a0","RowKey":"rke6814a0","Timestamp":"2021-02-22T14:24:37.7329395Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.283Z"}' + headers: + cache-control: no-cache + content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: Mon, 22 Feb 2021 14:24:37 GMT + etag: W/"datetime'2021-02-22T14%3A24%3A37.7329395Z'" + location: https://fake_table_account.table.core.windows.net/uttablee6814a0(PartitionKey='pke6814a0',RowKey='rke6814a0') + server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + x-content-type-options: nosniff + x-ms-version: '2019-02-02' + status: + code: 201 + message: Created + url: https://seankaneprim.table.core.windows.net/uttablee6814a0 +- request: + body: null + headers: + Accept: + - application/json;odata=minimalmetadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:37 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:37 GMT + x-ms-version: + - '2019-02-02' + method: GET + uri: https://fake_table_account.table.core.windows.net/uttablee6814a0(PartitionKey='pke6814a0',RowKey='rke6814a0') + response: + body: + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttablee6814a0/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A37.7329395Z''\"","PartitionKey":"pke6814a0","RowKey":"rke6814a0","Timestamp":"2021-02-22T14:24:37.7329395Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.283Z"}' + headers: + cache-control: no-cache + content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 + date: Mon, 22 Feb 2021 14:24:37 GMT + etag: W/"datetime'2021-02-22T14%3A24%3A37.7329395Z'" + server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + x-content-type-options: nosniff + x-ms-version: '2019-02-02' + status: + code: 200 + message: OK + url: https://seankaneprim.table.core.windows.net/uttablee6814a0(PartitionKey='pke6814a0',RowKey='rke6814a0') +- request: + body: null + headers: + Accept: + - application/json + Date: + - Mon, 22 Feb 2021 14:24:37 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:37 GMT + x-ms-version: + - '2019-02-02' + method: DELETE + uri: https://fake_table_account.table.core.windows.net/Tables('uttablee6814a0') + response: + body: + string: '' + headers: + cache-control: no-cache + content-length: '0' + date: Mon, 22 Feb 2021 14:24:37 GMT + server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 + x-content-type-options: nosniff + x-ms-version: '2019-02-02' + status: + code: 204 + message: No Content + url: https://seankaneprim.table.core.windows.net/Tables('uttablee6814a0') +version: 1 diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_query_user_filter_datetimes.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_query_user_filter_datetimes.yaml index b543bab0e86a..3502bc43f326 100644 --- a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_query_user_filter_datetimes.yaml +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_async.test_query_user_filter_datetimes.yaml @@ -11,11 +11,11 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT x-ms-version: - '2019-02-02' method: POST @@ -26,7 +26,7 @@ interactions: headers: cache-control: no-cache content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 - date: Wed, 06 Jan 2021 19:14:52 GMT + date: Mon, 22 Feb 2021 13:53:16 GMT location: https://fake_table_account.table.core.windows.net/Tables('uttable96d71746') server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -40,37 +40,38 @@ interactions: body: '{"PartitionKey": "pk96d71746", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk96d71746", "RowKey@odata.type": "Edm.String", "age": 39, "sex": "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, - "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": "Edm.Binary", "other": - 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", "clsid@odata.type": "Edm.Guid"}' + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata Content-Length: - - '577' + - '591' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_table_account.table.core.windows.net/uttable96d71746 response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A14%3A52.824101Z''\"","PartitionKey":"pk96d71746","RowKey":"rk96d71746","Timestamp":"2021-01-06T19:14:52.824101Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A17.1623617Z''\"","PartitionKey":"pk96d71746","RowKey":"rk96d71746","Timestamp":"2021-02-22T13:53:17.1623617Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}' headers: cache-control: no-cache content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 - date: Wed, 06 Jan 2021 19:14:52 GMT - etag: W/"datetime'2021-01-06T19%3A14%3A52.824101Z'" + date: Mon, 22 Feb 2021 13:53:16 GMT + etag: W/"datetime'2021-02-22T13%3A53%3A17.1623617Z'" location: https://fake_table_account.table.core.windows.net/uttable96d71746(PartitionKey='pk96d71746',RowKey='rk96d71746') server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -84,38 +85,38 @@ interactions: body: '{"PartitionKey": "pk96d717461", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk96d717461", "RowKey@odata.type": "Edm.String", "age": 49, "sex": "female", "sex@odata.type": "Edm.String", "married": false, "deceased": true, - "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": "Edm.Binary", - "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", "clsid@odata.type": - "Edm.Guid"}' + "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": + "Edm.Binary", "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata Content-Length: - - '592' + - '606' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:14:54 GMT + - Mon, 22 Feb 2021 13:53:16 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_table_account.table.core.windows.net/uttable96d71746 response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A14%3A52.944189Z''\"","PartitionKey":"pk96d717461","RowKey":"rk96d717461","Timestamp":"2021-01-06T19:14:52.944189Z","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833"}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A17.3484942Z''\"","PartitionKey":"pk96d717461","RowKey":"rk96d717461","Timestamp":"2021-02-22T13:53:17.3484942Z","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833"}' headers: cache-control: no-cache content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 - date: Wed, 06 Jan 2021 19:14:52 GMT - etag: W/"datetime'2021-01-06T19%3A14%3A52.944189Z'" + date: Mon, 22 Feb 2021 13:53:16 GMT + etag: W/"datetime'2021-02-22T13%3A53%3A17.3484942Z'" location: https://fake_table_account.table.core.windows.net/uttable96d71746(PartitionKey='pk96d717461',RowKey='rk96d717461') server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -133,22 +134,22 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:14:55 GMT + - Mon, 22 Feb 2021 13:53:16 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:14:55 GMT + - Mon, 22 Feb 2021 13:53:16 GMT x-ms-version: - '2019-02-02' method: GET - uri: https://fake_table_account.table.core.windows.net/uttable96d71746()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00Z' + uri: https://fake_table_account.table.core.windows.net/uttable96d71746()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00.000000Z' response: body: - string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746","value":[{"odata.etag":"W/\"datetime''2021-01-06T19%3A14%3A52.824101Z''\"","PartitionKey":"pk96d71746","RowKey":"rk96d71746","Timestamp":"2021-01-06T19:14:52.824101Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}]}' + string: '{"odata.metadata":"https://fake_table_account.table.core.windows.net/$metadata#uttable96d71746","value":[{"odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A17.1623617Z''\"","PartitionKey":"pk96d71746","RowKey":"rk96d71746","Timestamp":"2021-02-22T13:53:17.1623617Z","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833"}]}' headers: cache-control: no-cache content-type: application/json;odata=minimalmetadata;streaming=true;charset=utf-8 - date: Wed, 06 Jan 2021 19:14:52 GMT + date: Mon, 22 Feb 2021 13:53:16 GMT server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 transfer-encoding: chunked x-content-type-options: nosniff @@ -156,18 +157,18 @@ interactions: status: code: 200 message: OK - url: https://seankaneprim.table.core.windows.net/uttable96d71746()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00Z' + url: https://seankaneprim.table.core.windows.net/uttable96d71746()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00.000000Z' - request: body: null headers: Accept: - application/json Date: - - Wed, 06 Jan 2021 19:14:55 GMT + - Mon, 22 Feb 2021 13:53:16 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:14:55 GMT + - Mon, 22 Feb 2021 13:53:16 GMT x-ms-version: - '2019-02-02' method: DELETE @@ -178,7 +179,7 @@ interactions: headers: cache-control: no-cache content-length: '0' - date: Wed, 06 Jan 2021 19:14:52 GMT + date: Mon, 22 Feb 2021 13:53:16 GMT server: Windows-Azure-Table/1.0 Microsoft-HTTPAPI/2.0 x-content-type-options: nosniff x-ms-version: '2019-02-02' diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_datetime_milliseconds.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_datetime_milliseconds.yaml new file mode 100644 index 000000000000..9986f6591398 --- /dev/null +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_datetime_milliseconds.yaml @@ -0,0 +1,206 @@ +interactions: +- request: + body: '{"TableName": "uttable24e31516"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '32' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:37 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:37 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_cosmos_account.table.cosmos.azure.com/Tables + response: + body: + string: '{"TableName":"uttable24e31516","odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#Tables/@Element"}' + headers: + content-type: + - application/json;odata=minimalmetadata + date: + - Mon, 22 Feb 2021 14:24:40 GMT + etag: + - W/"datetime'2021-02-22T14%3A24%3A40.6199304Z'" + location: + - https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttable24e31516') + server: + - Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + status: + code: 201 + message: Ok +- request: + body: '{"PartitionKey": "pk24e31516", "PartitionKey@odata.type": "Edm.String", + "RowKey": "rk24e31516", "RowKey@odata.type": "Edm.String", "age": 39, "sex": + "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid", "milliseconds": "2011-11-04T00:05:23.283000Z", + "milliseconds@odata.type": "Edm.DateTime"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '681' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:40 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:40 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable24e31516 + response: + body: + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable24e31516/$metadata#uttable24e31516/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A41.4203912Z''\"","PartitionKey":"pk24e31516","RowKey":"rk24e31516","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.2830000Z","Timestamp":"2021-02-22T14:24:41.4203912Z"}' + headers: + content-type: + - application/json;odata=minimalmetadata + date: + - Mon, 22 Feb 2021 14:24:41 GMT + etag: + - W/"datetime'2021-02-22T14%3A24%3A41.4203912Z'" + location: + - https://fake_cosmos_account.table.cosmos.azure.com/uttable24e31516(PartitionKey='pk24e31516',RowKey='rk24e31516') + server: + - Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + status: + code: 201 + message: Created +- request: + body: null + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:40 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:40 GMT + x-ms-version: + - '2019-02-02' + method: GET + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable24e31516(PartitionKey='pk24e31516',RowKey='rk24e31516') + response: + body: + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable24e31516/$metadata#uttable24e31516/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A24%3A41.4203912Z''\"","PartitionKey":"pk24e31516","RowKey":"rk24e31516","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.2830000Z","Timestamp":"2021-02-22T14:24:41.4203912Z"}' + headers: + content-type: + - application/json;odata=minimalmetadata + date: + - Mon, 22 Feb 2021 14:24:41 GMT + etag: + - W/"datetime'2021-02-22T14%3A24%3A41.4203912Z'" + server: + - Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + status: + code: 200 + message: Ok +- request: + body: null + headers: + Accept: + - application/json + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '0' + Date: + - Mon, 22 Feb 2021 14:24:41 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:41 GMT + x-ms-version: + - '2019-02-02' + method: DELETE + uri: https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttable24e31516') + response: + body: + string: '' + headers: + content-length: + - '0' + date: + - Mon, 22 Feb 2021 14:24:41 GMT + server: + - Microsoft-HTTPAPI/2.0 + status: + code: 204 + message: No Content +- request: + body: null + headers: + Accept: + - application/json;odata=minimalmetadata + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:24:41 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:24:41 GMT + x-ms-version: + - '2019-02-02' + method: GET + uri: https://fake_cosmos_account.table.cosmos.azure.com/Tables + response: + body: + string: '{"value":[],"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#Tables"}' + headers: + content-type: + - application/json;odata=minimalmetadata + date: + - Mon, 22 Feb 2021 14:24:41 GMT + server: + - Microsoft-HTTPAPI/2.0 + transfer-encoding: + - chunked + status: + code: 200 + message: Ok +version: 1 diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_query_user_filter_datetimes.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_query_user_filter_datetimes.yaml index 51736cb80551..2de21fa0eace 100644 --- a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_query_user_filter_datetimes.yaml +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos.test_query_user_filter_datetimes.yaml @@ -15,11 +15,11 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:18:01 GMT + - Mon, 22 Feb 2021 13:53:17 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:01 GMT + - Mon, 22 Feb 2021 13:53:17 GMT x-ms-version: - '2019-02-02' method: POST @@ -31,9 +31,9 @@ interactions: content-type: - application/json;odata=minimalmetadata date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:20 GMT etag: - - W/"datetime'2021-01-06T19%3A18%3A00.7086088Z'" + - W/"datetime'2021-02-22T13%3A53%3A20.2417672Z'" location: - https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttableb01617bc') server: @@ -47,10 +47,11 @@ interactions: body: '{"PartitionKey": "pkb01617bc", "PartitionKey@odata.type": "Edm.String", "RowKey": "rkb01617bc", "RowKey@odata.type": "Edm.String", "age": 39, "sex": "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, - "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": "Edm.Binary", "other": - 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", "clsid@odata.type": "Edm.Guid"}' + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata @@ -59,31 +60,31 @@ interactions: Connection: - keep-alive Content-Length: - - '577' + - '591' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:20 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:20 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc response: body: - string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc/$metadata#uttableb01617bc/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A18%3A01.2901384Z''\"","PartitionKey":"pkb01617bc","RowKey":"rkb01617bc","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-01-06T19:18:01.2901384Z"}' + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc/$metadata#uttableb01617bc/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A21.4696456Z''\"","PartitionKey":"pkb01617bc","RowKey":"rkb01617bc","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-02-22T13:53:21.4696456Z"}' headers: content-type: - application/json;odata=minimalmetadata date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:20 GMT etag: - - W/"datetime'2021-01-06T19%3A18%3A01.2901384Z'" + - W/"datetime'2021-02-22T13%3A53%3A21.4696456Z'" location: - https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc(PartitionKey='pkb01617bc',RowKey='rkb01617bc') server: @@ -97,11 +98,11 @@ interactions: body: '{"PartitionKey": "pkb01617bc1", "PartitionKey@odata.type": "Edm.String", "RowKey": "rkb01617bc1", "RowKey@odata.type": "Edm.String", "age": 49, "sex": "female", "sex@odata.type": "Edm.String", "married": false, "deceased": true, - "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": "Edm.Binary", - "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", "clsid@odata.type": - "Edm.Guid"}' + "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": + "Edm.Binary", "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata @@ -110,31 +111,31 @@ interactions: Connection: - keep-alive Content-Length: - - '592' + - '606' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:20 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:20 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc response: body: - string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc/$metadata#uttableb01617bc/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A18%3A01.4064648Z''\"","PartitionKey":"pkb01617bc1","RowKey":"rkb01617bc1","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833","Timestamp":"2021-01-06T19:18:01.4064648Z"}' + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc/$metadata#uttableb01617bc/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A21.6239624Z''\"","PartitionKey":"pkb01617bc1","RowKey":"rkb01617bc1","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833","Timestamp":"2021-02-22T13:53:21.6239624Z"}' headers: content-type: - application/json;odata=minimalmetadata date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:21 GMT etag: - - W/"datetime'2021-01-06T19%3A18%3A01.4064648Z'" + - W/"datetime'2021-02-22T13%3A53%3A21.6239624Z'" location: - https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc(PartitionKey='pkb01617bc1',RowKey='rkb01617bc1') server: @@ -156,23 +157,23 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:21 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:21 GMT x-ms-version: - '2019-02-02' method: GET - uri: https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc()?$filter=birthday%20eq%20datetime%271970-10-04T00%3A00%3A00Z%27 + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttableb01617bc()?$filter=birthday%20eq%20datetime%271970-10-04T00%3A00%3A00.000000Z%27 response: body: - string: '{"value":[{"odata.etag":"W/\"datetime''2021-01-06T19%3A18%3A01.2901384Z''\"","PartitionKey":"pkb01617bc","RowKey":"rkb01617bc","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-01-06T19:18:01.2901384Z"}],"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#uttableb01617bc"}' + string: '{"value":[{"odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A21.4696456Z''\"","PartitionKey":"pkb01617bc","RowKey":"rkb01617bc","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-02-22T13:53:21.4696456Z"}],"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#uttableb01617bc"}' headers: content-type: - application/json;odata=minimalmetadata date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:21 GMT server: - Microsoft-HTTPAPI/2.0 transfer-encoding: @@ -192,11 +193,11 @@ interactions: Content-Length: - '0' Date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:21 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:21 GMT x-ms-version: - '2019-02-02' method: DELETE @@ -208,7 +209,7 @@ interactions: content-length: - '0' date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:21 GMT server: - Microsoft-HTTPAPI/2.0 status: @@ -226,11 +227,11 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:22 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:18:03 GMT + - Mon, 22 Feb 2021 13:53:22 GMT x-ms-version: - '2019-02-02' method: GET @@ -242,7 +243,7 @@ interactions: content-type: - application/json;odata=minimalmetadata date: - - Wed, 06 Jan 2021 19:18:00 GMT + - Mon, 22 Feb 2021 13:53:22 GMT server: - Microsoft-HTTPAPI/2.0 transfer-encoding: diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_datetime_milliseconds.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_datetime_milliseconds.yaml new file mode 100644 index 000000000000..5ec920ea5784 --- /dev/null +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_datetime_milliseconds.yaml @@ -0,0 +1,136 @@ +interactions: +- request: + body: '{"TableName": "uttablead311793"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Content-Length: + - '32' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:25:11 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:25:11 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_cosmos_account.table.cosmos.azure.com/Tables + response: + body: + string: '{"TableName":"uttablead311793","odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#Tables/@Element"}' + headers: + content-type: application/json;odata=minimalmetadata + date: Mon, 22 Feb 2021 14:25:13 GMT + etag: W/"datetime'2021-02-22T14%3A25%3A13.5132680Z'" + location: https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttablead311793') + server: Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + status: + code: 201 + message: Ok + url: https://seankaneprim.table.cosmos.azure.com/Tables +- request: + body: '{"PartitionKey": "pkad311793", "PartitionKey@odata.type": "Edm.String", + "RowKey": "rkad311793", "RowKey@odata.type": "Edm.String", "age": 39, "sex": + "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid", "milliseconds": "2011-11-04T00:05:23.283000Z", + "milliseconds@odata.type": "Edm.DateTime"}' + headers: + Accept: + - application/json;odata=minimalmetadata + Content-Length: + - '681' + Content-Type: + - application/json;odata=nometadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:25:13 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:25:13 GMT + x-ms-version: + - '2019-02-02' + method: POST + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttablead311793 + response: + body: + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttablead311793/$metadata#uttablead311793/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A25%3A14.2576136Z''\"","PartitionKey":"pkad311793","RowKey":"rkad311793","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.2830000Z","Timestamp":"2021-02-22T14:25:14.2576136Z"}' + headers: + content-type: application/json;odata=minimalmetadata + date: Mon, 22 Feb 2021 14:25:14 GMT + etag: W/"datetime'2021-02-22T14%3A25%3A14.2576136Z'" + location: https://fake_cosmos_account.table.cosmos.azure.com/uttablead311793(PartitionKey='pkad311793',RowKey='rkad311793') + server: Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + status: + code: 201 + message: Created + url: https://seankaneprim.table.cosmos.azure.com/uttablead311793 +- request: + body: null + headers: + Accept: + - application/json;odata=minimalmetadata + DataServiceVersion: + - '3.0' + Date: + - Mon, 22 Feb 2021 14:25:13 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:25:13 GMT + x-ms-version: + - '2019-02-02' + method: GET + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttablead311793(PartitionKey='pkad311793',RowKey='rkad311793') + response: + body: + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttablead311793/$metadata#uttablead311793/@Element","odata.etag":"W/\"datetime''2021-02-22T14%3A25%3A14.2576136Z''\"","PartitionKey":"pkad311793","RowKey":"rkad311793","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","milliseconds@odata.type":"Edm.DateTime","milliseconds":"2011-11-04T00:05:23.2830000Z","Timestamp":"2021-02-22T14:25:14.2576136Z"}' + headers: + content-type: application/json;odata=minimalmetadata + date: Mon, 22 Feb 2021 14:25:14 GMT + etag: W/"datetime'2021-02-22T14%3A25%3A14.2576136Z'" + server: Microsoft-HTTPAPI/2.0 + transfer-encoding: chunked + status: + code: 200 + message: Ok + url: https://seankaneprim.table.cosmos.azure.com/uttablead311793(PartitionKey='pkad311793',RowKey='rkad311793') +- request: + body: null + headers: + Accept: + - application/json + Date: + - Mon, 22 Feb 2021 14:25:13 GMT + User-Agent: + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 22 Feb 2021 14:25:13 GMT + x-ms-version: + - '2019-02-02' + method: DELETE + uri: https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttablead311793') + response: + body: + string: '' + headers: + content-length: '0' + date: Mon, 22 Feb 2021 14:25:14 GMT + server: Microsoft-HTTPAPI/2.0 + status: + code: 204 + message: No Content + url: https://seankaneprim.table.cosmos.azure.com/Tables('uttablead311793') +version: 1 diff --git a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_query_user_filter_datetimes.yaml b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_query_user_filter_datetimes.yaml index 6b01aeaa44a9..d912cce21d2c 100644 --- a/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_query_user_filter_datetimes.yaml +++ b/sdk/tables/azure-data-tables/tests/recordings/test_table_entity_cosmos_async.test_query_user_filter_datetimes.yaml @@ -11,11 +11,11 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:22:32 GMT + - Mon, 22 Feb 2021 13:53:52 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:22:32 GMT + - Mon, 22 Feb 2021 13:53:52 GMT x-ms-version: - '2019-02-02' method: POST @@ -25,8 +25,8 @@ interactions: string: '{"TableName":"uttable47611a39","odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#Tables/@Element"}' headers: content-type: application/json;odata=minimalmetadata - date: Wed, 06 Jan 2021 19:22:30 GMT - etag: W/"datetime'2021-01-06T19%3A22%3A30.4645128Z'" + date: Mon, 22 Feb 2021 13:53:54 GMT + etag: W/"datetime'2021-02-22T13%3A53%3A54.4158216Z'" location: https://fake_cosmos_account.table.cosmos.azure.com/Tables('uttable47611a39') server: Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -38,36 +38,37 @@ interactions: body: '{"PartitionKey": "pk47611a39", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk47611a39", "RowKey@odata.type": "Edm.String", "age": 39, "sex": "male", "sex@odata.type": "Edm.String", "married": true, "deceased": false, - "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": "Edm.Binary", "other": - 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", "clsid@odata.type": "Edm.Guid"}' + "ratio": 3.1, "evenratio": 3.0, "large": 933311100, "Birthday": "1973-10-04T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1970-10-04T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5", "binary@odata.type": + "Edm.Binary", "other": 20, "clsid": "c9da6455-213d-42c9-9a79-3e9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata Content-Length: - - '577' + - '591' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39 response: body: - string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39/$metadata#uttable47611a39/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A22%3A31.0592520Z''\"","PartitionKey":"pk47611a39","RowKey":"rk47611a39","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-01-06T19:22:31.0592520Z"}' + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39/$metadata#uttable47611a39/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A55.1257608Z''\"","PartitionKey":"pk47611a39","RowKey":"rk47611a39","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-02-22T13:53:55.1257608Z"}' headers: content-type: application/json;odata=minimalmetadata - date: Wed, 06 Jan 2021 19:22:30 GMT - etag: W/"datetime'2021-01-06T19%3A22%3A31.0592520Z'" + date: Mon, 22 Feb 2021 13:53:54 GMT + etag: W/"datetime'2021-02-22T13%3A53%3A55.1257608Z'" location: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39(PartitionKey='pk47611a39',RowKey='rk47611a39') server: Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -79,37 +80,37 @@ interactions: body: '{"PartitionKey": "pk47611a391", "PartitionKey@odata.type": "Edm.String", "RowKey": "rk47611a391", "RowKey@odata.type": "Edm.String", "age": 49, "sex": "female", "sex@odata.type": "Edm.String", "married": false, "deceased": true, - "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00Z", - "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00Z", "birthday@odata.type": - "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": "Edm.Binary", - "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", "clsid@odata.type": - "Edm.Guid"}' + "ratio": 5.2, "evenratio": 6.0, "large": 39999011, "Birthday": "1993-04-01T00:00:00.000000Z", + "Birthday@odata.type": "Edm.DateTime", "birthday": "1990-04-01T00:00:00.000000Z", + "birthday@odata.type": "Edm.DateTime", "binary": "YmluYXJ5LWJpbmFyeQ==", "binary@odata.type": + "Edm.Binary", "other": 40, "clsid": "c8da6455-213e-42d9-9b79-3f9149a57833", + "clsid@odata.type": "Edm.Guid"}' headers: Accept: - application/json;odata=minimalmetadata Content-Length: - - '592' + - '606' Content-Type: - application/json;odata=nometadata DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT x-ms-version: - '2019-02-02' method: POST uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39 response: body: - string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39/$metadata#uttable47611a39/@Element","odata.etag":"W/\"datetime''2021-01-06T19%3A22%3A31.1686152Z''\"","PartitionKey":"pk47611a391","RowKey":"rk47611a391","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833","Timestamp":"2021-01-06T19:22:31.1686152Z"}' + string: '{"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39/$metadata#uttable47611a39/@Element","odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A55.3397768Z''\"","PartitionKey":"pk47611a391","RowKey":"rk47611a391","age":49,"sex":"female","married":false,"deceased":true,"ratio":5.2,"evenratio":6.0,"large":39999011,"Birthday@odata.type":"Edm.DateTime","Birthday":"1993-04-01T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1990-04-01T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5LWJpbmFyeQ==","other":40,"clsid@odata.type":"Edm.Guid","clsid":"c8da6455-213e-42d9-9b79-3f9149a57833","Timestamp":"2021-02-22T13:53:55.3397768Z"}' headers: content-type: application/json;odata=minimalmetadata - date: Wed, 06 Jan 2021 19:22:30 GMT - etag: W/"datetime'2021-01-06T19%3A22%3A31.1686152Z'" + date: Mon, 22 Feb 2021 13:53:54 GMT + etag: W/"datetime'2021-02-22T13%3A53%3A55.3397768Z'" location: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39(PartitionKey='pk47611a391',RowKey='rk47611a391') server: Microsoft-HTTPAPI/2.0 transfer-encoding: chunked @@ -125,38 +126,38 @@ interactions: DataServiceVersion: - '3.0' Date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:54 GMT x-ms-version: - '2019-02-02' method: GET - uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00Z' + uri: https://fake_cosmos_account.table.cosmos.azure.com/uttable47611a39()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00.000000Z' response: body: - string: '{"value":[{"odata.etag":"W/\"datetime''2021-01-06T19%3A22%3A31.0592520Z''\"","PartitionKey":"pk47611a39","RowKey":"rk47611a39","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-01-06T19:22:31.0592520Z"}],"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#uttable47611a39"}' + string: '{"value":[{"odata.etag":"W/\"datetime''2021-02-22T13%3A53%3A55.1257608Z''\"","PartitionKey":"pk47611a39","RowKey":"rk47611a39","age":39,"sex":"male","married":true,"deceased":false,"ratio":3.1,"evenratio":3.0,"large":933311100,"Birthday@odata.type":"Edm.DateTime","Birthday":"1973-10-04T00:00:00.0000000Z","birthday@odata.type":"Edm.DateTime","birthday":"1970-10-04T00:00:00.0000000Z","binary@odata.type":"Edm.Binary","binary":"YmluYXJ5","other":20,"clsid@odata.type":"Edm.Guid","clsid":"c9da6455-213d-42c9-9a79-3e9149a57833","Timestamp":"2021-02-22T13:53:55.1257608Z"}],"odata.metadata":"https://fake_cosmos_account.table.cosmos.azure.com/$metadata#uttable47611a39"}' headers: content-type: application/json;odata=minimalmetadata - date: Wed, 06 Jan 2021 19:22:31 GMT + date: Mon, 22 Feb 2021 13:53:54 GMT server: Microsoft-HTTPAPI/2.0 transfer-encoding: chunked status: code: 200 message: Ok - url: https://seankaneprim.table.cosmos.azure.com/uttable47611a39()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00Z' + url: https://seankaneprim.table.cosmos.azure.com/uttable47611a39()?$filter=birthday%20eq%20datetime'1970-10-04T00:00:00.000000Z' - request: body: null headers: Accept: - application/json Date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:55 GMT User-Agent: - - azsdk-python-data-tables/12.0.0b4 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) + - azsdk-python-data-tables/12.0.0b5 Python/3.9.0rc1 (Windows-10-10.0.19041-SP0) x-ms-date: - - Wed, 06 Jan 2021 19:22:33 GMT + - Mon, 22 Feb 2021 13:53:55 GMT x-ms-version: - '2019-02-02' method: DELETE @@ -166,7 +167,7 @@ interactions: string: '' headers: content-length: '0' - date: Wed, 06 Jan 2021 19:22:31 GMT + date: Mon, 22 Feb 2021 13:53:55 GMT server: Microsoft-HTTPAPI/2.0 status: code: 204 diff --git a/sdk/tables/azure-data-tables/tests/test_table_entity.py b/sdk/tables/azure-data-tables/tests/test_table_entity.py index 605960de62fb..4553e18335ee 100644 --- a/sdk/tables/azure-data-tables/tests/test_table_entity.py +++ b/sdk/tables/azure-data-tables/tests/test_table_entity.py @@ -1887,3 +1887,25 @@ def test_sas_signed_identifier(self, tables_storage_account_name, tables_primary self._assert_default_entity(entities[0]) finally: self._tear_down() + + @TablesPreparer() + def test_datetime_milliseconds(self, tables_storage_account_name, tables_primary_storage_account_key): + # SAS URL is calculated from storage key, so this test runs live only + url = self.account_url(tables_storage_account_name, "table") + self._set_up(tables_storage_account_name, tables_primary_storage_account_key) + try: + entity = self._create_random_entity_dict() + + entity['milliseconds'] = datetime(2011, 11, 4, 0, 5, 23, 283000, tzinfo=tzutc()) + + self.table.create_entity(entity) + + received_entity = self.table.get_entity( + partition_key=entity['PartitionKey'], + row_key=entity['RowKey'] + ) + + assert entity['milliseconds'] == received_entity['milliseconds'] + + finally: + self._tear_down() diff --git a/sdk/tables/azure-data-tables/tests/test_table_entity_async.py b/sdk/tables/azure-data-tables/tests/test_table_entity_async.py index 6bf4f0f21073..2f4c4b48522c 100644 --- a/sdk/tables/azure-data-tables/tests/test_table_entity_async.py +++ b/sdk/tables/azure-data-tables/tests/test_table_entity_async.py @@ -1871,3 +1871,25 @@ async def test_sas_signed_identifier(self, tables_storage_account_name, tables_p self._assert_default_entity(entities[0]) finally: await self._tear_down() + + @TablesPreparer() + async def test_datetime_milliseconds(self, tables_storage_account_name, tables_primary_storage_account_key): + # SAS URL is calculated from storage key, so this test runs live only + url = self.account_url(tables_storage_account_name, "table") + await self._set_up(tables_storage_account_name, tables_primary_storage_account_key) + try: + entity = self._create_random_entity_dict() + + entity['milliseconds'] = datetime(2011, 11, 4, 0, 5, 23, 283000, tzinfo=tzutc()) + + await self.table.create_entity(entity) + + received_entity = await self.table.get_entity( + partition_key=entity['PartitionKey'], + row_key=entity['RowKey'] + ) + + assert entity['milliseconds'] == received_entity['milliseconds'] + + finally: + await self._tear_down() \ No newline at end of file diff --git a/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos.py b/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos.py index 18091aa04b14..c642b233b4c0 100644 --- a/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos.py +++ b/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos.py @@ -1944,3 +1944,26 @@ def test_sas_signed_identifier(self, tables_cosmos_account_name, tables_primary_ finally: self._tear_down() self.sleep(SLEEP_DELAY) + + @CosmosPreparer() + def test_datetime_milliseconds(self, tables_cosmos_account_name, tables_primary_cosmos_account_key): + # SAS URL is calculated from storage key, so this test runs live only + url = self.account_url(tables_cosmos_account_name, "table") + self._set_up(tables_cosmos_account_name, tables_primary_cosmos_account_key) + try: + entity = self._create_random_entity_dict() + + entity['milliseconds'] = datetime(2011, 11, 4, 0, 5, 23, 283000, tzinfo=tzutc()) + + self.table.create_entity(entity) + + received_entity = self.table.get_entity( + partition_key=entity['PartitionKey'], + row_key=entity['RowKey'] + ) + + assert entity['milliseconds'] == received_entity['milliseconds'] + + finally: + self._tear_down() + self.sleep(SLEEP_DELAY) \ No newline at end of file diff --git a/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos_async.py b/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos_async.py index 7b21757e92e3..084e00ba3cfa 100644 --- a/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos_async.py +++ b/sdk/tables/azure-data-tables/tests/test_table_entity_cosmos_async.py @@ -2030,3 +2030,26 @@ async def test_sas_signed_identifier(self, tables_cosmos_account_name, tables_pr await self._tear_down() if self.is_live: sleep(SLEEP_DELAY) + + @CosmosPreparer() + async def test_datetime_milliseconds(self, tables_cosmos_account_name, tables_primary_cosmos_account_key): + # SAS URL is calculated from storage key, so this test runs live only + url = self.account_url(tables_cosmos_account_name, "table") + await self._set_up(tables_cosmos_account_name, tables_primary_cosmos_account_key) + try: + entity = self._create_random_entity_dict() + + entity['milliseconds'] = datetime(2011, 11, 4, 0, 5, 23, 283000, tzinfo=tzutc()) + + await self.table.create_entity(entity) + + received_entity = await self.table.get_entity( + partition_key=entity['PartitionKey'], + row_key=entity['RowKey'] + ) + + assert entity['milliseconds'] == received_entity['milliseconds'] + + finally: + await self._tear_down() + self.sleep(SLEEP_DELAY) \ No newline at end of file From 878e384d52f3a8d2346f8986cd5b6c3385fe84d8 Mon Sep 17 00:00:00 2001 From: Xiang Yan Date: Mon, 1 Mar 2021 09:20:42 -0800 Subject: [PATCH 26/30] Appconfig perf test (#16809) * add perf test for app config * update readme * updates * move uuid.uuid4() into ctor --- .../dev_requirements.txt | 1 + .../tests/perfstress_tests/README.md | 42 ++++++++++++++++++ .../tests/perfstress_tests/__init__.py | 0 .../tests/perfstress_tests/get.py | 38 ++++++++++++++++ .../tests/perfstress_tests/set.py | 43 +++++++++++++++++++ 5 files changed, 124 insertions(+) create mode 100644 sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/README.md create mode 100644 sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/__init__.py create mode 100644 sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/get.py create mode 100644 sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/set.py diff --git a/sdk/appconfiguration/azure-appconfiguration/dev_requirements.txt b/sdk/appconfiguration/azure-appconfiguration/dev_requirements.txt index c3cff2092922..618a17b93e09 100644 --- a/sdk/appconfiguration/azure-appconfiguration/dev_requirements.txt +++ b/sdk/appconfiguration/azure-appconfiguration/dev_requirements.txt @@ -1,3 +1,4 @@ +-e ../../../tools/azure-devtools ../../core/azure-core -e ../../identity/azure-identity aiohttp>=3.0; python_version >= '3.5' diff --git a/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/README.md b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/README.md new file mode 100644 index 000000000000..a29db0d81af8 --- /dev/null +++ b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/README.md @@ -0,0 +1,42 @@ +# App config Performance Tests + +In order to run the performance tests, the `azure-devtools` package must be installed. This is done as part of the `dev_requirements`. +Start be creating a new virtual environment for your perf tests. This will need to be a Python 3 environment, preferably >=3.7. + +### Setup for test resources + +These tests will run against a pre-configured application configuration service. The following environment variable will need to be set for the tests to access the live resources: +``` +AZURE_APP_CONFIG_CONNECTION_STRING= +``` + +### Setup for perf test runs + +```cmd +(env) ~/azure-appconfiguration> pip install -r dev_requirements.txt +(env) ~/azure-appconfiguration> pip install -e . +``` + +## Test commands + +When `azure-devtools` is installed, you will have access to the `perfstress` command line tool, which will scan the current module for runable perf tests. Only a specific test can be run at a time (i.e. there is no "run all" feature). + +```cmd +(env) ~/azure-appconfiguration> cd tests +(env) ~/azure-appconfiguration/tests> perfstress +``` +Using the `perfstress` command alone will list the available perf tests found. + +### Common perf command line options +These options are available for all perf tests: +- `--duration=10` Number of seconds to run as many operations (the "run" function) as possible. Default is 10. +- `--iterations=1` Number of test iterations to run. Default is 1. +- `--parallel=1` Number of tests to run in parallel. Default is 1. +- `--warm-up=5` Number of seconds to spend warming up the connection before measuring begins. Default is 5. +- `--sync` Whether to run the tests in sync or async. Default is False (async). This flag must be used for Storage legacy tests, which do not support async. +- `--no-cleanup` Whether to keep newly created resources after test run. Default is False (resources will be deleted). + +## Example command +```cmd +(env) ~/azure-appconfiguration/tests> perfstress GetTest +``` diff --git a/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/__init__.py b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/__init__.py new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/get.py b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/get.py new file mode 100644 index 000000000000..fdecfb1c8cdc --- /dev/null +++ b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/get.py @@ -0,0 +1,38 @@ +# -------------------------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# -------------------------------------------------------------------------------------------- + +import os + +from azure_devtools.perfstress_tests import PerfStressTest + +from azure.appconfiguration import ConfigurationSetting, AzureAppConfigurationClient as SyncAppConfigClient +from azure.appconfiguration.aio import AzureAppConfigurationClient as AsyncAppConfigClient + + +class GetTest(PerfStressTest): + def __init__(self, arguments): + super().__init__(arguments) + connection_string = self.get_from_env("AZURE_APP_CONFIG_CONNECTION_STRING") + self.key = "KEY" + self.service_client = SyncAppConfigClient.from_connection_string(connection_string=connection_string) + self.async_service_client = AsyncAppConfigClient.from_connection_string(connection_string=connection_string) + + async def global_setup(self): + await super().global_setup() + kv = ConfigurationSetting( + key=self.key, + value="VALUE", + ) + await self.async_service_client.set_configuration_setting(kv) + + async def close(self): + # await self.async_service_client.close() + await super().close() + + def run_sync(self): + self.service_client.get_configuration_setting(key=self.key) + + async def run_async(self): + await self.async_service_client.get_configuration_setting(key=self.key) diff --git a/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/set.py b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/set.py new file mode 100644 index 000000000000..5e8f5e1a8f29 --- /dev/null +++ b/sdk/appconfiguration/azure-appconfiguration/tests/perfstress_tests/set.py @@ -0,0 +1,43 @@ +# -------------------------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for license information. +# -------------------------------------------------------------------------------------------- + +import os +import uuid + +from azure_devtools.perfstress_tests import PerfStressTest + +from azure.appconfiguration import ConfigurationSetting, AzureAppConfigurationClient as SyncAppConfigClient +from azure.appconfiguration.aio import AzureAppConfigurationClient as AsyncAppConfigClient + + +class SetTest(PerfStressTest): + service_client = None + async_service_client = None + + def __init__(self, arguments): + super().__init__(arguments) + connection_string = self.get_from_env("AZURE_APP_CONFIG_CONNECTION_STRING") + self.key = "KEY" + self.value = str(uuid.uuid4()) + self.service_client = SyncAppConfigClient.from_connection_string(connection_string=connection_string) + self.async_service_client = AsyncAppConfigClient.from_connection_string(connection_string=connection_string) + + async def close(self): + # await self.async_service_client.close() + await super().close() + + def run_sync(self): + kv = ConfigurationSetting( + key=self.key, + value="VALUE" + self.value, + ) + self.service_client.set_configuration_setting(kv) + + async def run_async(self): + kv = ConfigurationSetting( + key=self.key, + value="VALUE" + self.value, + ) + await self.async_service_client.set_configuration_setting(kv) From 92747dd1a0bb5e7f080a512d2ba97ecf7c9d82df Mon Sep 17 00:00:00 2001 From: Rakshith Bhyravabhotla Date: Mon, 1 Mar 2021 09:28:04 -0800 Subject: [PATCH 27/30] [eventgrid] Black formatting and tests suite (#16989) * Black formatting * tests * recordings * test --- .../azure/eventgrid/__init__.py | 10 +- .../azure/eventgrid/_constants.py | 6 +- .../azure/eventgrid/_event_mappings.py | 120 +++++++++++++----- .../azure/eventgrid/_helpers.py | 87 +++++++------ .../azure/eventgrid/_models.py | 65 +++++----- .../azure/eventgrid/_policies.py | 18 ++- .../azure/eventgrid/_publisher_client.py | 55 ++++---- .../eventgrid/_signature_credential_policy.py | 1 + .../azure/eventgrid/aio/__init__.py | 2 +- .../eventgrid/aio/_publisher_client_async.py | 71 +++++------ ..._send_event_grid_event_dict_data_dict.yaml | 38 ++++++ .../tests/test_eg_publisher_client.py | 24 ++++ .../tests/test_eg_publisher_client_async.py | 7 + .../tests/test_generate_sas.py | 29 +++++ 14 files changed, 352 insertions(+), 181 deletions(-) create mode 100644 sdk/eventgrid/azure-eventgrid/tests/recordings/test_eg_publisher_client.test_send_event_grid_event_dict_data_dict.yaml create mode 100644 sdk/eventgrid/azure-eventgrid/tests/test_generate_sas.py diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/__init__.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/__init__.py index 8c945af545a1..bb031e5ec320 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/__init__.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/__init__.py @@ -10,7 +10,11 @@ from ._models import CloudEvent, EventGridEvent from ._version import VERSION -__all__ = ['EventGridPublisherClient', 'CloudEvent', - 'EventGridEvent', 'generate_sas', 'SystemEventNames' - ] +__all__ = [ + "EventGridPublisherClient", + "CloudEvent", + "EventGridEvent", + "generate_sas", + "SystemEventNames", +] __version__ = VERSION diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_constants.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_constants.py index e762ff44804a..0d26f09c4bdb 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_constants.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_constants.py @@ -3,7 +3,7 @@ # Licensed under the MIT License. See License.txt in the project root for license information. # -------------------------------------------------------------------------------------------- -EVENTGRID_KEY_HEADER = 'aeg-sas-key' -EVENTGRID_TOKEN_HEADER = 'aeg-sas-token' +EVENTGRID_KEY_HEADER = "aeg-sas-key" +EVENTGRID_TOKEN_HEADER = "aeg-sas-token" DEFAULT_API_VERSION = "2018-01-01" -SAFE_ENCODE = '~()*!.\'' +SAFE_ENCODE = "~()*!.'" diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_event_mappings.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_event_mappings.py index cbd9c94828fc..f99040f4ce48 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_event_mappings.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_event_mappings.py @@ -4,30 +4,52 @@ # -------------------------------------------------------------------------------------------- from enum import Enum + class SystemEventNames(str, Enum): """ This enum represents the names of the various event types for the system events published to Azure Event Grid. To check the list of recognizable system topics, visit https://docs.microsoft.com/azure/event-grid/system-topics. """ - ACSChatMemberAddedToThreadWithUserEventName = "Microsoft.Communication.ChatMemberAddedToThreadWithUser" - ACSChatMemberRemovedFromThreadWithUserEventName = "Microsoft.Communication.ChatMemberRemovedFromThreadWithUser" + + ACSChatMemberAddedToThreadWithUserEventName = ( + "Microsoft.Communication.ChatMemberAddedToThreadWithUser" + ) + ACSChatMemberRemovedFromThreadWithUserEventName = ( + "Microsoft.Communication.ChatMemberRemovedFromThreadWithUser" + ) ACSChatMessageDeletedEventName = "Microsoft.Communication.ChatMessageDeleted" ACSChatMessageEditedEventName = "Microsoft.Communication.ChatMessageEdited" ACSChatMessageReceivedEventName = "Microsoft.Communication.ChatMessageReceived" - ACSChatThreadCreatedWithUserEventName = "Microsoft.Communication.ChatThreadCreatedWithUser" - ACSChatThreadPropertiesUpdatedPerUserEventName = "Microsoft.Communication.ChatThreadPropertiesUpdatedPerUser" - ACSChatThreadWithUserDeletedEventName = "Microsoft.Communication.ChatThreadWithUserDeleted" - ACSSMSDeliveryReportReceivedEventName = "Microsoft.Communication.SMSDeliveryReportReceived" + ACSChatThreadCreatedWithUserEventName = ( + "Microsoft.Communication.ChatThreadCreatedWithUser" + ) + ACSChatThreadPropertiesUpdatedPerUserEventName = ( + "Microsoft.Communication.ChatThreadPropertiesUpdatedPerUser" + ) + ACSChatThreadWithUserDeletedEventName = ( + "Microsoft.Communication.ChatThreadWithUserDeleted" + ) + ACSSMSDeliveryReportReceivedEventName = ( + "Microsoft.Communication.SMSDeliveryReportReceived" + ) ACSSMSReceivedEventName = "Microsoft.Communication.SMSReceived" - AppConfigurationKeyValueDeletedEventName = "Microsoft.AppConfiguration.KeyValueDeleted" - AppConfigurationKeyValueModifiedEventName = "Microsoft.AppConfiguration.KeyValueModified" + AppConfigurationKeyValueDeletedEventName = ( + "Microsoft.AppConfiguration.KeyValueDeleted" + ) + AppConfigurationKeyValueModifiedEventName = ( + "Microsoft.AppConfiguration.KeyValueModified" + ) ContainerRegistryChartDeletedEventName = "Microsoft.ContainerRegistry.ChartDeleted" ContainerRegistryChartPushedEventName = "Microsoft.ContainerRegistry.ChartPushed" ContainerRegistryImageDeletedEventName = "Microsoft.ContainerRegistry.ImageDeleted" ContainerRegistryImagePushedEventName = "Microsoft.ContainerRegistry.ImagePushed" - EventGridSubscriptionDeletedEventName = "Microsoft.EventGrid.SubscriptionDeletedEvent" - EventGridSubscriptionValidationEventName = "Microsoft.EventGrid.SubscriptionValidationEvent" + EventGridSubscriptionDeletedEventName = ( + "Microsoft.EventGrid.SubscriptionDeletedEvent" + ) + EventGridSubscriptionValidationEventName = ( + "Microsoft.EventGrid.SubscriptionValidationEvent" + ) EventHubCaptureFileCreatedEventName = "Microsoft.EventHub.CaptureFileCreated" IoTHubDeviceConnectedEventName = "Microsoft.Devices.DeviceConnected" IoTHubDeviceCreatedEventName = "Microsoft.Devices.DeviceCreated" @@ -37,18 +59,32 @@ class SystemEventNames(str, Enum): KeyVaultAccessPolicyChangedEventName = "Microsoft.KeyVault.VaultAccessPolicyChanged" KeyVaultCertificateExpiredEventName = "Microsoft.KeyVault.CertificateExpired" KeyVaultCertificateNearExpiryEventName = "Microsoft.KeyVault.CertificateNearExpiry" - KeyVaultCertificateNewVersionCreatedEventName = "Microsoft.KeyVault.CertificateNewVersionCreated" + KeyVaultCertificateNewVersionCreatedEventName = ( + "Microsoft.KeyVault.CertificateNewVersionCreated" + ) KeyVaultKeyExpiredEventName = "Microsoft.KeyVault.KeyExpired" KeyVaultKeyNearExpiryEventName = "Microsoft.KeyVault.KeyNearExpiry" KeyVaultKeyNewVersionCreatedEventName = "Microsoft.KeyVault.KeyNewVersionCreated" KeyVaultSecretExpiredEventName = "Microsoft.KeyVault.SecretExpired" KeyVaultSecretNearExpiryEventName = "Microsoft.KeyVault.SecretNearExpiry" - KeyVaultSecretNewVersionCreatedEventName = "Microsoft.KeyVault.SecretNewVersionCreated" - MachineLearningServicesDatasetDriftDetectedEventName = "Microsoft.MachineLearningServices.DatasetDriftDetected" - MachineLearningServicesModelDeployedEventName = "Microsoft.MachineLearningServices.ModelDeployed" - MachineLearningServicesModelRegisteredEventName = "Microsoft.MachineLearningServices.ModelRegistered" - MachineLearningServicesRunCompletedEventName = "Microsoft.MachineLearningServices.RunCompleted" - MachineLearningServicesRunStatusChangedEventName = "Microsoft.MachineLearningServices.RunStatusChanged" + KeyVaultSecretNewVersionCreatedEventName = ( + "Microsoft.KeyVault.SecretNewVersionCreated" + ) + MachineLearningServicesDatasetDriftDetectedEventName = ( + "Microsoft.MachineLearningServices.DatasetDriftDetected" + ) + MachineLearningServicesModelDeployedEventName = ( + "Microsoft.MachineLearningServices.ModelDeployed" + ) + MachineLearningServicesModelRegisteredEventName = ( + "Microsoft.MachineLearningServices.ModelRegistered" + ) + MachineLearningServicesRunCompletedEventName = ( + "Microsoft.MachineLearningServices.RunCompleted" + ) + MachineLearningServicesRunStatusChangedEventName = ( + "Microsoft.MachineLearningServices.RunStatusChanged" + ) MapsGeofenceEnteredEventName = "Microsoft.Maps.GeofenceEntered" MapsGeofenceExitedEventName = "Microsoft.Maps.GeofenceExited" MapsGeofenceResultEventName = "Microsoft.Maps.GeofenceResult" @@ -67,15 +103,31 @@ class SystemEventNames(str, Enum): MediaJobProcessingEventName = "Microsoft.Media.JobProcessing" MediaJobScheduledEventName = "Microsoft.Media.JobScheduled" MediaJobStateChangeEventName = "Microsoft.Media.JobStateChange" - MediaLiveEventConnectionRejectedEventName = "Microsoft.Media.LiveEventConnectionRejected" - MediaLiveEventEncoderConnectedEventName = "Microsoft.Media.LiveEventEncoderConnected" - MediaLiveEventEncoderDisconnectedEventName = "Microsoft.Media.LiveEventEncoderDisconnected" - MediaLiveEventIncomingDataChunkDroppedEventName = "Microsoft.Media.LiveEventIncomingDataChunkDropped" - MediaLiveEventIncomingStreamReceivedEventName = "Microsoft.Media.LiveEventIncomingStreamReceived" - MediaLiveEventIncomingStreamsOutOfSyncEventName = "Microsoft.Media.LiveEventIncomingStreamsOutOfSync" - MediaLiveEventIncomingVideoStreamsOutOfSyncEventName = "Microsoft.Media.LiveEventIncomingVideoStreamsOutOfSync" + MediaLiveEventConnectionRejectedEventName = ( + "Microsoft.Media.LiveEventConnectionRejected" + ) + MediaLiveEventEncoderConnectedEventName = ( + "Microsoft.Media.LiveEventEncoderConnected" + ) + MediaLiveEventEncoderDisconnectedEventName = ( + "Microsoft.Media.LiveEventEncoderDisconnected" + ) + MediaLiveEventIncomingDataChunkDroppedEventName = ( + "Microsoft.Media.LiveEventIncomingDataChunkDropped" + ) + MediaLiveEventIncomingStreamReceivedEventName = ( + "Microsoft.Media.LiveEventIncomingStreamReceived" + ) + MediaLiveEventIncomingStreamsOutOfSyncEventName = ( + "Microsoft.Media.LiveEventIncomingStreamsOutOfSync" + ) + MediaLiveEventIncomingVideoStreamsOutOfSyncEventName = ( + "Microsoft.Media.LiveEventIncomingVideoStreamsOutOfSync" + ) MediaLiveEventIngestHeartbeatEventName = "Microsoft.Media.LiveEventIngestHeartbeat" - MediaLiveEventTrackDiscontinuityDetectedEventName = "Microsoft.Media.LiveEventTrackDiscontinuityDetected" + MediaLiveEventTrackDiscontinuityDetectedEventName = ( + "Microsoft.Media.LiveEventTrackDiscontinuityDetected" + ) ResourceActionCancelEventName = "Microsoft.Resources.ResourceActionCancel" ResourceActionFailureEventName = "Microsoft.Resources.ResourceActionFailure" ResourceActionSuccessEventName = "Microsoft.Resources.ResourceActionSuccess" @@ -85,17 +137,21 @@ class SystemEventNames(str, Enum): ResourceWriteCancelEventName = "Microsoft.Resources.ResourceWriteCancel" ResourceWriteFailureEventName = "Microsoft.Resources.ResourceWriteFailure" ResourceWriteSuccessEventName = "Microsoft.Resources.ResourceWriteSuccess" - ServiceBusActiveMessagesAvailableWithNoListenersEventName = \ - "Microsoft.ServiceBus.ActiveMessagesAvailableWithNoListeners" - ServiceBusDeadletterMessagesAvailableWithNoListenerEventName = \ - "Microsoft.ServiceBus.DeadletterMessagesAvailableWithNoListener" + ServiceBusActiveMessagesAvailableWithNoListenersEventName = ( + "Microsoft.ServiceBus.ActiveMessagesAvailableWithNoListeners" + ) + ServiceBusDeadletterMessagesAvailableWithNoListenerEventName = ( + "Microsoft.ServiceBus.DeadletterMessagesAvailableWithNoListener" + ) StorageBlobCreatedEventName = "Microsoft.Storage.BlobCreated" StorageBlobDeletedEventName = "Microsoft.Storage.BlobDeleted" StorageBlobRenamedEventName = "Microsoft.Storage.BlobRenamed" StorageDirectoryCreatedEventName = "Microsoft.Storage.DirectoryCreated" StorageDirectoryDeletedEventName = "Microsoft.Storage.DirectoryDeleted" StorageDirectoryRenamedEventName = "Microsoft.Storage.DirectoryRenamed" - StorageLifecyclePolicyCompletedEventName = "Microsoft.Storage.LifecyclePolicyCompleted" + StorageLifecyclePolicyCompletedEventName = ( + "Microsoft.Storage.LifecyclePolicyCompleted" + ) WebAppServicePlanUpdatedEventName = "Microsoft.Web.AppServicePlanUpdated" WebAppUpdatedEventName = "Microsoft.Web.AppUpdated" WebBackupOperationCompletedEventName = "Microsoft.Web.BackupOperationCompleted" @@ -107,5 +163,7 @@ class SystemEventNames(str, Enum): WebSlotSwapCompletedEventName = "Microsoft.Web.SlotSwapCompleted" WebSlotSwapFailedEventName = "Microsoft.Web.SlotSwapFailed" WebSlotSwapStartedEventName = "Microsoft.Web.SlotSwapStarted" - WebSlotSwapWithPreviewCancelledEventName = "Microsoft.Web.SlotSwapWithPreviewCancelled" + WebSlotSwapWithPreviewCancelledEventName = ( + "Microsoft.Web.SlotSwapWithPreviewCancelled" + ) WebSlotSwapWithPreviewStartedEventName = "Microsoft.Web.SlotSwapWithPreviewStarted" diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_helpers.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_helpers.py index 9f06d8666bad..2780ceb569bb 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_helpers.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_helpers.py @@ -7,10 +7,11 @@ import hmac import base64 import six + try: from urllib.parse import quote except ImportError: - from urllib2 import quote # type: ignore + from urllib2 import quote # type: ignore from azure.core.pipeline.policies import AzureKeyCredentialPolicy from azure.core.credentials import AzureKeyCredential, AzureSasCredential @@ -20,102 +21,116 @@ if TYPE_CHECKING: from datetime import datetime + def generate_sas(endpoint, shared_access_key, expiration_date_utc, **kwargs): # type: (str, str, datetime, Any) -> str - """ Helper method to generate shared access signature given hostname, key, and expiration date. - :param str endpoint: The topic endpoint to send the events to. - Similar to .-1.eventgrid.azure.net - :param str shared_access_key: The shared access key to be used for generating the token - :param datetime.datetime expiration_date_utc: The expiration datetime in UTC for the signature. - :keyword str api_version: The API Version to include in the signature. - If not provided, the default API version will be used. - :rtype: str - - .. admonition:: Example: - - .. literalinclude:: ../samples/sync_samples/sample_generate_sas.py - :start-after: [START generate_sas] - :end-before: [END generate_sas] - :language: python - :dedent: 0 - :caption: Generate a shared access signature. + """Helper method to generate shared access signature given hostname, key, and expiration date. + :param str endpoint: The topic endpoint to send the events to. + Similar to .-1.eventgrid.azure.net + :param str shared_access_key: The shared access key to be used for generating the token + :param datetime.datetime expiration_date_utc: The expiration datetime in UTC for the signature. + :keyword str api_version: The API Version to include in the signature. + If not provided, the default API version will be used. + :rtype: str + + .. admonition:: Example: + + .. literalinclude:: ../samples/sync_samples/sample_generate_sas.py + :start-after: [START generate_sas] + :end-before: [END generate_sas] + :language: python + :dedent: 0 + :caption: Generate a shared access signature. """ full_endpoint = _get_full_endpoint(endpoint) full_endpoint = "{}?apiVersion={}".format( - full_endpoint, - kwargs.get('api_version', None) or constants.DEFAULT_API_VERSION + full_endpoint, kwargs.get("api_version", None) or constants.DEFAULT_API_VERSION ) encoded_resource = quote(full_endpoint, safe=constants.SAFE_ENCODE) encoded_expiration_utc = quote(str(expiration_date_utc), safe=constants.SAFE_ENCODE) unsigned_sas = "r={}&e={}".format(encoded_resource, encoded_expiration_utc) - signature = quote(_generate_hmac(shared_access_key, unsigned_sas), safe=constants.SAFE_ENCODE) + signature = quote( + _generate_hmac(shared_access_key, unsigned_sas), safe=constants.SAFE_ENCODE + ) signed_sas = "{}&s={}".format(unsigned_sas, signature) return signed_sas + def _get_endpoint_only_fqdn(endpoint): - if endpoint.startswith('http://'): + if endpoint.startswith("http://"): raise ValueError("HTTP is not supported. Only HTTPS is supported.") - if endpoint.startswith('https://'): + if endpoint.startswith("https://"): endpoint = endpoint.replace("https://", "") if endpoint.endswith("/api/events"): endpoint = endpoint.replace("/api/events", "") return endpoint + def _get_full_endpoint(endpoint): - if endpoint.startswith('http://'): + if endpoint.startswith("http://"): raise ValueError("HTTP is not supported. Only HTTPS is supported.") - if not endpoint.startswith('https://'): + if not endpoint.startswith("https://"): endpoint = "https://{}".format(endpoint) if not endpoint.endswith("/api/events"): endpoint = "{}/api/events".format(endpoint) return endpoint + def _generate_hmac(key, message): decoded_key = base64.b64decode(key) - bytes_message = message.encode('ascii') + bytes_message = message.encode("ascii") hmac_new = hmac.new(decoded_key, bytes_message, hashlib.sha256).digest() return base64.b64encode(hmac_new) + def _get_authentication_policy(credential): if credential is None: raise ValueError("Parameter 'self._credential' must not be None.") if isinstance(credential, AzureKeyCredential): - return AzureKeyCredentialPolicy(credential=credential, name=constants.EVENTGRID_KEY_HEADER) + return AzureKeyCredentialPolicy( + credential=credential, name=constants.EVENTGRID_KEY_HEADER + ) if isinstance(credential, AzureSasCredential): return EventGridSasCredentialPolicy( - credential=credential, - name=constants.EVENTGRID_TOKEN_HEADER + credential=credential, name=constants.EVENTGRID_TOKEN_HEADER ) - raise ValueError("The provided credential should be an instance of AzureSasCredential or AzureKeyCredential") + raise ValueError( + "The provided credential should be an instance of AzureSasCredential or AzureKeyCredential" + ) + def _is_cloud_event(event): # type: (Any) -> bool - required = ('id', 'source', 'specversion', 'type') + required = ("id", "source", "specversion", "type") try: - return all([_ in event for _ in required]) and event['specversion'] == "1.0" + return all([_ in event for _ in required]) and event["specversion"] == "1.0" except TypeError: return False + def _is_eventgrid_event(event): # type: (Any) -> bool - required = ('subject', 'eventType', 'data', 'dataVersion', 'id', 'eventTime') + required = ("subject", "eventType", "data", "dataVersion", "id", "eventTime") try: return all([prop in event for prop in required]) except TypeError: return False + def _eventgrid_data_typecheck(event): try: - data = event.get('data') + data = event.get("data") except AttributeError: data = event.data if isinstance(data, six.binary_type): - raise TypeError("Data in EventGridEvent cannot be bytes. Please refer to"\ - "https://docs.microsoft.com/en-us/azure/event-grid/event-schema") + raise TypeError( + "Data in EventGridEvent cannot be bytes. Please refer to" + "https://docs.microsoft.com/en-us/azure/event-grid/event-schema" + ) diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py index c886e78553a6..ba79546c8bc8 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py @@ -9,13 +9,17 @@ import json import six from msrest.serialization import UTC -from ._generated.models import EventGridEvent as InternalEventGridEvent, CloudEvent as InternalCloudEvent +from ._generated.models import ( + EventGridEvent as InternalEventGridEvent, + CloudEvent as InternalCloudEvent, +) class EventMixin(object): """ Mixin for the event models comprising of some helper methods. """ + @staticmethod def _from_json(event, encode): """ @@ -31,7 +35,7 @@ def _from_json(event, encode): return event -class CloudEvent(EventMixin): #pylint:disable=too-many-instance-attributes +class CloudEvent(EventMixin): # pylint:disable=too-many-instance-attributes """Properties of an event published to an Event Grid topic using the CloudEvent 1.0 Schema. All required parameters must be populated in order to send to Azure. @@ -88,7 +92,8 @@ class CloudEvent(EventMixin): #pylint:disable=too-many-instance-attributes unique for each distinct event. If not provided, a random UUID will be generated and used. :vartype id: Optional[str] """ - def __init__(self, source, type, **kwargs): # pylint: disable=redefined-builtin + + def __init__(self, source, type, **kwargs): # pylint: disable=redefined-builtin # type: (str, str, Any) -> None self.source = source self.type = type @@ -101,10 +106,12 @@ def __init__(self, source, type, **kwargs): # pylint: disable=redefined-builtin self.subject = kwargs.pop("subject", None) self.data_base64 = kwargs.pop("data_base64", None) self.extensions = {} - self.extensions.update(dict(kwargs.pop('extensions', {}))) + self.extensions.update(dict(kwargs.pop("extensions", {}))) if self.data is not None and self.data_base64 is not None: - raise ValueError("data and data_base64 cannot be provided at the same time.\ - Use data_base64 only if you are sending bytes, and use data otherwise.") + raise ValueError( + "data and data_base64 cannot be provided at the same time.\ + Use data_base64 only if you are sending bytes, and use data otherwise." + ) @classmethod def _from_generated(cls, cloud_event, **kwargs): @@ -112,7 +119,7 @@ def _from_generated(cls, cloud_event, **kwargs): generated = InternalCloudEvent.deserialize(cloud_event) if generated.additional_properties: extensions = dict(generated.additional_properties) - kwargs.setdefault('extensions', extensions) + kwargs.setdefault("extensions", extensions) return cls( id=generated.id, source=generated.source, @@ -191,40 +198,40 @@ class EventGridEvent(InternalEventGridEvent, EventMixin): If not provided, EventGrid will stamp onto event. :vartype metadata_version: str :ivar id: An identifier for the event. In not provided, a random UUID will be generated and used. - :vartype id: Optional[str] + :vartype id: str :ivar event_time: The time (in UTC) of the event. If not provided, it will be the time (in UTC) the event was generated. - :vartype event_time: Optional[~datetime.datetime] + :vartype event_time: ~datetime.datetime """ _validation = { - 'id': {'required': True}, - 'subject': {'required': True}, - 'data': {'required': True}, - 'event_type': {'required': True}, - 'event_time': {'required': True}, - 'metadata_version': {'readonly': True}, - 'data_version': {'required': True}, + "id": {"required": True}, + "subject": {"required": True}, + "data": {"required": True}, + "event_type": {"required": True}, + "event_time": {"required": True}, + "metadata_version": {"readonly": True}, + "data_version": {"required": True}, } _attribute_map = { - 'id': {'key': 'id', 'type': 'str'}, - 'topic': {'key': 'topic', 'type': 'str'}, - 'subject': {'key': 'subject', 'type': 'str'}, - 'data': {'key': 'data', 'type': 'object'}, - 'event_type': {'key': 'eventType', 'type': 'str'}, - 'event_time': {'key': 'eventTime', 'type': 'iso-8601'}, - 'metadata_version': {'key': 'metadataVersion', 'type': 'str'}, - 'data_version': {'key': 'dataVersion', 'type': 'str'}, + "id": {"key": "id", "type": "str"}, + "topic": {"key": "topic", "type": "str"}, + "subject": {"key": "subject", "type": "str"}, + "data": {"key": "data", "type": "object"}, + "event_type": {"key": "eventType", "type": "str"}, + "event_time": {"key": "eventTime", "type": "iso-8601"}, + "metadata_version": {"key": "metadataVersion", "type": "str"}, + "data_version": {"key": "dataVersion", "type": "str"}, } def __init__(self, subject, event_type, data, data_version, **kwargs): # type: (str, str, object, str, Any) -> None - kwargs.setdefault('id', uuid.uuid4()) - kwargs.setdefault('subject', subject) + kwargs.setdefault("id", uuid.uuid4()) + kwargs.setdefault("subject", subject) kwargs.setdefault("event_type", event_type) - kwargs.setdefault('event_time', dt.datetime.now(UTC()).isoformat()) - kwargs.setdefault('data', data) - kwargs.setdefault('data_version', data_version) + kwargs.setdefault("event_time", dt.datetime.now(UTC()).isoformat()) + kwargs.setdefault("data", data) + kwargs.setdefault("data_version", data_version) super(EventGridEvent, self).__init__(**kwargs) diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_policies.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_policies.py index 5de3c5025249..7617f0c9a516 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_policies.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_policies.py @@ -13,6 +13,7 @@ if TYPE_CHECKING: from azure.core.pipeline import PipelineRequest + class CloudEventDistributedTracingPolicy(SansIOHTTPPolicy): """CloudEventDistributedTracingPolicy is a policy which adds distributed tracing informatiom to a batch of cloud events. It does so by copying the `traceparent` and `tracestate` properties @@ -23,24 +24,27 @@ class CloudEventDistributedTracingPolicy(SansIOHTTPPolicy): See https://github.com/cloudevents/spec/blob/master/extensions/distributed-tracing.md for more information on distributed tracing and cloud events. """ + _CONTENT_TYPE = "application/cloudevents-batch+json; charset=utf-8" def on_request(self, request): # type: (PipelineRequest) -> None try: - traceparent = request.http_request.headers['traceparent'] - tracestate = request.http_request.headers['tracestate'] + traceparent = request.http_request.headers["traceparent"] + tracestate = request.http_request.headers["tracestate"] except KeyError: return - if (request.http_request.headers['content-type'] == CloudEventDistributedTracingPolicy._CONTENT_TYPE + if ( + request.http_request.headers["content-type"] + == CloudEventDistributedTracingPolicy._CONTENT_TYPE and traceparent is not None - ): + ): body = json.loads(request.http_request.body) for item in body: - if 'traceparent' not in item and 'tracestate' not in item: - item['traceparent'] = traceparent - item['tracestate'] = tracestate + if "traceparent" not in item and "tracestate" not in item: + item["traceparent"] = traceparent + item["tracestate"] = tracestate request.http_request.body = json.dumps(body) diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_publisher_client.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_publisher_client.py index 178eddc8f853..20b8b04df3b0 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_publisher_client.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_publisher_client.py @@ -19,7 +19,7 @@ ProxyPolicy, DistributedTracingPolicy, HttpLoggingPolicy, - UserAgentPolicy + UserAgentPolicy, ) from ._models import CloudEvent, EventGridEvent @@ -28,30 +28,28 @@ _get_authentication_policy, _is_cloud_event, _is_eventgrid_event, - _eventgrid_data_typecheck + _eventgrid_data_typecheck, +) +from ._generated._event_grid_publisher_client import ( + EventGridPublisherClient as EventGridPublisherClientImpl, ) -from ._generated._event_grid_publisher_client import EventGridPublisherClient as EventGridPublisherClientImpl from ._policies import CloudEventDistributedTracingPolicy from ._version import VERSION -from ._generated.models import CloudEvent as InternalCloudEvent if TYPE_CHECKING: # pylint: disable=unused-import,ungrouped-imports from azure.core.credentials import AzureKeyCredential, AzureSasCredential + SendType = Union[ CloudEvent, EventGridEvent, Dict, List[CloudEvent], List[EventGridEvent], - List[Dict] + List[Dict], ] -ListEventType = Union[ - List[CloudEvent], - List[EventGridEvent], - List[Dict] -] +ListEventType = Union[List[CloudEvent], List[EventGridEvent], List[Dict]] class EventGridPublisherClient(object): @@ -86,15 +84,14 @@ def __init__(self, endpoint, credential, **kwargs): self._endpoint = endpoint self._client = EventGridPublisherClientImpl( - policies=EventGridPublisherClient._policies(credential, **kwargs), - **kwargs - ) + policies=EventGridPublisherClient._policies(credential, **kwargs), **kwargs + ) @staticmethod def _policies(credential, **kwargs): # type: (Union[AzureKeyCredential, AzureSasCredential], Any) -> List[Any] auth_policy = _get_authentication_policy(credential) - sdk_moniker = 'eventgrid/{}'.format(VERSION) + sdk_moniker = "eventgrid/{}".format(VERSION) policies = [ RequestIdPolicy(**kwargs), HeadersPolicy(**kwargs), @@ -108,7 +105,7 @@ def _policies(credential, **kwargs): NetworkTraceLoggingPolicy(**kwargs), DistributedTracingPolicy(**kwargs), CloudEventDistributedTracingPolicy(), - HttpLoggingPolicy(**kwargs) + HttpLoggingPolicy(**kwargs), ] return policies @@ -175,31 +172,31 @@ def send(self, events, **kwargs): Has default value "application/json; charset=utf-8" for EventGridEvents, with "cloudevents-batch+json" for CloudEvents :rtype: None - """ + """ if not isinstance(events, list): events = cast(ListEventType, [events]) if isinstance(events[0], CloudEvent) or _is_cloud_event(events[0]): try: - events = [cast(CloudEvent, e)._to_generated(**kwargs) for e in events] # pylint: disable=protected-access + events = [ + cast(CloudEvent, e)._to_generated(**kwargs) for e in events # pylint: disable=protected-access + ] except AttributeError: - pass # means it's a dictionary - kwargs.setdefault("content_type", "application/cloudevents-batch+json; charset=utf-8") - return self._client.publish_cloud_event_events( - self._endpoint, - cast(List[InternalCloudEvent], events), - **kwargs - ) - kwargs.setdefault("content_type", "application/json; charset=utf-8") - if isinstance(events[0], EventGridEvent) or _is_eventgrid_event(events[0]): + pass # means it's a dictionary + kwargs.setdefault( + "content_type", "application/cloudevents-batch+json; charset=utf-8" + ) + elif isinstance(events[0], EventGridEvent) or _is_eventgrid_event(events[0]): + kwargs.setdefault("content_type", "application/json; charset=utf-8") for event in events: _eventgrid_data_typecheck(event) - return self._client.publish_custom_event_events(self._endpoint, cast(List, events), **kwargs) + return self._client.publish_custom_event_events( + self._endpoint, cast(List, events), **kwargs + ) def close(self): # type: () -> None - """Close the :class:`~azure.eventgrid.EventGridPublisherClient` session. - """ + """Close the :class:`~azure.eventgrid.EventGridPublisherClient` session.""" return self._client.close() def __enter__(self): diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_signature_credential_policy.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_signature_credential_policy.py index d3d7e33d4046..d0c6fc47d5e0 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_signature_credential_policy.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_signature_credential_policy.py @@ -20,6 +20,7 @@ class EventGridSasCredentialPolicy(SansIOHTTPPolicy): :param str name: The name of the token header used for the credential. :raises: ValueError or TypeError """ + def __init__(self, credential, name, **kwargs): # pylint: disable=unused-argument # type: (AzureSasCredential, str, Any) -> None super(EventGridSasCredentialPolicy, self).__init__() diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/__init__.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/__init__.py index 2de020d81e02..0d2dce7aaea2 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/__init__.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/__init__.py @@ -6,4 +6,4 @@ from ._publisher_client_async import EventGridPublisherClient -__all__ = ['EventGridPublisherClient'] +__all__ = ["EventGridPublisherClient"] diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/_publisher_client_async.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/_publisher_client_async.py index 797d2191b00c..5029e9a5f963 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/_publisher_client_async.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/aio/_publisher_client_async.py @@ -20,7 +20,7 @@ ProxyPolicy, DistributedTracingPolicy, HttpLoggingPolicy, - UserAgentPolicy + UserAgentPolicy, ) from .._policies import CloudEventDistributedTracingPolicy from .._models import CloudEvent, EventGridEvent @@ -29,28 +29,19 @@ _get_authentication_policy, _is_cloud_event, _is_eventgrid_event, - _eventgrid_data_typecheck + _eventgrid_data_typecheck, ) from .._generated.aio import EventGridPublisherClient as EventGridPublisherClientAsync -from .._generated.models import CloudEvent as InternalCloudEvent from .._version import VERSION SendType = Union[ - CloudEvent, - EventGridEvent, - Dict, - List[CloudEvent], - List[EventGridEvent], - List[Dict] + CloudEvent, EventGridEvent, Dict, List[CloudEvent], List[EventGridEvent], List[Dict] ] -ListEventType = Union[ - List[CloudEvent], - List[EventGridEvent], - List[Dict] -] +ListEventType = Union[List[CloudEvent], List[EventGridEvent], List[Dict]] + -class EventGridPublisherClient(): +class EventGridPublisherClient: """Asynchronous EventGridPublisherClient publishes events to an EventGrid topic or domain. It can be used to publish either an EventGridEvent, a CloudEvent or a Custom Schema. @@ -81,21 +72,20 @@ def __init__( self, endpoint: str, credential: Union[AzureKeyCredential, AzureSasCredential], - **kwargs: Any) -> None: + **kwargs: Any + ) -> None: self._client = EventGridPublisherClientAsync( - policies=EventGridPublisherClient._policies(credential, **kwargs), - **kwargs - ) + policies=EventGridPublisherClient._policies(credential, **kwargs), **kwargs + ) endpoint = _get_endpoint_only_fqdn(endpoint) self._endpoint = endpoint @staticmethod def _policies( - credential: Union[AzureKeyCredential, AzureSasCredential], - **kwargs: Any - ) -> List[Any]: + credential: Union[AzureKeyCredential, AzureSasCredential], **kwargs: Any + ) -> List[Any]: auth_policy = _get_authentication_policy(credential) - sdk_moniker = 'eventgridpublisherclient/{}'.format(VERSION) + sdk_moniker = "eventgridpublisherclient/{}".format(VERSION) policies = [ RequestIdPolicy(**kwargs), HeadersPolicy(**kwargs), @@ -109,15 +99,12 @@ def _policies( NetworkTraceLoggingPolicy(**kwargs), DistributedTracingPolicy(**kwargs), CloudEventDistributedTracingPolicy(), - HttpLoggingPolicy(**kwargs) + HttpLoggingPolicy(**kwargs), ] return policies @distributed_trace_async - async def send( - self, - events: SendType, - **kwargs: Any) -> None: + async def send(self, events: SendType, **kwargs: Any) -> None: """Sends events to a topic or a domain specified during the client initialization. A single instance or a list of dictionaries, CloudEvents or EventGridEvents are accepted. @@ -178,26 +165,27 @@ async def send( Has default value "application/json; charset=utf-8" for EventGridEvents, with "cloudevents-batch+json" for CloudEvents :rtype: None - """ + """ if not isinstance(events, list): events = cast(ListEventType, [events]) if isinstance(events[0], CloudEvent) or _is_cloud_event(events[0]): try: - events = [cast(CloudEvent, e)._to_generated(**kwargs) for e in events] # pylint: disable=protected-access + events = [ + cast(CloudEvent, e)._to_generated(**kwargs) for e in events # pylint: disable=protected-access + ] except AttributeError: - pass # means it's a dictionary - kwargs.setdefault("content_type", "application/cloudevents-batch+json; charset=utf-8") - return await self._client.publish_cloud_event_events( - self._endpoint, - cast(List[InternalCloudEvent], events), - **kwargs - ) - kwargs.setdefault("content_type", "application/json; charset=utf-8") - if isinstance(events[0], EventGridEvent) or _is_eventgrid_event(events[0]): + pass # means it's a dictionary + kwargs.setdefault( + "content_type", "application/cloudevents-batch+json; charset=utf-8" + ) + elif isinstance(events[0], EventGridEvent) or _is_eventgrid_event(events[0]): + kwargs.setdefault("content_type", "application/json; charset=utf-8") for event in events: _eventgrid_data_typecheck(event) - return await self._client.publish_custom_event_events(self._endpoint, cast(List, events), **kwargs) + return await self._client.publish_custom_event_events( + self._endpoint, cast(List, events), **kwargs + ) async def __aenter__(self) -> "EventGridPublisherClient": await self._client.__aenter__() @@ -207,6 +195,5 @@ async def __aexit__(self, *args: "Any") -> None: await self._client.__aexit__(*args) async def close(self) -> None: - """Close the :class:`~azure.eventgrid.aio.EventGridPublisherClient` session. - """ + """Close the :class:`~azure.eventgrid.aio.EventGridPublisherClient` session.""" await self._client.__aexit__() diff --git a/sdk/eventgrid/azure-eventgrid/tests/recordings/test_eg_publisher_client.test_send_event_grid_event_dict_data_dict.yaml b/sdk/eventgrid/azure-eventgrid/tests/recordings/test_eg_publisher_client.test_send_event_grid_event_dict_data_dict.yaml new file mode 100644 index 000000000000..820b5a3f8473 --- /dev/null +++ b/sdk/eventgrid/azure-eventgrid/tests/recordings/test_eg_publisher_client.test_send_event_grid_event_dict_data_dict.yaml @@ -0,0 +1,38 @@ +interactions: +- request: + body: '[{"subject": "sample", "data": {"key1": "Sample.EventGrid.Event"}, "eventType": + "Sample.EventGrid.Event", "dataVersion": "2.0", "id": "a63fbe5f-6e9d-49be-b660-c7e22eca46d9", + "eventTime": "2021-03-01 01:35:26.507333"}]' + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '217' + Content-Type: + - application/json; charset=utf-8 + User-Agent: + - azsdk-python-eventgrid/2.0.0b6 Python/3.7.3 (Windows-10-10.0.18362-SP0) + method: POST + uri: https://eventgridtestegtopic.westus-1.eventgrid.azure.net/api/events?api-version=2018-01-01 + response: + body: + string: '' + headers: + api-supported-versions: + - '2018-01-01' + content-length: + - '0' + date: + - Mon, 01 Mar 2021 09:35:25 GMT + server: + - Microsoft-HTTPAPI/2.0 + strict-transport-security: + - max-age=31536000; includeSubDomains + status: + code: 200 + message: OK +version: 1 diff --git a/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client.py b/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client.py index efd2458cf3d7..5792a07dec03 100644 --- a/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client.py +++ b/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client.py @@ -102,6 +102,24 @@ def test_send_event_grid_event_dict_data_bytes(self, resource_group, eventgrid_t with pytest.raises(TypeError, match="Data in EventGridEvent cannot be bytes*"): client.send(eg_event) + @CachedResourceGroupPreparer(name_prefix='eventgridtest') + @CachedEventGridTopicPreparer(name_prefix='eventgridtest') + def test_send_event_grid_event_dict_data_dict(self, resource_group, eventgrid_topic, eventgrid_topic_primary_key, eventgrid_topic_endpoint): + akc_credential = AzureKeyCredential(eventgrid_topic_primary_key) + client = EventGridPublisherClient(eventgrid_topic_endpoint, akc_credential) + eg_event = { + "subject":"sample", + "data":{"key1": "Sample.EventGrid.Event"}, + "eventType":"Sample.EventGrid.Event", + "dataVersion":"2.0", + "id": uuid.uuid4(), + "eventTime": datetime.now() + } + client.send(eg_event) + + + ### CLOUD EVENT TESTS + @CachedResourceGroupPreparer(name_prefix='eventgridtest') @CachedEventGridTopicPreparer(name_prefix='cloudeventgridtest') def test_send_cloud_event_data_dict(self, resource_group, eventgrid_topic, eventgrid_topic_primary_key, eventgrid_topic_endpoint): @@ -257,6 +275,12 @@ def test_send_signature_credential(self, resource_group, eventgrid_topic, eventg ) client.send(eg_event) + @CachedResourceGroupPreparer(name_prefix='eventgridtest') + @CachedEventGridTopicPreparer(name_prefix='eventgridtest') + def test_send_NONE_credential(self, resource_group, eventgrid_topic, eventgrid_topic_primary_key, eventgrid_topic_endpoint): + with pytest.raises(ValueError, match="Parameter 'self._credential' must not be None."): + client = EventGridPublisherClient(eventgrid_topic_endpoint, None) + @CachedResourceGroupPreparer(name_prefix='eventgridtest') @CachedEventGridTopicPreparer(name_prefix='customeventgridtest') def test_send_custom_schema_event(self, resource_group, eventgrid_topic, eventgrid_topic_primary_key, eventgrid_topic_endpoint): diff --git a/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client_async.py b/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client_async.py index 5a9152432c05..040866a36ac2 100644 --- a/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client_async.py +++ b/sdk/eventgrid/azure-eventgrid/tests/test_eg_publisher_client_async.py @@ -284,3 +284,10 @@ async def test_send_and_close_async_session(self, resource_group, eventgrid_topi type="Sample.Cloud.Event" ) await client.send(cloud_event) + + @CachedResourceGroupPreparer(name_prefix='eventgridtest') + @CachedEventGridTopicPreparer(name_prefix='cloudeventgridtest') + @pytest.mark.asyncio + def test_send_NONE_credential_async(self, resource_group, eventgrid_topic, eventgrid_topic_primary_key, eventgrid_topic_endpoint): + with pytest.raises(ValueError, match="Parameter 'self._credential' must not be None."): + client = EventGridPublisherClient(eventgrid_topic_endpoint, None) \ No newline at end of file diff --git a/sdk/eventgrid/azure-eventgrid/tests/test_generate_sas.py b/sdk/eventgrid/azure-eventgrid/tests/test_generate_sas.py new file mode 100644 index 000000000000..1ffa75c1b55d --- /dev/null +++ b/sdk/eventgrid/azure-eventgrid/tests/test_generate_sas.py @@ -0,0 +1,29 @@ +#------------------------------------------------------------------------- +# Copyright (c) Microsoft Corporation. All rights reserved. +# Licensed under the MIT License. See License.txt in the project root for +# license information. +#-------------------------------------------------------------------------- +import pytest +import datetime as dt +from datetime import timedelta +from msrest.serialization import UTC + +from azure.eventgrid import generate_sas + +def test_generate_sas_fails_with_http(): + expiration_date_utc = dt.datetime.now(UTC()) + timedelta(hours=1) + http_endpoint = "http://topic.eventgrid.endpoint" + with pytest.raises(ValueError): + signature = generate_sas(http_endpoint, "eventgrid_topic_primary_key", expiration_date_utc) + +def test_generate_sas_adds_https_if_not_exists(): + expiration_date_utc = dt.datetime.now(UTC()) + timedelta(hours=1) + http_endpoint = "topic.eventgrid.endpoint" + signature = generate_sas(http_endpoint, "eventgrid_topic_primary_key", expiration_date_utc) + assert signature.startswith("r=https") + +def test_generate_sas_adds_https_appends_api_events(): + expiration_date_utc = dt.datetime.now(UTC()) + timedelta(hours=1) + http_endpoint = "https://topic.eventgrid.endpoint" + signature = generate_sas(http_endpoint, "eventgrid_topic_primary_key", expiration_date_utc) + assert "%2Fapi%2Fevents" in signature \ No newline at end of file From abbfb5152c0dbbfc2671514c6fd0506d8c630bd6 Mon Sep 17 00:00:00 2001 From: tasherif-msft <69483382+tasherif-msft@users.noreply.github.com> Date: Mon, 1 Mar 2021 12:02:00 -0800 Subject: [PATCH 28/30] Fixed Content-MD5 serialization and typing (#16987) * Fixed Content-MD5 serialization and typing * fixed more typing --- .../azure/storage/blob/_blob_client.py | 10 +- .../azure/storage/blob/_models.py | 2 +- ...ock_blob.test_upload_blob_content_md5.yaml | 315 ++++++++++++++++++ ...ob_async.test_upload_blob_content_md5.yaml | 231 +++++++++++++ .../tests/test_block_blob.py | 27 +- .../tests/test_block_blob_async.py | 29 +- .../azure/storage/filedatalake/_models.py | 4 +- .../azure/storage/fileshare/_models.py | 2 +- 8 files changed, 607 insertions(+), 13 deletions(-) create mode 100644 sdk/storage/azure-storage-blob/tests/recordings/test_block_blob.test_upload_blob_content_md5.yaml create mode 100644 sdk/storage/azure-storage-blob/tests/recordings/test_block_blob_async.test_upload_blob_content_md5.yaml diff --git a/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py b/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py index 153b9b0751e7..01fc58ec28fd 100644 --- a/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py +++ b/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py @@ -385,7 +385,7 @@ def _upload_blob_options( # pylint:disable=too-many-statements kwargs['blob_headers'] = BlobHTTPHeaders( blob_cache_control=content_settings.cache_control, blob_content_type=content_settings.content_type, - blob_content_md5=bytearray(content_settings.content_md5) if content_settings.content_md5 else None, + blob_content_md5=content_settings.content_md5, blob_content_encoding=content_settings.content_encoding, blob_content_language=content_settings.content_language, blob_content_disposition=content_settings.content_disposition @@ -1208,7 +1208,7 @@ def _set_http_headers_options(self, content_settings=None, **kwargs): blob_headers = BlobHTTPHeaders( blob_cache_control=content_settings.cache_control, blob_content_type=content_settings.content_type, - blob_content_md5=bytearray(content_settings.content_md5) if content_settings.content_md5 else None, + blob_content_md5=content_settings.content_md5, blob_content_encoding=content_settings.content_encoding, blob_content_language=content_settings.content_language, blob_content_disposition=content_settings.content_disposition @@ -1376,7 +1376,7 @@ def _create_page_blob_options( # type: ignore blob_headers = BlobHTTPHeaders( blob_cache_control=content_settings.cache_control, blob_content_type=content_settings.content_type, - blob_content_md5=bytearray(content_settings.content_md5) if content_settings.content_md5 else None, + blob_content_md5=content_settings.content_md5, blob_content_encoding=content_settings.content_encoding, blob_content_language=content_settings.content_language, blob_content_disposition=content_settings.content_disposition @@ -1517,7 +1517,7 @@ def _create_append_blob_options(self, content_settings=None, metadata=None, **kw blob_headers = BlobHTTPHeaders( blob_cache_control=content_settings.cache_control, blob_content_type=content_settings.content_type, - blob_content_md5=bytearray(content_settings.content_md5) if content_settings.content_md5 else None, + blob_content_md5=content_settings.content_md5, blob_content_encoding=content_settings.content_encoding, blob_content_language=content_settings.content_language, blob_content_disposition=content_settings.content_disposition @@ -2350,7 +2350,7 @@ def _commit_block_list_options( # type: ignore blob_headers = BlobHTTPHeaders( blob_cache_control=content_settings.cache_control, blob_content_type=content_settings.content_type, - blob_content_md5=bytearray(content_settings.content_md5) if content_settings.content_md5 else None, + blob_content_md5=content_settings.content_md5, blob_content_encoding=content_settings.content_encoding, blob_content_language=content_settings.content_language, blob_content_disposition=content_settings.content_disposition diff --git a/sdk/storage/azure-storage-blob/azure/storage/blob/_models.py b/sdk/storage/azure-storage-blob/azure/storage/blob/_models.py index 2340431bd598..00a53dc68bfb 100644 --- a/sdk/storage/azure-storage-blob/azure/storage/blob/_models.py +++ b/sdk/storage/azure-storage-blob/azure/storage/blob/_models.py @@ -622,7 +622,7 @@ class ContentSettings(DictMixin): :param str cache_control: If the cache_control has previously been set for the blob, that value is stored. - :param str content_md5: + :param bytearray content_md5: If the content_md5 has been set for the blob, this response header is stored so that the client can check for message content integrity. diff --git a/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob.test_upload_blob_content_md5.yaml b/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob.test_upload_blob_content_md5.yaml new file mode 100644 index 000000000000..3c3b515334a9 --- /dev/null +++ b/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob.test_upload_blob_content_md5.yaml @@ -0,0 +1,315 @@ +interactions: +- request: + body: null + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '0' + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:18:10 GMT + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8?restype=container + response: + body: + string: '' + headers: + content-length: + - '0' + date: + - Mon, 01 Mar 2021 04:18:10 GMT + etag: + - '"0x8D8DC69063B0887"' + last-modified: + - Mon, 01 Mar 2021 04:18:10 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-version: + - '2020-06-12' + status: + code: 201 + message: Created +- request: + body: hello world + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '11' + Content-Type: + - application/octet-stream + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8/blob192b711b8 + response: + body: + string: '' + headers: + content-length: + - '0' + content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + date: + - Mon, 01 Mar 2021 04:18:10 GMT + etag: + - '"0x8D8DC6906463DF5"' + last-modified: + - Mon, 01 Mar 2021 04:18:10 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-content-crc64: + - vo7q9sPVKY0= + x-ms-request-server-encrypted: + - 'true' + x-ms-version: + - '2020-06-12' + status: + code: 201 + message: Created +- request: + body: null + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: HEAD + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8/blob192b711b8 + response: + body: + string: '' + headers: + accept-ranges: + - bytes + content-length: + - '11' + content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + content-type: + - application/octet-stream + date: + - Mon, 01 Mar 2021 04:18:10 GMT + etag: + - '"0x8D8DC6906463DF5"' + last-modified: + - Mon, 01 Mar 2021 04:18:10 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + vary: + - Origin + x-ms-access-tier: + - Hot + x-ms-access-tier-inferred: + - 'true' + x-ms-blob-type: + - BlockBlob + x-ms-creation-time: + - Mon, 01 Mar 2021 04:18:10 GMT + x-ms-lease-state: + - available + x-ms-lease-status: + - unlocked + x-ms-server-encrypted: + - 'true' + x-ms-version: + - '2020-06-12' + status: + code: 200 + message: OK +- request: + body: hello world this wont work + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '26' + Content-Type: + - application/octet-stream + If-None-Match: + - '*' + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8/blob292b711b8 + response: + body: + string: "\uFEFFMd5MismatchThe + MD5 value specified in the request did not match with the MD5 value calculated + by the server.\nRequestId:22874362-c01e-00be-4c51-0e3b8d000000\nTime:2021-03-01T04:18:10.9305633ZXrY7u+Ae7tCTyyK7j1rNww==jZ0KWGQraqYHX42NEbH9Vg==" + headers: + content-length: + - '405' + content-type: + - application/xml + date: + - Mon, 01 Mar 2021 04:18:10 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-error-code: + - Md5Mismatch + x-ms-version: + - '2020-06-12' + status: + code: 400 + message: The MD5 value specified in the request did not match with the MD5 value + calculated by the server. +- request: + body: hello world + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '11' + Content-Type: + - application/octet-stream + If-None-Match: + - '*' + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8/blob292b711b8 + response: + body: + string: '' + headers: + content-length: + - '0' + content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + date: + - Mon, 01 Mar 2021 04:18:10 GMT + etag: + - '"0x8D8DC690666ED45"' + last-modified: + - Mon, 01 Mar 2021 04:18:11 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-content-crc64: + - vo7q9sPVKY0= + x-ms-request-server-encrypted: + - 'true' + x-ms-version: + - '2020-06-12' + status: + code: 201 + message: Created +- request: + body: null + headers: + Accept: + - application/xml + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: HEAD + uri: https://storagename.blob.core.windows.net/utcontainer92b711b8/blob292b711b8 + response: + body: + string: '' + headers: + accept-ranges: + - bytes + content-length: + - '11' + content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + content-type: + - application/octet-stream + date: + - Mon, 01 Mar 2021 04:18:11 GMT + etag: + - '"0x8D8DC690666ED45"' + last-modified: + - Mon, 01 Mar 2021 04:18:11 GMT + server: + - Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + vary: + - Origin + x-ms-access-tier: + - Hot + x-ms-access-tier-inferred: + - 'true' + x-ms-blob-type: + - BlockBlob + x-ms-creation-time: + - Mon, 01 Mar 2021 04:18:11 GMT + x-ms-lease-state: + - available + x-ms-lease-status: + - unlocked + x-ms-server-encrypted: + - 'true' + x-ms-version: + - '2020-06-12' + status: + code: 200 + message: OK +version: 1 diff --git a/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob_async.test_upload_blob_content_md5.yaml b/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob_async.test_upload_blob_content_md5.yaml new file mode 100644 index 000000000000..537eb5ee29e7 --- /dev/null +++ b/sdk/storage/azure-storage-blob/tests/recordings/test_block_blob_async.test_upload_blob_content_md5.yaml @@ -0,0 +1,231 @@ +interactions: +- request: + body: null + headers: + Accept: + - application/xml + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer87a1435?restype=container + response: + body: + string: '' + headers: + content-length: '0' + date: Mon, 01 Mar 2021 04:21:20 GMT + etag: '"0x8D8DC69778E8AD9"' + last-modified: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-version: '2020-06-12' + status: + code: 201 + message: Created + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435?restype=container +- request: + body: hello world + headers: + Accept: + - application/xml + Content-Length: + - '11' + Content-Type: + - application/octet-stream + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer87a1435/blob187a1435 + response: + body: + string: '' + headers: + content-length: '0' + content-md5: XrY7u+Ae7tCTyyK7j1rNww== + date: Mon, 01 Mar 2021 04:21:20 GMT + etag: '"0x8D8DC69779243D2"' + last-modified: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-content-crc64: vo7q9sPVKY0= + x-ms-request-server-encrypted: 'true' + x-ms-version: '2020-06-12' + status: + code: 201 + message: Created + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435/blob187a1435 +- request: + body: null + headers: + Accept: + - application/xml + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: HEAD + uri: https://storagename.blob.core.windows.net/utcontainer87a1435/blob187a1435 + response: + body: + string: '' + headers: + accept-ranges: bytes + content-length: '11' + content-md5: XrY7u+Ae7tCTyyK7j1rNww== + content-type: application/octet-stream + date: Mon, 01 Mar 2021 04:21:20 GMT + etag: '"0x8D8DC69779243D2"' + last-modified: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + vary: Origin + x-ms-access-tier: Hot + x-ms-access-tier-inferred: 'true' + x-ms-blob-type: BlockBlob + x-ms-creation-time: Mon, 01 Mar 2021 04:21:20 GMT + x-ms-lease-state: available + x-ms-lease-status: unlocked + x-ms-server-encrypted: 'true' + x-ms-version: '2020-06-12' + status: + code: 200 + message: OK + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435/blob187a1435 +- request: + body: hello world this wont work + headers: + Accept: + - application/xml + Content-Length: + - '26' + Content-Type: + - application/octet-stream + If-None-Match: + - '*' + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer87a1435/blob287a1435 + response: + body: + string: "\uFEFFMd5MismatchThe + MD5 value specified in the request did not match with the MD5 value calculated + by the server.\nRequestId:1d84afe3-e01e-0096-2252-0e5a25000000\nTime:2021-03-01T04:21:20.9369998ZXrY7u+Ae7tCTyyK7j1rNww==jZ0KWGQraqYHX42NEbH9Vg==" + headers: + content-length: '405' + content-type: application/xml + date: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-error-code: Md5Mismatch + x-ms-version: '2020-06-12' + status: + code: 400 + message: The MD5 value specified in the request did not match with the MD5 value + calculated by the server. + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435/blob287a1435 +- request: + body: hello world + headers: + Accept: + - application/xml + Content-Length: + - '11' + Content-Type: + - application/octet-stream + If-None-Match: + - '*' + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-blob-content-md5: + - XrY7u+Ae7tCTyyK7j1rNww== + x-ms-blob-type: + - BlockBlob + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: PUT + uri: https://storagename.blob.core.windows.net/utcontainer87a1435/blob287a1435 + response: + body: + string: '' + headers: + content-length: '0' + content-md5: XrY7u+Ae7tCTyyK7j1rNww== + date: Mon, 01 Mar 2021 04:21:20 GMT + etag: '"0x8D8DC6977A029EA"' + last-modified: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + x-ms-content-crc64: vo7q9sPVKY0= + x-ms-request-server-encrypted: 'true' + x-ms-version: '2020-06-12' + status: + code: 201 + message: Created + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435/blob287a1435 +- request: + body: null + headers: + Accept: + - application/xml + User-Agent: + - azsdk-python-storage-blob/12.8.0b1 Python/3.8.5 (Windows-10-10.0.19041-SP0) + x-ms-date: + - Mon, 01 Mar 2021 04:21:21 GMT + x-ms-encryption-algorithm: + - AES256 + x-ms-version: + - '2020-06-12' + method: HEAD + uri: https://storagename.blob.core.windows.net/utcontainer87a1435/blob287a1435 + response: + body: + string: '' + headers: + accept-ranges: bytes + content-length: '11' + content-md5: XrY7u+Ae7tCTyyK7j1rNww== + content-type: application/octet-stream + date: Mon, 01 Mar 2021 04:21:20 GMT + etag: '"0x8D8DC6977A029EA"' + last-modified: Mon, 01 Mar 2021 04:21:20 GMT + server: Windows-Azure-Blob/1.0 Microsoft-HTTPAPI/2.0 + vary: Origin + x-ms-access-tier: Hot + x-ms-access-tier-inferred: 'true' + x-ms-blob-type: BlockBlob + x-ms-creation-time: Mon, 01 Mar 2021 04:21:20 GMT + x-ms-lease-state: available + x-ms-lease-status: unlocked + x-ms-server-encrypted: 'true' + x-ms-version: '2020-06-12' + status: + code: 200 + message: OK + url: https://emilydevtest.blob.core.windows.net/utcontainer87a1435/blob287a1435 +version: 1 diff --git a/sdk/storage/azure-storage-blob/tests/test_block_blob.py b/sdk/storage/azure-storage-blob/tests/test_block_blob.py index 7e0dfd9453cb..a916f49076d9 100644 --- a/sdk/storage/azure-storage-blob/tests/test_block_blob.py +++ b/sdk/storage/azure-storage-blob/tests/test_block_blob.py @@ -61,8 +61,8 @@ def _teardown(self, FILE_PATH): pass #--Helpers----------------------------------------------------------------- - def _get_blob_reference(self): - return self.get_resource_name(TEST_BLOB_PREFIX) + def _get_blob_reference(self, prefix=TEST_BLOB_PREFIX): + return self.get_resource_name(prefix) def _create_blob(self, tags=None, data=b'', **kwargs): blob_name = self._get_blob_reference() @@ -566,6 +566,29 @@ def test_create_small_block_blob_with_no_overwrite(self, resource_group, locatio self.assertEqual(props.last_modified, create_resp.get('last_modified')) self.assertEqual(props.blob_type, BlobType.BlockBlob) + @GlobalStorageAccountPreparer() + def test_upload_blob_content_md5(self, resource_group, location, storage_account, storage_account_key): + self._setup(storage_account, storage_account_key) + blob1_name = self._get_blob_reference(prefix="blob1") + blob2_name = self._get_blob_reference(prefix="blob2") + blob1 = self.bsc.get_blob_client(self.container_name, blob1_name) + blob2 = self.bsc.get_blob_client(self.container_name, blob2_name) + data1 = b'hello world' + data2 = b'hello world this wont work' + + # Act + blob1.upload_blob(data1, overwrite=True) + blob1_md5 = blob1.get_blob_properties().content_settings.content_md5 + blob2_content_settings = ContentSettings(content_md5=blob1_md5) + + # Passing data that does not match the md5 + with self.assertRaises(HttpResponseError): + blob2.upload_blob(data2, content_settings=blob2_content_settings) + # Correct data and corresponding md5 + blob2.upload_blob(data1, content_settings=blob2_content_settings) + blob2_md5 = blob2.get_blob_properties().content_settings.content_md5 + self.assertEqual(blob1_md5, blob2_md5) + @GlobalStorageAccountPreparer() def test_create_small_block_blob_with_overwrite(self, resource_group, location, storage_account, storage_account_key): self._setup(storage_account, storage_account_key) diff --git a/sdk/storage/azure-storage-blob/tests/test_block_blob_async.py b/sdk/storage/azure-storage-blob/tests/test_block_blob_async.py index a481a9cc7efd..a2c9155b762f 100644 --- a/sdk/storage/azure-storage-blob/tests/test_block_blob_async.py +++ b/sdk/storage/azure-storage-blob/tests/test_block_blob_async.py @@ -80,8 +80,8 @@ def _teardown(self, FILE_PATH): except: pass - def _get_blob_reference(self): - return self.get_resource_name(TEST_BLOB_PREFIX) + def _get_blob_reference(self, prefix=TEST_BLOB_PREFIX): + return self.get_resource_name(prefix) def _get_blob_with_special_chars_reference(self): return 'भारत¥test/testsubÐirÍ/'+self.get_resource_name('srcÆblob') @@ -659,6 +659,31 @@ async def test_get_block_list_committed_blocks(self, resource_group, location, s self.assertEqual(block_list[0][2].id, '3') self.assertEqual(block_list[0][2].size, 3) + @GlobalStorageAccountPreparer() + @AsyncStorageTestCase.await_prepared_test + async def test_upload_blob_content_md5(self, resource_group, location, storage_account, storage_account_key): + await self._setup(storage_account, storage_account_key) + blob1_name = self._get_blob_reference(prefix="blob1") + blob2_name = self._get_blob_reference(prefix="blob2") + blob1 = self.bsc.get_blob_client(self.container_name, blob1_name) + blob2 = self.bsc.get_blob_client(self.container_name, blob2_name) + data1 = b'hello world' + data2 = b'hello world this wont work' + + # Act + await blob1.upload_blob(data1, overwrite=True) + blob1_props = await blob1.get_blob_properties() + blob1_md5 = blob1_props.content_settings.content_md5 + blob2_content_settings = ContentSettings(content_md5=blob1_md5) + + # Passing data that does not match the md5 + with self.assertRaises(HttpResponseError): + await blob2.upload_blob(data2, content_settings=blob2_content_settings) + # Correct data and corresponding md5 + await blob2.upload_blob(data1, content_settings=blob2_content_settings) + blob2_props = await blob2.get_blob_properties() + blob2_md5 = blob2_props.content_settings.content_md5 + self.assertEqual(blob1_md5, blob2_md5) @GlobalStorageAccountPreparer() @AsyncStorageTestCase.await_prepared_test diff --git a/sdk/storage/azure-storage-file-datalake/azure/storage/filedatalake/_models.py b/sdk/storage/azure-storage-file-datalake/azure/storage/filedatalake/_models.py index 63b818a037b2..b99f9aa09d78 100644 --- a/sdk/storage/azure-storage-file-datalake/azure/storage/filedatalake/_models.py +++ b/sdk/storage/azure-storage-file-datalake/azure/storage/filedatalake/_models.py @@ -259,7 +259,7 @@ class ContentSettings(BlobContentSettings): :ivar str cache_control: If the cache_control has previously been set for the file, that value is stored. - :ivar str content_md5: + :ivar bytearray content_md5: If the content_md5 has been set for the file, this response header is stored so that the client can check for message content integrity. @@ -280,7 +280,7 @@ class ContentSettings(BlobContentSettings): :keyword str cache_control: If the cache_control has previously been set for the file, that value is stored. - :keyword str content_md5: + :keyword bytearray content_md5: If the content_md5 has been set for the file, this response header is stored so that the client can check for message content integrity. diff --git a/sdk/storage/azure-storage-file-share/azure/storage/fileshare/_models.py b/sdk/storage/azure-storage-file-share/azure/storage/fileshare/_models.py index 796b43b2e33b..ef937439dffa 100644 --- a/sdk/storage/azure-storage-file-share/azure/storage/fileshare/_models.py +++ b/sdk/storage/azure-storage-file-share/azure/storage/fileshare/_models.py @@ -274,7 +274,7 @@ class ContentSettings(DictMixin): :param str cache_control: If the cache_control has previously been set for the file, that value is stored. - :param str content_md5: + :param bytearray content_md5: If the content_md5 has been set for the file, this response header is stored so that the client can check for message content integrity. From adfce6bcd0e66b9d02f2354c89b6fb94c7feb73f Mon Sep 17 00:00:00 2001 From: tasherif-msft <69483382+tasherif-msft@users.noreply.github.com> Date: Mon, 1 Mar 2021 12:02:11 -0800 Subject: [PATCH 29/30] Fixed delete_blob method signature (#16983) --- .../azure-storage-blob/azure/storage/blob/_blob_client.py | 2 +- .../azure/storage/blob/aio/_blob_client_async.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py b/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py index 01fc58ec28fd..6806419ad73a 100644 --- a/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py +++ b/sdk/storage/azure-storage-blob/azure/storage/blob/_blob_client.py @@ -985,7 +985,7 @@ def _delete_blob_options(self, delete_snapshots=False, **kwargs): return options @distributed_trace - def delete_blob(self, delete_snapshots=False, **kwargs): + def delete_blob(self, delete_snapshots=None, **kwargs): # type: (str, **Any) -> None """Marks the specified blob for deletion. diff --git a/sdk/storage/azure-storage-blob/azure/storage/blob/aio/_blob_client_async.py b/sdk/storage/azure-storage-blob/azure/storage/blob/aio/_blob_client_async.py index 54a4e488b162..84cd3e3a6c9a 100644 --- a/sdk/storage/azure-storage-blob/azure/storage/blob/aio/_blob_client_async.py +++ b/sdk/storage/azure-storage-blob/azure/storage/blob/aio/_blob_client_async.py @@ -463,7 +463,7 @@ async def download_blob(self, offset=None, length=None, **kwargs): return downloader @distributed_trace_async - async def delete_blob(self, delete_snapshots=False, **kwargs): + async def delete_blob(self, delete_snapshots=None, **kwargs): # type: (str, Any) -> None """Marks the specified blob for deletion. From 36f200366070ccb4f8781e5ceaa0cec4c68b1a7b Mon Sep 17 00:00:00 2001 From: Rakshith Bhyravabhotla Date: Mon, 1 Mar 2021 13:53:02 -0800 Subject: [PATCH 30/30] [EventGrid] Improve docs (#16986) * intital * read me improvements * migration guide * blundera * nit * Apply suggestions from code review Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> Co-authored-by: swathipil <76007337+swathipil@users.noreply.github.com> --- sdk/eventgrid/azure-eventgrid/README.md | 201 ++++++++++++++++-- .../azure/eventgrid/_models.py | 2 +- .../azure-eventgrid/migration_guide.md | 25 ++- .../azure-eventgrid/samples/README.md | 2 + ...le_publish_cloud_event_using_dict_async.py | 2 +- ...nts_using_cloud_events_1.0_schema_async.py | 2 +- ...consume_cloud_events_from_storage_queue.py | 2 +- ...eventgrid_events_from_service_bus_queue.py | 2 +- 8 files changed, 219 insertions(+), 19 deletions(-) diff --git a/sdk/eventgrid/azure-eventgrid/README.md b/sdk/eventgrid/azure-eventgrid/README.md index 8702858a8ed6..9629b210e18b 100644 --- a/sdk/eventgrid/azure-eventgrid/README.md +++ b/sdk/eventgrid/azure-eventgrid/README.md @@ -2,13 +2,14 @@ Azure Event Grid is a fully-managed intelligent event routing service that allows for uniform event consumption using a publish-subscribe model. -[Source code][python-eg-src] | [Package (PyPI)][python-eg-pypi] | [API reference documentation][python-eg-ref-docs]| [Product documentation][python-eg-product-docs] | [Samples][python-eg-samples]| [Changelog][python-eg-changelog] +[Source code][python-eg-src] | [Package (PyPI)][python-eg-pypi] | [API reference documentation][python-eg-ref-docs] | [Product documentation][python-eg-product-docs] | [Samples][python-eg-samples] | [Changelog][python-eg-changelog] ## Getting started ### Prerequisites * Python 2.7, or 3.5 or later is required to use this package. -* You must have an [Azure subscription][azure_subscription] and an Event Grid Topic resource to use this package. +* You must have an [Azure subscription][azure_subscription] and an Event Grid Topic resource to use this package. Follow this [step-by-step tutorial](https://docs.microsoft.com/azure/event-grid/custom-event-quickstart-portal) to register the Event Grid resource provider and create Event Grid topics using the [Azure portal](https://portal.azure.com/). There is a [similar tutorial](https://docs.microsoft.com/azure/event-grid/custom-event-quickstart) using [Azure CLI](https://docs.microsoft.com/cli/azure). + ### Install the package Install the Azure Event Grid client library for Python with [pip][pip]: @@ -38,29 +39,70 @@ In order to interact with the Event Grid service, you will need to create an ins An **endpoint** and **credential** are necessary to instantiate the client object. #### Looking up the endpoint -You can find the endpoint and the hostname on the Azure portal. +You can find the topic endpoint within the Event Grid Topic resource on the Azure portal. This will look like: +`"https://..eventgrid.azure.net/api/events"` +The topic hostname is the URL host component of this endpoint, which will be in the format: +`"https://..eventgrid.azure.net"` #### Create the client with AzureKeyCredential -To use an API key as the `credential` parameter, +To use an Access key as the `credential` parameter, pass the key as a string into an instance of [AzureKeyCredential][azure-key-credential]. +> **Note:** The Access Key may be found in the azure portal in the "Access Keys" menu of the Event Grid Topic resource. They may also be obtained via the azure CLI, or the `azure-mgmt-eventgrid` library. A guide for getting access keys can be found [here](https://docs.microsoft.com/azure/event-grid/get-access-keys). + ```python from azure.core.credentials import AzureKeyCredential from azure.eventgrid import EventGridPublisherClient endpoint = "https://..eventgrid.azure.net" -credential = AzureKeyCredential("") +credential = AzureKeyCredential("") eg_publisher_client = EventGridPublisherClient(endpoint, credential) ``` +> **Note:** A client may also be authenticated via SAS signature, using the `AzureSasCredential`. A sample demonstrating this, is available [here][python-eg-sample-publish-sas-signature] ([async_version][python-eg-sample-publish-sas-signature-async]). + +> **Note:** The `generate_sas` method can be used to generate a shared access signature. A sample demonstrating this can be seen [here][python-eg-generate-sas]. ## Key concepts Information about the key concepts on Event Grid, see [Concepts in Azure Event Grid][publisher-service-doc] +### Topic +A [topic](https://docs.microsoft.com/azure/event-grid/concepts#topics) is a channel within the EventGrid service to send events. The event schema that a topic accepts is decided at topic creation time. If events of a schema type are sent to a topic that requires a different schema type, errors will be raised. + +### Domain +An event [domain](https://docs.microsoft.com/azure/event-grid/event-domains) is a management tool for large numbers of Event Grid topics related to the same application. They allow you to publish events to thousands of topics. Domains also give you authorization and authentication control over each topic. For more information, visit [Event domain overview](https://docs.microsoft.com/azure/event-grid/event-domains). + +When you create an event domain, a publishing endpoint for this domain is made available to you. This process is similar to creating an Event Grid Topic. The only difference is that, when publishing to a domain, you must specify the topic within the domain that you'd like the event to be delivered to. + +### Event schemas +An [**event**](https://docs.microsoft.com/azure/event-grid/concepts#events) is the smallest amount of information that fully describes something that happened in the system. When a custom topic or domain is created, you must specify the schema that will be used when publishing events. + +Event Grid supports multiple schemas for encoding events. + +#### Event Grid schema +While you may configure your topic to use a [custom schema](https://docs.microsoft.com/azure/event-grid/input-mappings), it is more common to use the already-defined Event Grid schema. See the specifications and requirements [here](https://docs.microsoft.com/azure/event-grid/event-schema). + +#### CloudEvents v1.0 schema +Another option is to use the CloudEvents v1.0 schema. [CloudEvents](https://cloudevents.io/) is a Cloud Native Computing Foundation project which produces a specification for describing event data in a common way. The service summary of CloudEvents can be found [here](https://docs.microsoft.com/azure/event-grid/cloud-event-schema). + ### EventGridPublisherClient -`EventGridPublisherClient` provides operations to send event data to topic hostname specified during client initialization. -CloudEvents and EventGridEvents can be sent either as a single event or a list of respective typed objects or their equivalent dict representations. To send a custom schema, a dict representation can be used. Please have a look at the [samples](https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/eventgrid/azure-eventgrid/samples) for detailed examples. +`EventGridPublisherClient` provides operations to send event data to a topic hostname specified during client initialization. + +Regardless of the schema that your topic or domain is configured to use, `EventGridPublisherClient` will be used to publish events to it. Use the `send` method publishing events. + +The following formats of events are allowed to be sent: +- A list or a single instance of strongly typed EventGridEvents. +- A dict representation of a serialized EventGridEvent object. +- A list or a single instance of strongly typed CloudEvents. +- A dict representation of a serialized CloudEvent object. + +- A dict representation of any Custom Schema. + +Please have a look at the [samples](https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/eventgrid/azure-eventgrid/samples) for detailed examples. + + + **Note:** It is important to know if your topic supports Cloud or EventGrid events before publishing. If you send to a topic that does not support the schema of the event you are sending, send() will throw an exception. ## Examples @@ -68,6 +110,8 @@ The following sections provide several code snippets covering some of the most c * [Send an Event Grid Event](#send-an-event-grid-event) * [Send a Cloud Event](#send-a-cloud-event) +* [Consume a payload from storage queue](#consume-from-storage-queue) +* [Consume from ServiceBus](#consume-from-servicebus) ### Send an Event Grid Event @@ -117,6 +161,103 @@ client = EventGridPublisherClient(endpoint, credential) client.send(event) ``` +### Consume from storage queue + +This example consumes a message received from storage queue and deserializes it to a CloudEvent object. + +```Python +from azure.eventgrid import CloudEvent +from azure.storage.queue import QueueServiceClient, BinaryBase64DecodePolicy +import os +import json + +# all types of CloudEvents below produce same DeserializedEvent +connection_str = os.environ['STORAGE_QUEUE_CONN_STR'] +queue_name = os.environ['STORAGE_QUEUE_NAME'] + +with QueueServiceClient.from_connection_string(connection_str) as qsc: + payload = qsc.get_queue_client( + queue=queue_name, + message_decode_policy=BinaryBase64DecodePolicy() + ).peek_messages() + + ## deserialize payload into a list of typed Events + events = [CloudEvent.from_dict(json.loads(msg.content)) for msg in payload] +``` + +### Consume from servicebus + +This example consumes a payload message received from ServiceBus and deserializes it to an EventGridEvent object. + +```Python +from azure.eventgrid import EventGridEvent +from azure.servicebus import ServiceBusClient +import os +import json + +# all types of EventGridEvents below produce same DeserializedEvent +connection_str = os.environ['SERVICE_BUS_CONN_STR'] +queue_name = os.environ['SERVICE_BUS_QUEUE_NAME'] + +with ServiceBusClient.from_connection_string(connection_str) as sb_client: + payload = sb_client.get_queue_receiver(queue_name).receive_messages() + + ## deserialize payload into a list of typed Events + events = [EventGridEvent.from_dict(json.loads(next(msg.body).decode('utf-8'))) for msg in payload] +``` + +## Distributed Tracing with EventGrid + +You can use opentelemetry for Python as usual with EventGrid since it's compatible with azure-core tracing integration. + +Here is an example of using OpenTelemetry to trace sending a CloudEvent. + +First, set OpenTelemetry as enabled tracing plugin for EventGrid. + +```python +from azure.core.settings import settings +from azure.core.tracing.ext.opentelemetry_span import OpenTelemetrySpan + +settings.tracing_implementation = OpenTelemetrySpan +``` + +Regular open telemetry usage from here. See [OpenTelemetry](https://github.com/open-telemetry/opentelemetry-python) for details. +This example uses a simple console exporter to export the traces. Any exporter can be used here including `azure-monitor-opentelemetry-exporter`, `jaeger`, `zipkin` etc. + +```python +from opentelemetry import trace +from opentelemetry.sdk.trace import TracerProvider +from opentelemetry.sdk.trace.export import ConsoleSpanExporter +from opentelemetry.sdk.trace.export import SimpleExportSpanProcessor + +# Simple console exporter +exporter = ConsoleSpanExporter() + +trace.set_tracer_provider(TracerProvider()) +tracer = trace.get_tracer(__name__) +trace.get_tracer_provider().add_span_processor( + SimpleExportSpanProcessor(exporter) +) +``` + +Once the `tracer` and `exporter` are set, please follow the example below to start collecting traces while using the `send` method from the `EventGridPublisherClient` to send a CloudEvent object. + +```python +import os +from azure.eventgrid import EventGridPublisherClient, CloudEvent +from azure.core.credentials import AzureKeyCredential + +hostname = os.environ['CLOUD_TOPIC_HOSTNAME'] +key = AzureKeyCredential(os.environ['CLOUD_ACCESS_KEY']) +cloud_event = CloudEvent( + source = 'demo', + type = 'sdk.demo', + data = {'test': 'hello'}, +) +with tracer.start_as_current_span(name="MyApplication"): + client = EventGridPublisherClient(hostname, key) + client.send(cloud_event) +``` ## Troubleshooting @@ -145,12 +286,28 @@ The following section provides several code snippets illustrating common pattern These code samples show common champion scenario operations with the Azure Event Grid client library. -* Publish EventGrid Events to a topic: [sample_publish_eg_events_to_a_topic.py][python-eg-sample-egevent] -* Publish EventGrid Events to a domain: [sample_publish_eg_events_to_a_domain.py][python-eg-sample-egevent-to-domain] -* Publish a Cloud Event: [sample_publish_events_using_cloud_events_1.0_schema.py][python-eg-sample-send-cloudevent] +* Generate Shared Access Signature: [sample_generate_sas.py][python-eg-generate-sas] + +* Authenticate the client: [sample_authentication.py][python-eg-auth] ([async_version][python-eg-auth-async]) + +* Publish events to a topic using SAS: [sample_publish_events_to_a_topic_using_sas_credential_async.py][python-eg-sample-send-using-sas] ([async_version][python-eg-sample-send-using-sas-async]) +* Publish Event Grid Events to a topic: [sample_publish_eg_events_to_a_topic.py][python-eg-sample-eg-event] ([async_version][python-eg-sample-eg-event-async]) +* Publish EventGrid Events to a domain topic: [sample_publish_eg_events_to_a_domain_topic.py][python-eg-sample-eg-event-to-domain] ([async_version][python-eg-sample-eg-event-to-domain-async]) +* Publish a Cloud Event: [sample_publish_events_using_cloud_events_1.0_schema.py][python-eg-sample-send-cloudevent] ([async_version][python-eg-sample-send-cloudevent-async]) +* Publish a Custom Schema: [sample_publish_custom_schema_to_a_topic.py][python-eg-publish-custom-schema] ([async_version][python-eg-publish-custom-schema-async]) + +The following samples cover publishing and consuming `dict` representations of EventGridEvents and CloudEvents. +* Publish EventGridEvent as dict like representation: [sample_publish_eg_event_using_dict.py][python-eg-sample-send-eg-as-dict] ([async_version][python-eg-sample-send-eg-as-dict-async]) + +* Publish CloudEvent as dict like representation: [sample_publish_cloud_event_using_dict.py][python-eg-sample-send-cloudevent-as-dict] ([async_version][python-eg-sample-send-cloudevent-as-dict-async]) + +* Consume a Custom Payload of raw cloudevent data: [sample_consume_custom_payload.py][python-eg-sample-consume-custom-payload] More samples can be found [here][python-eg-samples]. +* More samples related to the send scenario can be seen [here][python-eg-publish-samples]. +* To see more samples related to consuming a payload from different messaging services as a typed object, please visit [Consume Samples][python-eg-consume-samples] + ### Additional documentation For more extensive documentation on Azure Event Grid, see the [Event Grid documentation][python-eg-product-docs] on docs.microsoft.com. @@ -180,10 +337,28 @@ This project has adopted the [Microsoft Open Source Code of Conduct][code_of_con [azure_core_ref_docs]: https://aka.ms/azsdk/python/core/docs [azure_subscription]: https://azure.microsoft.com/free/ -[python-eg-sample-egevent]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_eg_events_to_a_topic.py -[python-eg-sample-egevent-to-domain]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_eg_events_to_a_domain.py +[python-eg-auth]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_authentication.py +[python-eg-generate-sas]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_generate_sas.py +[python-eg-sample-send-using-sas]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_events_to_a_topic_using_sas_credential.py +[python-eg-sample-eg-event]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_eg_events_to_a_topic.py +[python-eg-sample-eg-event-to-domain]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_eg_events_to_a_domain.py [python-eg-sample-send-cloudevent]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_events_using_cloud_events_1.0_schema.py -[publisher-service-doc]: https://docs.microsoft.com/azure/event-grid/concepts +[python-eg-publish-custom-schema]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_custom_schema_to_a_topic.py +[python-eg-sample-send-eg-as-dict]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_eg_event_using_dict.py +[python-eg-sample-send-cloudevent-as-dict]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_cloud_event_using_dict.py + +[python-eg-auth-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_authentication_async.py +[python-eg-sample-send-using-sas-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_to_a_topic_using_sas_credential_async.py +[python-eg-sample-eg-event-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_eg_events_to_a_topic_async.py +[python-eg-sample-eg-event-to-domain-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_eg_events_to_a_domain_async.py +[python-eg-sample-send-cloudevent-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_using_cloud_events_1.0_schema_async.py +[python-eg-publish-custom-schema-async]:https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_custom_schema_to_a_topic_async.py +[python-eg-sample-send-eg-as-dict-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_eg_event_using_dict_async.py +[python-eg-sample-send-cloudevent-as-dict-async]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_cloud_event_using_dict_async.py + +[python-eg-publish-samples]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/publish_samples +[python-eg-consume-samples]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/consume_samples +[python-eg-sample-consume-custom-payload]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_consume_custom_payload.py [cla]: https://cla.microsoft.com [code_of_conduct]: https://opensource.microsoft.com/codeofconduct/ diff --git a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py index ba79546c8bc8..5154ed979fa4 100644 --- a/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py +++ b/sdk/eventgrid/azure-eventgrid/azure/eventgrid/_models.py @@ -173,7 +173,7 @@ class EventGridEvent(InternalEventGridEvent, EventMixin): If not provided, will be stamped with an empty value. :type data_version: str :keyword topic: Optional. The resource path of the event source. If not provided, Event Grid will - stamp onto the event. + stamp onto the event. This is required when sending event(s) to a domain. :type topic: str :keyword metadata_version: Optional. The schema version of the event metadata. If provided, must match Event Grid Schema exactly. If not provided, EventGrid will stamp onto event. diff --git a/sdk/eventgrid/azure-eventgrid/migration_guide.md b/sdk/eventgrid/azure-eventgrid/migration_guide.md index 82df62e6f7e9..cedaa9067263 100644 --- a/sdk/eventgrid/azure-eventgrid/migration_guide.md +++ b/sdk/eventgrid/azure-eventgrid/migration_guide.md @@ -36,7 +36,7 @@ The modern Event Grid client library also provides the ability to share in some The v2.x major version comes with support for [CloudEvents](https://github.com/cloudevents/spec). Now the cloud native Cloud Events can be directly published using the `CloudEvent` constructor or as a dictionary as follows: ```Python -from azure.eventgrid import CloudEvent +from azure.core.messaging import CloudEvent cloud_event = CloudEvent( type="Contoso.Items.ItemReceived", @@ -73,6 +73,29 @@ The `publish_events` API is replaced with `send` in v2.0. Additionally, `send` A |---|---|---| |`EventGridClient(credentials).publish_events(topic_hostname, events)`|`EventGridPublisherClient(endpoint, credential).send(events)`|[Sample for client construction](https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_publish_events_using_cloud_events_1.0_schema.py)| +### Consuming Events + +The v2.x major version supports deserializing dictionaries into strongly typed objects. The `from_dict` methods in the `CloudEvent` and `EventGridEvent` models can be used for the same. + +This example consumes a payload message received from ServiceBus and deserializes it to an EventGridEvent object. + +```Python +from azure.eventgrid import EventGridEvent +from azure.servicebus import ServiceBusClient +import os +import json + +# all types of EventGridEvents below produce same DeserializedEvent +connection_str = os.environ['SERVICE_BUS_CONN_STR'] +queue_name = os.environ['SERVICE_BUS_QUEUE_NAME'] + +with ServiceBusClient.from_connection_string(connection_str) as sb_client: + payload = sb_client.get_queue_receiver(queue_name).receive_messages() + + ## deserialize payload into a list of typed Events + events = [EventGridEvent.from_dict(json.loads(next(msg.body).decode('utf-8'))) for msg in payload] +``` + ## Additional samples More examples can be found at [here](https://github.com/Azure/azure-sdk-for-python/tree/master/sdk/eventgrid/azure-eventgrid/samples) diff --git a/sdk/eventgrid/azure-eventgrid/samples/README.md b/sdk/eventgrid/azure-eventgrid/samples/README.md index 7d6b396200ab..68ebc6dfb929 100644 --- a/sdk/eventgrid/azure-eventgrid/samples/README.md +++ b/sdk/eventgrid/azure-eventgrid/samples/README.md @@ -71,4 +71,6 @@ To publish events, dict representation of the models could also be used as follo [python-eg-publish-samples]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/publish_samples [python-eg-consume-samples]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/consume_samples +[python-eg-sample-consume-custom-payload]: https://github.com/Azure/azure-sdk-for-python/blob/master/sdk/eventgrid/azure-eventgrid/samples/sync_samples/sample_consume_custom_payload.py + [publisher-service-doc]: https://docs.microsoft.com/azure/event-grid/concepts diff --git a/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_cloud_event_using_dict_async.py b/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_cloud_event_using_dict_async.py index 41e6af899021..db958983fb53 100644 --- a/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_cloud_event_using_dict_async.py +++ b/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_cloud_event_using_dict_async.py @@ -30,7 +30,7 @@ async def publish(): # [START publish_cloud_event_dict_async] async with client: - client.send([ + await client.send([ { "type": "Contoso.Items.ItemReceived", "source": "/contoso/items", diff --git a/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_using_cloud_events_1.0_schema_async.py b/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_using_cloud_events_1.0_schema_async.py index a957db463337..24a881e51eb5 100644 --- a/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_using_cloud_events_1.0_schema_async.py +++ b/sdk/eventgrid/azure-eventgrid/samples/async_samples/sample_publish_events_using_cloud_events_1.0_schema_async.py @@ -28,7 +28,7 @@ async def publish(): credential = AzureKeyCredential(topic_key) client = EventGridPublisherClient(endpoint, credential) - client.send([ + await client.send([ CloudEvent( type="Contoso.Items.ItemReceived", source="/contoso/items", diff --git a/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_cloud_events_from_storage_queue.py b/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_cloud_events_from_storage_queue.py index 68a7b6e4a56b..919183405d4d 100644 --- a/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_cloud_events_from_storage_queue.py +++ b/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_cloud_events_from_storage_queue.py @@ -29,7 +29,7 @@ message_decode_policy=BinaryBase64DecodePolicy() ).peek_messages() - ## deserialize payload into a lost of typed Events + ## deserialize payload into a list of typed Events events = [CloudEvent.from_dict(json.loads(msg.content)) for msg in payload] for event in events: diff --git a/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_eventgrid_events_from_service_bus_queue.py b/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_eventgrid_events_from_service_bus_queue.py index 6ea2c8c694a8..a99f98f4fb7f 100644 --- a/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_eventgrid_events_from_service_bus_queue.py +++ b/sdk/eventgrid/azure-eventgrid/samples/consume_samples/consume_eventgrid_events_from_service_bus_queue.py @@ -25,7 +25,7 @@ with ServiceBusClient.from_connection_string(connection_str) as sb_client: payload = sb_client.get_queue_receiver(queue_name).receive_messages() - ## deserialize payload into a lost of typed Events + ## deserialize payload into a list of typed Events events = [EventGridEvent.from_dict(json.loads(next(msg.body).decode('utf-8'))) for msg in payload] for event in events: